- 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.
65 lines
2.4 KiB
PHP
65 lines
2.4 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.
|
|
************************************************************************************/
|
|
|
|
class CustomView_SaveAjax_Action extends CustomView_Save_Action {
|
|
|
|
function __construct() {
|
|
parent::__construct();
|
|
$this->exposeMethod('updateColumns');
|
|
}
|
|
|
|
public function process(Vtiger_Request $request) {
|
|
$response = new Vtiger_Response();
|
|
$cvId = $request->get('record');
|
|
if (!$cvId) {
|
|
$response->setError('Filter Not specified');
|
|
$response->emit();
|
|
return;
|
|
}
|
|
|
|
$mode = $request->get('mode');
|
|
if(!empty($mode)) {
|
|
$this->invokeExposedMethod($mode, $request);
|
|
return;
|
|
}
|
|
|
|
$customViewModel = CustomView_Record_Model::getInstanceById($cvId);
|
|
$customViewModel->set('setdefault',$request->get('setdefault'));
|
|
$customViewModel->save(true);
|
|
$response->setResult(array('id'=>$cvId,'isdefault'=>$customViewModel->get('setdefault')));
|
|
$response->emit();
|
|
}
|
|
|
|
|
|
/**
|
|
* Function to updated selected Custom view columns
|
|
* @param Vtiger_Request $request
|
|
*/
|
|
public function updateColumns(Vtiger_Request $request) {
|
|
$cvid = $request->get('record');
|
|
$customViewModel = CustomView_Record_Model::getInstanceById($cvid);
|
|
$response = new Vtiger_Response();
|
|
if ($customViewModel) {
|
|
$selectedColumns = $request->get('columnslist');
|
|
$customViewModel->deleteSelectedFields();
|
|
$customViewModel->saveSelectedFields($selectedColumns);
|
|
/**
|
|
* We are setting list_headers in session when we manage columns.
|
|
* we should clear this from session in order to apply view
|
|
*/
|
|
$listViewSessionKey = $customViewModel->getModule()->getName().'_'.$cvid;
|
|
Vtiger_ListView_Model::deleteParamsSession($listViewSessionKey,'list_headers');
|
|
$response->setResult(array('message'=>vtranslate('List columns saved successfully',$request->getModule()), 'listviewurl'=>$customViewModel->getModule()->getListViewUrl().'&viewname='.$cvid));
|
|
} else {
|
|
$response->setError(vtranslate('Filter does not exist',$request->getModule()));
|
|
}
|
|
$response->emit();
|
|
}
|
|
} |