$order_item = new PluginOrderOrder_Item(); switch ($_POST['chooseAction']) { case 'bill': case 'state': if (isset($_POST["item"])) { foreach ($_POST["item"] as $key => $val) { if ($val == 1) { $tmp = $_POST; $tmp['id'] = $key; $order_item->update($tmp); // Update infocom $ic = new Infocom(); $ic->getFromDBforDevice($order_item->fields['itemtype'], $order_item->fields['items_id']); $config = PluginOrderConfig::getConfig(); if ($config->canAddBillDetails()) { if ($bill->getFromDB($_POST["plugin_order_bills_id"])) { $fields['id'] = $ic->fields['id']; $fields['bill'] = $bill->fields['number']; $fields['warranty_date'] = $bill->fields['billdate']; } } $ic->update($fields); } } } break; } PluginOrderOrder::updateBillState($order_item->fields['plugin_order_orders_id']); Html::back(); } $dropdown = new PluginOrderBill();
public function generateInfoComRelatedToOrder($entity, $detailID, $itemtype, $items_id, $templateID = 0) { global $CFG_GLPI; //Do not try to generate infocoms if itemtype doesn't support it (ie contracts...) if (in_array($itemtype, $CFG_GLPI["infocom_types"])) { // Retrieve configuration for generate assets feature $config = PluginOrderConfig::getConfig(); $fields = array(); //Create empty infocom, in order to forward entities_id and is_recursive $ic = new Infocom(); $infocomID = !$ic->getFromDBforDevice($itemtype, $items_id) ? false : $ic->fields["id"]; $detail = new PluginOrderOrder_Item(); $detail->getFromDB($detailID); $order = new PluginOrderOrder(); $order->getFromDB($detail->fields["plugin_order_orders_id"]); $order_supplier = new PluginOrderOrder_Supplier(); $order_supplier->getFromDBByOrder($detail->fields["plugin_order_orders_id"]); if ($templateID) { if ($ic->getFromDBforDevice($itemtype, $templateID)) { $fields = $ic->fields; unset($fields["id"]); if (isset($fields["immo_number"])) { $fields["immo_number"] = autoName($fields["immo_number"], "immo_number", 1, 'Infocom', $entity); } if (empty($fields['buy_date'])) { unset($fields['buy_date']); } } } $fields["entities_id"] = $entity; $fields["itemtype"] = $itemtype; $fields["items_id"] = $items_id; $fields["order_number"] = $order->fields["num_order"]; $fields["delivery_number"] = $detail->fields["delivery_number"]; $fields["budgets_id"] = $order->fields["budgets_id"]; $fields["suppliers_id"] = $order->fields["suppliers_id"]; $fields["value"] = $detail->fields["price_discounted"]; $fields["order_date"] = $order->fields["order_date"]; if (!is_null($detail->fields["delivery_date"])) { $fields["delivery_date"] = $detail->fields["delivery_date"]; } // Get bill data if ($config->canAddBillDetails()) { $bill = new PluginOrderBill(); if ($bill->getFromDB($detail->fields["plugin_order_bills_id"])) { $fields['bill'] = $bill->fields['number']; $fields['warranty_date'] = $bill->fields['billdate']; } } foreach (array('warranty_date', 'buy_date', 'inventory_date') as $date) { if (!isset($fields[$date])) { $fields[$date] = 'NULL'; } } $fields['_no_warning'] = true; if ($infocomID) { $fields['id'] = $infocomID; $ic->update($fields); } else { $ic->add($fields); } } }