- 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.
83 lines
2.8 KiB
PHP
83 lines
2.8 KiB
PHP
<?php
|
|
|
|
/*+********************************************************************************
|
|
* The content of this file is subject to the Reports 4 You license.
|
|
* ("License"); You may not use this file except in compliance with the License
|
|
* The Initial Developer of the Original Code is IT-Solutions4You s.r.o.
|
|
* Portions created by IT-Solutions4You s.r.o. are Copyright(C) IT-Solutions4You s.r.o.
|
|
* All Rights Reserved.
|
|
********************************************************************************/
|
|
|
|
class ITS4YouReports_HighChartUtils_Helper
|
|
{
|
|
|
|
public static function isStacked($type)
|
|
{
|
|
return (false !== strpos($type, 'stacked'));
|
|
}
|
|
|
|
public function getQuickFiltersFromRequest(Vtiger_Request $request)
|
|
{
|
|
global $default_charset;
|
|
$qfRequest = [];
|
|
$requestAll = $request->getAll();
|
|
if ($requestAll['quick_filter_criteria']) {
|
|
$decodedQFCriteria = html_entity_decode($requestAll['quick_filter_criteria'], ENT_QUOTES, $default_charset);
|
|
$quickFilterCriteria = Zend_Json::decode($decodedQFCriteria);
|
|
// transformation
|
|
foreach ($quickFilterCriteria as $qfArray) {
|
|
$qfRequest[$qfArray['columnname']]['value'] = $qfArray['value'];
|
|
$qfRequest[$qfArray['columnname']]['radio'] = $qfArray['radio_value'];
|
|
}
|
|
}
|
|
|
|
return $qfRequest;
|
|
}
|
|
|
|
public static function getHighChartDataLabelFormatByType($type, $pointDecimals)
|
|
{
|
|
switch ($type) {
|
|
case 'piepercentage':
|
|
$format = '<b>{point.name}</b> {point.percentage:.1f} %';
|
|
break;
|
|
default:
|
|
$format = "<b>{point.name}</b> ({point.y:,.$pointDecimals})";
|
|
break;
|
|
}
|
|
|
|
return $format;
|
|
}
|
|
|
|
public static function getHighChartTooltipByType($type)
|
|
{
|
|
$tooltip = "formatter: function () {
|
|
return '<b>' + this.x + '</b><br/>' + this.series.name + ': ' + this.y ";
|
|
|
|
if (self::isStacked($type)) {
|
|
$tooltip .= "+ '<br/>' + '" . vtranslate("LBL_TOTAL", "ITS4YouReports") .
|
|
vtranslate("LBL_DOUBLEDOT", "ITS4YouReports") . " ' + this.point.stackTotal";
|
|
}
|
|
|
|
$tooltip .= ';
|
|
}';
|
|
|
|
return $tooltip;
|
|
}
|
|
|
|
public static function getHighChartSeriesTooltipByType($type)
|
|
{
|
|
switch ($type) {
|
|
case 'pie':
|
|
case 'piepercentage':
|
|
$tooltip = "valueSuffix: '',
|
|
pointFormat: '{series.name}: <br>{point.percentage:.1f} %<br>value: {point.y}'";
|
|
break;
|
|
default:
|
|
$tooltip = "valueSuffix: ''";
|
|
break;
|
|
}
|
|
|
|
return $tooltip;
|
|
}
|
|
}
|