2018-12-10 04:59:02 -06:00
< div class = "edit-tab-content" ng-repeat = "style in editor.panel.styles" >
< div class = "section gf-form-group" >
< h5 class = "section-heading" > Options< / h5 >
< div class = "gf-form-inline" >
< div class = "gf-form" >
2018-12-15 11:09:18 -06:00
< label class = "gf-form-label width-12" > Apply to columns named< / label >
2018-12-10 04:59:02 -06:00
< input type = "text" placeholder = "Name or regex" class = "gf-form-input width-13" ng-model = "style.pattern" bs-tooltip = "'Specify regex using /my.*regex/ syntax'"
2018-01-26 10:25:12 -06:00
bs-typeahead="editor.getColumnNames" ng-blur="editor.render()" data-min-length=0 data-items=100 ng-model-onblur
data-placement="right">
2017-05-09 05:35:44 -05:00
< / div >
< / div >
2018-12-10 04:59:02 -06:00
< div class = "gf-form" ng-if = "style.type !== 'hidden'" >
2018-12-15 11:09:18 -06:00
< label class = "gf-form-label width-12" > Column Header< / label >
< input type = "text" class = "gf-form-input width-12" ng-model = "style.alias" ng-change = "editor.render()" ng-model-onblur placeholder = "Override header label" >
2018-12-10 04:59:02 -06:00
< / div >
2019-04-04 03:34:59 -05:00
< gf-form-switch class = "gf-form" label-class = "width-12" label = "Render value as link" checked = "style.link" on-change = "editor.render()" > < / gf-form-switch >
2018-12-10 04:59:02 -06:00
< / div >
2017-05-09 05:35:44 -05:00
2018-12-10 04:59:02 -06:00
< div class = "section gf-form-group" >
< h5 class = "section-heading" > Type< / h5 >
2017-05-09 05:35:44 -05:00
2018-12-10 04:59:02 -06:00
< div class = "gf-form" >
2018-12-15 11:09:18 -06:00
< label class = "gf-form-label width-10" > Type< / label >
2018-12-10 04:59:02 -06:00
< div class = "gf-form-select-wrapper width-16" >
< select class = "gf-form-input" ng-model = "style.type" ng-options = "c.value as c.text for c in editor.columnTypes" ng-change = "editor.render()" > < / select >
2017-05-09 05:35:44 -05:00
< / div >
2018-12-10 04:59:02 -06:00
< / div >
< div class = "gf-form" ng-if = "style.type === 'date'" >
2018-12-15 11:09:18 -06:00
< label class = "gf-form-label width-10" > Date Format< / label >
2018-12-10 04:59:02 -06:00
< gf-form-dropdown model = "style.dateFormat" css-class = "gf-form-input width-16" lookup-text = "true"
2018-01-29 03:46:05 -06:00
get-options="editor.dateFormats" on-change="editor.render()" allow-custom="true">
2018-12-10 04:59:02 -06:00
< / gf-form-dropdown >
< / div >
2017-05-09 05:35:44 -05:00
2018-12-10 04:59:02 -06:00
< div ng-if = "style.type === 'string'" >
2018-12-15 11:09:18 -06:00
< gf-form-switch class = "gf-form" label-class = "width-10" ng-if = "style.type === 'string'" label = "Sanitize HTML" checked = "style.sanitize"
2019-04-04 03:34:59 -05:00
on-change="editor.render()">< / gf-form-switch >
2018-12-10 04:59:02 -06:00
< / div >
2020-01-09 09:01:12 -06:00
< div ng-if = "style.type !== 'hidden'" >
< div class = "gf-form" >
< label class = "gf-form-label width-10" > Align< / label >
< gf-form-dropdown model = "style.align"
css-class="gf-form-input width-16"
lookup-text="true"
get-options="editor.alignTypes"
allow-custom="false"
on-change="editor.render()"
allow-custom="false"/>
< / div >
< / div >
2018-12-10 04:59:02 -06:00
< div ng-if = "style.type === 'string'" >
2018-12-15 11:09:18 -06:00
< gf-form-switch class = "gf-form" label-class = "width-10" ng-if = "style.type === 'string'" label = "Preserve Formatting" checked = "style.preserveFormat"
2019-04-04 03:34:59 -05:00
on-change="editor.render()">< / gf-form-switch >
2018-12-10 04:59:02 -06:00
< / div >
2017-05-09 05:35:44 -05:00
2018-12-10 04:59:02 -06:00
< div ng-if = "style.type === 'number'" >
< div class = "gf-form" >
2018-12-15 11:09:18 -06:00
< label class = "gf-form-label width-10" > Unit< / label >
2018-12-10 04:59:02 -06:00
< div class = "gf-form-dropdown-typeahead width-16" ng-model = "style.unit" dropdown-typeahead2 = "editor.unitFormats" dropdown-typeahead-on-select = "editor.setUnitFormat(style, $subItem)" > < / div >
< / div >
< div class = "gf-form" >
2018-12-15 11:09:18 -06:00
< label class = "gf-form-label width-10" > Decimals< / label >
2018-12-10 04:59:02 -06:00
< input type = "number" class = "gf-form-input width-4" data-placement = "right" ng-model = "style.decimals" ng-change = "editor.render()"
2018-01-26 10:25:12 -06:00
ng-model-onblur>
2017-05-09 05:35:44 -05:00
< / div >
< / div >
2018-12-10 04:59:02 -06:00
< / div >
2017-05-09 05:35:44 -05:00
2018-12-10 04:59:02 -06:00
< div class = "section gf-form-group" ng-if = "style.type === 'string'" >
< h5 class = "section-heading" > Value Mappings< / h5 >
< div class = "editor-row" >
< div class = "gf-form-group" >
< div class = "gf-form" >
< span class = "gf-form-label" >
Type
< / span >
< div class = "gf-form-select-wrapper" >
< select class = "gf-form-input" ng-model = "style.mappingType"
ng-options="c.value as c.text for c in editor.mappingTypes" ng-change="editor.render()">< / select >
< / div >
< / div >
< div class = "gf-form-group" ng-if = "style.mappingType==1" >
< div class = "gf-form" ng-repeat = "map in style.valueMaps" >
2018-03-05 09:18:47 -06:00
< span class = "gf-form-label" >
2018-12-10 04:59:02 -06:00
< i class = "fa fa-remove pointer" ng-click = "editor.removeValueMap(style, $index)" > < / i >
2018-03-05 09:18:47 -06:00
< / span >
2018-12-10 04:59:02 -06:00
< input type = "text" class = "gf-form-input max-width-6" ng-model = "map.value" placeholder = "Value" ng-blur = "editor.render()" >
< label class = "gf-form-label" >
< i class = "fa fa-arrow-right" > < / i >
< / label >
< input type = "text" class = "gf-form-input max-width-8" ng-model = "map.text" placeholder = "Text" ng-blur = "editor.render()" >
< / div >
< div class = "gf-form" >
< label class = "gf-form-label" >
< a class = "pointer" ng-click = "editor.addValueMap(style)" > < i class = "fa fa-plus" > < / i > < / a >
< / label >
2018-03-05 09:18:47 -06:00
< / div >
2018-12-10 04:59:02 -06:00
< / div >
< div class = "gf-form-group" ng-if = "style.mappingType==2" >
< div class = "gf-form" ng-repeat = "rangeMap in style.rangeMaps" >
< span class = "gf-form-label" >
< i class = "fa fa-remove pointer" ng-click = "editor.removeRangeMap(style, $index)" > < / i >
< / span >
< span class = "gf-form-label" > From< / span >
< input type = "text" ng-model = "rangeMap.from" class = "gf-form-input max-width-6" ng-blur = "editor.render()" >
< span class = "gf-form-label" > To< / span >
< input type = "text" ng-model = "rangeMap.to" class = "gf-form-input max-width-6" ng-blur = "editor.render()" >
< span class = "gf-form-label" > Text< / span >
< input type = "text" ng-model = "rangeMap.text" class = "gf-form-input max-width-8" ng-blur = "editor.render()" >
2018-03-05 09:18:47 -06:00
< / div >
2018-12-10 04:59:02 -06:00
< div class = "gf-form" >
< label class = "gf-form-label" >
< a class = "pointer" ng-click = "editor.addRangeMap(style)" > < i class = "fa fa-plus" > < / i > < / a >
< / label >
2018-03-05 09:18:47 -06:00
< / div >
< / div >
< / div >
< / div >
2018-12-10 04:59:02 -06:00
< / div >
2018-03-05 09:18:47 -06:00
2018-12-10 04:59:02 -06:00
< div class = "section gf-form-group" ng-if = "['number', 'string'].indexOf(style.type) !== -1" >
< h5 class = "section-heading" > Thresholds< / h5 >
< div class = "gf-form" >
< label class = "gf-form-label width-8" > Thresholds
< tip > Comma separated values< / tip >
< / label >
< input type = "text" class = "gf-form-input width-10" ng-model = "style.thresholds" placeholder = "50,80" ng-blur = "editor.render()"
array-join>
< / div >
< div class = "gf-form" >
< label class = "gf-form-label width-8" > Color Mode< / label >
< div class = "gf-form-select-wrapper width-10" >
< select class = "gf-form-input" ng-model = "style.colorMode" ng-options = "c.value as c.text for c in editor.colorModes" ng-change = "editor.render()" > < / select >
2017-05-09 05:35:44 -05:00
< / div >
2018-12-10 04:59:02 -06:00
< / div >
< div class = "gf-form" >
< label class = "gf-form-label width-8" > Colors< / label >
< span class = "gf-form-label" >
2019-03-26 09:18:46 -05:00
< color-picker color = "style.colors[0]" onChange = "editor.onColorChange(style, 0)" > < / color-picker >
2018-12-10 04:59:02 -06:00
< / span >
< span class = "gf-form-label" >
2019-03-26 09:18:46 -05:00
< color-picker color = "style.colors[1]" onChange = "editor.onColorChange(style, 1)" > < / color-picker >
2018-12-10 04:59:02 -06:00
< / span >
< span class = "gf-form-label" >
2019-03-26 09:18:46 -05:00
< color-picker color = "style.colors[2]" onChange = "editor.onColorChange(style, 2)" > < / color-picker >
2018-12-10 04:59:02 -06:00
< / span >
< div class = "gf-form-label" >
< a class = "pointer" ng-click = "editor.invertColorOrder($index)" > Invert< / a >
2017-05-09 05:35:44 -05:00
< / div >
< / div >
2018-12-10 04:59:02 -06:00
< / div >
2017-05-09 05:35:44 -05:00
2018-12-10 04:59:02 -06:00
< div class = "section gf-form-group" ng-if = "style.link" >
< h5 class = "section-heading" > Link< / h5 >
< div class = "gf-form" >
< label class = "gf-form-label width-9" >
Url
< info-popover mode = "right-normal" >
< p > Specify an URL (relative or absolute)< / p >
< span >
Use special variables to specify cell values:
< br >
< em > ${__cell}< / em > refers to current cell value
< br >
< em > ${__cell_n}< / em > refers to Nth column value in current row. Column indexes are started from 0. For instance,
< em > ${__cell_1}< / em > refers to second column's value.
< br >
< em > ${__cell:raw}< / em > syntax. By default values are URI encoded. If the value is a complete URL you can disable all encoding using
< / span >
< / info-popover >
< / label >
< input type = "text" class = "gf-form-input width-29" ng-model = "style.linkUrl" ng-blur = "editor.render()" ng-model-onblur data-placement = "right" >
< / div >
< div class = "gf-form" >
< label class = "gf-form-label width-9" >
Tooltip
< info-popover mode = "right-normal" >
< p > Specify text for link tooltip.< / p >
< span >
2018-08-28 08:23:25 -05:00
This title appears when user hovers pointer over the cell with link. Use the same variables as for URL.
2018-12-10 04:59:02 -06:00
< / span >
< / info-popover >
< / label >
< input type = "text" class = "gf-form-input width-29" ng-model = "style.linkTooltip" ng-blur = "editor.render()" ng-model-onblur
2018-01-26 10:25:12 -06:00
data-placement="right">
2017-07-18 13:59:34 -05:00
< / div >
2018-12-10 04:59:02 -06:00
< gf-form-switch class = "gf-form" label-class = "width-9" label = "Open in new tab" checked = "style.linkTargetBlank" > < / gf-form-switch >
< / div >
2017-07-18 13:59:34 -05:00
2018-12-10 04:59:02 -06:00
< div class = "clearfix" > < / div >
< div class = "gf-form-group" >
2017-05-09 05:35:44 -05:00
< button class = "btn btn-danger btn-small" ng-click = "editor.removeColumnStyle(style)" >
< i class = "fa fa-trash" > < / i > Remove Rule
< / button >
< / div >
2018-12-13 04:35:07 -06:00
< hr >
2018-12-10 04:59:02 -06:00
< / div >
2018-12-13 04:35:07 -06:00
2018-12-10 04:59:02 -06:00
< div class = "gf-form-button-row" >
< button class = "btn btn-inverse" ng-click = "editor.addColumnStyle()" >
< i class = "fa fa-plus" > < / i > Add column style
< / button >
< / div >
2018-12-13 04:35:07 -06:00