- Added comprehensive AI Assistant system (aiassist/ directory): * Vector search and embedding capabilities * Typebot proxy integration * Elastic search functionality * Message classification and chat history * MCP proxy for external integrations - Implemented Court Status API (GetCourtStatus.php): * Real-time court document status checking * Integration with external court systems * Comprehensive error handling and logging - Enhanced S3 integration: * Improved file backup system with metadata * Batch processing capabilities * Enhanced error logging and recovery * Copy operations with URL fixing - Added Telegram contact creation API - Improved error logging across all modules - Enhanced callback system for AI responses - Extensive backup file storage with timestamps - Updated documentation and README files - File storage improvements: * Thousands of backup files with proper metadata * Fix operations for broken file references * Project-specific backup and recovery systems * Comprehensive file integrity checking Total: 26,461+ files added/modified including AWS SDK, vendor dependencies, and extensive backup system.
77 lines
2.7 KiB
PHP
77 lines
2.7 KiB
PHP
<?php
|
|
/*+***********************************************************************************
|
|
* The contents of this file are subject to the vtiger CRM Public License Version 1.0
|
|
* ("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.
|
|
*************************************************************************************/
|
|
|
|
class PriceBooks_RelationListView_Model extends Vtiger_RelationListView_Model {
|
|
|
|
public function getHeaders() {
|
|
$headerFields = parent::getHeaders();
|
|
|
|
//Added to support List Price
|
|
$field = new Vtiger_Field_Model();
|
|
$field->set('name', 'listprice');
|
|
$field->set('column', 'listprice');
|
|
$field->set('label', 'List Price');
|
|
$headerFields['listprice'] = $field;
|
|
|
|
return $headerFields;
|
|
}
|
|
|
|
public function getEntries($pagingModel) {
|
|
$db = PearDatabase::getInstance();
|
|
$parentModule = $this->getParentRecordModel()->getModule();
|
|
$relationModule = $this->getRelationModel()->getRelationModuleModel();
|
|
$relatedColumnFieldMapping = $relationModule->getConfigureRelatedListFields();
|
|
if(count($relatedColumnFieldMapping) <= 0){
|
|
$relatedColumnFieldMapping = $relationModule->getRelatedListFields();
|
|
}
|
|
|
|
$query = $this->getRelationQuery();
|
|
|
|
$startIndex = $pagingModel->getStartIndex();
|
|
$pageLimit = $pagingModel->getPageLimit();
|
|
|
|
$orderBy = $this->getForSql('orderby');
|
|
$sortOrder = $this->getForSql('sortorder');
|
|
if($orderBy) {
|
|
$query = "$query ORDER BY $orderBy $sortOrder";
|
|
}
|
|
|
|
$limitQuery = $query .' LIMIT '.$startIndex.','.$pageLimit;
|
|
$result = $db->pquery($limitQuery, array());
|
|
$relatedRecordList = array();
|
|
|
|
for($i=0; $i< $db->num_rows($result); $i++ ) {
|
|
$row = $db->fetch_row($result,$i);
|
|
$newRow = array();
|
|
foreach($row as $col=>$val){
|
|
if(array_key_exists($col,$relatedColumnFieldMapping))
|
|
$newRow[$relatedColumnFieldMapping[$col]] = $val;
|
|
}
|
|
|
|
$recordId = $row['crmid'];
|
|
$newRow['id'] = $recordId;
|
|
//Added to support List Price
|
|
$newRow['listprice'] = CurrencyField::convertToUserFormat($row['listprice'], null, true);
|
|
|
|
$record = Vtiger_Record_Model::getCleanInstance($relationModule->get('name'));
|
|
$relatedRecordList[$recordId] = $record->setData($newRow)->setModuleFromInstance($relationModule);
|
|
}
|
|
$pagingModel->calculatePageRange($relatedRecordList);
|
|
|
|
$nextLimitQuery = $query. ' LIMIT '.($startIndex+$pageLimit).' , 1';
|
|
$nextPageLimitResult = $db->pquery($nextLimitQuery, array());
|
|
if($db->num_rows($nextPageLimitResult) > 0){
|
|
$pagingModel->set('nextPageExists', true);
|
|
}else{
|
|
$pagingModel->set('nextPageExists', false);
|
|
}
|
|
return $relatedRecordList;
|
|
}
|
|
} |