sdk-datagrid
Version:
Customizable (Angular) datagrid with data options for manipulation, and charts for visualization.
109 lines • 40.1 kB
JavaScript
import { Component, EventEmitter, Input, Output } from '@angular/core';
import { SDKDataGridMessage } from '../../models/datagrid-message';
import { Clone } from '../../utils/clone';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
export class SDKDataGridChartOptionComponent {
constructor() {
this.columns = [];
this.chart = "";
this.closeEvent = new EventEmitter();
this.applyEvent = new EventEmitter();
this.chartType = "bar";
this.columnLabel = "";
this.columnDataX = "";
this.columnDataY = "";
this.dataOption = false;
this._columns = [];
/**************************************************************************
* Message Variable
**************************************************************************/
this.showMessage = false;
this.message = new SDKDataGridMessage();
}
ngOnChanges(_args) {
this._columns = Clone.deepCopy(this.columns);
this.initialize();
}
initialize() {
this._columns = this._columns.filter((column) => column.isVisible && !column.isAction);
if (this.chart === "") {
this.chart = {
Type: "bar",
Show: false,
Label: "",
DataX: "",
DataY: "",
Option: false
};
}
this.chartType = this.chart.Type;
this.columnLabel = this.chart.Label;
this.columnDataX = this.chart.DataX;
this.columnDataY = this.chart.DataY;
this.dataOption = this.chart.Option;
}
getColumnOriginalName(column) {
let originalName = column.Name;
if (column.FriendlyName && column.FriendlyName !== "") {
originalName = column.FriendlyName;
}
else if (column.DisplayName && column.DisplayName !== "") {
originalName = column.DisplayName;
}
return originalName;
}
getValue(event) {
return event.target.value;
}
reset() {
this.message = {
Title: "Reset Chart",
Text: "Are you sure?",
OKText: "YES",
CancelText: "NO",
OK: () => {
this.chart = "";
this.initialize();
},
Cancel: () => {
this.showMessage = false;
}
};
this.showMessage = true;
}
apply() {
let show = true;
if (['bar', 'line', 'radar'].indexOf(this.chartType) > -1 && (this.columnLabel === "" || this.columnDataX === "" || this.columnDataY === ""))
show = false;
if (['doughnut', 'pie', 'polarArea'].indexOf(this.chartType) > -1 && (this.columnLabel === "" || this.columnDataY === ""))
show = false;
this.chart = {
Type: this.chartType,
Show: show,
Label: this.columnLabel,
DataX: this.columnDataX,
DataY: this.columnDataY,
Option: this.dataOption
};
this.applyEvent.emit(this.chart);
}
close() {
this.closeEvent.emit();
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SDKDataGridChartOptionComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: SDKDataGridChartOptionComponent, selector: "sdk-datagrid-chart-option", inputs: { columns: "columns", chart: "chart" }, outputs: { closeEvent: "closeEvent", applyEvent: "applyEvent" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"sdk-datagrid-window\">\r\n <div class=\"header\">\r\n <span class=\"title\">Chart</span>\r\n <span title=\"Close\" class=\"sdk-icon close\" (click)=\"close()\">close</span>\r\n </div>\r\n <div class=\"content no-actions\">\r\n <div class=\"no-box\">\r\n <div class=\"section\">\r\n <span>Chart Type</span>\r\n <select class=\"column\" (change)=\"chartType = getValue($event)\">\r\n <option value=\"bar\" [selected]=\"(chartType === 'bar') ? 'selected' : ''\">Bar</option>\r\n <option value=\"doughnut\" [selected]=\"(chartType === 'doughnut') ? 'selected' : ''\">Doughnut</option>\r\n <option value=\"line\" [selected]=\"(chartType === 'line') ? 'selected' : ''\">Line</option>\r\n <option value=\"pie\" [selected]=\"(chartType === 'pie') ? 'selected' : ''\">Pie</option>\r\n <option value=\"polarArea\" [selected]=\"(chartType === 'polarArea') ? 'selected' : ''\">Polar Area</option>\r\n <option value=\"radar\" [selected]=\"(chartType === 'radar') ? 'selected' : ''\">Radar</option>\r\n </select>\r\n </div>\r\n <div class=\"section\">\r\n <span *ngIf=\"['bar', 'line', 'radar'].indexOf(chartType) > -1\">Column for Grouping</span>\r\n <span *ngIf=\"['doughnut', 'pie', 'polarArea'].indexOf(chartType) > -1\">Column for Sections</span>\r\n <select class=\"column\" (change)=\"columnLabel = getValue($event)\">\r\n <option selected value=\"\"></option>\r\n <ng-container *ngFor=\"let column of _columns\">\r\n <option [value]=\"column.Name\" [selected]=\"(columnLabel === column.Name) ? 'selected' : ''\">{{ getColumnOriginalName(column) }}</option>\r\n </ng-container>\r\n </select>\r\n </div>\r\n <div *ngIf=\"['bar', 'line', 'radar'].indexOf(chartType) > -1\" class=\"section\">\r\n <span>Column for X-Axis (Bottom)</span>\r\n <span class=\"note\">(typically a timespan)</span>\r\n <select class=\"column\" (change)=\"columnDataX = getValue($event)\">\r\n <option selected value=\"\"></option>\r\n <ng-container *ngFor=\"let column of _columns\">\r\n <option [value]=\"column.Name\" [selected]=\"(columnDataX === column.Name) ? 'selected' : ''\">{{ getColumnOriginalName(column) }}</option>\r\n </ng-container>\r\n </select>\r\n </div>\r\n <div class=\"section\">\r\n <div *ngIf=\"['bar', 'line', 'radar'].indexOf(chartType) > -1\">\r\n <span>Column for Y-Axis (Left Side)</span>\r\n <span class=\"note\">(typically a number)</span>\r\n </div>\r\n <div *ngIf=\"['doughnut', 'pie', 'polarArea'].indexOf(chartType) > -1\">\r\n <span>Column to Summarize</span>\r\n <span class=\"note\">(must be a number)</span>\r\n </div>\r\n <select class=\"column\" (change)=\"columnDataY = getValue($event)\">\r\n <option selected value=\"\"></option>\r\n <ng-container *ngFor=\"let column of _columns\">\r\n <option [value]=\"column.Name\" [selected]=\"(columnDataY === column.Name) ? 'selected' : ''\">{{ getColumnOriginalName(column) }}</option>\r\n </ng-container>\r\n </select>\r\n </div>\r\n <div *ngIf=\"['bar'].indexOf(chartType) > -1\" class=\"section\">\r\n <div style=\"display: inline-block;\">\r\n <span class=\"data-label\" (click)=\"dataOption = !dataOption\">Stack Data?</span>\r\n <input class=\"data-option\" type=\"checkbox\" [checked]=\"dataOption\" (change)=\"dataOption = !dataOption\">\r\n </div>\r\n </div>\r\n <div *ngIf=\"['line'].indexOf(chartType) > -1\" class=\"section\">\r\n <div style=\"display: inline-block;\">\r\n <span class=\"data-label\" (click)=\"dataOption = !dataOption\">Fill Data?</span>\r\n <input class=\"data-option\" type=\"checkbox\" [checked]=\"dataOption\" (change)=\"dataOption = !dataOption\">\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"footer\">\r\n <button class=\"sdk-button delete\" (click)=\"reset()\">Reset</button>\r\n <button class=\"sdk-button\" (click)=\"apply()\">Apply</button>\r\n </div>\r\n</div>\r\n\r\n<!-- Lock -->\r\n<div *ngIf=\"showMessage\" title=\"\" class=\"sdk-datagrid-windows-lock\"></div>\r\n\r\n<!-- Message -->\r\n<div *ngIf=\"showMessage\" title=\"\" class=\"sdk-datagrid-message\">\r\n <div class=\"title\">{{ message.Title }}</div>\r\n <div class=\"text\" [innerHtml]=\"message.Text\"></div>\r\n <div class=\"action\">\r\n <button class=\"sdk-button\" (click)=\"message.OK()\">{{ message.OKText }}</button>\r\n <button class=\"sdk-button cancel\" (click)=\"message.Cancel()\">{{ message.CancelText }}</button>\r\n </div>\r\n</div>\r\n", styles: [".sdk-datagrid-window{position:absolute;inset:10px;overflow:hidden}.sdk-datagrid-window .header{position:absolute;top:0;right:0;left:0;height:50px}.sdk-datagrid-window .header .title{position:absolute;top:0;left:0;font-size:large;font-weight:600}.sdk-datagrid-window .header .sdk-icon.close{position:absolute;top:0;right:0}.sdk-datagrid-window .actions{position:absolute;top:50px;right:0;left:0;margin-top:5px;height:50px;width:100%}.sdk-datagrid-window .actions .button-left{float:left;margin:0}.sdk-datagrid-window .actions .button-right{float:right;margin:0 5px 0 0}.sdk-datagrid-window .content{position:absolute;inset:100px 0 50px;border:1px solid var(--sdk-border-dark);display:block;background:var(--sdk-white);border-radius:4px;margin-top:0;overflow:auto;text-align:left}.sdk-datagrid-window .content.no-actions{top:50px}.sdk-datagrid-window .content .keyword{position:relative;padding:5px 10px}.sdk-datagrid-window .content .no-box{position:relative;background-color:var(--sdk-white);text-align:left;margin:4px;box-sizing:border-box;cursor:default}.sdk-datagrid-window .content .no-box input{border-radius:unset;border-width:unset;margin:unset;padding:unset;width:unset}.sdk-datagrid-window .content .no-box input.data-option{padding:0;margin:0 5px 0 0;vertical-align:middle;cursor:pointer}.sdk-datagrid-window .content .no-box .data-label{padding:0;margin:0 10px 0 0;display:inline;vertical-align:middle;text-transform:uppercase;font-weight:600;font-size:small;cursor:pointer}.sdk-datagrid-window .content .box{position:relative;border:1px solid var(--sdk-border);background-color:var(--sdk-white);text-align:left;margin:4px;box-sizing:border-box;cursor:default}.sdk-datagrid-window .content .cdk-drag-preview{box-sizing:border-box;border-radius:4px;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.sdk-datagrid-window .content .cdk-drag-placeholder{opacity:0}.sdk-datagrid-window .content .cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}.sdk-datagrid-window .content .list.cdk-drop-list-dragging .box:not(.cdk-drag-placeholder){transition:transform .25s cubic-bezier(0,0,.2,1)}.sdk-datagrid-window .content .section{margin:10px 10px 20px}.sdk-datagrid-window .content .section span{margin-bottom:5px;display:block;font-weight:600}.sdk-datagrid-window .content .section .column{display:block;padding:5px;width:100%}.sdk-datagrid-window .content .section .note{margin:-10px 0 5px;font-size:small;font-style:italic;font-weight:400}.sdk-datagrid-window .content .no-records{height:100%;width:100%;display:table;text-align:center;align-items:center}.sdk-datagrid-window .content .no-records span{display:table-cell;vertical-align:middle;font-size:large;font-weight:600;color:var(--sdk-red)}.sdk-datagrid-window .content .error{display:table;text-align:left;vertical-align:top;padding:20px;color:var(--sdk-red)}.sdk-datagrid-window .footer{position:absolute;right:0;left:0;bottom:0;height:40px;width:100%;text-align:center}.sdk-datagrid-window input,.sdk-datagrid-window select{border-radius:5px;border-width:.5px;margin:0;padding:5px;width:100%}.sdk-datagrid-window input:hover,.sdk-datagrid-window select:hover{border-width:1px}.sdk-datagrid-windows-lock{position:absolute;inset:0;z-index:8;overflow:hidden;background-color:var(--sdk-black);opacity:.33}.sdk-datagrid-message{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);height:200px;width:300px;background-color:var(--sdk-white);border-top:.5px solid var(--sdk-gray);border-left:.5px solid var(--sdk-gray);border-bottom:.5px solid var(--sdk-gray);box-shadow:5px 5px 10px #606060;z-index:10}.sdk-datagrid-message .title{position:absolute;top:0;left:0;right:0;height:50px;padding-top:10px;color:var(--sdk-blue);font-size:1.5em;font-weight:600;text-align:center}.sdk-datagrid-message .text{position:absolute;inset:50px 0;padding:0 10px;text-align:center}.sdk-datagrid-message .action{position:absolute;left:0;right:0;bottom:0;height:50px;text-align:center}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SDKDataGridChartOptionComponent, decorators: [{
type: Component,
args: [{ selector: 'sdk-datagrid-chart-option', template: "<div class=\"sdk-datagrid-window\">\r\n <div class=\"header\">\r\n <span class=\"title\">Chart</span>\r\n <span title=\"Close\" class=\"sdk-icon close\" (click)=\"close()\">close</span>\r\n </div>\r\n <div class=\"content no-actions\">\r\n <div class=\"no-box\">\r\n <div class=\"section\">\r\n <span>Chart Type</span>\r\n <select class=\"column\" (change)=\"chartType = getValue($event)\">\r\n <option value=\"bar\" [selected]=\"(chartType === 'bar') ? 'selected' : ''\">Bar</option>\r\n <option value=\"doughnut\" [selected]=\"(chartType === 'doughnut') ? 'selected' : ''\">Doughnut</option>\r\n <option value=\"line\" [selected]=\"(chartType === 'line') ? 'selected' : ''\">Line</option>\r\n <option value=\"pie\" [selected]=\"(chartType === 'pie') ? 'selected' : ''\">Pie</option>\r\n <option value=\"polarArea\" [selected]=\"(chartType === 'polarArea') ? 'selected' : ''\">Polar Area</option>\r\n <option value=\"radar\" [selected]=\"(chartType === 'radar') ? 'selected' : ''\">Radar</option>\r\n </select>\r\n </div>\r\n <div class=\"section\">\r\n <span *ngIf=\"['bar', 'line', 'radar'].indexOf(chartType) > -1\">Column for Grouping</span>\r\n <span *ngIf=\"['doughnut', 'pie', 'polarArea'].indexOf(chartType) > -1\">Column for Sections</span>\r\n <select class=\"column\" (change)=\"columnLabel = getValue($event)\">\r\n <option selected value=\"\"></option>\r\n <ng-container *ngFor=\"let column of _columns\">\r\n <option [value]=\"column.Name\" [selected]=\"(columnLabel === column.Name) ? 'selected' : ''\">{{ getColumnOriginalName(column) }}</option>\r\n </ng-container>\r\n </select>\r\n </div>\r\n <div *ngIf=\"['bar', 'line', 'radar'].indexOf(chartType) > -1\" class=\"section\">\r\n <span>Column for X-Axis (Bottom)</span>\r\n <span class=\"note\">(typically a timespan)</span>\r\n <select class=\"column\" (change)=\"columnDataX = getValue($event)\">\r\n <option selected value=\"\"></option>\r\n <ng-container *ngFor=\"let column of _columns\">\r\n <option [value]=\"column.Name\" [selected]=\"(columnDataX === column.Name) ? 'selected' : ''\">{{ getColumnOriginalName(column) }}</option>\r\n </ng-container>\r\n </select>\r\n </div>\r\n <div class=\"section\">\r\n <div *ngIf=\"['bar', 'line', 'radar'].indexOf(chartType) > -1\">\r\n <span>Column for Y-Axis (Left Side)</span>\r\n <span class=\"note\">(typically a number)</span>\r\n </div>\r\n <div *ngIf=\"['doughnut', 'pie', 'polarArea'].indexOf(chartType) > -1\">\r\n <span>Column to Summarize</span>\r\n <span class=\"note\">(must be a number)</span>\r\n </div>\r\n <select class=\"column\" (change)=\"columnDataY = getValue($event)\">\r\n <option selected value=\"\"></option>\r\n <ng-container *ngFor=\"let column of _columns\">\r\n <option [value]=\"column.Name\" [selected]=\"(columnDataY === column.Name) ? 'selected' : ''\">{{ getColumnOriginalName(column) }}</option>\r\n </ng-container>\r\n </select>\r\n </div>\r\n <div *ngIf=\"['bar'].indexOf(chartType) > -1\" class=\"section\">\r\n <div style=\"display: inline-block;\">\r\n <span class=\"data-label\" (click)=\"dataOption = !dataOption\">Stack Data?</span>\r\n <input class=\"data-option\" type=\"checkbox\" [checked]=\"dataOption\" (change)=\"dataOption = !dataOption\">\r\n </div>\r\n </div>\r\n <div *ngIf=\"['line'].indexOf(chartType) > -1\" class=\"section\">\r\n <div style=\"display: inline-block;\">\r\n <span class=\"data-label\" (click)=\"dataOption = !dataOption\">Fill Data?</span>\r\n <input class=\"data-option\" type=\"checkbox\" [checked]=\"dataOption\" (change)=\"dataOption = !dataOption\">\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"footer\">\r\n <button class=\"sdk-button delete\" (click)=\"reset()\">Reset</button>\r\n <button class=\"sdk-button\" (click)=\"apply()\">Apply</button>\r\n </div>\r\n</div>\r\n\r\n<!-- Lock -->\r\n<div *ngIf=\"showMessage\" title=\"\" class=\"sdk-datagrid-windows-lock\"></div>\r\n\r\n<!-- Message -->\r\n<div *ngIf=\"showMessage\" title=\"\" class=\"sdk-datagrid-message\">\r\n <div class=\"title\">{{ message.Title }}</div>\r\n <div class=\"text\" [innerHtml]=\"message.Text\"></div>\r\n <div class=\"action\">\r\n <button class=\"sdk-button\" (click)=\"message.OK()\">{{ message.OKText }}</button>\r\n <button class=\"sdk-button cancel\" (click)=\"message.Cancel()\">{{ message.CancelText }}</button>\r\n </div>\r\n</div>\r\n", styles: [".sdk-datagrid-window{position:absolute;inset:10px;overflow:hidden}.sdk-datagrid-window .header{position:absolute;top:0;right:0;left:0;height:50px}.sdk-datagrid-window .header .title{position:absolute;top:0;left:0;font-size:large;font-weight:600}.sdk-datagrid-window .header .sdk-icon.close{position:absolute;top:0;right:0}.sdk-datagrid-window .actions{position:absolute;top:50px;right:0;left:0;margin-top:5px;height:50px;width:100%}.sdk-datagrid-window .actions .button-left{float:left;margin:0}.sdk-datagrid-window .actions .button-right{float:right;margin:0 5px 0 0}.sdk-datagrid-window .content{position:absolute;inset:100px 0 50px;border:1px solid var(--sdk-border-dark);display:block;background:var(--sdk-white);border-radius:4px;margin-top:0;overflow:auto;text-align:left}.sdk-datagrid-window .content.no-actions{top:50px}.sdk-datagrid-window .content .keyword{position:relative;padding:5px 10px}.sdk-datagrid-window .content .no-box{position:relative;background-color:var(--sdk-white);text-align:left;margin:4px;box-sizing:border-box;cursor:default}.sdk-datagrid-window .content .no-box input{border-radius:unset;border-width:unset;margin:unset;padding:unset;width:unset}.sdk-datagrid-window .content .no-box input.data-option{padding:0;margin:0 5px 0 0;vertical-align:middle;cursor:pointer}.sdk-datagrid-window .content .no-box .data-label{padding:0;margin:0 10px 0 0;display:inline;vertical-align:middle;text-transform:uppercase;font-weight:600;font-size:small;cursor:pointer}.sdk-datagrid-window .content .box{position:relative;border:1px solid var(--sdk-border);background-color:var(--sdk-white);text-align:left;margin:4px;box-sizing:border-box;cursor:default}.sdk-datagrid-window .content .cdk-drag-preview{box-sizing:border-box;border-radius:4px;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.sdk-datagrid-window .content .cdk-drag-placeholder{opacity:0}.sdk-datagrid-window .content .cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}.sdk-datagrid-window .content .list.cdk-drop-list-dragging .box:not(.cdk-drag-placeholder){transition:transform .25s cubic-bezier(0,0,.2,1)}.sdk-datagrid-window .content .section{margin:10px 10px 20px}.sdk-datagrid-window .content .section span{margin-bottom:5px;display:block;font-weight:600}.sdk-datagrid-window .content .section .column{display:block;padding:5px;width:100%}.sdk-datagrid-window .content .section .note{margin:-10px 0 5px;font-size:small;font-style:italic;font-weight:400}.sdk-datagrid-window .content .no-records{height:100%;width:100%;display:table;text-align:center;align-items:center}.sdk-datagrid-window .content .no-records span{display:table-cell;vertical-align:middle;font-size:large;font-weight:600;color:var(--sdk-red)}.sdk-datagrid-window .content .error{display:table;text-align:left;vertical-align:top;padding:20px;color:var(--sdk-red)}.sdk-datagrid-window .footer{position:absolute;right:0;left:0;bottom:0;height:40px;width:100%;text-align:center}.sdk-datagrid-window input,.sdk-datagrid-window select{border-radius:5px;border-width:.5px;margin:0;padding:5px;width:100%}.sdk-datagrid-window input:hover,.sdk-datagrid-window select:hover{border-width:1px}.sdk-datagrid-windows-lock{position:absolute;inset:0;z-index:8;overflow:hidden;background-color:var(--sdk-black);opacity:.33}.sdk-datagrid-message{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);height:200px;width:300px;background-color:var(--sdk-white);border-top:.5px solid var(--sdk-gray);border-left:.5px solid var(--sdk-gray);border-bottom:.5px solid var(--sdk-gray);box-shadow:5px 5px 10px #606060;z-index:10}.sdk-datagrid-message .title{position:absolute;top:0;left:0;right:0;height:50px;padding-top:10px;color:var(--sdk-blue);font-size:1.5em;font-weight:600;text-align:center}.sdk-datagrid-message .text{position:absolute;inset:50px 0;padding:0 10px;text-align:center}.sdk-datagrid-message .action{position:absolute;left:0;right:0;bottom:0;height:50px;text-align:center}\n"] }]
}], propDecorators: { columns: [{
type: Input
}], chart: [{
type: Input
}], closeEvent: [{
type: Output
}], applyEvent: [{
type: Output
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chart-option.component.js","sourceRoot":"","sources":["../../../../../../projects/sdk-datagrid/src/lib/options/chart/chart-option.component.ts","../../../../../../projects/sdk-datagrid/src/lib/options/chart/chart-option.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\n\r\nimport { SDKDataGridColumn } from '../../models/datagrid-column';\r\nimport { SDKDataGridMessage } from '../../models/datagrid-message';\r\n\r\nimport { Clone } from '../../utils/clone';\r\n\r\n@Component({\r\n    selector: 'sdk-datagrid-chart-option',\r\n    templateUrl: './chart-option.component.html',\r\n    styleUrls: ['./chart-option.component.scss']\r\n})\r\n\r\nexport class SDKDataGridChartOptionComponent {\r\n    @Input() columns: SDKDataGridColumn[] = [];\r\n    @Input() chart: any = \"\";\r\n    @Output() closeEvent = new EventEmitter();\r\n    @Output() applyEvent = new EventEmitter();\r\n\r\n    public chartType = \"bar\";\r\n    public columnLabel = \"\";\r\n    public columnDataX = \"\";\r\n    public columnDataY = \"\";\r\n    public dataOption = false;\r\n\r\n    protected _columns: SDKDataGridColumn[] = [];\r\n\r\n    /**************************************************************************\r\n    * Message Variable\r\n    **************************************************************************/\r\n    protected showMessage: boolean = false;\r\n    protected message: SDKDataGridMessage = new SDKDataGridMessage();\r\n\r\n    public ngOnChanges(_args: any) {\r\n        this._columns = Clone.deepCopy(this.columns);\r\n\r\n        this.initialize();\r\n    }\r\n\r\n    private initialize() {\r\n        this._columns = this._columns.filter((column: SDKDataGridColumn) => column.isVisible && !column.isAction);\r\n        \r\n        if (this.chart === \"\") {\r\n            this.chart = {\r\n                Type: \"bar\",\r\n                Show: false,\r\n                Label: \"\",\r\n                DataX: \"\",\r\n                DataY: \"\",\r\n                Option: false\r\n            };\r\n        }\r\n\r\n        this.chartType = this.chart.Type;\r\n        this.columnLabel = this.chart.Label;\r\n        this.columnDataX = this.chart.DataX;\r\n        this.columnDataY = this.chart.DataY;\r\n        this.dataOption = this.chart.Option;\r\n    }\r\n\r\n    public getColumnOriginalName(column: SDKDataGridColumn) {\r\n        let originalName = column.Name;\r\n\r\n        if (column.FriendlyName && column.FriendlyName !== \"\") {\r\n            originalName = column.FriendlyName;\r\n        } else if (column.DisplayName && column.DisplayName !== \"\") {\r\n            originalName = column.DisplayName;\r\n        }\r\n\r\n        return originalName;\r\n    }\r\n\r\n    public getValue(event: any) {\r\n        return event.target.value;\r\n    }\r\n\r\n    public reset() {\r\n        this.message = {\r\n            Title: \"Reset Chart\",\r\n            Text: \"Are you sure?\",\r\n            OKText: \"YES\",\r\n            CancelText: \"NO\",\r\n            OK: () => {\r\n                this.chart = \"\";\r\n\r\n                this.initialize();\r\n            },\r\n            Cancel: () => {\r\n                this.showMessage = false;\r\n            }\r\n        };\r\n\r\n        this.showMessage = true;\r\n    }\r\n\r\n    public apply() {\r\n        let show = true;\r\n\r\n        if (['bar', 'line', 'radar'].indexOf(this.chartType) > -1 && (this.columnLabel === \"\" || this.columnDataX === \"\" || this.columnDataY === \"\")) show = false;\r\n        if (['doughnut', 'pie', 'polarArea'].indexOf(this.chartType) > -1 && (this.columnLabel === \"\" || this.columnDataY === \"\")) show = false;\r\n\r\n        this.chart = {\r\n            Type: this.chartType,\r\n            Show: show,\r\n            Label: this.columnLabel,\r\n            DataX: this.columnDataX,\r\n            DataY: this.columnDataY,\r\n            Option: this.dataOption\r\n        };\r\n\r\n        this.applyEvent.emit(this.chart);\r\n    }\r\n\r\n    public close() {\r\n        this.closeEvent.emit();\r\n    }\r\n}\r\n","<div class=\"sdk-datagrid-window\">\r\n    <div class=\"header\">\r\n        <span class=\"title\">Chart</span>\r\n        <span title=\"Close\" class=\"sdk-icon close\" (click)=\"close()\">close</span>\r\n    </div>\r\n    <div class=\"content no-actions\">\r\n        <div class=\"no-box\">\r\n            <div class=\"section\">\r\n                <span>Chart Type</span>\r\n                <select class=\"column\" (change)=\"chartType = getValue($event)\">\r\n                    <option value=\"bar\" [selected]=\"(chartType === 'bar') ? 'selected' : ''\">Bar</option>\r\n                    <option value=\"doughnut\" [selected]=\"(chartType === 'doughnut') ? 'selected' : ''\">Doughnut</option>\r\n                    <option value=\"line\" [selected]=\"(chartType === 'line') ? 'selected' : ''\">Line</option>\r\n                    <option value=\"pie\" [selected]=\"(chartType === 'pie') ? 'selected' : ''\">Pie</option>\r\n                    <option value=\"polarArea\" [selected]=\"(chartType === 'polarArea') ? 'selected' : ''\">Polar Area</option>\r\n                    <option value=\"radar\" [selected]=\"(chartType === 'radar') ? 'selected' : ''\">Radar</option>\r\n                </select>\r\n            </div>\r\n            <div class=\"section\">\r\n                <span *ngIf=\"['bar', 'line', 'radar'].indexOf(chartType) > -1\">Column for Grouping</span>\r\n                <span *ngIf=\"['doughnut', 'pie', 'polarArea'].indexOf(chartType) > -1\">Column for Sections</span>\r\n                <select class=\"column\" (change)=\"columnLabel = getValue($event)\">\r\n                    <option selected value=\"\"></option>\r\n                    <ng-container *ngFor=\"let column of _columns\">\r\n                        <option [value]=\"column.Name\" [selected]=\"(columnLabel === column.Name) ? 'selected' : ''\">{{ getColumnOriginalName(column)  }}</option>\r\n                    </ng-container>\r\n                </select>\r\n            </div>\r\n            <div *ngIf=\"['bar', 'line', 'radar'].indexOf(chartType) > -1\" class=\"section\">\r\n                <span>Column for X-Axis (Bottom)</span>\r\n                <span class=\"note\">(typically a timespan)</span>\r\n                <select class=\"column\" (change)=\"columnDataX = getValue($event)\">\r\n                    <option selected value=\"\"></option>\r\n                    <ng-container *ngFor=\"let column of _columns\">\r\n                        <option [value]=\"column.Name\" [selected]=\"(columnDataX === column.Name) ? 'selected' : ''\">{{ getColumnOriginalName(column) }}</option>\r\n                    </ng-container>\r\n                </select>\r\n            </div>\r\n            <div class=\"section\">\r\n                <div *ngIf=\"['bar', 'line', 'radar'].indexOf(chartType) > -1\">\r\n                    <span>Column for Y-Axis (Left Side)</span>\r\n                    <span class=\"note\">(typically a number)</span>\r\n                </div>\r\n                <div *ngIf=\"['doughnut', 'pie', 'polarArea'].indexOf(chartType) > -1\">\r\n                    <span>Column to Summarize</span>\r\n                    <span class=\"note\">(must be a number)</span>\r\n                </div>\r\n                <select class=\"column\" (change)=\"columnDataY = getValue($event)\">\r\n                    <option selected value=\"\"></option>\r\n                    <ng-container *ngFor=\"let column of _columns\">\r\n                        <option [value]=\"column.Name\" [selected]=\"(columnDataY === column.Name) ? 'selected' : ''\">{{ getColumnOriginalName(column) }}</option>\r\n                    </ng-container>\r\n                </select>\r\n            </div>\r\n            <div *ngIf=\"['bar'].indexOf(chartType) > -1\" class=\"section\">\r\n                <div style=\"display: inline-block;\">\r\n                    <span class=\"data-label\" (click)=\"dataOption = !dataOption\">Stack Data?</span>\r\n                    <input class=\"data-option\" type=\"checkbox\" [checked]=\"dataOption\" (change)=\"dataOption = !dataOption\">\r\n                </div>\r\n            </div>\r\n            <div *ngIf=\"['line'].indexOf(chartType) > -1\" class=\"section\">\r\n                <div style=\"display: inline-block;\">\r\n                    <span class=\"data-label\" (click)=\"dataOption = !dataOption\">Fill Data?</span>\r\n                    <input class=\"data-option\" type=\"checkbox\" [checked]=\"dataOption\" (change)=\"dataOption = !dataOption\">\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n    <div class=\"footer\">\r\n        <button class=\"sdk-button delete\" (click)=\"reset()\">Reset</button>\r\n        <button class=\"sdk-button\" (click)=\"apply()\">Apply</button>\r\n    </div>\r\n</div>\r\n\r\n<!-- Lock -->\r\n<div *ngIf=\"showMessage\" title=\"\" class=\"sdk-datagrid-windows-lock\"></div>\r\n\r\n<!-- Message -->\r\n<div *ngIf=\"showMessage\" title=\"\" class=\"sdk-datagrid-message\">\r\n    <div class=\"title\">{{ message.Title }}</div>\r\n    <div class=\"text\" [innerHtml]=\"message.Text\"></div>\r\n    <div class=\"action\">\r\n        <button class=\"sdk-button\" (click)=\"message.OK()\">{{ message.OKText }}</button>\r\n        <button class=\"sdk-button cancel\" (click)=\"message.Cancel()\">{{ message.CancelText }}</button>\r\n    </div>\r\n</div>\r\n"]}