Files
crm.clientright.ru/layouts/vlayout/modules/Settings/ModuleManager/resources/ModuleManager.js
Fedor ac7467f0b4 Major CRM updates: AI Assistant, Court Status API, S3 integration improvements, and extensive file storage system
- 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.
2025-10-16 11:17:21 +03:00

225 lines
8.7 KiB
JavaScript

/*+***********************************************************************************
* 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.
*************************************************************************************/
jQuery.Class('Settings_Module_Manager_Js', {
}, {
/*
* function to update the module status for the module
* @params: currentTarget - checkbox related to module.
*/
updateModuleStatus : function(currentTarget) {
var aDeferred = jQuery.Deferred();
var forModule = currentTarget.data('module');
var status = currentTarget.is(':checked');
var progressIndicatorElement = jQuery.progressIndicator({
'position' : 'html',
'blockInfo' : {
'enabled' : true
}
});
var params = {}
params['module'] = app.getModuleName();
params['parent'] = app.getParentModuleName();
params['updateStatus'] = status;
params['forModule'] = forModule
params['action'] = 'Basic';
params['mode'] = 'updateModuleStatus';
AppConnector.request(params).then(
function(data) {
progressIndicatorElement.progressIndicator({'mode' : 'hide'});
aDeferred.resolve(data);
},
function(error) {
progressIndicatorElement.progressIndicator({'mode' : 'hide'});
//TODO : Handle error
aDeferred.reject(error);
}
);
return aDeferred.promise();
},
//This will show the notification message using pnotify
showNotify : function(customParams) {
var params = {
title : app.vtranslate('JS_MESSAGE'),
text: customParams.text,
animation: 'show',
type: 'info'
};
Vtiger_Helper_Js.showPnotify(params);
},
registerEventsForImportFromZip : function(container) {
container.on('change','[ name="acceptDisclaimer"]', function(e){
var element = jQuery(e.currentTarget);
var importFromZip = container.find('[name="importFromZip"]');
var uploadedFile = jQuery('#moduleZip').val();
var disabledStatus = importFromZip.attr('disabled');
if((element.is(':checked')) && (uploadedFile != '')){
if(typeof disabledStatus != "undefined"){
importFromZip.removeAttr('disabled');
}
} else {
if(typeof disabledStatus == "undefined"){
importFromZip.attr('disabled', "disabled");
}
}
});
container.on('change','[name="moduleZip"]', function(){
container.find('[ name="acceptDisclaimer"]').trigger('click');
});
container.on('click','.importModule,.updateModule',function(e){
var element = jQuery(e.currentTarget);
var params = {};
if(element.hasClass('updateModule')){
params = {
'module' : app.getModuleName(),
'parent' : app.getParentModuleName(),
'action' : 'Basic',
'mode' : 'updateUserModuleStep3'
};
} else if(element.hasClass('importModule')){
params = {
'module' : app.getModuleName(),
'parent' : app.getParentModuleName(),
'action' : 'Basic',
'mode' : 'importUserModuleStep3'
};
}
params['module_import_file'] = container.find('[name="module_import_file"]').val();
params['module_import_type'] = container.find('[name="module_import_type"]').val();
params['module_import_name'] = container.find('[name="module_import_name"]').val();
var progressIndicatorElement = jQuery.progressIndicator({
'position' : 'html',
'blockInfo' : {
'enabled' : true
}
});
AppConnector.request(params).then(
function(data) {
progressIndicatorElement.progressIndicator({'mode' : 'hide'});
element.addClass('hide');
var importModuleName = data.result.importModuleName;
var importStatusModal = jQuery(container).find('.importStatusModal').clone(true, true);
importStatusModal.removeClass('hide');
var headerMessage, containerMessage;
if(element.hasClass('updateModule')){
headerMessage = app.vtranslate('JS_UPDATE_SUCCESSFULL');
containerMessage = app.vtranslate('JS_UPDATED_MODULE');
} else if(element.hasClass('importModule')){
headerMessage = app.vtranslate('JS_IMPORT_SUCCESSFULL');
containerMessage = app.vtranslate('JS_IMPORTED_MODULE');
}
var callBackFunction = function(data) {
data.find('.statusHeader').html(headerMessage);
data.find('.statusContainer').html(importModuleName + ' ' + containerMessage);
};
app.showModalWindow(importStatusModal,function(data) {
if(typeof callBackFunction == 'function') {
callBackFunction(data);
}}, {'width':'1000px'});
},
function(error) {
progressIndicatorElement.progressIndicator({'mode' : 'hide'});
}
);
});
container.on('click','.acceptLicense', function(e){
var element = jQuery(e.currentTarget);
var saveButton = container.find('[name="saveButton"]')
if(element.is(':checked')){
saveButton.removeAttr("disabled");
} else {
if(typeof saveButton.attr('disabled') == 'undefined'){
saveButton.attr('disabled',"disabled");
}
}
});
},
registerEvents : function(e){
var thisInstance = this;
var container = jQuery('#moduleManagerContents');
var importFromZipContainer = jQuery('#importModules');
if(importFromZipContainer.length > 0){
thisInstance.registerEventsForImportFromZip(importFromZipContainer);
}
//register click event for check box to update the module status
container.on('click', '[name="moduleStatus"]', function(e){
var currentTarget = jQuery(e.currentTarget);
var moduleBlock = currentTarget.closest('.moduleManagerBlock');
var actionButtons = moduleBlock.find('.actions');
var forModule = currentTarget.data('moduleTranslation');
var moduleDetails = moduleBlock.find('.moduleImage, .moduleName');
if(currentTarget.is(':checked')){
//show the settings button for the module.
actionButtons.removeClass('hide');
//changing opacity of the block if the module is enabled
moduleDetails.removeClass('dull');
//update the module status as enabled
thisInstance.updateModuleStatus(currentTarget).then(
function(data) {
var params = {
text: forModule+' '+app.vtranslate('JS_MODULE_ENABLED')
}
thisInstance.showNotify(params);
},
function(error){
//TODO: Handle Error
}
);
} else {
//hide the settings button for the module.
actionButtons.addClass('hide');
//changing opacity of the block if the module is disabled
moduleDetails.addClass('dull');
//update the module status as disabled
thisInstance.updateModuleStatus(currentTarget).then(
function(data) {
var params = {
text: forModule+' '+app.vtranslate('JS_MODULE_DISABLED')
}
thisInstance.showNotify(params);
},
function(error){
//TODO: Handle Error
}
);
}
});
}
});
jQuery(document).ready(function(){
var settingModuleManagerInstance = new Settings_Module_Manager_Js();
settingModuleManagerInstance.registerEvents();
})