%PDF- %PDF-
Direktori : /home/bitrix/www/bitrix/components/bitrix/report.view/templates/.default/ |
Current File : /home/bitrix/www/bitrix/components/bitrix/report.view/templates/.default/template.php |
<?php \Bitrix\Main\UI\Extension::load("ui.buttons"); \Bitrix\Main\UI\Extension::load("ui.buttons.icons"); if (!defined("B_PROLOG_INCLUDED") || B_PROLOG_INCLUDED!==true)die(); /** @var CBitrixComponentTemplate $this */ /** @global CMain $APPLICATION */ global $APPLICATION; $resultTableId = 'report-result-table'; /** * @param CBitrixComponentTemplate &$component * @param mixed &$arParams[] * @param mixed &$arResult[] */ function reportViewShowTopButtons(&$component, &$arParams, &$arResult) { /** @global CMain $APPLICATION */ global $APPLICATION; $isStExport = is_array($arResult['STEXPORT_PARAMS']); $stExportManagerId = ''; if ($isStExport) { $stExportManagerId = $arResult['STEXPORT_PARAMS']['managerId']; } $component->SetViewTarget("pagetitle", 100);?> <script> (function () { BX.ready(function () { var element = document.body.querySelector('[data-role="action-report"]'); BX.bind( element, 'click', function () { var isStExport = <? echo $isStExport ? 'true' : 'false'; ?>; BX.PopupMenu.show( element.getAttribute('data-role'), element, [ isStExport ? { text: '<?=GetMessage('REPORT_EXCEL_EXPORT')?>', onclick: "BX.Report.StExportManager.items['<?= CUtil::JSEscape($stExportManagerId) ?>'].startExport('excel')", className: 'reports-title-excel-icon' } : { text: '<?=GetMessage('REPORT_EXCEL_EXPORT')?>', href: '<?=CUtil::JSEscape($APPLICATION->GetCurPageParam("EXCEL=Y&ncc=1"));?>', className: 'reports-title-excel-icon' }, { text: '<?=GetMessage('REPORT_COPY')?>', href: '<?=CUtil::JSEscape(CComponentEngine::MakePathFromTemplate($arParams["PATH_TO_REPORT_CONSTRUCT"], array("report_id" => $arParams['REPORT_ID'], 'action' => 'copy')));?>', className: 'reports-title-copy-icon' } <? if ($arResult['MARK_DEFAULT'] <= 0 && $arResult['AUTHOR']) : ?> ,{ text: '<?=GetMessage('REPORT_EDIT')?>', href: '<?=CUtil::JSEscape(CComponentEngine::MakePathFromTemplate($arParams["PATH_TO_REPORT_CONSTRUCT"], array("report_id" => $arParams['REPORT_ID'], 'action' => 'edit')));?>', className: 'reports-title-edit-icon' } <? endif; ?> ], { offsetLeft: 20, angle: { offset: 5 } } ) } ) }) })(); </script> <button class="ui-btn ui-btn-light-border ui-btn-icon-setting ui-btn-themes" data-role="action-report"></button> <a class="ui-btn ui-btn-primary ui-btn-icon-back" href="<?=CComponentEngine::MakePathFromTemplate($arParams["PATH_TO_REPORT_LIST"], array());?>"> <?=GetMessage('REPORT_RETURN_TO_LIST')?></a> <?php $component->EndViewTarget(); } if (!empty($arResult['ERROR'])) { $GLOBALS['APPLICATION']->SetAdditionalCSS('/bitrix/js/report/css/report.css'); $APPLICATION->SetTitle($arResult['report']['TITLE']); echo $arResult['ERROR']; reportViewShowTopButtons($this, $arParams, $arResult); return false; } if ($arParams['USE_CHART'] && $arResult['settings']['chart']['display']) { require_once($_SERVER['DOCUMENT_ROOT'].'/bitrix/modules/main/img.php'); // amCharts $GLOBALS['APPLICATION']->AddHeadScript('/bitrix/js/main/amcharts/3.3/amcharts.js'); $GLOBALS['APPLICATION']->AddHeadScript('/bitrix/js/main/amcharts/3.3/serial.js'); $GLOBALS['APPLICATION']->AddHeadScript('/bitrix/js/main/amcharts/3.3/pie.js'); } // calendar CJSCore::Init(array('date')); $arPeriodTypes = array( "month" => GetMessage("TASKS_THIS_MONTH"), "month_ago" => GetMessage("TASKS_PREVIOUS_MONTH"), "week" => GetMessage("TASKS_THIS_WEEK"), "week_ago" => GetMessage("TASKS_PREVIOUS_WEEK"), "days" => GetMessage("TASKS_LAST_N_DAYS"), "after" => GetMessage("TASKS_AFTER"), "before" => GetMessage("TASKS_BEFORE"), "interval" => GetMessage("TASKS_DATE_INTERVAL"), "all" => GetMessage("TASKS_DATE_ALL") ); $GLOBALS['APPLICATION']->SetAdditionalCSS('/bitrix/js/report/css/report.css'); $APPLICATION->SetTitle($arResult['report']['TITLE']); // determine column data type function getResultColumnDataType(&$viewColumnInfo, &$customColumnTypes, $helperClassName) { $dataType = null; if (is_array($customColumnTypes) && array_key_exists($viewColumnInfo['fieldName'], $customColumnTypes)) { $dataType = $customColumnTypes[$viewColumnInfo['fieldName']]; } else { /** @var Bitrix\Main\Entity\Field[] $viewColumnInfo */ $dataType = call_user_func(array($helperClassName, 'getFieldDataType'), $viewColumnInfo['field']); } if (!empty($viewColumnInfo['prcnt'])) { $dataType = 'float'; } else if (!empty($viewColumnInfo['aggr'])) { if ($viewColumnInfo['aggr'] == 'COUNT_DISTINCT') $dataType = 'integer'; else if ($viewColumnInfo['aggr'] == 'GROUP_CONCAT') $dataType = 'string'; else if ($dataType == 'boolean') { if ($viewColumnInfo['aggr'] == 'MIN' || $viewColumnInfo['aggr'] == 'AVG' || $viewColumnInfo['aggr'] == 'MAX' || $viewColumnInfo['aggr'] == 'SUM' || $viewColumnInfo['aggr'] == 'COUNT_DISTINCT') { $dataType = 'integer'; } } } return $dataType; } ?> <div class="reports-result-list-wrap"> <?php if ($arParams['USE_CHART'] && $arResult['settings']['chart']['display']): ?> <style type="text/css"> div.graph { background-color: white; border: 1px solid #D0D8D9; box-shadow: 1px 1px 2px 0 rgba(88, 112, 118, 0.1); border-radius: 2px; color: gray; font-size: 14px; margin: 0 3px 23px; overflow: auto; padding: 0 16px; } a.report-chart-show:before { background:url("") no-repeat; } a.report-chart-hide:before { background:url("") no-repeat; } a.report-chart-show:before, a.report-chart-hide:before { content: ""; height: 3px; width: 6px; display: inline-block; margin: 0 4px 2px 0; } a.report-chart-show, a.report-chart-hide { font-size: 12px; color: gray; cursor: pointer; border-bottom: 1px dashed gray; margin-left: 4px; text-decoration: none; } </style> <?php // data preparation for the chart function prepareChartData(&$arResult, &$arGroupingResult = null) { $nMaxValues = 500; $result = array('requestData' => array(), 'columnsNames' => array(), 'err' => 0); // check $chartSettings = $arResult['settings']['chart']; if (!isset($chartSettings['x_column'])) { $result['err'] = 49; } $xColumnIndex = $chartSettings['x_column']; if (!is_array($arResult['viewColumns'][$xColumnIndex])) { $result['err'] = 49; return $result; } if (!is_array($chartSettings['y_columns'])) { $result['err'] = 49; return $result; } $yColumnsCount = count($chartSettings['y_columns']); if ($yColumnsCount === 0) { $result['err'] = 49; return $result; } foreach ($chartSettings['y_columns'] as $yColumnIndex) { if (!is_array($arResult['viewColumns'][$yColumnIndex])) { $result['err'] = 49; break; } } if ($result['err'] !== 0) { return $result; } $chartTypeIds = array(); foreach ($arResult['chartTypes'] as $chartTypeInfo) $chartTypeIds[] = $chartTypeInfo['id']; if (!is_set($chartSettings['type']) || empty($chartSettings['type']) || !in_array($chartSettings['type'], $chartTypeIds)) { $result['err'] = 49; return $result; } $chartType = $chartSettings['type']; if ($chartType === 'pie') $yColumnsCount = 1; // pie chart has only one array of a values $xColumnDataType = getResultColumnDataType($arResult['viewColumns'][$xColumnIndex], $arResult['customColumnTypes'], $arResult['helperClassName']); $xColumnResultName = $arResult['viewColumns'][$xColumnIndex]['resultName']; $yColumnsIndexes = array(); $yColumnsResultNames = array(); $columnsHumanTitles = array(); $columnsHumanTitles[0] = $arResult['viewColumns'][$xColumnIndex]['humanTitle']; $columnsTypes = array(); $columnsTypes[0] = $xColumnDataType; for ($i = 0; $i < $yColumnsCount; $i++) { $yColumnsIndexes[] = $yColumnIndex = $chartSettings['y_columns'][$i]; $yColumnsResultNames[] = $arResult['viewColumns'][$yColumnIndex]['resultName']; $columnsHumanTitles[] = $arResult['viewColumns'][$yColumnIndex]['humanTitle']; $columnsTypes[$i + 1] = getResultColumnDataType($arResult['viewColumns'][$yColumnIndex], $arResult['customColumnTypes'], $arResult['helperClassName']); } $requestData = array( 'type' => $chartType, 'columnTypes' => $columnsTypes ); unset($columnsTypes); if (!is_null($arGroupingResult) && is_array($arGroupingResult)) { $n = count($arGroupingResult); if ($chartType !== 'pie') $n = min($nMaxValues, $n); for ($i = 0; $i < $n; $i++) { $row = array(); $dataRow = $arGroupingResult[$i]; $row[0] = htmlspecialcharsback(str_replace(array(' ', '"'), array('', '"'), strip_tags($dataRow[$xColumnIndex]))); foreach ($yColumnsIndexes as $yColumnIndex) $row[] = htmlspecialcharsback(str_replace(array(' ', '"'), array('', '"'), strip_tags($dataRow[$yColumnIndex]))); $requestData['data'][] = $row; } } else { $n = count($arResult['data']); if ($chartType !== 'pie') $n = min($nMaxValues, $n); for ($i = 0; $i < $n; $i++) { $row = array(); $dataRow = $arResult['data'][$i]; $bHasMultipleValues = false; if (isset($arResult['customChartData'][$i][$xColumnResultName]['multiple'])) { $customValueInfo = $arResult['customChartData'][$i][$xColumnResultName]; if ($customValueInfo['multiple'] === true) { $nValue = 0; $dataValue = null; foreach ($customValueInfo as $cvKey => $cvInfo) { if ($cvKey !== 'multiple') { /*switch ($xColumnDataType) { case 'boolean': case 'float': case 'integer': if ($nValue === 0) $dataValue = $cvInfo['value']; else $dataValue = $cvInfo['value'] + $dataValue; break; case 'date': case 'datetime': case 'string': case 'text': case 'enum': case 'file': case 'disk_file': case 'employee': case 'crm': case 'crm_status': case 'iblock_element': case 'iblock_section': if ($nValue === 0) $dataValue = $cvInfo['value']; else $dataValue = $dataValue.' / '.$cvInfo['value']; break; }*/ if ($nValue === 0) { $dataValue = $cvInfo['value']; } else { $dataValue = $dataValue . ' / ' . $cvInfo['value']; $bHasMultipleValues = true; } $nValue++; } } } else { $dataValue = $customValueInfo[0]['value']; } } else { $dataValue = $dataRow[$xColumnResultName]; if (is_array($dataValue)) { $dataValue = implode(' / ', $dataValue); $bHasMultipleValues = true; } } if ($bHasMultipleValues) { $requestData['columnTypes'][0] = $xColumnDataType = 'string'; } unset($bHasMultipleValues); $row[0] = htmlspecialcharsback(str_replace(array(' ', '"'), array('', '"'), strip_tags($dataValue))); foreach ($yColumnsResultNames as $yColumnResultName) { if (isset($arResult['customChartData'][$i][$yColumnResultName]['multiple'])) { $customValueInfo = $arResult['customChartData'][$i][$yColumnResultName]; if ($customValueInfo['multiple'] === true) { $dataValue = 0; foreach ($customValueInfo as $cvKey => $cvInfo) { if ($cvKey !== 'multiple') $dataValue = $cvInfo['value'] + $dataValue; } } else { $dataValue = $customValueInfo[0]['value']; } } else { $dataValue = $dataRow[$yColumnResultName]; } $row[] = htmlspecialcharsback(str_replace(array(' ', '"'), array('', '"'), strip_tags($dataValue))); } $requestData['data'][] = $row; } } $result['requestData'] = $requestData; $result['columnsNames'] = $columnsHumanTitles; return $result; } function validateChartData(&$chartInfo) { $err = 0; $chartXValueTypes = array('boolean', 'date', 'datetime', 'float', 'integer', 'string', 'text', 'enum', 'file', 'disk_file', 'employee', 'crm', 'crm_status', 'iblock_element', 'iblock_section'); $chartTypes = array( array('id' => 'line', 'name' => GetMessage('REPORT_CHART_TYPE_LINE1'), 'value_types' => array( /*'boolean', 'date', 'datetime', */ 'float', 'integer'/*, 'string', 'text', 'enum', 'file', 'disk_file', 'employee', 'crm', 'crm_status', 'iblock_element', 'iblock_section'*/)), array('id' => 'bar', 'name' => GetMessage('REPORT_CHART_TYPE_BAR1'), 'value_types' => array( /*'boolean', 'date', 'datetime', */ 'float', 'integer'/*, 'string', 'text', 'enum', 'file', 'disk_file', 'employee', 'crm', 'crm_status', 'iblock_element', 'iblock_section'*/)), array('id' => 'pie', 'name' => GetMessage('REPORT_CHART_TYPE_PIE'), 'value_types' => array( /*'boolean', 'date', 'datetime', */ 'float', 'integer'/*, 'string', 'text', 'enum', 'file', 'disk_file', 'employee', 'crm', 'crm_status', 'iblock_element', 'iblock_section'*/)), ); // check meta $columnYValueTypes = array(); $nColumns = 0; if (is_array($chartInfo) && is_array($chartInfo['requestData'])) { $chartTypeIds = array(); foreach ($chartTypes as &$chartTypeInfo) $chartTypeIds[] = $chartTypeInfo['id']; $chartTypesIndexes = array_flip($chartTypeIds); $columnYValueTypes = $chartTypes[$chartTypesIndexes[$chartInfo['requestData']['type']]]['value_types']; if (isset($chartInfo['requestData']['type']) && in_array($chartInfo['requestData']['type'], $chartTypeIds)) { if (isset($chartInfo['requestData']['columnTypes']) && is_array($chartInfo['requestData']['columnTypes'])) { if (isset($chartInfo['columnsNames']) && is_array($chartInfo['columnsNames'])) { $nColumnsNames = count($chartInfo['columnsNames']); $nColumns = count($chartInfo['requestData']['columnTypes']); if ($nColumns >= 2) { if ($nColumns === $nColumnsNames) { if ($chartInfo['requestData']['type'] == 'pie' && $nColumns != 2) $err = 5; else { foreach ($chartInfo['requestData']['columnTypes'] as $columnIndex => $columnType) { if (is_int($columnIndex) && $columnIndex >= 0) { if ($columnIndex === 0) { if (!in_array($columnType, $chartXValueTypes)) $err = 7; } else { if (!in_array($columnType, $columnYValueTypes)) $err = 8; } } else $err = 6; if ($err !== 0) break; } } } else $err = 17; } else $err = 4; } else $err = 16; } else $err = 3; } else $err = 2; } else $err = 1; // check data if ($err === 0) { if (isset($chartInfo['requestData']['data']) && is_array($chartInfo['requestData']['data'])) { foreach ($chartInfo['requestData']['data'] as $rowIndex => &$dataRow) { if (is_int($rowIndex) && $rowIndex >= 0) { if (is_array($dataRow)) { $nDataColumns = count($dataRow); if ($nDataColumns === $nColumns) { foreach ($dataRow as $columnIndex => &$dataValue) { if (is_int($columnIndex) && $columnIndex >= 0) { // convert type of value switch ($chartInfo['requestData']['columnTypes'][$columnIndex]) { case 'date': case 'datetime': if (!empty($dataValue)) { if (!CheckDateTime($dataValue, CSite::GetDateFormat('SHORT'))) $err = 15; } break; case 'float': if (is_string($dataValue)) $dataValue = str_replace(' ', '', $dataValue); $dataValue = (float)$dataValue; break; case 'integer': if (is_string($dataValue)) $dataValue = str_replace(' ', '', $dataValue); $dataValue = (int)$dataValue; break; case 'boolean': case 'string': case 'text': case 'enum': case 'file': case 'disk_file': case 'employee': case 'crm': case 'crm_status': case 'iblock_element': case 'iblock_section': $dataValue = (string)$dataValue; break; default: $err = 14; } } else $err = 13; if ($err !== 0) break; } } else $err = 12; } else $err = 11; } else $err = 10; if ($err !== 0) break; } } else $err = 9; } return $err; } function prepareChartDataForAmCharts(&$chartInfo) { $type = $categoryField = $categoryType = ''; $width = $height = 0; $data = $valueColors = $valueTypes = $valueFields = array(); $baseColor = '6699CC'; $err = validateChartData($chartInfo); if ($err === 0) { switch ($chartInfo['requestData']['type']) { case 'line': $type = 'line'; break; case 'bar': $type = 'column'; break; case 'pie': $type = 'pie'; break; default: $type = 'line'; } $data = array(); // chart size $minWidth = 192; $minHeight = 120; $maxWidth = 10000; $maxHeight = 6250; if (isset($chartInfo['requestData']['width'])) { $width = intval($chartInfo['requestData']['width']); if ($width < $minWidth) $width = $minWidth; if ($width > $maxWidth) $width = $maxWidth; } else $width = 670; if (isset($chartInfo['requestData']['height'])) { $height = intval($chartInfo['requestData']['height']); if ($height < $minHeight) $height = $minHeight; if ($height > $maxHeight) $height = $maxHeight; } else $height = 420; $categoryType = $chartInfo['requestData']['columnTypes'][0]; if ($type === 'line') { if (count($chartInfo['requestData']['data']) >= 1) { $bDateSort = false; $arDateSort = array(); $tmpData = array(); foreach ($chartInfo['requestData']['data'] as $rowIndex => $row) { $dataRow = array(); foreach ($row as $k => $v) { $bSkipRow = false; if ($k === 0) { if ($categoryType === 'date' || $categoryType === 'datetime') { if ($rowIndex === 0) $bDateSort = true; if (empty($v)) $bSkipRow = true; $v = ConvertDateTime($v, 'YYYY-MM-DD HH:MI:SS'); $v[10] = 'T'; if ($bDateSort && !$bSkipRow) $arDateSort[$rowIndex] = strtotime($v); } } $dataRow[$chartInfo['columnsNames'][$k]] = $v; } if (!$bSkipRow) $tmpData[] = $dataRow; } if (!$bDateSort) { $data = $tmpData; } else { if (count($arDateSort) >= 1) { asort($arDateSort); foreach (array_keys($arDateSort) as $rowIndex) $data[] = $tmpData[$rowIndex]; } } unset($tmpData); if (count($data) >= 1) { $nColors = count($chartInfo['columnsNames']) - 1; $color = $baseColor; foreach ($chartInfo['columnsNames'] as $k => $v) { if ($k === 0) { $categoryField = $v; } else { $valueFields[] = $v; $valueTypes[] = $chartInfo['requestData']['columnTypes'][$k]; $valueColors[] = '#'.$color; $color = GetNextRGB($color, $nColors); } } } else $err = 48; } else $err = 47;//42; } else if ($type === 'column') { if (count($chartInfo['requestData']['data']) >= 1) { foreach ($chartInfo['requestData']['data'] as $row) { $dataRow = array(); foreach ($row as $k => $v) $dataRow[$chartInfo['columnsNames'][$k]] = $v; $data[] = $dataRow; } $nColors = count($chartInfo['columnsNames']) - 1; $color = $baseColor; foreach ($chartInfo['columnsNames'] as $k => $v) { if ($k === 0) { $categoryField = $v; } else { $valueFields[] = $v; $valueTypes[] = $chartInfo['requestData']['columnTypes'][$k]; $valueColors[] = '#'.$color; $color = GetNextRGB($color, $nColors); } } } else $err = 47;//43; } else if ($type === 'pie') { if (count($chartInfo['requestData']['data']) >= 1) { $arConsolidated = array(); foreach ($chartInfo['requestData']['data'] as $dataRow) { $index = $dataRow[0]; $arConsolidated[$index] += $dataRow[1]; } $sumAll = 0.0; foreach ($arConsolidated as $k => $v) { if ($v <= 0.0) unset($arConsolidated[$k]); else $sumAll += $v; } $arCounting = $arConsolidated; $nValues = count($arCounting); if ($nValues > 0) { $sumAllPrcnt = 0; foreach ($arCounting as $k => $v) { $arCounting[$k] = $v * 100 / $sumAll; $sumAllPrcnt =+ $arCounting[$k]; } if (arsort($arCounting, SORT_NUMERIC)) { $averageValuePrcnt = $sumAllPrcnt/$nValues; $trifleFactor = max($averageValuePrcnt/50, 1.0); $i = 0; $prcntCount = 0.0; $offset = 0; foreach ($arCounting as $k => $v) { if ($v < $trifleFactor) { $offset = $i; break; } else $prcntCount += $v; $i++; } $sumTrifle = 0; if ($offset > 0) { $arTrifle = array_slice($arCounting, $offset, null, true); $arCounting = array_slice($arCounting, 0, $offset, true); foreach (array_keys($arTrifle) as $k) $sumTrifle += $arConsolidated[$k]; } if (round($prcntCount,2) < 100.0) { $trifleName = GetMessage('REPORT_CHART_TRIFLE_LABEL_TEXT'); $arCounting[$trifleName] = 100.0 - $prcntCount; $arConsolidated[$trifleName] = $sumTrifle; $nValues++; } $nColors = count($arCounting); $color = $baseColor; foreach ($arCounting as $k => $v) { $dataRow = array( $chartInfo['columnsNames'][0] => $k, $chartInfo['columnsNames'][1] => round($arConsolidated[$k], 2) ); $data[] = $dataRow; $valueColors[] = '#'.$color; $color = GetNextRGB($color, $nColors); } $categoryField = $chartInfo['columnsNames'][0]; $valueFields[] = $chartInfo['columnsNames'][1]; $valueTypes[] = $chartInfo['requestData']['columnTypes'][1]; } else $err = 46; } else $err = 45; } else $err = 47;//44; } else $err = 41; } $amChartData = array('err' => $err); if ($err === 0) { $amChartData['type'] = $type; $amChartData['width'] = $width; $amChartData['height'] = $height; $amChartData['data'] = $data; $amChartData['categoryField'] = $categoryField; $amChartData['categoryType'] = $categoryType; $amChartData['valueFields'] = $valueFields; $amChartData['valueTypes'] = $valueTypes; $amChartData['valueColors'] = $valueColors; } return $amChartData; } $chartInfo = prepareChartData($arResult); if (is_array($chartInfo) && isset($chartInfo['err']) && $chartInfo['err'] !== 0) { $chartErrorCode = $chartInfo['err']; } else { $amChartData = prepareChartDataForAmCharts($chartInfo); $chartErrorCode = $amChartData['err']; } unset($chartInfo); $chartErrorMessage = ''; if ($chartErrorCode !== 0) { $chartErrorMessage = GetMessage('REPORT_CHART_ERR_'.sprintf('%02d', $chartErrorCode)); } ?> <div style="margin-bottom: 14px;"><a id="report-chart-showhide" class="report-chart-show"><?= GetMessage('REPORT_CHART_HIDE') ?></a></div> <div id="report-chart-container" class="graph"<?php echo ($chartErrorCode > 0) ? '' : ' style="height: 540px;"'; ?>><?= htmlspecialcharsbx($chartErrorMessage) ?></div> <script type="text/javascript"> function reportChartShowHide() { var chartContainer = BX("report-chart-container"); if (chartContainer) { if (chartContainer.style.display === "none") { chartContainer.style.display = ""; this.innerHTML = BX.util.htmlspecialchars("<?= CUtil::JSEscape(GetMessage('REPORT_CHART_HIDE')) ?>"); this.className = "report-chart-show"; } else { chartContainer.style.display = "none"; this.innerHTML = BX.util.htmlspecialchars("<?= CUtil::JSEscape(GetMessage('REPORT_CHART_SHOW')) ?>"); this.className = "report-chart-hide"; } } } BX.ready(function(){ var chartLink = BX("report-chart-showhide"); if (chartLink) { BX.bind(chartLink, "click", reportChartShowHide); } }); <? if ($chartErrorCode === 0): ?> function drawChart() { var amChartData = <?=CUtil::PhpToJSObject($amChartData)?>; var chartType = amChartData["type"]; var valueFields = amChartData["valueFields"]; var valueColors = amChartData["valueColors"]; // CHART var chart = null; if (chartType === "pie") { chart = new AmCharts.AmPieChart(); } else { chart = new AmCharts.AmSerialChart(); } chart.dataProvider = amChartData["data"]; chart.numberFormatter = { precision: -1, decimalSeparator: '.', thousandsSeparator:' ' }; chart.percentFormatter = { precision: 2, decimalSeparator: '.', thousandsSeparator:' ' }; chart.zoomOutText = "<?=GetMessage('REPORT_CHART_SHOW_ALL_TEXT')?>"; if (chart.dataProvider !== null && BX.type.isArray(chart.dataProvider) && chart.dataProvider.length > 0) { for (var i = 0; i < chart.dataProvider.length; i++) { if (chart.dataProvider[i][amChartData["categoryField"]] !== "") { chart.dataProvider[i]["__BN__TITLE__"] = BX.util.htmlspecialchars(chart.dataProvider[i][amChartData["categoryField"]]); } } } if (chartType === "pie") { chart.addTitle(amChartData["categoryField"] + ": " + valueFields[0]); chart.titleField = amChartData["categoryField"]; chart.valueField = valueFields[0]; chart.outlineAlpha = 0.8; chart.outlineThickness = 0; chart.balloonText = "<div>[[__BN__TITLE__]]: [[percents]]%</div>" + BX.util.htmlspecialchars(valueFields[0]) + ": <b>[[value]]</b>"; chart.colors = valueColors; chart.groupedTitle = "<?=GetMessage('REPORT_CHART_TRIFLE_LABEL_TEXT')?>"; } else { chart.categoryField = amChartData["categoryField"]; } chart.startDuration = 1; if (chartType === "column" || chartType === "pie") { chart.depth3D = 15; chart.angle = 30; } if (chartType === "line" || chartType === "column") { // AXES X var categoryAxis = chart.categoryAxis; var categoryType = "string"; categoryAxis.labelRotation = 45; if (chartType === 'column') { categoryAxis.gridPosition = "start"; } categoryAxis.title = amChartData["categoryField"]; if (chartType === "line" && (amChartData["categoryType"] === "date" || amChartData["categoryType"] === "datetime")) { categoryType = "date"; categoryAxis.dateFormats = [ {period:"fff", format:"JJ:NN:SS"}, {period:"ss", format:"JJ:NN:SS"}, {period:"mm", format:"JJ:NN"}, {period:"hh", format:"JJ:NN"}, {period:"DD", format:"DD.MM"}, {period:"WW", format:"DD.MM"}, {period:"MM", format:"MM.YYYY"}, {period:"YYYY", format:"MM.YYYY"} ]; categoryAxis.parseDates = true; categoryAxis.minPeriod = "DD"; } // VALUE for (var i = 0; i < valueFields.length; i++) { // GRAPH var graph = new AmCharts.AmGraph(); graph.title = valueFields[i]; graph.valueField = valueFields[i]; graph.balloonText = BX.util.htmlspecialchars(valueFields[i]) + ": <b>[[value]]</b>"; graph.type = chartType; graph.lineAlpha = 0.8; graph.lineColor = valueColors[i]; if (chartType === "column") { graph.fillAlphas = 0.8; } if (chartType === "line") { graph.bullet = "round"; graph.hideBulletsCount = 30; graph.bulletBorderThickness = 1; } chart.addGraph(graph); } // CURSOR var chartCursor = new AmCharts.ChartCursor(); //chartCursor.zoomable = false; if (chartType === "line") { chartCursor.cursorAlpha = 0.8; chartCursor.cursorPosition = "mouse"; if (categoryType === "string") { chartCursor.categoryBalloonFunction = function (value) { if (BX.type.isNotEmptyString(value)) { return BX.util.htmlspecialchars(value); } else { return value; } }; } else if (categoryType === "date") { chartCursor.categoryBalloonDateFormat = "DD.MM.YYYY"; } } else if (chartType === 'column') { chartCursor.cursorAlpha = 0; chartCursor.categoryBalloonEnabled = false; } chart.addChartCursor(chartCursor); } // LEGEND var legend = new AmCharts.AmLegend(); legend.align = "left"; legend.markerType = "square"; legend.valueWidth = 120; //legend.useMarkerColorForValues = true; chart.addLegend(legend); // WRITE chart.write("report-chart-container"); } <? if (\Bitrix\Main\Page\Frame::isAjaxRequest()):?> drawChart(); <? else: ?> AmCharts.ready(drawChart); <? endif ?> <? endif; // if ($chartErrorCode === 0) ?> </script> <?php endif; // if ($arParams['USE_CHART'] && $arResult['settings']['chart']['display']): ?> <div class="report-table-wrap<? echo ($arResult['allowHorizontalScroll'] ? ' main-grid-fade' : ''); ?>"><? if ($arResult['allowHorizontalScroll']) : ?><? ?><div class="main-grid-fade-shadow-left"></div><? ?><div class="main-grid-fade-shadow-right"></div><? ?><div class="main-grid-ear main-grid-ear-left"></div><? ?><div class="main-grid-ear main-grid-ear-right"></div><? endif; ?> <div class="main-grid-container"> <div class="reports-list-left-corner"></div> <div class="reports-list-right-corner"></div> <table cellspacing="0" class="reports-list-table" id="<?= $resultTableId ?>"> <thead> <!-- head --> <tr> <? $i = 0; foreach($arResult['viewColumns'] as $colId => $col): ?> <? $i++; if ($i == 1) { $th_class = 'reports-first-column'; } else if ($i == count($arResult['viewColumns'])) { $th_class = 'reports-last-column'; } else { $th_class = 'reports-head-cell'; } // sorting //$defaultSort = 'DESC'; $defaultSort = $col['defaultSort']; if ($colId == $arResult['sort_id'] && !empty($defaultSort)) { $th_class .= ' reports-selected-column'; if($arResult['sort_type'] == 'ASC') { $th_class .= ' reports-head-cell-top'; } } else { if ($defaultSort == 'ASC') { $th_class .= ' reports-head-cell-top'; } } ?> <th class="<?=$th_class?>" colId="<?=$colId?>" defaultSort="<?=$defaultSort?>"> <div class="reports-head-cell"><?if($defaultSort): ?><span class="reports-table-arrow"></span><? endif?><span class="reports-head-cell-title"><?=htmlspecialcharsbx($col['humanTitle'])?></span></div> </th> <? endforeach; ?> </tr> </thead> <tbody> <!-- data --> <? $rowNum = 0; ?> <? foreach ($arResult['data'] as $row): ?> <tr class="reports-list-item"> <? $i = 0; foreach($arResult['viewColumns'] as $col): ?> <? $i++; if ($i == 1) { $td_class = 'reports-first-column'; } else if ($i == count($arResult['viewColumns'])) { $td_class = 'reports-last-column'; } else { $td_class = ''; } if (CReport::isColumnPercentable($col, $arResult['helperClassName'])) { $colType = getResultColumnDataType($col, $arResult['customColumnTypes'], $arResult['helperClassName']); if (!in_array($colType, array('string', 'datetime', 'date', 'boolean'), true)) $td_class .= ' reports-numeric-column'; } $finalValue = $row[$col['resultName']]; // add link if (!empty($col['href']) && !empty($row['__HREF_'.$col['resultName']])) { if (is_array($finalValue)) { // grc foreach ($finalValue as $grcIndex => $v) { $finalValue[$grcIndex] = '<a target="_blank" href="' .$arResult['grcData'][$col['resultName']][$grcIndex]['__HREF_'.$col['resultName']] .'">'.$v.'</a>'; } } elseif (strlen($row[$col['resultName']])) { $finalValue = '<a target="_blank" href="'.$row['__HREF_'.$col['resultName']].'">'.$row[$col['resultName']].'</a>'; } } $redSign = false; if (isset($arResult['customChartData'][$rowNum][$col['resultName']]['multiple'])) { $customValueInfo = &$arResult['customChartData'][$rowNum][$col['resultName']]; if ($customValueInfo['multiple'] === true) { $dataValue = 0; foreach ($customValueInfo as $cvKey => $cvInfo) { if ($cvKey !== 'multiple' && isset($cvInfo['type']) && ($cvInfo['type'] === 'float' || $cvInfo['type'] === 'integer')) { if ($cvInfo['value'] < 0) { $redSign = true; break; } } } unset($cvKey, $cvInfo); } else { $cvInfo = &$customValueInfo[0]; if (isset($cvInfo['type']) && ($cvInfo['type'] === 'float' || $cvInfo['type'] === 'integer')) { if ($cvInfo['value'] < 0) $redSign = true; } unset($cvInfo); } unset($customValueInfo); } // magic glue if (is_array($finalValue)) { $finalValue = join(' / ', $finalValue); } if ($arResult['settings']['red_neg_vals'] === true) { if ($redSign || (is_numeric($finalValue) && $finalValue < 0)) $td_class .= ' report-red-neg-val'; } ?> <td class="<?=$td_class?>"><?=$finalValue?></td> <? endforeach; ?> </tr> <? $rowNum++; ?> <? endforeach; ?> <tr> <td colspan="<?=count($arResult['viewColumns'])?>" class="reports-pretotal-column"> <?php echo $arResult["NAV_STRING"]?> <br /><br /> <span style="font-size: 14px;"><?=GetMessage('REPORT_TOTAL')?></span> </td> </tr> <tr> <? $i = 0; foreach($arResult['viewColumns'] as $col): ?> <? $i++; if ($i == 1) { $td_class = 'reports-first-column'; } else if ($i == count($arResult['viewColumns'])) { $td_class = 'reports-last-column'; } else { $td_class = ''; } ?> <td class="<?=$td_class?> reports-total-column" sstyle="background-color: #F0F0F0;"><?=htmlspecialcharsbx($col['humanTitle'])?></td> <? endforeach; ?> </tr> <tr> <? $i = 0; foreach($arResult['viewColumns'] as $col): ?> <? $i++; if ($i == 1) { $td_class = 'reports-first-column'; } else if ($i == count($arResult['viewColumns'])) { $td_class = 'reports-last-column'; } else { $td_class = ''; } if (CReport::isColumnPercentable($col, $arResult['helperClassName'])) { $colType = getResultColumnDataType($col, $arResult['customColumnTypes'], $arResult['helperClassName']); if (!in_array($colType, array('string', 'datetime', 'date', 'boolean'), true)) $td_class .= ' reports-numeric-column'; } ?> <td class="<?=$td_class?>"><?=array_key_exists('TOTAL_'.$col['resultName'], $arResult['total']) ? $arResult['total']['TOTAL_'.$col['resultName']] : '—'?></td> <? endforeach; ?> </tr> </tbody> </table> </div> <script type="text/javascript"> BX.ready(function(){ var rows = BX.findChildren(BX('<?= $resultTableId ?>'), {tag:'th'}, true); for (i = 0 ; i < rows.length ; i++) { var ds = rows[i].getAttribute('defaultSort'); if (ds == '') { BX.addClass(rows[i], 'report-column-disabled-sort'); continue; } BX.bind(rows[i], 'click', function(){ var colId = this.getAttribute('colId'); var sortType = ''; var isCurrent = BX.hasClass(this, 'reports-selected-column'); if (isCurrent) { var currentSortType = BX.hasClass(this, 'reports-head-cell-top') ? 'ASC' : 'DESC'; sortType = currentSortType == 'ASC' ? 'DESC' : 'ASC'; } else { sortType = this.getAttribute('defaultSort'); } var idInp = BX.findChild(BX('report-rewrite-filter'), {attr:{name:'sort_id'}}); var typeInp = BX.findChild(BX('report-rewrite-filter'), {attr:{name:'sort_type'}}); idInp.value = colId; typeInp.value = sortType; BX.submit(BX('report-rewrite-filter')); }); } }); </script> </div> </div> <?php $this->SetViewTarget("sidebar_tools_1", 100);?> <!-- control examples --> <div id="report-chfilter-examples" style="display: none;"> <div class="filter-field filter-field-user chfilter-field-\Bitrix\Main\User" callback="RTFilter_chooseUser"> <label for="user-email" class="filter-field-title">%TITLE% "%COMPARE%"</label> <span class="webform-field-textbox-inner"> <input id="%ID%" type="text" class="webform-field-textbox" caller="true" /> <input type="hidden" name="%NAME%" value=""/> <a href="" class="webform-field-textbox-clear"></a> </span> </div> <div class="filter-field filter-field-crm chfilter-field-enum"> <label class="filter-field-title">%TITLE% "%COMPARE%"</label> </div> <div class="filter-field filter-field-crm chfilter-field-crm"> <label class="filter-field-title">%TITLE% "%COMPARE%"</label> </div> <div class="filter-field filter-field-crm_status chfilter-field-crm_status"> <label class="filter-field-title">%TITLE% "%COMPARE%"</label> </div> <div class="filter-field filter-field-iblock_element chfilter-field-iblock_element"> <label class="filter-field-title">%TITLE% "%COMPARE%"</label> </div> <div class="filter-field filter-field-iblock_section chfilter-field-iblock_section"> <label class="filter-field-title">%TITLE% "%COMPARE%"</label> </div> <div class="filter-field filter-field-employee chfilter-field-employee" callback="RTFilter_chooseUser"> <label for="user-email" class="filter-field-title">%TITLE% "%COMPARE%"</label> <span class="webform-field-textbox-inner"> <input id="%ID%" type="text" class="webform-field-textbox" caller="true" /> <input type="hidden" name="%NAME%" value=""/> <a href="" class="webform-field-textbox-clear"></a> </span> </div> <div class="filter-field filter-field-user chfilter-field-\Bitrix\Socialnetwork\Workgroup" callback="RTFilter_chooseGroup"> <label for="user-email" class="filter-field-title">%TITLE% "%COMPARE%"</label> <span class="webform-field-textbox-inner"> <input id="%ID%" type="text" class="webform-field-textbox" caller="true" /> <input type="hidden" name="%NAME%" value=""/> <a href="" class="webform-field-textbox-clear"></a> </span> </div> <div class="filter-field chfilter-field-datetime"> <label for="" class="filter-field-title">%TITLE% "%COMPARE%"</label> <input type="text" value="%VALUE%" name="%NAME%" value="" class="filter-field-calendar" id="" /><a class="filter-date-interval-calendar" href="" title="<?=GetMessage('TASKS_PICK_DATE')?>"><img border="0" src="/bitrix/js/main/core/images/calendar-icon.gif" alt="<?=GetMessage('TASKS_PICK_DATE')?>"></a> </div> <div class="filter-field chfilter-field-string"> <label for="" class="filter-field-title">%TITLE% "%COMPARE%"</label> <input type="text" value="%VALUE%" name="%NAME%" value="" class="filter-textbox" id="" /> </div> <div class="filter-field chfilter-field-text"> <label for="" class="filter-field-title">%TITLE% "%COMPARE%"</label> <input type="text" value="%VALUE%" name="%NAME%" value="" class="filter-textbox" id="" /> </div> <div class="filter-field chfilter-field-integer"> <label for="" class="filter-field-title">%TITLE% "%COMPARE%"</label> <input type="text" value="%VALUE%" name="%NAME%" value="" class="filter-textbox" id="" /> </div> <div class="filter-field chfilter-field-float"> <label for="" class="filter-field-title">%TITLE% "%COMPARE%"</label> <input type="text" value="%VALUE%" name="%NAME%" value="" class="filter-textbox" id="" /> </div> <div class="filter-field chfilter-field-boolean" callback="RTFilter_chooseBoolean"> <label for="" class="filter-field-title">%TITLE% "%COMPARE%"</label> <select name="%NAME%" class="filter-dropdown" id="%ID%" caller="true"> <option value=""><?=GetMessage('REPORT_IGNORE_FILTER_VALUE')?></option> <option value="true"><?=GetMessage('REPORT_BOOLEAN_VALUE_TRUE')?></option> <option value="false"><?=GetMessage('REPORT_BOOLEAN_VALUE_FALSE')?></option> </select> <script type="text/javascript"> function RTFilter_chooseBooleanCatch(value) { setSelectValue(RTFilter_chooseBoolean_LAST_CALLER, value); } </script> </div> </div> <div class="sidebar-block"> <b class="r2"></b><b class="r1"></b><b class="r0"></b> <div class="sidebar-block-inner"> <div class="filter-block-title report-filter-block-title"><?=GetMessage('REPORT_FILTER')?><!--<a class="filter-settings" href=""></a>--></div> <div class="filter-block filter-field-date-combobox filter-field-date-combobox-interval"> <form id="report-rewrite-filter" action="<?=CComponentEngine::MakePathFromTemplate( $arParams["PATH_TO_REPORT_VIEW"], array('report_id' => $arParams['REPORT_ID']) );?>" method="GET"> <input type="hidden" name="set_filter" value="Y" /> <input type="hidden" name="sort_id" value="<?=htmlspecialcharsbx($arResult['sort_id'])?>" /> <input type="hidden" name="sort_type" value="<?=htmlspecialcharsbx($arResult['sort_type'])?>" /> <?=$APPLICATION->GetViewContent("report_view_prefilter")?> <!-- period --> <div class="filter-field"> <label for="task-interval-filter" class="filter-field-title"><?=GetMessage('REPORT_PERIOD')?></label> <select class="filter-dropdown" style="margin-bottom: 0;" onchange="OnTaskIntervalChange(this)" id="task-interval-filter" name="F_DATE_TYPE"> <?php foreach ($arPeriodTypes as $key => $type): ?> <option value="<?php echo $key?>"<?=($key == $arResult['period']['type']) ? " selected" : ""?>><?php echo $type?></option> <?php endforeach;?> </select> <span class="filter-date-interval<?php if (isset($arResult["FILTER"]["F_DATE_TYPE"])) { switch ($arResult["FILTER"]["F_DATE_TYPE"]) { case "interval": echo " filter-date-interval-after filter-date-interval-before"; break; case "before": echo " filter-date-interval-before"; break; case "after": echo " filter-date-interval-after"; break; } } ?>"><span class="filter-date-interval-from"><input type="text" class="filter-date-interval-from" name="F_DATE_FROM" id="REPORT_INTERVAL_F_DATE_FROM" value="<?=$arResult['form_date']['from']?>"/><a class="filter-date-interval-calendar" href="" title="<?php echo GetMessage("TASKS_PICK_DATE")?>" id="filter-date-interval-calendar-from"><img border="0" src="/bitrix/js/main/core/images/calendar-icon.gif" alt="<?php echo GetMessage("TASKS_PICK_DATE")?>"></a></span><span class="filter-date-interval-hellip">…</span><span class="filter-date-interval-to"><input type="text" class="filter-date-interval-to" name="F_DATE_TO" id ="REPORT_INTERVAL_F_DATE_TO" value="<?=$arResult['form_date']['to']?>"/><a href="" class="filter-date-interval-calendar" title="<?php echo GetMessage("TASKS_PICK_DATE")?>" id="filter-date-interval-calendar-to"><img border="0" src="/bitrix/js/main/core/images/calendar-icon.gif" alt="<?php echo GetMessage("TASKS_PICK_DATE")?>"></a></span> </span> <span class="filter-day-interval<?php if ($arResult["FILTER"]["F_DATE_TYPE"] == "days"): ?> filter-day-interval-selected<?php endif; ?>"><input type="text" size="5" class="filter-date-days" value="<?= htmlspecialcharsbx($arResult['form_date']['days']) ?>" name="F_DATE_DAYS"/> <?php echo GetMessage("TASKS_REPORT_DAYS"); ?></span> <script type="text/javascript"> function OnTaskIntervalChange(select) { select.parentNode.className = "filter-field filter-field-date-combobox " + "filter-field-date-combobox-" + select.value; var dateInterval = BX.findNextSibling(select, { "tag": "span", 'className': "filter-date-interval" }); var dayInterval = BX.findNextSibling(select, { "tag": "span", 'className': "filter-day-interval" }); BX.removeClass(dateInterval, "filter-date-interval-after filter-date-interval-before"); BX.removeClass(dayInterval, "filter-day-interval-selected"); if (select.value == "interval") BX.addClass(dateInterval, "filter-date-interval-after filter-date-interval-before"); else if(select.value == "before") BX.addClass(dateInterval, "filter-date-interval-before"); else if(select.value == "after") BX.addClass(dateInterval, "filter-date-interval-after"); else if(select.value == "days") BX.addClass(dayInterval, "filter-day-interval-selected"); } BX.ready(function() { BX.bind(BX("filter-date-interval-calendar-from"), "click", function(e) { if (!e) e = window.event; var curDate = new Date(); var curTimestamp = Math.round(curDate / 1000) - curDate.getTimezoneOffset()*60; BX.calendar({ node: this, field: BX('REPORT_INTERVAL_F_DATE_FROM'), bTime: false }); BX.PreventDefault(e); }); BX.bind(BX("filter-date-interval-calendar-to"), "click", function(e) { if (!e) e = window.event; var curDate = new Date(); var curTimestamp = Math.round(curDate / 1000) - curDate.getTimezoneOffset()*60; BX.calendar({ node: this, field: BX('REPORT_INTERVAL_F_DATE_TO'), bTime: false }); BX.PreventDefault(e); }); jsCalendar.InsertDate = function(value) { BX.removeClass(this.field.parentNode.parentNode, "webform-field-textbox-empty"); var value = this.ValueToString(value); this.field.value = value.substr(11, 8) == "00:00:00" ? value.substr(0, 10) : value.substr(0, 16); this.Close(); } OnTaskIntervalChange(BX('task-interval-filter')); }); </script> </div> <div id="report-filter-chfilter"> <!-- insert changeable filters --> <? // prepare info $info = array(); foreach($arResult['changeableFilters'] as $chFilter) { $field = isset($chFilter['field']) ? $chFilter['field'] : null; // Try to obtain qualified field name (e.g. 'COMPANY_BY.COMPANY_TYPE_BY.STATUS_ID') $name = isset($chFilter['name']) ? $chFilter['name'] : ($field ? $field->GetName() : ''); $info[] = array( 'TITLE' => $chFilter['title'], 'COMPARE' => ToLower(GetMessage('REPORT_FILTER_COMPARE_VAR_'.$chFilter['compare'])), 'NAME' =>$chFilter['formName'], 'ID' => $chFilter['formId'], 'VALUE' => $chFilter['value'], 'FIELD_NAME' => $name, 'FIELD_TYPE' => $chFilter['data_type'], 'IS_UF' => $chFilter['isUF'], 'UF_ID' => $chFilter['ufId'], 'UF_NAME' => $chFilter['ufName'] ); } // filter fields selectors $ufInfoUsed = array(); foreach ($arResult['changeableFilters'] as $chFilter) { if (isset($chFilter['isUF']) && $chFilter['isUF'] === true && isset($chFilter['data_type']) && ($chFilter['data_type'] === 'enum' ||$chFilter['data_type'] === 'crm' || $chFilter['data_type'] === 'crm_status' || $chFilter['data_type'] === 'iblock_element' || $chFilter['data_type'] === 'iblock_section') && isset($chFilter['ufId']) && isset($chFilter['ufName']) && is_array($arResult['ufInfo'][$chFilter['ufId']][$chFilter['ufName']])) { if (!isset($ufInfoUsed[$chFilter['ufId']][$chFilter['ufName']])) $ufInfoUsed[$chFilter['ufId']][$chFilter['ufName']] = &$arResult['ufInfo'][$chFilter['ufId']][$chFilter['ufName']]; } } if (!empty($ufInfoUsed)) { $APPLICATION->IncludeComponent( 'bitrix:report.filter.field.selector', '', array('ufInfo' => $ufInfoUsed), false, array('HIDE_ICONS' => true) ); } ?> <script type="text/javascript"> BX.ready(function() { var info = <?=CUtil::PhpToJSObject($info)?>; var cpControl, fieldType, tipicalControl, isUF, ufId, ufName, cpSelector, selectorIndex; for (var i in info) { if (!info.hasOwnProperty(i)) continue; cpControl = null; fieldType = info[i].FIELD_TYPE; // insert value control // search in `examples-custom` by name or type // then search in `examples` by type cpControl = BX.clone( BX.findChild( BX('report-chfilter-examples-custom'), {className: 'chfilter-field-' + info[i].FIELD_NAME} ) || BX.findChild( BX('report-chfilter-examples-custom'), {className: 'chfilter-field-' + fieldType} ) || BX.findChild( BX('report-chfilter-examples'), {className: 'chfilter-field-' + fieldType} ), true ); //global replace %ID%, %NAME%, %TITLE% and etc. cpControl.innerHTML = cpControl.innerHTML.replace(/%((?!VALUE)[A-Z]+)%/gi, function(str, p1, offset, s) { var n = p1.toUpperCase(); return typeof(info[i][n]) != 'undefined' ? BX.util.htmlspecialchars(info[i][n]) : str; }); tipicalControl = true; isUF = !!info[i]["IS_UF"]; if (isUF) { ufId = info[i]["UF_ID"]; ufName = info[i]["UF_NAME"]; if (fieldType === 'enum' ||fieldType === 'crm' || fieldType === 'crm_status' || fieldType === 'iblock_element' || fieldType === 'iblock_section') { tipicalControl = false; } } if (tipicalControl) { if (cpControl.getAttribute('callback') != null) { // set last caller var callerName = cpControl.getAttribute('callback') + '_LAST_CALLER'; var callerObj = BX.findChild(cpControl, {attr:'caller'}, true); window[callerName] = callerObj; // set value var cbFuncName = cpControl.getAttribute('callback') + 'Catch'; window[cbFuncName](info[i].VALUE); } else { cpControl.innerHTML = cpControl.innerHTML.replace('%VALUE%', BX.util.htmlspecialchars(info[i].VALUE)); } BX('report-filter-chfilter').appendChild(cpControl); } else { BX('report-filter-chfilter').appendChild(cpControl); var filterFieldSelector = BX.Report.FilterFieldSelectorManager.getSelector(ufId, ufName); if (filterFieldSelector) { cpSelector = filterFieldSelector.makeFilterField(cpControl, null, info[i]["NAME"]); if (cpSelector) { selectorIndex = cpSelector.getAttribute("ufSelectorIndex"); filterFieldSelector.setFilterValue(selectorIndex, info[i]["VALUE"]); } } } } }); </script> </div> </form> <form id="report-reset-filter" action="<?=CComponentEngine::MakePathFromTemplate( $arParams["PATH_TO_REPORT_VIEW"], array('report_id' => $arParams['REPORT_ID']) );?>" method="GET"> <input type="hidden" name="sort_id" value="<?=htmlspecialcharsbx($arResult['sort_id'])?>" /> <input type="hidden" name="sort_type" value="<?=htmlspecialcharsbx($arResult['sort_type'])?>" /> </form> <div class="filter-field-buttons"> <input id="report-rewrite-filter-button" type="submit" value="<?=GetMessage('REPORT_FILTER_APPLY')?>" class="filter-submit"> <input id="report-reset-filter-button" type="submit" name="del_filter_company_search" value="<?=GetMessage('REPORT_FILTER_CANCEL')?>" class="filter-submit"> </div> <script type="text/javascript"> BX.ready(function(){ BX.bind(BX('report-reset-filter-button'), 'click', function(){ BX.submit(BX('report-reset-filter')); }); BX.bind(BX('report-rewrite-filter-button'), 'click', function(){ BX.submit(BX('report-rewrite-filter')); }); // User controls var controls = BX.findChildren(BX('report-rewrite-filter'), {className: /chfilter-field-(\\Bitrix\\Main\\User|employee)/}, true); if (controls != null) { for (i in controls) { var inp = BX.findChild(controls[i], {tag:'input', attr:{type:'text'}}, true); var x = BX.findNextSibling(inp, {tag:'a'}); BX.bind(inp, 'click', RTFilter_chooseUser); BX.bind(inp, 'blur', RTFilter_chooseUserCatchFix); BX.bind(x, 'click', RTFilter_chooseUserClear); } } // Group controls var controls = BX.findChildren(BX('report-rewrite-filter'), {className:'chfilter-field-\\Bitrix\\Socialnetwork\\Workgroup'}, true); if (controls != null) { for (i in controls) { var inp = BX.findChild(controls[i], {tag:'input', attr:{type:'text'}}, true); var x = BX.findNextSibling(inp, {tag:'a'}); BX.bind(inp, 'click', RTFilter_chooseGroup); //BX.bind(inp, 'blur', RTFilter_chooseGroupCatchFix); BX.bind(x, 'click', RTFilter_chooseGroupClear); } } // Date controls var controls = BX.findChildren(BX('report-rewrite-filter'), {className:'chfilter-field-datetime'}, true); if (controls != null) { for (i in controls) { var butt = BX.findChild(controls[i], {tag:'img'}, true); BX.bind(butt, "click", function(e) { BX.PreventDefault(e); var valueInput = BX.findChild(this.parentNode.parentNode, {tag:'input'}); var curDate = new Date(); var curTimestamp = Math.round(curDate / 1000) - curDate.getTimezoneOffset()*60; BX.calendar({ node: this, field: valueInput, bTime: false }); }); } } }); function setSelectValue(select, value) { var i, j; var bFirstSelected = false; var bMultiple = !!(select.getAttribute('multiple')); if (!(value instanceof Array)) value = new Array(value); for (i=0; i<select.options.length; i++) { for (j in value) { if (select.options[i].value == value[j]) { if (!bFirstSelected) {bFirstSelected = true; select.selectedIndex = i;} select.options[i].selected = true; break; } } if (!bMultiple && bFirstSelected) break; } } function RTFilter_chooseUser(control) { if (this.parentNode) { var elem = this; } else { var elem = BX.findChild(control, {tag:'input', attr: {type:'text'}}, true); } singlePopup = BX.PopupWindowManager.create("single-employee-popup-"+Math.random(), elem, { offsetTop : 1, autoHide : true, content : BX("Single_"+elem.id+"_selector_content") }); if (singlePopup.popupContainer.style.display != "block") { singlePopup.show(); } RTFilter_chooseUser_LAST_CALLER = elem; } function RTFilter_chooseUserCatch(user) { var inp = RTFilter_chooseUser_LAST_CALLER; var hid = BX.findNextSibling(inp, {tag:'input',attr:{type:'hidden'}}); var x = BX.findNextSibling(inp, {tag:'a'}); hid.value = user.id; if (parseInt(user.id) > 0) { inp.value = user.name; x.style.display = 'inline'; } else { inp.value = ''; x.style.display = 'none'; } try { singlePopup.close(); } catch (e) {} } function RTFilter_chooseUserCatchFix() { var inp = RTFilter_chooseUser_LAST_CALLER; var hid = BX.findNextSibling(inp, {tag:'input',attr:{type:'hidden'}}); if (inp.value.length < 1 && parseInt(hid.value) > 0) { var fobj = window['O_Single_' + inp.id]; inp.value = fobj.arSelected[hid.value].name; } } function RTFilter_chooseUserClear(e) { RTFilter_chooseUser_LAST_CALLER = BX.findChild(this.parentNode, {tag:'input',attr:{type:'text'}}); BX.PreventDefault(e); RTFilter_chooseUserCatch({id:''}); } function RTFilter_chooseGroup(control) { if (this.parentNode) { var elem = this; } else { var elem = BX.findChild(control, {tag:'input', attr: {type:'text'}}, true); } var popup = window['filterGroupsPopup_'+elem.id]; popup.searchInput = elem; popup.popupWindow.setBindElement(elem); popup.show(); RTFilter_chooseGroup_LAST_CALLER = elem; } function RTFilter_chooseGroupCatch(group) { if (group.length < 1) return; group = group[0]; var inp = RTFilter_chooseGroup_LAST_CALLER; var hid = BX.findNextSibling(inp, {tag:'input',attr:{type:'hidden'}}); var x = BX.findNextSibling(inp, {tag:'a'}); hid.value = group.id; if (parseInt(group.id) > 0) { inp.value = group.title; x.style.display = 'inline'; } else { inp.value = ''; x.style.display = 'none'; } try { var popup = window['filterGroupsPopup_'+inp.id]; popup.popupWindow.close(); } catch (e) {} } function RTFilter_chooseGroupClear(e) { RTFilter_chooseGroup_LAST_CALLER = BX.findChild(this.parentNode, {tag:'input',attr:{type:'text'}}); BX.PreventDefault(e); RTFilter_chooseGroupCatch([{id:0}]); } </script> <? foreach ($arResult['changeableFilters'] as $chFilter) { /** @var \Bitrix\Main\Entity\ReferenceField[] $chFilter */ if (($chFilter['field'] && $chFilter['field'] instanceof \Bitrix\Main\Entity\ReferenceField && $chFilter['field']->getRefEntityName() == '\Bitrix\Main\User') || (isset($chFilter['isUF']) && $chFilter['isUF'] === true && isset($chFilter['data_type']) && $chFilter['data_type'] === 'employee')) { // user selector $name = $APPLICATION->IncludeComponent( "bitrix:intranet.user.selector.new", ".default", array( "MULTIPLE" => "N", "NAME" => "Single_" . $chFilter['formId'], "INPUT_NAME" => $chFilter['formId'], "VALUE" => $chFilter['value']['id'], "POPUP" => "Y", "ON_SELECT" => "RTFilter_chooseUserCatch", "NAME_TEMPLATE" => $arParams["USER_NAME_FORMAT"] ), null, array("HIDE_ICONS" => "Y") ); } else if ($chFilter['field'] && $chFilter['field'] instanceof \Bitrix\Main\Entity\ReferenceField && $chFilter['field']->getRefEntityName() == '\Bitrix\Socialnetwork\Workgroup') { // group selector $name = $APPLICATION->IncludeComponent( "bitrix:socialnetwork.group.selector", ".default", array( "ON_SELECT" => "RTFilter_chooseGroupCatch", //callback "SEARCH_INPUT" => $chFilter['formId'], "JS_OBJECT_NAME" => "filterGroupsPopup_" . $chFilter['formId'], "SELECTED" => $chFilter['value'][0]['id'] ), null, array("HIDE_ICONS" => "Y") ); } } ?> </div> </div> <i class="r0"></i><i class="r1"></i><i class="r2"></i> </div> <? if (strlen($arResult['report']['DESCRIPTION'])): ?> <div class="sidebar-block"> <b class="r2"></b><b class="r1"></b><b class="r0"></b> <div class="sidebar-block-inner"> <div class="filter-block-title report-filter-block-title"><?=GetMessage('REPORT_DESCRIPTION')?></div> <div class="reports-description-text"> <?=htmlspecialcharsbx($arResult['report']['DESCRIPTION'])?> </div> </div> </div> <? endif; ?> <?php if ($arResult['allowHorizontalScroll']) { Bitrix\Main\Page\Asset::getInstance()->addJs('/bitrix/components/bitrix/main.ui.grid/templates/.default/js/utils.js'); Bitrix\Main\Page\Asset::getInstance()->addJs('/bitrix/components/bitrix/main.ui.grid/templates/.default/js/fader.js'); $hScrollSettings = array( 'tableId' => $resultTableId, 'allowHorizontalScroll' => $arResult['allowHorizontalScroll'], 'allowPinHeader' => false, 'classHide' => 'main-grid-hide', 'classShow' => 'show', 'classEarLeft' => 'main-grid-ear-left', 'classEarRight' => 'main-grid-ear-right', 'classFadeContainerLeft' => 'main-grid-fade-left', 'classFadeContainerRight' => 'main-grid-fade-right', 'classFadeShadowLeft' => 'main-grid-fade-shadow-left', 'classFadeShadowRight' => 'main-grid-fade-shadow-right' ); ?> <script type="text/javascript"> BX.ready( function() { BX.Report.View.HScroll.create( "<?=CUtil::JSEscape($resultTableId.'_hscroll')?>", <?=CUtil::PhpToJSObject($hScrollSettings)?> ); } ); </script><?php } if (is_array($arResult['STEXPORT_PARAMS'])) { Bitrix\Main\Page\Asset::getInstance()->addJs('/bitrix/js/report/lrpdialog.js'); Bitrix\Main\Page\Asset::getInstance()->addJs('/bitrix/js/report/stexport.js'); ?> <script type="text/javascript"> BX.ready( function() { BX.Report.LongRunningProcessDialog.messages = { startButton: "<?=GetMessageJS('CRM_REPORT_LRP_DLG_BTN_START')?>", stopButton: "<?=GetMessageJS('CRM_REPORT_LRP_DLG_BTN_STOP')?>", closeButton: "<?=GetMessageJS('CRM_REPORT_LRP_DLG_BTN_CLOSE')?>", wait: "<?=GetMessageJS('CRM_REPORT_LRP_DLG_WAIT')?>", requestError: "<?=GetMessageJS('CRM_REPORT_LRP_DLG_REQUEST_ERR')?>" }; BX.Report.StExportManager.create( "<?=CUtil::JSEscape($arResult['STEXPORT_PARAMS']['managerId'])?>", <?=CUtil::PhpToJSObject($arResult['STEXPORT_PARAMS'])?> ); } ); </script><?php } $this->EndViewTarget(); reportViewShowTopButtons($this, $arParams, $arResult); ?>