%PDF- %PDF-
Direktori : /home/bitrix/www/bitrix/components/bitrix/report.construct/templates/admin/ |
Current File : //home/bitrix/www/bitrix/components/bitrix/report.construct/templates/admin/template.php |
<?php if (!defined("B_PROLOG_INCLUDED") || B_PROLOG_INCLUDED!==true)die(); if (!empty($arResult['ERROR'])) { echo $arResult['ERROR']; return false; } if (!empty($arResult['FORM_ERROR'])) { ?> <font color='red'><?=$arResult['FORM_ERROR']?></font><br/><br/> <? } $GLOBALS['APPLICATION']->SetAdditionalCSS('/bitrix/js/report/css/report.css'); $GLOBALS['APPLICATION']->AddHeadScript('/bitrix/js/report/construct.js'); CJSCore::Init(array('date', 'access')); ?> <!-- Redefinition of some styles --> <style type="text/css"> #sale-report-construct-buttons-block { padding-top: 18px; } .reports-filter-quan-item {height: 30px;} .reports-filter-quan-item .reports-checkbox { margin: 0;} .reports-filter-block { width: 800px; } .report-filter-calendar { margin-left: 4px; } .reports-forming-column { height: 38px; padding-top: 0px; } .reports-add-col-button-down, .reports-add-col-button-up, .reports-checkbox { vertical-align: middle; margin-top: 8px; padding: 0;} /* grouping */ .reports-grouping-checkbox, .reports-grouping-subtotal-checkbox { display:inline-block; margin-right:6px; position:relative; vertical-align:middle; } .reports-grouping-header { padding: 0 0 15px 42px; font-size: 0px; position: relative; } .reports-image-arrow-bottom1 { background: url("\ gAAAAcAAAAVCAIAAAAFLmMUAAAABnRSTlMA/wD/AP83WBt9AAAARElEQVQYle2RwQ3AMAgDQ8Rkt\ zes5j5QaaREygK918kyH2OSxoa3ZWYJ4GsFKJn7+Z9eUpPUyxbAHMusn+slItrt+LcH3bElmA5AL\ PgAAAAASUVORK5CYII=") no-repeat scroll 0 0 transparent; } .reports-image-arrow-bottom2 { background: url("\ gAAAIEAAAAVCAIAAADuNRpSAAAABnRSTlMA/wD/AP83WBt9AAAAe0lEQVRYhe3ZQQqAMAwAwVZ8W\ R7er8VDpVIfkBXcOfVYuhAh9sxsQp30BX5qjDEPEWEDTETMw8HeQ80GX2ADng14NuDZgGcDng14N\ uDZgPfsKtYGQ8W2fdHaYKiSs4hnA17PzNeXwIlU7Gj7oxug3j2L5tMbANH9n4y7AHQnFgWuXmHqA\ AAAAElFTkSuQmCC") no-repeat scroll 0 0 transparent; } .reports-checkbox-g-arrow-bottom { display: block; height: 21px; width: 7px; position: absolute; bottom: 0; left: 32px; } .reports-checkbox-gs-arrow-bottom { display: block; height: 21px; width: 129px; position: absolute; bottom: 0; left: 51px; } .reports-grouping-header-title { color:#a6a6a6; line-height:11px; font-size:11px; width: 130px; display: inline-block; position: relative; margin-right: 10px; } /*.reports-filter-item { height: 30px; }*/ .reports-filter-butt-wrap { top: 3px; } .reports-filter-butt-wrap .reports-checkbox { margin-top: 0px; } .reports-filter-item-name { width: 160px; vertical-align: top; margin-top: 1px; } .reports-filter-item select { vertical-align: top; } .reports-sort-column { margin-bottom: 15px; } .reports-add-col-title { height: 16px; padding-top: 3px; } .reports-add-col-tit-prcnt, .reports-add-col-tit-edit, .reports-add-col-tit-prcnt-close, .reports-add-col-tit-remove { top: 4px; } .reports-add-col-title { height: 32px; } .reports-add-col-select.reports-add-col-select-calc { position: relative; top: -5px; } .reports-add-col-title { top: 10px; } .reports-add-col-tit-text { margin-right: 5px; } .reports-add-col-input input { position: relative; top: -5px; } .reports-add-col-inp-title { top: -17px; } .reports-add-col-select-prcnt, .reports-add-col-select-prcnt-by { position: relative; top: -5px; } .reports-limit-res-select-lable { margin-right: 5px; margin-left: 5px; } table.edit-table div {font-size:14px;} .reports-list-table th { font: 14px Arial,Helvetica,sans-serif; } .filter-field-date-combobox .filter-date-interval{display:none;} .filter-field-date-combobox span.filter-date-interval-hellip{display:none;} .filter-field-date-combobox .filter-date-interval-after{display:inline;} .filter-field-date-combobox .filter-date-interval-before{display:inline;} .filter-field-date-combobox .filter-date-interval-after.filter-date-interval-before{display:block;margin-top:0.5em;} .filter-field-date-combobox .filter-date-interval-after.filter-date-interval-before span.filter-date-interval-hellip{display:inline-block;margin:0;} .filter-field-date-combobox .filter-date-interval-to{display:none;} .filter-field-date-combobox .filter-date-interval-from{display:none;} .filter-field-date-combobox .filter-date-interval-after .filter-date-interval-to{display:inline;} .filter-field-date-combobox .filter-date-interval-before .filter-date-interval-from{display:inline;} .filter-field-date-combobox .filter-day-interval {display:none;} .filter-field-date-combobox .filter-day-interval-selected {display:inline;} .webform-content { padding: 7px 20px 15px 16px; } .pagetitle-wrap { margin: 0px -3px 0px -1px; min-height: 30px; padding: 0px 0px 4px 4px; position: relative; } .pagetitle { color: rgb(85, 85, 85); font-size: 30px; margin: -2px 0px 0px; padding: 0px; font-weight: normal; text-shadow: 0px 1px 0px rgb(255, 255, 255); } .pagetitle-menu { right: 5px; top: 0px; position: absolute; z-index: 2; } .adm-filter-box-sizing { width: auto; } .reports-title-label { padding-top: 20px; } #bx-admin-prefix .popup-window-close-icon { background-color: inherit; right: 0; top: 0; } </style> <script type="text/javascript"> initReportControls(); BX.message({'REPORT_DEFAULT_TITLE': '<?=CUtil::JSEscape(GetMessage('REPORT_DEFAULT_TITLE'))?>'}); BX.message({'REPORT_ADD': '<?=CUtil::JSEscape(GetMessage('REPORT_ADD'))?>'}); BX.message({'REPORT_CANCEL': '<?=CUtil::JSEscape(GetMessage('REPORT_CANCEL'))?>'}); BX.message({'REPORT_PRCNT_VIEW_IS_NOT_AVAILABLE': '<?=CUtil::JSEscape(GetMessage('REPORT_PRCNT_VIEW_IS_NOT_AVAILABLE'))?>'}); BX.message({'REPORT_PRCNT_BUTTON_TITLE': '<?=CUtil::JSEscape(GetMessage('REPORT_PRCNT_BUTTON_TITLE'))?>'}); </script> <!-- The form is defined in a body of administrative page --> <?php echo bitrix_sessid_post('csrf_token')?> <div class="reports-constructor"> <div class="adm-filter-wrap"> <? $_title = ''; if (!empty($arResult['report']['TITLE'])) $_title = $arResult['report']['TITLE']; ?> <div class="adm-input-wrap"> <div class="reports-title-label"><?=GetMessage('REPORT_TITLE')?></div> <input style="padding-left: 5px; padding-right: 5px;" class="adm-input" type="text" id="reports-new-title" name="report_title" value="<?=htmlspecialcharsbx($_title)?>" /> <div class="reports-title-label"><?=GetMessage('REPORT_DESCRIPTION')?></div> <div style="padding-left: 0px; padding-right: 10px;"> <textarea rows="5" style="padding-left: 5px; padding-right: 5px; width: 100%;" name="report_description"><?=htmlspecialcharsbx($arResult['report']['DESCRIPTION'])?></textarea> </div> </div> <?php /* Site option */ ?> <? if (isset($arParams['F_SALE_SITE'])): ?> <div class="reports-title-label"><?=GetMessage('SALE_REPORT_SITE')?></div> <div class="adm-filter-alignment adm-calendar-block"> <div class="adm-filter-box-sizing"> <?php $selected = $arParams['F_SALE_SITE']; $siteList = call_user_func(array($arParams['REPORT_HELPER_CLASS'], 'getSiteList')); ?> <span class="adm-select-wrap"> <select class="adm-select" id="sale-site-filter" name="F_SALE_SITE"> <? foreach($siteList as $kLID => $vSiteName): ?> <option <?php if ($kLID==$selected) echo 'selected="1"'; ?>value="<?=htmlspecialcharsbx($kLID)?>"><?=htmlspecialcharsbx($vSiteName)?></option> <? endforeach; ?> </select> </span> </div> </div> <? endif; ?> <div class="reports-title-label"><?=GetMessage('REPORT_PERIOD')?></div> <? $_date_from = ''; $_date_to = ''; if ($arResult["preSettings"]["period"]['type'] == 'interval') { $_date_from = ConvertTimeStamp($arResult["preSettings"]["period"]['value'][0], 'SHORT'); $_date_to = ConvertTimeStamp($arResult["preSettings"]["period"]['value'][1], 'SHORT'); } else if ($arResult["preSettings"]["period"]['type'] == 'before') { $_date_from = ConvertTimeStamp($arResult["preSettings"]["period"]['value'], 'SHORT'); } else if ($arResult["preSettings"]["period"]['type'] == 'after') { $_date_to = ConvertTimeStamp($arResult["preSettings"]["period"]['value'], 'SHORT'); } ?> <!-- stub --> <div style="display: none;"> <select id="task-interval-filter"> <option value="" selected></option> </select> <span class="filter-date-interval"></span> <span class="filter-day-interval"> </span> </div> <!-- period --> <div class="adm-filter-alignment adm-calendar-block"> <div class="adm-filter-box-sizing"> <!-- period select --> <span class="adm-select-wrap adm-calendar-period"> <select onchange="OnReportIntervalChange(this)" name="F_DATE_TYPE" id="report-interval-filter" class="adm-select adm-calendar-period"> <?php foreach($arResult['periodTypes'] as $key):?> <option value="<?=htmlspecialcharsbx($key)?>"<?=($key == $arResult["preSettings"]["period"]['type']) ? ' selected' : ''?>><?=GetMessage('REPORT_CALEND_'.ToUpper(htmlspecialcharsbx($key)))?></option> <?php endforeach;?> </select> </span> <!-- filter date from --> <div style="display: none;" class="adm-input-wrap adm-calendar-inp adm-calendar-first"> <input type="text" value="<?=$_date_from?>" size="10" name="F_DATE_FROM" id="REPORT_INTERVAL_F_DATE_FROM" class="adm-input adm-calendar-from"> <img onclick="BX.calendar({node:this, field:'REPORT_INTERVAL_F_DATE_FROM', form: '', bTime: false, bHideTime: false});" title="<?php echo GetMessage("TASKS_PICK_DATE")?>" class="adm-calendar-icon"> </div> <!-- filter separator --> <span style="display: none;" class="adm-calendar-separate"></span> <!-- filter date to --> <div style="display: none;" class="adm-input-wrap adm-calendar-second"> <input type="text" value="<?=$_date_to?>" size="10" name="F_DATE_TO" id="REPORT_INTERVAL_F_DATE_TO" class="adm-input adm-calendar-to"> <img onclick="BX.calendar({node:this, field:'REPORT_INTERVAL_F_DATE_TO', form: '', bTime: false, bHideTime: false});" title="<?php echo GetMessage("TASKS_PICK_DATE")?>" class="adm-calendar-icon"> </div> <!-- days field --> <div style="display: none;" class="adm-input-wrap filter-day-interval"> <span class="<?php if ($arResult["preSettings"]["period"]['type'] == "days"): ?>filter-day-interval-selected<?php endif; ?>"> <input type="text" size="5" class="filter-date-days" value="<?php echo $arResult["preSettings"]["period"]['type'] == "days" ? $arResult["preSettings"]["period"]['value'] : ""?>" name="F_DATE_DAYS"/> </span> <span> <?php echo GetMessage("REPORT_CALEND_REPORT_DAYS")?></span> </div> </div> </div> <script type="text/javascript"> function OnReportIntervalChange(select) { var filterSelectContainer = BX.findParent(select); var filterDateFrom = BX.findNextSibling(filterSelectContainer, {'tag':'div', 'className': 'adm-calendar-first'}); var filterDateSeparator = BX.findNextSibling(filterDateFrom, {'tag':'span', 'className': 'adm-calendar-separate'}); var filterDateTo = BX.findNextSibling(filterDateSeparator, {'tag':'div', 'className': 'adm-calendar-second'}); var filterDays = BX.findNextSibling(filterDateTo, {'tag':'div', 'className': 'filter-day-interval'}); filterDateFrom.style.display = 'none'; filterDateSeparator.style.display = 'none'; filterDateTo.style.display = 'none'; filterDays.style.display = 'none'; if (select.value == "interval") { filterDateFrom.style.display = 'inline-block'; filterDateSeparator.style.display = 'inline-block'; filterDateTo.style.display = 'inline-block'; } else if(select.value == "before") filterDateTo.style.display = 'inline-block'; else if(select.value == "after") filterDateFrom.style.display = 'inline-block'; else if(select.value == "days") filterDays.style.display = 'inline-block'; } BX.ready(function() { OnReportIntervalChange(BX('report-interval-filter')); }); </script> </div> <!-- select --> <div class="reports-content-block-disabled-style" id='report_columns_list'> <span class="reports-content-block-title"><?=GetMessage('REPORT_COLUMNS')?></span> <div class="reports-add-columns-block" id="reports-add-columns-block"> <div class="reports-grouping-header"> <span class="reports-checkbox-g-arrow-bottom reports-image-arrow-bottom1"></span> <span class="reports-grouping-header-title"><?=GetMessage('REPORT_GROUP_RESULT_BY_COLUMN')?></span> <span class="reports-checkbox-gs-arrow-bottom reports-image-arrow-bottom2"></span> <span class="reports-grouping-header-title"><?=GetMessage('REPORT_GROUP_RESULT_SUBTOTAL')?></span> </div> <div id="reports-forming-column-example" style="display: none"> <input type="hidden" name="report_select_columns[%s][name]" /> <span class="reports-add-col-checkbox"> <input type="checkbox" class="reports-checkbox"/> </span><span class="reports-grouping-checkbox"> <input type="checkbox" class="reports-checkbox" /> </span><span class="reports-grouping-subtotal-checkbox"> <input type="checkbox" class="reports-checkbox" /> </span><span class="reports-add-col-buttons-bl"> <span class="reports-add-col-button-down"></span><span class="reports-add-col-button-up"></span> </span><span class="reports-add-col-title"><span class="reports-add-col-tit-text"></span><span class="reports-add-col-input"><input type="text" name="report_select_columns[%s][alias]"/><span class="reports-add-col-inp-title"><?=GetMessage('REPORT_NEW_COLUMN_TITLE')?></span></span><span class="reports-add-col-tit-prcnt" title="<?=GetMessage('REPORT_PRCNT_BUTTON_TITLE')?>"></span><span class="reports-add-col-tit-edit" title="<?=GetMessage('REPORT_CHANGE_COLUMN_TITLE')?>"></span><span class="reports-add-col-tit-remove" title="<?=GetMessage('REPORT_REMOVE_COLUMN')?>"></span></span> </div> <div class="reports-add-column" id="reports-add-column-block"> <span class="reports-checkbox-arrow"></span> <span class="reports-checkbox-title"><?=GetMessage('REPORT_CALC_COLUMN')?></span><span class="reports-add-column-link reports-dashed" id="reports-add-select-column-button"><?=GetMessage('REPORT_ADD_SELECT_COLUMN')?></span> </div> </div> <?php /* use columns selection of price types */ ?> <?php if (call_user_func(array($arParams['REPORT_HELPER_CLASS'], 'getOwnerId')) === 'sale_SaleProduct'): ?> <div class="reports-filter-quan-item"> <input type="checkbox" <?=($arResult['preSettings']['helper_spec']['ucspt'] === true)?'checked="checked" ':''?> class="reports-checkbox" id="report-helper-spec-ucspt" name="helper_spec_ucspt" /> <span class="reports-limit-res-select-lable"> <label for="report-helper-spec-ucspt"><?=GetMessage('REPORT_HELPER_SPEC_UCSPT')?></label> </span> </div> <?php endif; ?> <div class="reports-sort-column"> <span class="reports-content-block-title"><?=GetMessage('REPORT_SORT_BY_SELECT_COLUMN')?></span><select class="reports-sort-select" id="reports-sort-select" name="reports_sort_select"><option value="_">_</option></select> <select name="reports_sort_type_select" id="reports-sort-type-select" class="reports-sort-type-select"><option value="ASC"><?=GetMessage('REPORT_SORT_TYPE_ASC')?></option><option value="DESC"><?=GetMessage('REPORT_SORT_TYPE_DESC')?></option></select> </div> <script type="text/javascript"> BX.ready(function() { GLOBAL_REPORT_SELECT_COLUMN_COUNT = 0; <? foreach ($arResult['preSettings']['select'] as $num => $selElem): ?> addSelectColumn(BX.findChild( BX('reports-add_col-popup-cont'), {tag:'input', attr:{type:'checkbox', name:'<?=CUtil::JSEscape($selElem['name'])?>'}}, true ), '<?=strlen($selElem['aggr']) ? CUtil::JSEscape($selElem['aggr']) : ''?>', '<?=strlen($selElem['alias']) ? CUtil::JSEscape($selElem['alias']) : ''?>', <?=$num?>, <?=($selElem['grouping']) ? 'true' : 'false'?>, <?=($selElem['grouping_subtotal']) ? 'true' : 'false'?>); <? endforeach; ?> <? foreach ($arResult['preSettings']['select'] as $num => $selElem): ?> <? if (strlen($selElem['prcnt'])): ?> setPrcntView(<?=$num?>, '<?=CUtil::JSEscape($selElem['prcnt'])?>'); <? endif; ?> <? endforeach; ?> <? if (array_key_exists("sort", $arResult["preSettings"])): ?> // add default sort setSelectValue(BX('reports-sort-select'), '<?=CUtil::JSEscape($arResult["preSettings"]['sort'])?>'); <? endif; ?> <? if (array_key_exists("sort_type", $arResult["preSettings"])): ?> // add default sort setSelectValue(BX('reports-sort-type-select'), '<?=CUtil::JSEscape($arResult["preSettings"]['sort_type'])?>'); <? endif; ?> startSubFilterRestore(); }); </script> </div> <!-- filters --> <div class="webform-additional-fields"> <div class="reports-content-block-disabled-style"> <span class="reports-content-block-title reports-title-filter"><?=GetMessage('REPORT_FILTER')?></span> <div class="reports-filter-block"> <div class="reports-limit-results" id="reports-filter-base-andor-selector"> <span class="reports-limit-res-select-lable"><?=GetMessage('REPORT_RESULT_LIMIT_BY')?></span><select filterId="0" class="reports-limit-res-select"> <option value="AND"><?=GetMessage('REPORT_ANDOR_AND')?></option> <option value="OR"><?=GetMessage('REPORT_ANDOR_OR')?></option> </select><span class="reports-limit-res-select-lable" id="reports-filter-base-andor-selector-text-and"><?=GetMessage('REPORT_RESULT_LIMIT_CONDITIONS')?></span><span class="reports-limit-res-select-lable" id="reports-filter-base-andor-selector-text-or" style="display: none;"><?=GetMessage('REPORT_RESULT_LIMIT_CONDITION')?></span> </div> <div id="reports-filter-item-example" style="display: none;"> <span class="reports-filter-item-name"><span class="reports-dashed"><?=GetMessage('REPORT_CHOOSE_FIELD')?></span></span><span class="reports-filter-butt-wrap"><span class="reports-filter-del-item"><i></i></span><span class="reports-filter-add-item"><i></i></span><span class="reports-filter-and-or"><span class="reports-filter-and-or-text"><?=GetMessage('REPORT_ANDOR')?></span><i></i></span><input type="checkbox" class="reports-checkbox" name="changeable" checked /></span> </div> <div id="reports-filter-andor-container-example" style="display: none" class="reports-filter-andor-container"> <div class="reports-filter-andor-item"> <select style="width: 80px;"> <option value="AND"><?=GetMessage('REPORT_ANDOR_ALL')?></option> <option value="OR"><?=GetMessage('REPORT_ANDOR_ANY')?></option> </select> <span class="reports-limit-res-select-lable reports-limit-res-select-lable-and"><?=GetMessage('REPORT_ANDOR_ALL_LABEL')?></span><span class="reports-limit-res-select-lable reports-limit-res-select-lable-or" style="display: none;"><?=GetMessage('REPORT_ANDOR_ANY_LABEL')?></span><span class="reports-filter-butt-wrap"><span class="reports-filter-del-item"><i></i></span><span class="reports-filter-add-item"><i></i></span><span class="reports-filter-and-or"><span class="reports-filter-and-or-text"><?=GetMessage('REPORT_ANDOR')?></span><i></i></span><input type="checkbox" class="reports-checkbox" disabled/></span> </div> </div> <div class="reports-filter-andor-container" id="reports-filter-columns-container"></div> <div class="reports-filter-checkbox-title"> <span class="reports-filter-checkbox-arrow"></span> <span class="reports-filter-checkbox-tit-text"><?=GetMessage('REPORT_CHANGE_FILTER_IN_VIEW')?></span> </div> </div> <script type="text/javascript"> var GLOBAL_REPORT_FILTER_COUNT = 1; var GLOBAL_REPORT_GROUPING_COLUMNS_COUNT = 0; var GLOBAL_PRE_FILTERS = null; <? if (!empty($arResult["preSettings"]["filter"])): ?> var GLOBAL_PRE_FILTERS = <?=CUtil::PhpToJSObject($arResult["preSettings"]["filter"])?>; <? endif; ?> BX.ready(function() { <? if (!empty($arResult["preSettings"]["limit"])): ?> // add default limit setReportLimit(true, '<?=$arResult["preSettings"]["limit"]?>'); <? endif; ?> <? if ($arResult["preSettings"]["grouping_mode"] === true): ?> enableReportLimit(false); <? endif; ?> }); </script> <div class="reports-filter-quan-item"> <input type="checkbox" class="reports-checkbox" id="report-filter-limit-checkbox"/> <span class="reports-limit-res-select-lable"><label for="report-filter-limit-checkbox"><?=GetMessage('REPORT_RESULT_LIMIT')?></label></span> <input type="text" class="reports-filter-quan-inp" id="report-filter-limit-input" name="report_filter_limit" disabled/> </div> <div class="reports-filter-quan-item"> <input type="checkbox" <?=($arResult['preSettings']['red_neg_vals'] === true)?'checked="checked" ':''?> class="reports-checkbox" id="report-negative-values-red-checkbox" name="report_red_neg_vals"/> <span class="reports-limit-res-select-lable"> <label for="report-negative-values-red-checkbox"><?=GetMessage('REPORT_NEGATIVE_VALUES_RED')?></label> </span> </div> <div class="reports-filter-quan-item" style="margin-top: 10px;"> <input type="checkbox" <?=($arResult['preSettings']['mobile']['enabled'] === true)?'checked="checked" ':''?> class="reports-checkbox" id="report-mobile-settings" name="report_mobile_enabled"/> <span class="reports-limit-res-select-lable"> <label for="report-mobile-settings"><?=GetMessage('REPORT_MOBILE_SETTINGS')?></label> </span> </div> </div> <div class="webform-corners-bottom"> <div class="webform-left-corner"></div> <div class="webform-right-corner"></div> </div> </div> <!-- preview --> <div class="reports-preview-table-report" id="reports-preview-table-report"> <span class="reports-prev-table-title"><?=GetMessage('REPORT_SCHEME_PREVIEW')?></span> <div class="reports-list"> <div class="reports-list-left-corner"></div> <div class="reports-list-right-corner"></div> <table cellspacing="0" class="report-list-table"> <tr> <th></th> </tr> </table> </div> </div> <!-- chart configuration --> <?php if ($arParams['USE_CHART']): ?> <style type="text/css"> .report-chart-add-ycolumn { display: none; float: left; position: relative; top: 0px; left: 0px; width: 10px; height: 10px; padding: 3px 3px 3px 3px; margin-left: 4px; background: url("/bitrix/js/report/css/images/sprites.png") -119px -3px no-repeat; cursor: pointer; } .report-chart-add-ycolumn-dummy { float: left; position: relative; top: 0px; left: 0px; width: 10px; height: 10px; padding: 3px 3px 3px 3px; margin-left: 4px; } .report-chart-remove-ycolumn { display: none; float: right; position: relative; top: 0px; right: 0px; width: 10px; height: 10px; padding: 3px 3px 3px 3px; cursor: pointer; } .report-chart-remove-ycolumn-dummy { float: right; position: relative; top: 0px; right: 0px; width: 10px; height: 10px; padding: 3px 3px 3px 3px; } .report-chart-span-minus { display: block; position: relative; top: 4px; width: 10px; height: 2px; background: url("/bitrix/js/report/css/images/sprites.png") -122px 0 no-repeat; cursor: pointer; } .report-chart-remove-ycolumn-bottom { float: left; left: 0; margin-left: 4px; right: auto; } .report-chart-add-ycolumn:hover { background-color: #C0C0C0; } .report-chart-remove-ycolumn:hover { background-color: #C0C0C0; } .report-chart-last-ycolumn-block:hover td .report-chart-add-ycolumn, .report-chart-last-ycolumn-block:hover td .report-chart-remove-ycolumn {display: block;} .report-chart-select-col {float: left; width: 100%;} #report-chart-config {padding-top: 20px;} #report-chart-switch {margin: 12px 0 12px 0;} #report-chart-params div {margin-bottom: 20px; padding: 4px 0;} #report-chart-display-checkbox {vertical-align: middle;} #report-chart-switch label {vertical-align: middle;} </style> <script type="text/javascript"> var GLOBAL_BX_REPORT_USING_CHARTS = true; </script> <?php $fDisplayChart = $arResult['preSettings']['chart']['display']; ?> <div id="report-chart-config"> <div id="report-chart-switch" class="reports-content-block-title<?php echo ($fDisplayChart)?' reports-title-filter':''; ?>"> <input id="report-chart-display-checkbox" type="checkbox"<?php echo ($fDisplayChart)?' checked':''; ?> name="display_chart"/> <label for="report-chart-display-checkbox"><?php echo htmlspecialcharsbx(GetMessage('REPORT_CHART_DISPLAY')); ?></label> </div> <div id="report-chart-params"<?php echo ($fDisplayChart)?'':' style="display: none;"'; ?>> <div> <span><label class="reports-title-label" for="report-chart-type"><?php echo htmlspecialcharsbx(GetMessage('REPORT_CHART_TYPE_LABEL_TEXT').':'); ?></label></span> <span> <select id="report-chart-type" name="chart_type"> <?php $bSelectFirst = true; $chartTypeSetting = $arResult['preSettings']['chart']['type']; if ($chartTypeSetting !== null) { $chartTypeIds = array(); foreach ($arResult['chartTypes'] as $chartTypeInfo) $chartTypeIds[] = $chartTypeInfo['id']; if (in_array($chartTypeSetting, $chartTypeIds)) $bSelectFirst = false; } ?> <?php $i = 0; foreach($arResult['chartTypes'] as $chartType): ?> <option value="<?=htmlspecialcharsbx($chartType['id'])?>"<?php if (($i++ === 0 && $bSelectFirst) || $chartType['id'] == $chartTypeSetting) echo 'selected="selected"'; ?>> <?=htmlspecialcharsbx($chartType['name'])?> </option> <?php endforeach; ?> </select> </span> </div> <table> <tr> <td><label class="reports-title-label" for="report-chart-args"><?php echo htmlspecialcharsbx(GetMessage('REPORT_CHART_LABEL_TEXT_ARGS').':'); ?></label></td> <td> <select id="report-chart-args" class="report-chart-select-col" name="chart_x"></select> </td> <td> <span class="report-chart-remove-ycolumn-dummy"></span> <span class="report-chart-add-ycolumn-dummy"></span> </td> </tr> <?php $yColumnsMaxNumber = 10; $yColumns = $arResult['preSettings']['chart']['y_columns']; $yColumnLastIndex = 0; $yColumnsLabelText = GetMessage('REPORT_CHART_LABEL_TEXT_VALUES'); if (is_array($yColumns)) { $n = count($yColumns); if ($n > 1) $yColumnLastIndex = $n - 1; } ?> <?php for ($i = 0; $i <= $yColumnLastIndex; $i++): ?> <tr<?php if ($yColumnLastIndex === $i) echo ' id="report-chart-last-ycolumn-block" class="report-chart-last-ycolumn-block"'; ?>> <td> <label class="reports-title-label"<?php echo ' for="report-chart-values['.$i.']"'; ?>><?php echo htmlspecialcharsbx($yColumnsLabelText.(($yColumnLastIndex > 0) ? ' ('.($i+1).')' : '').':'); ?> </label> </td> <td> <select<?php echo ' id="report-chart-values['.$i.']"'; ?> class="report-chart-select-col"<?php echo ' name="chart_y['.$i.']"'; ?>></select> </td> <td></td> </tr> <?php endfor; // for ($i = 1; $i <= $yColumnLastIndex; $i++): ?> </table> </div> <!-- add y column prototype --> <span id="report-chart-add-ycolumn-proto" class="report-chart-add-ycolumn" title="<?=htmlspecialcharsbx(GetMessage('REPORT_CHART_ADD_COL_LABEL_TITLE'))?>"></span> <!-- remove y column prototype --> <span id="report-chart-remove-ycolumn-proto" class="report-chart-remove-ycolumn" title="<?=htmlspecialcharsbx(GetMessage('REPORT_CHART_REMOVE_COL_LABEL_TITLE'))?>"> <span class="report-chart-span-minus"></span> </span> </div> <script type="text/javascript"> BX.ready(function () { var i, colId, match; var xColumnIndex = null, yColumnsIndexes = []; <?php $xColumnIndex = $arResult['preSettings']['chart']['x_column']; $yColumnsIndexes = $arResult['preSettings']['chart']['y_columns']; if ($xColumnIndex !== null && is_array($yColumnsIndexes) && count($yColumnsIndexes) > 0) { echo 'xColumnIndex = '.CUtil::JSEscape($xColumnIndex).';'.PHP_EOL; foreach ($yColumnsIndexes as $k => $v) { echo "\t\t".'yColumnsIndexes['.CUtil::JSEscape(intval($k)).'] = '.CUtil::JSEscape(intval($v)).';'. PHP_EOL; } } ?> var xSelect = BX('report-chart-args'); if (xSelect) if (xColumnIndex !== null) setSelectValue(xSelect, xColumnIndex); var ySelects = BX.findChildren(BX('report-chart-params'), {'tag': 'select', attr: {name: /chart_y\[\d+\]/}}, true); for (i in ySelects) { if (match = /\[(\d+)\]/.exec(ySelects[i].name)) { colId = match[1]; if (colId !== null && yColumnsIndexes[colId] !== null) setSelectValue(ySelects[i], yColumnsIndexes[colId]); } } var chartCheckbox = BX('report-chart-display-checkbox'); if (chartCheckbox) { BX.bind(chartCheckbox, 'click', function () { var chartSwitchBlock = BX('report-chart-switch'); var chartParamsBlock = BX('report-chart-params'); if (chartSwitchBlock) { if (this.checked) BX.addClass(chartSwitchBlock, 'reports-title-filter'); else BX.removeClass(chartSwitchBlock, 'reports-title-filter'); } if (chartParamsBlock) { if (this.checked) chartParamsBlock.style.display = ''; else chartParamsBlock.style.display = 'none'; } }); } // create "report-chart-add-ycolumn" if needed chartCreateYColumnSpanAdd(); // create "report-chart-remove-ycolumn" if needed chartCreateYColumnSpanRemove(); // chart type processing BX.bind(BX('report-chart-type'), 'change', chartOnChangeType); chartOnChangeType(); }); function chartCreateYColumnSpanAdd() { var lastYcolumnBlock, container, ySelect, blockIndex; var addYColumnSpan = BX('report-chart-add-ycolumn'); if (!addYColumnSpan) { lastYcolumnBlock = BX('report-chart-last-ycolumn-block'); if (lastYcolumnBlock) { ySelect = BX.findChildren(lastYcolumnBlock, {tag: 'select', 'className': 'report-chart-select-col'}, true); if (ySelect) { container = BX.findNextSibling(ySelect[0].parentNode, {tag: 'td'}); if (container) { blockIndex = chartGetStringIndex(ySelect[0].id); if (blockIndex < <?=CUtil::JSEscape($yColumnsMaxNumber - 1)?>) { addYColumnSpan = BX.clone(BX('report-chart-add-ycolumn-proto'), true); addYColumnSpan.id = 'report-chart-add-ycolumn'; container.appendChild(addYColumnSpan); BX.bind(addYColumnSpan, 'click', chartOnClickAddYcolumn); } } } } } } function chartCreateYColumnSpanRemove() { var lastYcolumnBlock, container, ySelect, blockIndex; var removeYColumnSpan = BX('report-chart-remove-ycolumn'); if (!removeYColumnSpan) { lastYcolumnBlock = BX('report-chart-last-ycolumn-block'); if (lastYcolumnBlock) { ySelect = BX.findChildren(lastYcolumnBlock, {tag: 'select', 'className': 'report-chart-select-col'}, true); if (ySelect) { container = BX.findNextSibling(ySelect[0].parentNode, {tag: 'td'}); if (container) { blockIndex = chartGetStringIndex(ySelect[0].id); if (blockIndex > 0) { removeYColumnSpan = BX.clone(BX('report-chart-remove-ycolumn-proto'), true); removeYColumnSpan.id = 'report-chart-remove-ycolumn'; if (blockIndex === <?=CUtil::JSEscape($yColumnsMaxNumber - 1)?>) BX.addClass(removeYColumnSpan, 'report-chart-remove-ycolumn-bottom'); container.appendChild(removeYColumnSpan); BX.bind(removeYColumnSpan, 'click', chartOnClickRemoveYcolumn); } } } } } } function chartOnClickAddYcolumn() { var container, block, blockCopy; var labelNode, labelText, selectNode, plusSpan, minusSpan; var prevLabelNode, prevLabelText; var blockIndex = null; block = this.parentNode.parentNode; if (block) { container = block.parentNode; chartRemoveWithClearId('report-chart-add-ycolumn'); chartRemoveWithClearId('report-chart-remove-ycolumn'); blockCopy = BX.clone(block); labelNode = BX.findChildren(blockCopy, {tag: 'label', 'className': 'reports-title-label'}, true); if (labelNode) { labelNode[0].setAttribute('for', chartIncStringIndex(labelNode[0].getAttribute('for'))); selectNode = BX.findChildren(blockCopy, {tag: 'select', 'className': 'report-chart-select-col'}, true); if (selectNode) { blockIndex = chartGetStringIndex(selectNode[0].id) + 1; selectNode[0].id = chartIncStringIndex(selectNode[0].id); selectNode[0].name = chartIncStringIndex(selectNode[0].name); } } if (blockIndex != null) { chartSetYColumnLabelText(labelNode[0], true, blockIndex + 1); if (blockIndex === 1) { prevLabelNode = BX.findChildren(block, {tag: 'label', 'className': 'reports-title-label'}, true); if (prevLabelNode) chartSetYColumnLabelText(prevLabelNode[0], true, blockIndex); } BX.removeClass(block, 'report-chart-last-ycolumn-block'); block.id = null; blockCopy.id = 'report-chart-last-ycolumn-block'; container.appendChild(blockCopy); chartCreateYColumnSpanAdd(); chartCreateYColumnSpanRemove(); } } } function chartRemoveWithClearId(id) { if (id) { var el = BX(id); if (el) { el.id = null; BX.remove(el); } } } function chartOnClickRemoveYcolumn() { var container, block, prevBlock; var labelNode, labelText, selectNode, blockIndex; block = this.parentNode.parentNode; prevBlock = BX.findPreviousSibling(block, {tag: block.tagName}) if (block && prevBlock) { container = block.parentNode; chartRemoveWithClearId('report-chart-add-ycolumn'); chartRemoveWithClearId('report-chart-remove-ycolumn'); labelNode = BX.findChildren(prevBlock, {tag: 'label', 'className': 'reports-title-label'}, true); if (labelNode) { selectNode = BX.findChildren(prevBlock, {tag: 'select', 'className': 'report-chart-select-col'}, true); if (selectNode) blockIndex = chartGetStringIndex(selectNode[0].id); } if (blockIndex != null) { if (blockIndex === 0) chartSetYColumnLabelText(labelNode[0]); BX.removeClass(block, 'report-chart-last-ycolumn-block'); block.id = null; BX.remove(block); prevBlock.id = 'report-chart-last-ycolumn-block'; BX.addClass(prevBlock, 'report-chart-last-ycolumn-block'); chartCreateYColumnSpanAdd(); chartCreateYColumnSpanRemove(); } } } function chartGetStringIndex(str) { var match; var index = null; newStr = null; if (match = /\[(\d+)\]/.exec(str)) index = match[1]; return parseInt(index); } function chartIncStringIndex(str) { var match, newStr; newStr = null; if (match = /\[(\d+)\]/.exec(str)) { newStr = match.input.substr(0, match.index)+'['+(++match[1])+']'+ match.input.substr(match.index+match[0].length); } return newStr; } function chartGetYColTypes() { return {<?php echo PHP_EOL; $i = 0; $li = count($arResult['chartTypes']) - 1; foreach ($arResult['chartTypes'] as $chartType) { echo "\t\t\t'".CUtil::JSEscape($chartType['id']).'\' : ['; $j = 0; foreach ($chartType['value_types'] as $v) echo (($j++ > 0)?',':'').'\''.CUtil::JSEscape($v).'\''; echo ']'.(($i++ < $li)?',':'').PHP_EOL; } ?> }; } function chartOnChangeType() { var chartTypeSelect; <?php // In this call selection lists of columns of values will be reformed. // It allows to filter types of sampled columns of values depending on chart type without use of a // special function. ?> rebuildSortSelect(); chartTypeSelect = BX('report-chart-type'); if (chartTypeSelect) chartSetYColumnStyle(chartTypeSelect.value === 'pie'); } function chartSetYColumnStyle(single) { var labels, index, container, params; single = !!single; params = BX('report-chart-params'); if (params) { labels = BX.findChildren(params, {tag: 'label', attr: {for: /report-chart-values\[\d\]/}}, true); if (labels.length > 1) { for (var i in labels) { index = chartGetStringIndex(labels[i].getAttribute('for')); if (index === 0) chartSetYColumnLabelText(labels[i], !single, index + 1); else { container = labels[i].parentNode.parentNode; if (container) container.style.display = (single) ? 'none' : ''; } } } else { container = labels[0].parentNode.parentNode; if (container) { if (single) BX.removeClass(container, 'report-chart-last-ycolumn-block'); else BX.addClass(container, 'report-chart-last-ycolumn-block'); } } } } function chartSetYColumnLabelText(label, indexed, index) { var labelText; if (!label) return; indexed = !!indexed; if (indexed && index == null) return; index = parseInt(index); labelText = '<?=CUtil::JSEscape($yColumnsLabelText)?>' + ((indexed) ? ' (' + index + ')' : '') + ':'; label.innerHTML = labelText; } </script> <?php endif; // if ($arParams['USE_CHART']): ?> </div> <!-- add select column popup --> <div class="reports-add_col-popup-cont" id="reports-add_col-popup-cont" style="display:none;"> <div class="reports-add_col-popup-title"> <?=GetMessage('REPORT_POPUP_COLUMN_TITLE'.'_'.call_user_func(array($arParams['REPORT_HELPER_CLASS'], 'getOwnerId')))?> </div> <div class="popup-window-hr popup-window-buttons-hr"><i></i></div> <div class="reports-add_col-popup"> <?=call_user_func(array($arParams['REPORT_HELPER_CLASS'], 'buildHTMLSelectTreePopup'), $arResult['fieldsTree'])?> </div> </div> <!-- choose filter column popup --> <div class="reports-add_col-popup-cont reports-add_filcol-popup-cont" id="reports-add_filcol-popup-cont" style="display:none;"> <div class="reports-add_col-popup-title"> <?=GetMessage('REPORT_POPUP_FILTER_TITLE'.'_'.call_user_func(array($arParams['REPORT_HELPER_CLASS'], 'getOwnerId')))?> </div> <div class="popup-window-hr popup-window-buttons-hr"><i></i></div> <div class="reports-add_col-popup"> <?=call_user_func(array($arParams['REPORT_HELPER_CLASS'], 'buildHTMLSelectTreePopup'), $arResult['fieldsTree'], true)?> </div> </div> <!-- percent view examples --> <div id="report-select-prcnt-examples" style="display: none"> <select class="reports-add-col-select-prcnt" style="margin-left: 4px; display: none;" disabled> <option value="self_column"><?=GetMessage('REPORT_PRCNT_BY_COLUMN')?></option> <option value="other_field"><?=GetMessage('REPORT_PRCNT_BY_FIELD')?></option> </select> <select class="reports-add-col-select-prcnt-by" style="margin-left: 4px; display: none;" disabled> </select> </div> <!-- select calc examples --> <div id="report-select-calc-examples" style="display: none"> <? foreach($arResult['calcVariations'] as $key => $values): ?> <select id="report-select-calc-<?=$key?>" disabled> <? foreach ($values as $v): ?> <option value="<?=htmlspecialcharsbx($v)?>"><?=GetMessage('REPORT_SELECT_CALC_VAR_'.htmlspecialcharsbx($v))?></option> <? endforeach; ?> </select> <? endforeach; ?> </div> <!-- filter compare examples --> <div id="report-filter-compare-examples" style="display: none"> <? foreach($arResult['compareVariations'] as $key => $values): ?> <select id="report-filter-compare-<?=htmlspecialcharsbx($key)?>" class="report-filter-compare-<?=htmlspecialcharsbx($key)?>"> <? foreach ($values as $v): ?> <option value="<?=$v?>"><?=GetMessage('REPORT_FILTER_COMPARE_VAR_'.$v)?></option> <? endforeach; ?> </select> <? endforeach; ?> </div> <!-- filter value control examples --> <div id="report-filter-value-control-examples" style="display: none"> <span name="report-filter-value-control-integer"> <input type="text" name="value" /> </span> <span name="report-filter-value-control-float"> <input type="text" name="value" /> </span> <span name="report-filter-value-control-string"> <input type="text" name="value" /> </span> <span name="report-filter-value-control-boolean"> <select class="report-filter-select" name="value"> <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> </span> <span name="report-filter-value-control-datetime" class="report-filter-calendar"> <input type="text" class="reports-filter-input" name="value" /><img alt="img" class="reports-filt-calen-img" src="/bitrix/js/main/core/images/calendar-icon.gif" /> </span> </div>