| Conditions | 7 |
| Paths | 6 |
| Total Lines | 26 |
| Code Lines | 18 |
| Lines | 0 |
| Ratio | 0 % |
| Changes | 3 | ||
| Bugs | 2 | Features | 0 |
| 1 | <?php |
||
| 16 | public function parse() |
||
| 17 | { |
||
| 18 | if (is_array($this->data) && empty($this->data['@attributes'])) { |
||
| 19 | foreach ($this->data as $warehouseCount) { |
||
| 20 | $count = $warehouseCount['@attributes']['КоличествоНаСкладе']; |
||
| 21 | $objectId = \App::$cur->migrations->findObject((string) $warehouseCount['@attributes']['ИдСклада'], 'Ecommerce\Warehouse'); |
||
| 22 | if ($objectId) { |
||
| 23 | $modelName = get_class($this->model); |
||
| 24 | $warehouse = \Ecommerce\Item\Offer\Warehouse::get([[$modelName::index(), $this->model->pk()], [\Ecommerce\Warehouse::index(), $objectId->object_id]]); |
||
| 25 | if (!$warehouse) { |
||
| 26 | $warehouse = new \Ecommerce\Item\Offer\Warehouse([ |
||
| 27 | $modelName::index() => $this->model->pk(), |
||
| 28 | \Ecommerce\Warehouse::index() => $objectId->object_id, |
||
| 29 | 'count' => $count |
||
| 30 | ]); |
||
| 31 | $warehouse->save(); |
||
| 32 | } else { |
||
| 33 | if ($warehouse->count != $count) { |
||
| 34 | $warehouse->count = $count; |
||
| 35 | $warehouse->save(); |
||
| 36 | } |
||
| 37 | } |
||
| 38 | } |
||
| 39 | } |
||
| 40 | } |
||
| 41 | } |
||
| 42 | |||
| 44 |