UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

497 lines (496 loc) 34.9 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import * as tslib_1 from "tslib"; import { Component, ElementRef, EventEmitter, Output, Input } from '@angular/core'; import { AbstractDataView } from './AbstractDataView'; import { PhloxDataChartModel } from '.././model/models'; import { Option } from '../../decorator/decorators'; import { BEFORE_CHART_SELECT_EVENT, CHART_SELECT_EVENT, CHART_ERROR, CHART_READY } from '../../share/CustomEventType'; import { EventUtils } from '../../share/shares'; var /** @type {?} */ TYPE_NAME = "phxChart"; var PhloxChart = /** @class */ (function (_super) { tslib_1.__extends(PhloxChart, _super); function PhloxChart(elementRef) { var _this = _super.call(this, elementRef) || this; _this.chartReadyEvent = new EventEmitter(); // before event is not require _this.chartErrorEvent = new EventEmitter(); // before event is not require _this.beforeChartSelectEvent = new EventEmitter(); _this.chartSelectEvent = new EventEmitter(); _this.beforeChartMouseOverEvent = new EventEmitter(); _this.chartMouseOverEvent = new EventEmitter(); _this.beforeChartMouseOutEvent = new EventEmitter(); _this.chartMouseOutEvent = new EventEmitter(); return _this; } /** * @return {?} */ PhloxChart.prototype.ngOnInit = /** * @return {?} */ function () { _super.prototype.ngOnInit.call(this); if (this.chartType !== undefined && this.chartType !== null && this.dataTable !== undefined && this.dataTable !== null && this.cols !== undefined && this.cols !== null && this.rows !== undefined && this.rows !== null) { this.model = new PhloxDataChartModel(this.chartType, this.dataTable, this.formatters, this.options, this.title, this.subtitle, this.width, this.height, this.cols, this.rows); } }; /** * @return {?} */ PhloxChart.prototype.isSelfDataDirty = /** * @return {?} */ function () { return false; }; /** * @param {?} data * @return {?} */ PhloxChart.prototype.selfSaveData = /** * @param {?} data * @return {?} */ function (data) { }; /** * @return {?} */ PhloxChart.prototype.selfResetData = /** * @return {?} */ function () { }; /** * @return {?} */ PhloxChart.prototype.doPreload = /** * @return {?} */ function () { return new Promise(function (resolve, reject) { resolve(null); }); }; /** * @return {?} */ PhloxChart.prototype.doLoaded = /** * @return {?} */ function () { }; /** * @param {?} dataTable * @return {?} */ PhloxChart.prototype.reloadData = /** * @param {?} dataTable * @return {?} */ function (dataTable) { this.model.dataTable = dataTable; this.model = JSON.parse(JSON.stringify(this.model)); }; /** * @param {?} event * @param {?=} fireEvent * @return {?} */ PhloxChart.prototype.onChartSelectEvent = /** * @param {?} event * @param {?=} fireEvent * @return {?} */ function (event, fireEvent) { var _this = this; if (fireEvent === null || fireEvent === undefined) { fireEvent = true; } EventUtils.handleBrowserEvent(this, 'beforeChartSelectEvent', event, fireEvent, function ($event) { // doEvent }, function ($event) { // emitBeforeEvent // emitBeforeEvent _this.emitBeforeChartSelectEvent($event); }, function ($event, result) { // emitAfterEvent // emitAfterEvent _this.emitChartSelectEvent($event); }, function ($event) { // doPrevented }); }; /** * @param {?} $event * @return {?} */ PhloxChart.prototype.emitBeforeChartSelectEvent = /** * @param {?} $event * @return {?} */ function ($event) { var /** @type {?} */ eventData = null; // emit event var /** @type {?} */ data = eventData; var /** @type {?} */ ev = EventUtils.newCustomEvent(BEFORE_CHART_SELECT_EVENT, this, data, $event); if (this.beforeChartSelectEvent !== null && this.beforeChartSelectEvent !== undefined) { this.beforeChartSelectEvent.emit(ev); } }; /** * @param {?} $event * @return {?} */ PhloxChart.prototype.emitChartSelectEvent = /** * @param {?} $event * @return {?} */ function ($event) { var /** @type {?} */ eventData = $event; // emit event var /** @type {?} */ data = eventData; var /** @type {?} */ ev = EventUtils.newCustomEvent(CHART_SELECT_EVENT, this, data, $event); if (this.chartSelectEvent !== null && this.chartSelectEvent !== undefined) { this.chartSelectEvent.emit(ev); } }; /** * @param {?} $event * @return {?} */ PhloxChart.prototype.emitChartReadyEvent = /** * @param {?} $event * @return {?} */ function ($event) { var /** @type {?} */ eventData = null; // emit event var /** @type {?} */ data = eventData; var /** @type {?} */ ev = EventUtils.newCustomEvent(CHART_READY, this, data, event); if (this.chartReadyEvent !== null && this.chartReadyEvent !== undefined) { this.chartReadyEvent.emit(ev); } }; /** * @param {?} $event * @return {?} */ PhloxChart.prototype.emitChartErrorEvent = /** * @param {?} $event * @return {?} */ function ($event) { var /** @type {?} */ eventData = null; // emit event var /** @type {?} */ data = eventData; var /** @type {?} */ ev = EventUtils.newCustomEvent(CHART_ERROR, this, data, event); if (this.chartErrorEvent !== null && this.chartErrorEvent !== undefined) { this.chartErrorEvent.emit(ev); } }; /** * @param {?} event * @param {?=} fireEvent * @return {?} */ PhloxChart.prototype.onChartReadyEvent = /** * @param {?} event * @param {?=} fireEvent * @return {?} */ function (event, fireEvent) { if (fireEvent === null || fireEvent === undefined) { fireEvent = true; } this.emitChartReadyEvent(event); }; /** * @param {?} event * @param {?=} fireEvent * @return {?} */ PhloxChart.prototype.onChartErrorEvent = /** * @param {?} event * @param {?=} fireEvent * @return {?} */ function (event, fireEvent) { if (fireEvent === null || fireEvent === undefined) { fireEvent = true; } this.emitChartErrorEvent(event); }; /** * @return {?} */ PhloxChart.prototype.getchartReadyEvent = /** * @return {?} */ function () { return this.chartReadyEvent; }; /** * @return {?} */ PhloxChart.prototype.getchartErrorEvent = /** * @return {?} */ function () { return this.chartErrorEvent; }; /** * @return {?} */ PhloxChart.prototype.getchartSelectEvent = /** * @return {?} */ function () { return this.chartSelectEvent; }; /** * @return {?} */ PhloxChart.prototype.getchartMouseOverEvent = /** * @return {?} */ function () { return this.chartMouseOverEvent; }; /** * @return {?} */ PhloxChart.prototype.getchartMouseOutEvent = /** * @return {?} */ function () { return this.chartMouseOutEvent; }; /** * @param {?} options * @return {?} */ PhloxChart.prototype.setOptions = /** * @param {?} options * @return {?} */ function (options) { this.model.options = options; this.reloadData(this.model.dataTable); }; /** * @param {?} chartType * @return {?} */ PhloxChart.prototype.setChartType = /** * @param {?} chartType * @return {?} */ function (chartType) { this.model.chartType = chartType; this.reloadData(this.model.dataTable); }; /** * @param {?} title * @return {?} */ PhloxChart.prototype.setTitle = /** * @param {?} title * @return {?} */ function (title) { this.model.title = title; this.reloadData(this.model.dataTable); }; /** * @param {?} subtitle * @return {?} */ PhloxChart.prototype.setSubtitle = /** * @param {?} subtitle * @return {?} */ function (subtitle) { this.model.subtitle = subtitle; this.reloadData(this.model.dataTable); }; /** * @return {?} */ PhloxChart.prototype.getModel = /** * @return {?} */ function () { return this.model; }; /** * @param {?} model * @return {?} */ PhloxChart.prototype.setModel = /** * @param {?} model * @return {?} */ function (model) { this.model = model; }; PhloxChart.TYPE_NAME = TYPE_NAME; PhloxChart.decorators = [ { type: Component, args: [{ moduleId: module.id, selector: TYPE_NAME, template: "<div class=\"phxChart\">\n <google-chart [data]=\"getModel()\" (chartReady)=\"onChartReadyEvent($event)\" (chartError)=\"onChartErrorEvent($event)\" (chartSelect)=\"onChartSelectEvent($event)\"></google-chart>\n</div> " },] }, ]; /** @nocollapse */ PhloxChart.ctorParameters = function () { return [ { type: ElementRef, }, ]; }; PhloxChart.propDecorators = { "chartReadyEvent": [{ type: Output, args: ['phxChartReady',] },], "chartErrorEvent": [{ type: Output, args: ['phxChartError',] },], "beforeChartSelectEvent": [{ type: Output, args: ['phxBeforeChartSelect',] },], "chartSelectEvent": [{ type: Output, args: ['phxChartSelect',] },], "beforeChartMouseOverEvent": [{ type: Output, args: ['phxBeforeChartMouseOver',] },], "chartMouseOverEvent": [{ type: Output, args: ['phxChartMouseOver',] },], "beforeChartMouseOutEvent": [{ type: Output, args: ['phxBeforeChartMouseOut',] },], "chartMouseOutEvent": [{ type: Output, args: ['phxChartMouseOut',] },], "dataTable": [{ type: Input },], "chartType": [{ type: Input },], "formatters": [{ type: Input },], "title": [{ type: Input },], "subtitle": [{ type: Input },], "options": [{ type: Input },], "width": [{ type: Input },], "height": [{ type: Input },], "cols": [{ type: Input },], "rows": [{ type: Input },], }; tslib_1.__decorate([ Option('chartReady'), tslib_1.__metadata("design:type", EventEmitter) ], PhloxChart.prototype, "chartReadyEvent", void 0); tslib_1.__decorate([ Option('chartError'), tslib_1.__metadata("design:type", EventEmitter) ], PhloxChart.prototype, "chartErrorEvent", void 0); tslib_1.__decorate([ Option('beforeChartSelect'), tslib_1.__metadata("design:type", EventEmitter) ], PhloxChart.prototype, "beforeChartSelectEvent", void 0); tslib_1.__decorate([ Option('chartSelect'), tslib_1.__metadata("design:type", EventEmitter) ], PhloxChart.prototype, "chartSelectEvent", void 0); tslib_1.__decorate([ Option('beforeChartMouseOver'), tslib_1.__metadata("design:type", EventEmitter) ], PhloxChart.prototype, "beforeChartMouseOverEvent", void 0); tslib_1.__decorate([ Option('chartMouseOver'), tslib_1.__metadata("design:type", EventEmitter) ], PhloxChart.prototype, "chartMouseOverEvent", void 0); tslib_1.__decorate([ Option('beforeChartMouseOut'), tslib_1.__metadata("design:type", EventEmitter) ], PhloxChart.prototype, "beforeChartMouseOutEvent", void 0); tslib_1.__decorate([ Option('chartMouseOut'), tslib_1.__metadata("design:type", EventEmitter) ], PhloxChart.prototype, "chartMouseOutEvent", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Array) ], PhloxChart.prototype, "dataTable", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], PhloxChart.prototype, "chartType", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Array) ], PhloxChart.prototype, "formatters", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], PhloxChart.prototype, "title", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], PhloxChart.prototype, "subtitle", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Object) ], PhloxChart.prototype, "options", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], PhloxChart.prototype, "width", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], PhloxChart.prototype, "height", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Array) ], PhloxChart.prototype, "cols", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Array) ], PhloxChart.prototype, "rows", void 0); return PhloxChart; }(AbstractDataView)); export { PhloxChart }; function PhloxChart_tsickle_Closure_declarations() { /** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */ PhloxChart.decorators; /** * @nocollapse * @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>} */ PhloxChart.ctorParameters; /** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */ PhloxChart.propDecorators; /** @type {?} */ PhloxChart.TYPE_NAME; /** @type {?} */ PhloxChart.prototype.chartReadyEvent; /** @type {?} */ PhloxChart.prototype.chartErrorEvent; /** @type {?} */ PhloxChart.prototype.beforeChartSelectEvent; /** @type {?} */ PhloxChart.prototype.chartSelectEvent; /** @type {?} */ PhloxChart.prototype.beforeChartMouseOverEvent; /** @type {?} */ PhloxChart.prototype.chartMouseOverEvent; /** @type {?} */ PhloxChart.prototype.beforeChartMouseOutEvent; /** @type {?} */ PhloxChart.prototype.chartMouseOutEvent; /** @type {?} */ PhloxChart.prototype.dataTable; /** @type {?} */ PhloxChart.prototype.chartType; /** @type {?} */ PhloxChart.prototype.formatters; /** @type {?} */ PhloxChart.prototype.title; /** @type {?} */ PhloxChart.prototype.subtitle; /** @type {?} */ PhloxChart.prototype.options; /** @type {?} */ PhloxChart.prototype.width; /** @type {?} */ PhloxChart.prototype.height; /** @type {?} */ PhloxChart.prototype.cols; /** @type {?} */ PhloxChart.prototype.rows; /** @type {?} */ PhloxChart.prototype.model; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"PhloxChart.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/dataview/PhloxChart.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ElementRef, EventEmitter, Output, ViewChild, Input } from '@angular/core';\r\nimport { AbstractDataView } from './AbstractDataView';\r\nimport { IHasModel } from '../IHasModel';\r\nimport { PhloxDataChartModel } from '.././model/models';\r\nimport { Option } from '../../decorator/decorators';\r\nimport { GoogleChartComponent } from 'ng2-google-charts';\r\nimport { BEFORE_CHART_MOUSE_OVER_EVENT, CHART_MOUSE_OVER_EVENT, BEFORE_CHART_MOUSE_OUT_EVENT, CHART_MOUSE_OUT_EVENT, BEFORE_CHART_SELECT_EVENT, CHART_SELECT_EVENT, CHART_ERROR, CHART_READY } from '../../share/CustomEventType';\r\nimport { EventUtils } from '../../share/shares';\r\n\r\nconst TYPE_NAME: string = \"phxChart\";\r\n\r\n@Component({\r\n  moduleId: module.id,\r\n  selector: TYPE_NAME,\r\n  template: `<div class=\"phxChart\">\r\n    <google-chart [data]=\"getModel()\" (chartReady)=\"onChartReadyEvent($event)\" (chartError)=\"onChartErrorEvent($event)\" (chartSelect)=\"onChartSelectEvent($event)\"></google-chart>\r\n</div> `\r\n})\r\n\r\nexport class PhloxChart extends AbstractDataView implements IHasModel, OnInit {\r\n\r\n  public static readonly TYPE_NAME: string = TYPE_NAME;\r\n\r\n  @Option('chartReady')\r\n  @Output('phxChartReady')\r\n  protected chartReadyEvent: EventEmitter<any>;\r\n  @Option('chartError')\r\n  @Output('phxChartError')\r\n  protected chartErrorEvent: EventEmitter<any>;\r\n  @Option('beforeChartSelect')\r\n  @Output('phxBeforeChartSelect')\r\n  protected beforeChartSelectEvent: EventEmitter<any>;\r\n  @Option('chartSelect')\r\n  @Output('phxChartSelect')\r\n  protected chartSelectEvent: EventEmitter<any>;\r\n  @Option('beforeChartMouseOver')\r\n  @Output('phxBeforeChartMouseOver')\r\n  protected beforeChartMouseOverEvent: EventEmitter<any>;\r\n  @Option('chartMouseOver')\r\n  @Output('phxChartMouseOver')\r\n  protected chartMouseOverEvent: EventEmitter<any>;\r\n  @Option('beforeChartMouseOut')\r\n  @Output('phxBeforeChartMouseOut')\r\n  protected beforeChartMouseOutEvent: EventEmitter<any>;\r\n  @Option('chartMouseOut')\r\n  @Output('phxChartMouseOut')\r\n  protected chartMouseOutEvent: EventEmitter<any>;\r\n\r\n  @Input()\r\n  @Option()\r\n  protected dataTable: any[];\r\n  @Input()\r\n  @Option()\r\n  protected chartType: string;\r\n  @Input()\r\n  @Option()\r\n  protected formatters: any[];\r\n  @Input()\r\n  @Option()\r\n  protected title : string;\r\n  @Input()\r\n  @Option()\r\n  protected subtitle: string;\r\n  @Input()\r\n  @Option()\r\n  protected options: any;\r\n  @Input()\r\n  @Option()\r\n  protected width: string;\r\n  @Input()\r\n  @Option()\r\n  protected height: string;\r\n  @Input()\r\n  @Option()\r\n  protected cols: any[];\r\n  @Input()\r\n  @Option()\r\n  protected rows: any[];\r\n\r\n  //   protected chartWrapper: ChartWrapper;\r\n  protected model: PhloxDataChartModel;\r\n\r\n\r\n  constructor(elementRef: ElementRef) {\r\n    super(elementRef);\r\n\r\n    this.chartReadyEvent = new EventEmitter(); // before event is not require\r\n    this.chartErrorEvent = new EventEmitter(); // before event is not require\r\n    this.beforeChartSelectEvent = new EventEmitter();\r\n    this.chartSelectEvent = new EventEmitter();\r\n    this.beforeChartMouseOverEvent = new EventEmitter();\r\n    this.chartMouseOverEvent = new EventEmitter();\r\n    this.beforeChartMouseOutEvent = new EventEmitter();\r\n    this.chartMouseOutEvent = new EventEmitter();\r\n\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    super.ngOnInit();\r\n\r\n    if(this.chartType !== undefined && this.chartType !== null &&\r\n      this.dataTable !== undefined && this.dataTable !== null &&\r\n      this.cols !== undefined && this.cols !== null &&\r\n      this.rows !== undefined && this.rows !== null  ) {\r\n        this.model = new PhloxDataChartModel(\r\n          this.chartType,\r\n          this.dataTable,\r\n          this.formatters,\r\n          this.options,\r\n          this.title,\r\n          this.subtitle,\r\n          this.width,\r\n          this.height,\r\n          this.cols,\r\n          this.rows\r\n        );\r\n      }\r\n  }\r\n\r\n  public isSelfDataDirty(): boolean {\r\n    return false;\r\n  }\r\n\r\n  public selfSaveData(data: any): void {\r\n\r\n  }\r\n\r\n  public selfResetData(): void {\r\n\r\n  }\r\n\r\n  public doPreload(): Promise<any> {     return new Promise((resolve, reject) => {       resolve(null);     });   }  public doLoaded(): void {\r\n\r\n  }\r\n\r\n  public reloadData(dataTable: any[]): void {\r\n    this.model.dataTable = dataTable;\r\n    this.model = JSON.parse(JSON.stringify(this.model));\r\n  }\r\n\r\n  public onChartSelectEvent(event: any, fireEvent?: boolean) {\r\n    if (fireEvent === null || fireEvent === undefined) {\r\n      fireEvent = true;\r\n    }\r\n\r\n    EventUtils.handleBrowserEvent(this, 'beforeChartSelectEvent', event, fireEvent, ($event: Event) => {\r\n      // doEvent\r\n    }, ($event: Event) => {\r\n      // emitBeforeEvent\r\n      this.emitBeforeChartSelectEvent($event);\r\n    }, ($event: Event, result: any) => {\r\n      // emitAfterEvent\r\n      this.emitChartSelectEvent($event);\r\n    }, ($event: Event) => {\r\n      // doPrevented\r\n    });\r\n  }\r\n\r\n  protected emitBeforeChartSelectEvent($event: Event) {\r\n    let eventData: any = null\r\n\r\n    // emit event\r\n    let data: any = eventData;\r\n    let ev = EventUtils.newCustomEvent(BEFORE_CHART_SELECT_EVENT, this, data, $event);\r\n\r\n    if (this.beforeChartSelectEvent !== null && this.beforeChartSelectEvent !== undefined) {\r\n      this.beforeChartSelectEvent.emit(ev);\r\n    }\r\n  }\r\n\r\n  protected emitChartSelectEvent($event: Event) {\r\n    let eventData: any = $event\r\n\r\n    // emit event\r\n    let data: any = eventData;\r\n    let ev = EventUtils.newCustomEvent(CHART_SELECT_EVENT, this, data, $event);\r\n\r\n    if (this.chartSelectEvent !== null && this.chartSelectEvent !== undefined) {\r\n      this.chartSelectEvent.emit(ev);\r\n    }\r\n  }\r\n\r\n  protected emitChartReadyEvent($event: Event) {\r\n    let eventData: any = null\r\n\r\n    // emit event\r\n    let data: any = eventData;\r\n    let ev = EventUtils.newCustomEvent(CHART_READY, this, data, event);\r\n\r\n    if (this.chartReadyEvent !== null && this.chartReadyEvent !== undefined) {\r\n      this.chartReadyEvent.emit(ev);\r\n    }\r\n  }\r\n\r\n  protected emitChartErrorEvent($event: Event) {\r\n    let eventData: any = null\r\n\r\n    // emit event\r\n    let data: any = eventData;\r\n    let ev = EventUtils.newCustomEvent(CHART_ERROR, this, data, event);\r\n\r\n    if (this.chartErrorEvent !== null && this.chartErrorEvent !== undefined) {\r\n      this.chartErrorEvent.emit(ev);\r\n    }\r\n  }\r\n\r\n  public onChartReadyEvent(event: any, fireEvent?: boolean) {\r\n    if (fireEvent === null || fireEvent === undefined) {\r\n      fireEvent = true;\r\n    }\r\n\r\n    this.emitChartReadyEvent(event);\r\n  }\r\n\r\n  public onChartErrorEvent(event: any, fireEvent?: boolean) {\r\n    if (fireEvent === null || fireEvent === undefined) {\r\n      fireEvent = true;\r\n    }\r\n\r\n    this.emitChartErrorEvent(event);\r\n  }\r\n\r\n  public getchartReadyEvent(): EventEmitter<any> {\r\n    return this.chartReadyEvent;\r\n  }\r\n\r\n  public getchartErrorEvent(): EventEmitter<any> {\r\n    return this.chartErrorEvent;\r\n  }\r\n\r\n  public getchartSelectEvent(): EventEmitter<any> {\r\n    return this.chartSelectEvent;\r\n  }\r\n\r\n  public getchartMouseOverEvent(): EventEmitter<any> {\r\n    return this.chartMouseOverEvent;\r\n  }\r\n\r\n  public getchartMouseOutEvent(): EventEmitter<any> {\r\n    return this.chartMouseOutEvent;\r\n  }\r\n\r\n  public setOptions(options: any): void {\r\n    this.model.options = options;\r\n    this.reloadData(this.model.dataTable);\r\n  }\r\n\r\n  public setChartType(chartType: string): void {\r\n    this.model.chartType = chartType;\r\n    this.reloadData(this.model.dataTable);\r\n  }\r\n\r\n  public setTitle(title: string): void {\r\n    this.model.title = title;\r\n    this.reloadData(this.model.dataTable);\r\n  }\r\n\r\n  public setSubtitle(subtitle: string): void {\r\n    this.model.subtitle = subtitle;\r\n    this.reloadData(this.model.dataTable);\r\n  }\r\n\r\n  public getModel(): PhloxDataChartModel {\r\n    return this.model;\r\n  }\r\n\r\n  public setModel(model: PhloxDataChartModel): void {\r\n    this.model = model;\r\n  }\r\n}\r\n"]}