Files
CRM/modules/Inventory/actions/BasicAjax.php
BACHIR SOULDI 2794e62571 first commit
2025-09-28 08:49:37 +01:00

97 lines
3.8 KiB
PHP

<?php
/*+**********************************************************************************
* The contents of this file are subject to the vtiger CRM Public License Version 1.1
* ("License"); You may not use this file except in compliance with the License
* The Original Code is: vtiger CRM Open Source
* The Initial Developer of the Original Code is vtiger.
* Portions created by vtiger are Copyright (C) vtiger.
* All Rights Reserved.
************************************************************************************/
require_once 'SUtiles.php';
class Inventory_BasicAjax_Action extends Vtiger_BasicAjax_Action {
public function process(Vtiger_Request $request) {
$searchValue = $request->get('search_value');
$searchModule = $request->get('search_module');
$parentRecordId = $request->get('parent_id');
$parentModuleName = $request->get('parent_module');
$relatedModule = $request->get('module');
$currentUser = Users_Record_Model::getCurrentUserModel();
$roleid = $currentUser->get('roleid');
$userid = $currentUser->get('id');
if($searchModule == 'Accounts' && $relatedModule == 'SalesOrder') {
$parentRecordId = $userid;
$parentModuleName = "Users";
}
$searchModuleModel = Vtiger_Module_Model::getInstance($searchModule);
$records = $searchModuleModel->searchRecord($searchValue, $parentRecordId, $parentModuleName, $relatedModule);
//Supporting sequence based search in updation of Inventory record
$isLineItem = false;
$sequenceBasedRecords = array();
if (in_array($searchModule, array('Products', 'Services'))) {
$isLineItem = true;
foreach ($records as $moduleName => $recordModels) {
foreach ($recordModels as $recordId => $recordModel) {
$records[$moduleName][$recordId] = Vtiger_Record_Model::getInstanceById($recordId, $moduleName);
}
}
$sequenceBasedRecords = $searchModuleModel->searchRecordsOnSequenceNumber($searchValue, $relatedModule);
if ($sequenceBasedRecords) {
foreach ($sequenceBasedRecords as $recordId => $recordModel) {
$records[$searchModule][$recordId] = $recordModel;
}
}
$fieldName = 'product_no';
if ($searchModule === 'Services') {
$fieldName = 'service_no';
}
}
$baseRecordId = $request->get('base_record');
$result = array();
foreach($records as $moduleName => $recordModels) {
foreach($recordModels as $recordModel) {
if($recordModel->getId() != $baseRecordId) {
$recordLabel = decode_html($recordModel->getName());
if ($isLineItem) {
$recordLabel = $recordModel->get($fieldName)." - $recordLabel";
}
if($searchModule == 'Accounts' && $relatedModule == 'SalesOrder') {
$record = Vtiger_Record_Model::getInstanceById($recordModel->getId());
if(isPharma($roleid)) {
$userIdassigned = $record->get('assigned_user_id');
if(!isResponsable($roleid)) {
if(isUserInRole($userIdassigned, $record->get('vm2_id'), $record->get('vm3_id'), $roleid))
$result[] = array('label'=>decode_html($recordModel->getName()), 'value'=>decode_html($recordModel->getName()), 'id'=>$recordModel->getId());
} else {
if($userIdassigned == $userid || $record->get('vm2_id') == $userid || $record->get('vm3_id') == $userid)
$result[] = array('label'=>decode_html($recordModel->getName()), 'value'=>decode_html($recordModel->getName()), 'id'=>$recordModel->getId());
}
} else {
$result[] = array('label' => $recordLabel, 'value' => $recordLabel, 'id' => $recordModel->getId());
}
} else {
$result[] = array('label'=>decode_html($recordModel->getName()), 'value'=>decode_html($recordModel->getName()), 'id'=>$recordModel->getId());
}
}
}
}
$response = new Vtiger_Response();
$response->setResult($result);
$response->emit();
}
}