@bizdoc/core 1.13.34 → 1.13.36

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (42) hide show
  1. package/esm2020/lib/admin/document-trace/trace-element.component.mjs +4 -4
  2. package/esm2020/lib/admin/form/workflow/workflow.component.mjs +52 -19
  3. package/esm2020/lib/browse/expanded-item/expanded-item.component.mjs +3 -5
  4. package/esm2020/lib/compose/trace/flow.component.mjs +5 -6
  5. package/esm2020/lib/compose/trace/trace.component.mjs +7 -11
  6. package/esm2020/lib/core/models.mjs +1 -1
  7. package/esm2020/lib/cube/grid/spreadsheet.component.mjs +2 -1
  8. package/esm2020/lib/dashboard/cube/compare.widget.mjs +6 -5
  9. package/esm2020/lib/dashboard/score/compare-groups.widget.mjs +206 -0
  10. package/esm2020/lib/dashboard/score/peers-performance.widget.mjs +2 -2
  11. package/esm2020/lib/dashboard/score/pending-results.widget.mjs +5 -9
  12. package/esm2020/lib/modules/chart.module.mjs +10 -10
  13. package/esm2020/lib/modules/circular-gauge.module.mjs +1 -1
  14. package/esm2020/lib/modules/dayjs.module.mjs +41 -0
  15. package/esm2020/lib/modules/diagram.module.mjs +1 -1
  16. package/esm2020/lib/modules/gantt.module.mjs +4 -3
  17. package/esm2020/lib/modules/pivot.module.mjs +1 -1
  18. package/esm2020/lib/reports/cube/usage-base.mjs +2 -2
  19. package/esm2020/lib/reports/cube/usage-chart.component.mjs +11 -7
  20. package/esm2020/lib/reports/cube/usage-pivot.component.mjs +21 -3
  21. package/esm2020/lib/reports/report.mobile.component.mjs +3 -3
  22. package/esm2020/lib/reports/report.pane.component.mjs +3 -3
  23. package/esm2020/lib/shared.module.mjs +14 -32
  24. package/esm2020/lib/system.module.mjs +2 -1
  25. package/esm2020/public-api.mjs +2 -2
  26. package/fesm2015/bizdoc-core.mjs +203 -135
  27. package/fesm2015/bizdoc-core.mjs.map +1 -1
  28. package/fesm2020/bizdoc-core.mjs +203 -136
  29. package/fesm2020/bizdoc-core.mjs.map +1 -1
  30. package/lib/admin/form/workflow/workflow.component.d.ts +9 -6
  31. package/lib/core/models.d.ts +1 -0
  32. package/lib/dashboard/score/{compare-departments.widget.d.ts → compare-groups.widget.d.ts} +3 -3
  33. package/lib/dashboard/score/pending-results.widget.d.ts +0 -1
  34. package/lib/modules/chart.module.d.ts +1 -1
  35. package/lib/modules/dayjs.module.d.ts +6 -0
  36. package/lib/reports/cube/usage-base.d.ts +1 -1
  37. package/lib/reports/cube/usage-pivot.component.d.ts +5 -1
  38. package/lib/shared.module.d.ts +21 -19
  39. package/lib/system.module.d.ts +1 -0
  40. package/package.json +1 -1
  41. package/public-api.d.ts +1 -1
  42. package/esm2020/lib/dashboard/score/compare-departments.widget.mjs +0 -206
@@ -83,14 +83,15 @@ let CubeCompareWidget = CubeCompareWidget_1 = class CubeCompareWidget {
83
83
  this.primaryYAxis = {
84
84
  skeleton: 'duration',
85
85
  labelStyle: {
86
- size: '0px'
87
- }, visible: true,
86
+ //size: '0px'
87
+ },
88
+ labelFormat: '',
88
89
  titleStyle: {
89
90
  fontFamily: FONT_FAMILY
90
91
  },
91
92
  title: this._translate.get('Duration'),
92
- lineStyle: { width: 0 },
93
- minorTickLines: { width: 0 }
93
+ //lineStyle: { width: 0 },
94
+ //minorTickLines: { width: 0 }
94
95
  };
95
96
  this.margin = {
96
97
  bottom: 0
@@ -211,4 +212,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.5", ngImpor
211
212
  type: ViewChild,
212
213
  args: [ChartComponent]
213
214
  }] } });
214
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"compare.widget.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/dashboard/cube/compare.widget.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnDestroy, ViewChild, ElementRef } from \"@angular/core\";\r\nimport { Chart, AxisModel, CrosshairSettingsModel, TooltipSettingsModel, SeriesModel, LegendSeriesModel, RowModel, LineSeriesService, CrosshairService, ColumnSeriesService, MarginModel, ZoomSettingsModel, ITooltipRenderEventArgs, ChartAreaModel, ChartComponent, ISharedTooltipRenderEventArgs } from \"@syncfusion/ej2-angular-charts\";\r\nimport { Subject } from \"rxjs\";\r\nimport { takeUntil } from \"rxjs/operators\";\r\nimport dayjs from 'dayjs';\r\nimport { WidgetComponent } from \"../../core/base\";\r\nimport { BizDoc } from \"../../core/decorators\";\r\nimport { TranslateService } from \"../../core/translate.service\";\r\nimport { SessionService } from \"../../core/session.service\";\r\nimport { DatasourceService } from \"../../core/datasource.service\";\r\nimport { WidgetRef } from \"../widget-ref\";\r\nimport { FONT_FAMILY } from \"../../core/colors\";\r\n/** */\r\n@Component({\r\n  //templateUrl: './compare.widget.html',\r\n  template: '',\r\n  providers: [LineSeriesService, CrosshairService, ColumnSeriesService],\r\n  host: {\r\n    '[id]': 'id',\r\n    dir: 'ltr'\r\n  }\r\n})\r\n@BizDoc({\r\n  selector: 'bizdoc-cube-compare'\r\n})\r\nexport class CubeCompareWidget implements WidgetComponent<Model[]>, OnDestroy {\r\n  static nextId = 0;\r\n  readonly id = `cube-compare-${CubeCompareWidget.nextId++}`;\r\n  palettes = this._session.accentPalette;\r\n  @ViewChild(ChartComponent) chart: Chart;\r\n  theme: 'Material' | 'MaterialDark' = this._session.theme.dark ? 'MaterialDark' : 'Material'\r\n  readonly enableRtl = this._session.inverse;\r\n  readonly rows: RowModel[] = [\r\n    {\r\n      height: '15%'\r\n    }, {\r\n      height: '85%'\r\n    }\r\n  ];\r\n  readonly axes: AxisModel[] = [{\r\n    name: 'primary',\r\n    labelStyle: { size: '0px' },\r\n    rowIndex: 1\r\n  }, {\r\n    name: 'volume',\r\n    rowIndex: 0,\r\n    majorGridLines: { width: 0 }, lineStyle: { width: 0 },\r\n    labelStyle: { size: '0px' },\r\n    majorTickLines: { width: 0 }\r\n  }];\r\n  readonly chartArea: ChartAreaModel = {\r\n    border: {\r\n      width: 0\r\n    }\r\n  };\r\n  readonly zoomSettings: ZoomSettingsModel = {\r\n    mode: 'X',\r\n    enableMouseWheelZooming: true,\r\n    enablePinchZooming: true,\r\n    toolbarItems: [],\r\n    enableSelectionZooming: false,\r\n    enableScrollbar: true\r\n  };\r\n  readonly primaryXAxis: AxisModel = {\r\n    valueType: 'DateTime',\r\n    labelFormat: 'MMM dd',\r\n    labelStyle: {\r\n      fontFamily: FONT_FAMILY\r\n    },\r\n    labelIntersectAction: 'Hide',\r\n    majorGridLines: { width: 0 }\r\n  };\r\n  readonly crosshair: CrosshairSettingsModel = {\r\n    enable: true,\r\n    lineType: 'Vertical'\r\n  };\r\n  readonly tooltip: TooltipSettingsModel = {\r\n    enable: true, shared: true, textStyle: {\r\n      fontFamily: FONT_FAMILY\r\n    },\r\n  };\r\n  readonly legend: LegendSeriesModel = {\r\n    visible: true,\r\n    isInversed: this._session.inverse,\r\n    textStyle: {\r\n      fontFamily: FONT_FAMILY\r\n    },\r\n  };\r\n  readonly primaryYAxis: AxisModel = {\r\n    skeleton: 'duration',\r\n    labelStyle: {\r\n      size: '0px'\r\n    }, visible: true,\r\n    titleStyle: {\r\n      fontFamily: FONT_FAMILY\r\n    },\r\n    title: this._translate.get('Duration'),\r\n    lineStyle: { width: 0 },\r\n    minorTickLines: { width: 0 }\r\n  };\r\n  readonly margin: MarginModel = {\r\n    bottom: 0\r\n  };\r\n  series: SeriesModel[];\r\n  height: string;\r\n  private readonly _destroy = new Subject<void>();\r\n  constructor(private _translate: TranslateService,\r\n    private _widgetRef: WidgetRef,\r\n    private _elementRef: ElementRef,\r\n    private _type: DatasourceService,\r\n    private _session: SessionService) {\r\n    _session.themeChange.pipe(takeUntil(this._destroy)).subscribe(t => {\r\n      this.theme = t.dark ? 'MaterialDark' : 'Material';\r\n      this.palettes = _session.accentPalette;\r\n      this._draw();\r\n    });\r\n    _widgetRef.resize.subscribe(d => {\r\n      this.height = `${d.height}px`;\r\n      if (this.chart) this.chart.height = this.height;\r\n    });\r\n  }\r\n  async onBind(data: Model[]) {\r\n    await this._prepare(data);\r\n    this._draw();\r\n  }\r\n  private _draw() {\r\n    this.chart && this.chart.destroy();\r\n    this.chart = new Chart({\r\n      axes: this.axes,\r\n      series: this.series,\r\n      height: this.height,\r\n      rows: this.rows,\r\n      legendSettings: this.legend,\r\n      crosshair: this.crosshair,\r\n      tooltip: this.tooltip,\r\n      background: 'transparent',\r\n      chartArea: this.chartArea,\r\n      primaryXAxis: this.primaryXAxis,\r\n      primaryYAxis: this.primaryYAxis,\r\n      theme: this.theme,\r\n      margin: this.margin,\r\n      useGroupingSeparator: true,\r\n      palettes: this.palettes,\r\n      zoomSettings: this.zoomSettings,\r\n      sharedTooltipRender: this.sharedTooltipRender.bind(this),\r\n    }, this._elementRef.nativeElement);\r\n\r\n  }\r\n  sharedTooltipRender(evt: ISharedTooltipRenderEventArgs) {\r\n    evt.data.forEach((d, i) => {\r\n      if (evt.series[d.seriesIndex].yName !== 'count')\r\n        evt.text[i] = `${d.seriesName} : <b>${dayjs.duration(d.pointY as any, 's').humanize()}</b>`;\r\n    });\r\n  }\r\n  private async _prepare(data: Model[]) {\r\n    const indicatorData: Volume[] = [], series: SeriesModel[] = [];\r\n    for (var item of data) {\r\n      item.points.forEach(p => {\r\n        const date = p.date = new Date(p.date),\r\n          indicator = indicatorData.find(i => i.date.valueOf() === date.valueOf());\r\n        if (indicator)\r\n          indicator.count += p.count;\r\n        else\r\n          indicatorData.push({ count: p.count, date });\r\n      });\r\n      const cube = this._session.profile.cubes.find(c => c.name === this._widgetRef.options.cube || this._widgetRef.options.cube == null);\r\n      const axis = cube.axes.find(a => a.name === this._widgetRef.options.series);\r\n      const title = await this._type.get(axis.dataType, item.series).toPromise();\r\n      series.push({\r\n        type: 'Line',\r\n        xName: 'date',\r\n        yName: 'duration',\r\n        yAxisName: 'primary',\r\n        name: title,\r\n        dataSource: item.points,\r\n        marker: {\r\n          width: 6,\r\n          height: 6,\r\n          visible: false\r\n        }\r\n      } as SeriesModel);\r\n    }\r\n    series.push({\r\n      type: 'Column',\r\n      xName: 'date',\r\n      yName: 'count',\r\n      name: this._translate.get('Volume'),\r\n      dataSource: indicatorData,\r\n      yAxisName: 'volume',\r\n      marker: {\r\n        width: 0,\r\n        height: 0,\r\n        visible: false\r\n      }\r\n    });\r\n    this.series = series;\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.chart && this.chart.destroy();\r\n    this._destroy.next();\r\n    this._destroy.complete();\r\n  }\r\n}\r\n\r\ninterface Model {\r\n  points: Point[];\r\n  series: string;\r\n}\r\ninterface Point {\r\n  date: Date;\r\n  duration: number;\r\n  count: number;\r\n}\r\ninterface Volume {\r\n  date: Date;\r\n  count: number;\r\n}\r\n"]}
215
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"compare.widget.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/dashboard/cube/compare.widget.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnDestroy, ViewChild, ElementRef } from \"@angular/core\";\r\nimport { Chart, AxisModel, CrosshairSettingsModel, TooltipSettingsModel, SeriesModel, LegendSeriesModel, RowModel, LineSeriesService, CrosshairService, ColumnSeriesService, MarginModel, ZoomSettingsModel, ITooltipRenderEventArgs, ChartAreaModel, ChartComponent, ISharedTooltipRenderEventArgs } from \"@syncfusion/ej2-angular-charts\";\r\nimport { Subject } from \"rxjs\";\r\nimport { takeUntil } from \"rxjs/operators\";\r\nimport dayjs from 'dayjs';\r\nimport { WidgetComponent } from \"../../core/base\";\r\nimport { BizDoc } from \"../../core/decorators\";\r\nimport { TranslateService } from \"../../core/translate.service\";\r\nimport { SessionService } from \"../../core/session.service\";\r\nimport { DatasourceService } from \"../../core/datasource.service\";\r\nimport { WidgetRef } from \"../widget-ref\";\r\nimport { FONT_FAMILY } from \"../../core/colors\";\r\n/** */\r\n@Component({\r\n  //templateUrl: './compare.widget.html',\r\n  template: '',\r\n  providers: [LineSeriesService, CrosshairService, ColumnSeriesService],\r\n  host: {\r\n    '[id]': 'id',\r\n    dir: 'ltr'\r\n  }\r\n})\r\n@BizDoc({\r\n  selector: 'bizdoc-cube-compare'\r\n})\r\nexport class CubeCompareWidget implements WidgetComponent<Model[]>, OnDestroy {\r\n  static nextId = 0;\r\n  readonly id = `cube-compare-${CubeCompareWidget.nextId++}`;\r\n  palettes = this._session.accentPalette;\r\n  @ViewChild(ChartComponent) chart: Chart;\r\n  theme: 'Material' | 'MaterialDark' = this._session.theme.dark ? 'MaterialDark' : 'Material'\r\n  readonly enableRtl = this._session.inverse;\r\n  readonly rows: RowModel[] = [\r\n    {\r\n      height: '15%'\r\n    }, {\r\n      height: '85%'\r\n    }\r\n  ];\r\n  readonly axes: AxisModel[] = [{\r\n    name: 'primary',\r\n    labelStyle: { size: '0px' },\r\n    rowIndex: 1\r\n  }, {\r\n    name: 'volume',\r\n    rowIndex: 0,\r\n    majorGridLines: { width: 0 }, lineStyle: { width: 0 },\r\n    labelStyle: { size: '0px' },\r\n    majorTickLines: { width: 0 }\r\n  }];\r\n  readonly chartArea: ChartAreaModel = {\r\n    border: {\r\n      width: 0\r\n    }\r\n  };\r\n  readonly zoomSettings: ZoomSettingsModel = {\r\n    mode: 'X',\r\n    enableMouseWheelZooming: true,\r\n    enablePinchZooming: true,\r\n    toolbarItems: [],\r\n    enableSelectionZooming: false,\r\n    enableScrollbar: true\r\n  };\r\n  readonly primaryXAxis: AxisModel = {\r\n    valueType: 'DateTime',\r\n    labelFormat: 'MMM dd',\r\n    labelStyle: {\r\n      fontFamily: FONT_FAMILY\r\n    },\r\n    labelIntersectAction: 'Hide',\r\n    majorGridLines: { width: 0 }\r\n  };\r\n  readonly crosshair: CrosshairSettingsModel = {\r\n    enable: true,\r\n    lineType: 'Vertical'\r\n  };\r\n  readonly tooltip: TooltipSettingsModel = {\r\n    enable: true, shared: true, textStyle: {\r\n      fontFamily: FONT_FAMILY\r\n    },\r\n  };\r\n  readonly legend: LegendSeriesModel = {\r\n    visible: true,\r\n    isInversed: this._session.inverse,\r\n    textStyle: {\r\n      fontFamily: FONT_FAMILY\r\n    },\r\n  };\r\n  readonly primaryYAxis: AxisModel = {\r\n    skeleton: 'duration',\r\n    labelStyle: {\r\n      //size: '0px'\r\n    },\r\n    labelFormat: '',\r\n    titleStyle: {\r\n      fontFamily: FONT_FAMILY\r\n    },\r\n    title: this._translate.get('Duration'),\r\n    //lineStyle: { width: 0 },\r\n    //minorTickLines: { width: 0 }\r\n  };\r\n  readonly margin: MarginModel = {\r\n    bottom: 0\r\n  };\r\n  series: SeriesModel[];\r\n  height: string;\r\n  private readonly _destroy = new Subject<void>();\r\n  constructor(private _translate: TranslateService,\r\n    private _widgetRef: WidgetRef,\r\n    private _elementRef: ElementRef,\r\n    private _type: DatasourceService,\r\n    private _session: SessionService) {\r\n    _session.themeChange.pipe(takeUntil(this._destroy)).subscribe(t => {\r\n      this.theme = t.dark ? 'MaterialDark' : 'Material';\r\n      this.palettes = _session.accentPalette;\r\n      this._draw();\r\n    });\r\n    _widgetRef.resize.subscribe(d => {\r\n      this.height = `${d.height}px`;\r\n      if (this.chart) this.chart.height = this.height;\r\n    });\r\n  }\r\n  async onBind(data: Model[]) {\r\n    await this._prepare(data);\r\n    this._draw();\r\n  }\r\n  private _draw() {\r\n    this.chart && this.chart.destroy();\r\n    this.chart = new Chart({\r\n      axes: this.axes,\r\n      series: this.series,\r\n      height: this.height,\r\n      rows: this.rows,\r\n      legendSettings: this.legend,\r\n      crosshair: this.crosshair,\r\n      tooltip: this.tooltip,\r\n      background: 'transparent',\r\n      chartArea: this.chartArea,\r\n      primaryXAxis: this.primaryXAxis,\r\n      primaryYAxis: this.primaryYAxis,\r\n      theme: this.theme,\r\n      margin: this.margin,\r\n      useGroupingSeparator: true,\r\n      palettes: this.palettes,\r\n      zoomSettings: this.zoomSettings,\r\n      sharedTooltipRender: this.sharedTooltipRender.bind(this),\r\n    }, this._elementRef.nativeElement);\r\n\r\n  }\r\n  sharedTooltipRender(evt: ISharedTooltipRenderEventArgs) {\r\n    evt.data.forEach((d, i) => {\r\n      if (evt.series[d.seriesIndex].yName !== 'count')\r\n        evt.text[i] = `${d.seriesName} : <b>${dayjs.duration(d.pointY as any, 's').humanize()}</b>`;\r\n    });\r\n  }\r\n  private async _prepare(data: Model[]) {\r\n    const indicatorData: Volume[] = [], series: SeriesModel[] = [];\r\n    for (var item of data) {\r\n      item.points.forEach(p => {\r\n        const date = p.date = new Date(p.date),\r\n          indicator = indicatorData.find(i => i.date.valueOf() === date.valueOf());\r\n        if (indicator)\r\n          indicator.count += p.count;\r\n        else\r\n          indicatorData.push({ count: p.count, date });\r\n      });\r\n      const cube = this._session.profile.cubes.find(c => c.name === this._widgetRef.options.cube || this._widgetRef.options.cube == null);\r\n      const axis = cube.axes.find(a => a.name === this._widgetRef.options.series);\r\n      const title = await this._type.get(axis.dataType, item.series).toPromise();\r\n      series.push({\r\n        type: 'Line',\r\n        xName: 'date',\r\n        yName: 'duration',\r\n        yAxisName: 'primary',\r\n        name: title,\r\n        dataSource: item.points,\r\n        marker: {\r\n          width: 6,\r\n          height: 6,\r\n          visible: false\r\n        }\r\n      } as SeriesModel);\r\n    }\r\n    series.push({\r\n      type: 'Column',\r\n      xName: 'date',\r\n      yName: 'count',\r\n      name: this._translate.get('Volume'),\r\n      dataSource: indicatorData,\r\n      yAxisName: 'volume',\r\n      marker: {\r\n        width: 0,\r\n        height: 0,\r\n        visible: false\r\n      }\r\n    });\r\n    this.series = series;\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.chart && this.chart.destroy();\r\n    this._destroy.next();\r\n    this._destroy.complete();\r\n  }\r\n}\r\n\r\ninterface Model {\r\n  points: Point[];\r\n  series: string;\r\n}\r\ninterface Point {\r\n  date: Date;\r\n  duration: number;\r\n  count: number;\r\n}\r\ninterface Volume {\r\n  date: Date;\r\n  count: number;\r\n}\r\n"]}
@@ -0,0 +1,206 @@
1
+ var CompareGroupsWidget_1;
2
+ import { __decorate } from "tslib";
3
+ import { Component, ViewChild } from "@angular/core";
4
+ import { Chart, LineSeriesService, CrosshairService, ColumnSeriesService, ChartComponent } from "@syncfusion/ej2-angular-charts";
5
+ import { BizDoc } from "../../core/decorators";
6
+ import { Subject } from "rxjs";
7
+ import { takeUntil } from "rxjs/operators";
8
+ import dayjs from 'dayjs';
9
+ import { FONT_FAMILY } from "../../core/colors";
10
+ import * as i0 from "@angular/core";
11
+ import * as i1 from "../../core/translate.service";
12
+ import * as i2 from "../widget-ref";
13
+ import * as i3 from "../../core/session.service";
14
+ /** */
15
+ let CompareGroupsWidget = CompareGroupsWidget_1 = class CompareGroupsWidget {
16
+ constructor(_translate, widgetRef, _elementRef, _session) {
17
+ this._translate = _translate;
18
+ this._elementRef = _elementRef;
19
+ this._session = _session;
20
+ this.id = `groups-compare-${CompareGroupsWidget_1.nextId++}`;
21
+ this.palettes = this._session.accentPalette;
22
+ this.theme = this._session.theme.dark ? 'MaterialDark' : 'Material';
23
+ this.enableRtl = this._session.inverse;
24
+ this.rows = [
25
+ {
26
+ height: '15%'
27
+ }, {
28
+ height: '85%'
29
+ }
30
+ ];
31
+ this.axes = [{
32
+ name: 'primary',
33
+ labelStyle: { size: '0px' },
34
+ rowIndex: 1
35
+ }, {
36
+ name: 'volume',
37
+ rowIndex: 0,
38
+ majorGridLines: { width: 0 }, lineStyle: { width: 0 },
39
+ labelStyle: { size: '0px' },
40
+ majorTickLines: { width: 0 }
41
+ }];
42
+ this.chartArea = {
43
+ border: {
44
+ width: 0
45
+ }
46
+ };
47
+ this.zoomSettings = {
48
+ mode: 'X',
49
+ enableMouseWheelZooming: true,
50
+ enablePinchZooming: true,
51
+ toolbarItems: [],
52
+ enableSelectionZooming: false,
53
+ enableScrollbar: true
54
+ };
55
+ this.primaryXAxis = {
56
+ valueType: 'DateTime',
57
+ labelFormat: 'MMM dd',
58
+ labelStyle: {
59
+ fontFamily: FONT_FAMILY
60
+ },
61
+ labelIntersectAction: 'Hide',
62
+ majorGridLines: { width: 0 }
63
+ };
64
+ this.crosshair = {
65
+ enable: true,
66
+ lineType: 'Vertical'
67
+ };
68
+ this.tooltip = {
69
+ enable: true, shared: true, textStyle: {
70
+ fontFamily: FONT_FAMILY
71
+ },
72
+ };
73
+ this.legend = {
74
+ visible: true,
75
+ isInversed: this._session.inverse,
76
+ textStyle: {
77
+ fontFamily: FONT_FAMILY
78
+ },
79
+ };
80
+ this.primaryYAxis = {
81
+ skeleton: 'duration',
82
+ labelStyle: {
83
+ size: '0px'
84
+ },
85
+ title: this._translate.get('Duration'),
86
+ lineStyle: { width: 0 },
87
+ minorTickLines: { width: 0 }
88
+ };
89
+ this.margin = {
90
+ bottom: 0
91
+ };
92
+ this._destroy = new Subject();
93
+ _session.themeChange.pipe(takeUntil(this._destroy)).subscribe(t => {
94
+ this.theme = t.dark ? 'MaterialDark' : 'Material';
95
+ this.palettes = _session.accentPalette;
96
+ this._draw();
97
+ });
98
+ widgetRef.resize.subscribe(d => {
99
+ this.height = `${d.height}px`;
100
+ if (this.chart)
101
+ this.chart.height = this.height;
102
+ });
103
+ }
104
+ onBind(data) {
105
+ this._prepare(data);
106
+ this.data = data;
107
+ this._draw();
108
+ }
109
+ _draw() {
110
+ this.chart && this.chart.destroy();
111
+ this.chart = new Chart({
112
+ axes: this.axes,
113
+ series: this.series,
114
+ height: this.height,
115
+ rows: this.rows,
116
+ legendSettings: this.legend,
117
+ crosshair: this.crosshair,
118
+ tooltip: this.tooltip,
119
+ background: 'transparent',
120
+ chartArea: this.chartArea,
121
+ primaryXAxis: this.primaryXAxis,
122
+ primaryYAxis: this.primaryYAxis,
123
+ theme: this.theme,
124
+ margin: this.margin,
125
+ useGroupingSeparator: true,
126
+ palettes: this.palettes,
127
+ zoomSettings: this.zoomSettings,
128
+ sharedTooltipRender: this.sharedTooltipRender.bind(this),
129
+ }, this._elementRef.nativeElement);
130
+ }
131
+ sharedTooltipRender(evt) {
132
+ evt.data.forEach((d, i) => {
133
+ if (evt.series[d.seriesIndex].yName !== 'count')
134
+ evt.text[i] = `${d.seriesName} : <b>${dayjs.duration(d.pointY, 's').humanize()}</b>`;
135
+ });
136
+ }
137
+ _prepare(data) {
138
+ const indicatorData = [], series = data.map(s => {
139
+ s.points.forEach(p => {
140
+ const date = p.date = new Date(p.date), indicator = indicatorData.find(i => i.date.valueOf() === date.valueOf());
141
+ if (indicator)
142
+ indicator.count += p.count;
143
+ else
144
+ indicatorData.push({ count: p.count, date });
145
+ });
146
+ const serie = {
147
+ type: 'Line',
148
+ xName: 'date',
149
+ yName: 'duration',
150
+ yAxisName: 'primary',
151
+ name: s.title,
152
+ dataSource: s.points,
153
+ marker: {
154
+ width: 6,
155
+ height: 6,
156
+ visible: false
157
+ }
158
+ };
159
+ return serie;
160
+ });
161
+ series.push({
162
+ type: 'Column',
163
+ xName: 'date',
164
+ yName: 'count',
165
+ name: this._translate.get('Volume'),
166
+ dataSource: indicatorData,
167
+ yAxisName: 'volume',
168
+ marker: {
169
+ width: 0,
170
+ height: 0,
171
+ visible: false
172
+ }
173
+ });
174
+ this.series = series;
175
+ }
176
+ ngOnDestroy() {
177
+ this.chart && this.chart.destroy();
178
+ this._destroy.next();
179
+ this._destroy.complete();
180
+ }
181
+ };
182
+ CompareGroupsWidget.nextId = 0;
183
+ CompareGroupsWidget.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.5", ngImport: i0, type: CompareGroupsWidget, deps: [{ token: i1.TranslateService }, { token: i2.WidgetRef }, { token: i0.ElementRef }, { token: i3.SessionService }], target: i0.ɵɵFactoryTarget.Component });
184
+ CompareGroupsWidget.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.5", type: CompareGroupsWidget, selector: "ng-component", host: { attributes: { "dir": "ltr" }, properties: { "id": "id" } }, providers: [LineSeriesService, CrosshairService, ColumnSeriesService], viewQueries: [{ propertyName: "chart", first: true, predicate: ChartComponent, descendants: true }], ngImport: i0, template: '', isInline: true });
185
+ CompareGroupsWidget = CompareGroupsWidget_1 = __decorate([
186
+ BizDoc({
187
+ selector: 'bizdoc-compare-groups'
188
+ })
189
+ ], CompareGroupsWidget);
190
+ export { CompareGroupsWidget };
191
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.5", ngImport: i0, type: CompareGroupsWidget, decorators: [{
192
+ type: Component,
193
+ args: [{
194
+ //templateUrl: './compare-groups.widget.html',
195
+ template: '',
196
+ providers: [LineSeriesService, CrosshairService, ColumnSeriesService],
197
+ host: {
198
+ '[id]': 'id',
199
+ dir: 'ltr'
200
+ }
201
+ }]
202
+ }], ctorParameters: function () { return [{ type: i1.TranslateService }, { type: i2.WidgetRef }, { type: i0.ElementRef }, { type: i3.SessionService }]; }, propDecorators: { chart: [{
203
+ type: ViewChild,
204
+ args: [ChartComponent]
205
+ }] } });
206
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"compare-groups.widget.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/dashboard/score/compare-groups.widget.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnDestroy, ViewChild, ElementRef } from \"@angular/core\";\r\nimport { Chart, AxisModel, CrosshairSettingsModel, TooltipSettingsModel, SeriesModel, LegendSeriesModel, RowModel, LineSeriesService, CrosshairService, ColumnSeriesService, MarginModel, ZoomSettingsModel, ITooltipRenderEventArgs, ChartAreaModel, ChartComponent, ISharedTooltipRenderEventArgs } from \"@syncfusion/ej2-angular-charts\";\r\nimport { WidgetComponent } from \"../../core/base\";\r\nimport { BizDoc } from \"../../core/decorators\";\r\nimport { TranslateService } from \"../../core/translate.service\";\r\nimport { SessionService } from \"../../core/session.service\";\r\nimport { Subject } from \"rxjs\";\r\nimport { takeUntil } from \"rxjs/operators\";\r\nimport dayjs from 'dayjs';\r\nimport { WidgetRef } from \"../widget-ref\";\r\nimport { FONT_FAMILY } from \"../../core/colors\";\r\n/** */\r\n@Component({\r\n  //templateUrl: './compare-groups.widget.html',\r\n  template: '',\r\n  providers: [LineSeriesService, CrosshairService, ColumnSeriesService],\r\n  host: {\r\n    '[id]': 'id',\r\n    dir: 'ltr'\r\n  }\r\n})\r\n@BizDoc({\r\n  selector: 'bizdoc-compare-groups'\r\n})\r\nexport class CompareGroupsWidget implements WidgetComponent<Department[]>, OnDestroy {\r\n  static nextId = 0;\r\n  readonly id = `groups-compare-${CompareGroupsWidget.nextId++}`;\r\n  palettes = this._session.accentPalette;\r\n  @ViewChild(ChartComponent) chart: Chart;\r\n  theme: 'Material' | 'MaterialDark' = this._session.theme.dark ? 'MaterialDark' : 'Material'\r\n  readonly enableRtl = this._session.inverse;\r\n  readonly rows: RowModel[] = [\r\n    {\r\n      height: '15%'\r\n    }, {\r\n      height: '85%'\r\n    }\r\n  ];\r\n  readonly axes: AxisModel[] = [{\r\n    name: 'primary',\r\n    labelStyle: { size: '0px' },\r\n    rowIndex: 1\r\n  }, {\r\n    name: 'volume',\r\n    rowIndex: 0,\r\n    majorGridLines: { width: 0 }, lineStyle: { width: 0 },\r\n    labelStyle: { size: '0px' },\r\n    majorTickLines: { width: 0 }\r\n  }];\r\n  readonly chartArea: ChartAreaModel = {\r\n    border: {\r\n      width: 0\r\n    }\r\n  };\r\n  readonly zoomSettings: ZoomSettingsModel = {\r\n    mode: 'X',\r\n    enableMouseWheelZooming: true,\r\n    enablePinchZooming: true,\r\n    toolbarItems: [],\r\n    enableSelectionZooming: false,\r\n    enableScrollbar: true\r\n  };\r\n  readonly primaryXAxis: AxisModel = {\r\n    valueType: 'DateTime',\r\n    labelFormat: 'MMM dd',\r\n    labelStyle: {\r\n      fontFamily: FONT_FAMILY\r\n    },\r\n    labelIntersectAction: 'Hide',\r\n    majorGridLines: { width: 0 }\r\n  };\r\n  readonly crosshair: CrosshairSettingsModel = {\r\n    enable: true,\r\n    lineType: 'Vertical'\r\n  };\r\n  readonly tooltip: TooltipSettingsModel = {\r\n    enable: true, shared: true, textStyle: {\r\n      fontFamily: FONT_FAMILY\r\n    },\r\n  };\r\n  readonly legend: LegendSeriesModel = {\r\n    visible: true,\r\n    isInversed: this._session.inverse,\r\n    textStyle: {\r\n      fontFamily: FONT_FAMILY\r\n    },\r\n  };\r\n  readonly primaryYAxis: AxisModel = {\r\n    skeleton: 'duration',\r\n    labelStyle: {\r\n      size: '0px'\r\n    },\r\n    title: this._translate.get('Duration'),\r\n    lineStyle: { width: 0 },\r\n    minorTickLines: { width: 0 }\r\n  };\r\n  readonly margin: MarginModel = {\r\n    bottom: 0\r\n  };\r\n  series: SeriesModel[];\r\n  height: string;\r\n  private readonly _destroy = new Subject<void>();\r\n  data: Department[];\r\n  constructor(private _translate: TranslateService,\r\n    widgetRef: WidgetRef,\r\n    private _elementRef: ElementRef,\r\n    private _session: SessionService) {\r\n    _session.themeChange.pipe(takeUntil(this._destroy)).subscribe(t => {\r\n      this.theme = t.dark ? 'MaterialDark' : 'Material';\r\n      this.palettes = _session.accentPalette;\r\n      this._draw();\r\n    });\r\n    widgetRef.resize.subscribe(d => {\r\n      this.height = `${d.height}px`;\r\n      if (this.chart) this.chart.height = this.height;\r\n    });\r\n  }\r\n  onBind(data: Department[]) {\r\n    this._prepare(data);\r\n    this.data = data;\r\n    this._draw();\r\n  }\r\n  private _draw() {\r\n    this.chart && this.chart.destroy();\r\n    this.chart = new Chart({\r\n      axes: this.axes,\r\n      series: this.series,\r\n      height: this.height,\r\n      rows: this.rows,\r\n      legendSettings: this.legend,\r\n      crosshair: this.crosshair,\r\n      tooltip: this.tooltip,\r\n      background: 'transparent',\r\n      chartArea: this.chartArea,\r\n      primaryXAxis: this.primaryXAxis,\r\n      primaryYAxis: this.primaryYAxis,\r\n      theme: this.theme,\r\n      margin: this.margin,\r\n      useGroupingSeparator: true,\r\n      palettes: this.palettes,\r\n      zoomSettings: this.zoomSettings,\r\n      sharedTooltipRender: this.sharedTooltipRender.bind(this),\r\n    }, this._elementRef.nativeElement);\r\n\r\n  }\r\n  sharedTooltipRender(evt: ISharedTooltipRenderEventArgs) {\r\n    evt.data.forEach((d, i) => {\r\n      if (evt.series[d.seriesIndex].yName !== 'count')\r\n        evt.text[i] = `${d.seriesName} : <b>${dayjs.duration(d.pointY as any, 's').humanize()}</b>`;\r\n    });\r\n  }\r\n  private _prepare(data: Department[]) {\r\n    const indicatorData: Volume[] = [], series = data.map(s => {\r\n      s.points.forEach(p => {\r\n        const date = p.date = new Date(p.date),\r\n          indicator = indicatorData.find(i => i.date.valueOf() === date.valueOf());\r\n        if (indicator)\r\n          indicator.count += p.count;\r\n        else\r\n          indicatorData.push({ count: p.count, date });\r\n      });\r\n      const serie: SeriesModel = {\r\n        type: 'Line',\r\n        xName: 'date',\r\n        yName: 'duration',\r\n        yAxisName: 'primary',\r\n        name: s.title,\r\n        dataSource: s.points,\r\n        marker: {\r\n          width: 6,\r\n          height: 6,\r\n          visible: false\r\n        }\r\n      };\r\n      return serie;\r\n    });\r\n    series.push({\r\n      type: 'Column',\r\n      xName: 'date',\r\n      yName: 'count',\r\n      name: this._translate.get('Volume'),\r\n      dataSource: indicatorData,\r\n      yAxisName: 'volume',\r\n      marker: {\r\n        width: 0,\r\n        height: 0,\r\n        visible: false\r\n      }\r\n    });\r\n    this.series = series;\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.chart && this.chart.destroy();\r\n    this._destroy.next();\r\n    this._destroy.complete();\r\n  }\r\n}\r\n\r\ninterface Department {\r\n  points: Point[];\r\n  title: string;\r\n}\r\ninterface Point {\r\n  date: Date;\r\n  duration: number;\r\n  count: number;\r\n}\r\ninterface Volume {\r\n  date: Date;\r\n  count: number;\r\n}\r\n"]}
@@ -230,7 +230,7 @@ PeersPerformanceWidget.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", v
230
230
  PeersPerformanceWidget.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.5", type: PeersPerformanceWidget, selector: "ng-component", host: { attributes: { "dir": "ltr" }, properties: { "id": "this.id" }, styleAttribute: "display: block" }, viewQueries: [{ propertyName: "gauge", first: true, predicate: CircularGaugeComponent, descendants: true }], ngImport: i0, template: '', isInline: true });
231
231
  PeersPerformanceWidget = PeersPerformanceWidget_1 = __decorate([
232
232
  BizDoc({
233
- selector: 'bizdoc-departmental-performance'
233
+ selector: 'bizdoc-peers-performance'
234
234
  })
235
235
  ], PeersPerformanceWidget);
236
236
  export { PeersPerformanceWidget };
@@ -250,4 +250,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.5", ngImpor
250
250
  type: ViewChild,
251
251
  args: [CircularGaugeComponent]
252
252
  }] } });
253
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"peers-performance.widget.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/dashboard/score/peers-performance.widget.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnDestroy, ViewChild, ElementRef, HostBinding } from \"@angular/core\";\r\nimport { Directionality } from \"@angular/cdk/bidi\";\r\nimport { DurationFormatPipe } from \"../../core/pipes/duration-format.pipe\";\r\nimport { CircularGauge, RangeModel, AnnotationModel, PointerModel, TickModel, LabelModel, LineModel, GaugeDirection, Annotations, ITooltipRenderEventArgs, TooltipSettingsModel, MarginModel, GaugeTooltip, CircularGaugeComponent } from \"@syncfusion/ej2-angular-circulargauge\";\r\nimport { LegendSettingsModel } from \"@syncfusion/ej2-circulargauge/src/circular-gauge/legend/legend-model\";\r\nimport dayjs from 'dayjs';\r\nimport { Subject, Observable, forkJoin } from \"rxjs\";\r\nimport { takeUntil, map } from \"rxjs/operators\";\r\nimport { BizDoc } from \"../../core/decorators\";\r\nimport { WidgetComponent } from \"../../core/base\";\r\nimport { AccountService } from \"../../core/account.service\";\r\nimport { SessionService } from \"../../core/session.service\";\r\nimport { TranslateService } from \"../../core/translate.service\";\r\nimport { WidgetRef } from \"../widget-ref\";\r\nimport { FONT_FAMILY } from \"../../core/colors\";\r\n\r\nCircularGauge.Inject(Annotations, GaugeTooltip);\r\n\r\nconst MAX_PEERS = 10;\r\n@Component({\r\n  template: '',\r\n  //templateUrl: 'peers-performance.widget.html',\r\n  host: {\r\n    style: 'display: block',\r\n    dir: 'ltr'\r\n  }\r\n})\r\n@BizDoc({\r\n  selector: 'bizdoc-departmental-performance'\r\n})\r\nexport class PeersPerformanceWidget implements WidgetComponent<PeerModel[]>, OnDestroy {\r\n  static nextId = 0;\r\n  @HostBinding()\r\n  readonly id = `peers-performance-${PeersPerformanceWidget.nextId++}`;\r\n  @ViewChild(CircularGaugeComponent) gauge: CircularGauge;\r\n  theme: 'Material' | 'MaterialDark' = this._session.theme.dark ? 'MaterialDark' : 'Material';\r\n  annotations: AnnotationModel[];\r\n  ranges: RangeModel[];\r\n  pointers: PointerModel[];\r\n  max = 0;\r\n  readonly direction: GaugeDirection = this._dir.value === 'ltr' ? 'ClockWise' : 'AntiClockWise';\r\n  readonly lineStyle: LineModel = { width: 0 };\r\n  readonly labelStyle: LabelModel = { font: { size: '0px' } };\r\n  readonly majorTicks: TickModel = { width: 0 };\r\n  readonly minorTicks: TickModel = { width: 0 };\r\n  readonly legendSettings: LegendSettingsModel = {\r\n    visible: true, position: 'Top', shape: 'Diamond', alignment: 'Center',\r\n    padding: 0,\r\n    margin: { top: 0, bottom: 20 },\r\n    location: { y: 0 },\r\n    textStyle: {\r\n      fontFamily: FONT_FAMILY\r\n    }\r\n  };\r\n  readonly tooltip: TooltipSettingsModel = {\r\n    enable: true, type: ['Range', 'Pointer'], textStyle: {\r\n      fontFamily: FONT_FAMILY\r\n    },\r\n    annotationSettings: {},\r\n    showAtMousePosition: false\r\n  };\r\n  readonly margin: MarginModel = { left: 0, top: 0, right: 0, bottom: 0 };\r\n  height: string;\r\n  width: string;\r\n  private _score: number;\r\n  private _standardHigh = 0;\r\n  private _standardLow = 0;\r\n  private _data: PeerModel[];\r\n  private readonly _destroy = new Subject<void>();\r\n  constructor(private _session: SessionService,\r\n    ref: WidgetRef,\r\n    private _elementRef: ElementRef,\r\n    private _service: AccountService,\r\n    private _dir: Directionality,\r\n    private _duration: DurationFormatPipe,\r\n    private _translate: TranslateService) {\r\n    _session.themeChange.pipe(takeUntil(this._destroy)).\r\n      subscribe(t => {\r\n        this.theme = t.dark ? 'MaterialDark' : 'Material';\r\n        this.gauge.theme = this.theme;\r\n        this._prepare();\r\n        this._refresh();\r\n        this._animate();\r\n      });\r\n    ref.resize.subscribe(d => {\r\n      this.height = `${d.height}px`;\r\n      this.width = `${d.width}px`;\r\n      if (this.gauge) {\r\n        this.gauge.height = this.height;\r\n        this.gauge.width = this.width;\r\n        this._animate();\r\n      }\r\n    });\r\n  }\r\n  onBind(data: PeerModel[]) {\r\n    this._decorare(data).subscribe(() => {\r\n      this._prepare();\r\n      if (!this.gauge) this._draw();\r\n      else this._refresh();\r\n      this._animate();\r\n    });\r\n  }\r\n  /**\r\n   * \r\n   * @param data\r\n   */\r\n  private _decorare(data: PeerModel[]): Observable<any> {\r\n    const observers: Observable<any>[] = [];\r\n    data.forEach(i => {\r\n      if (i.duration > this.max) this.max = i.duration;\r\n      if (i.userId === this._session.profile.userId) i.name = this._translate.get('You');\r\n      else {\r\n        const promise = this._service.get(i.userId).pipe(map(u =>\r\n          i.name = u.nick || u.name));\r\n        observers.push(promise);\r\n      }\r\n      if (i.standard) {\r\n        if (i.standard > this._standardHigh) this._standardHigh = i.standard;\r\n        if (this._standardLow === 0 || i.standard < this._standardLow) this._standardLow = i.standard;\r\n        if (i.standard > this.max) this.max = i.standard;\r\n      }\r\n      if (i.userId === this._session.profile.userId)\r\n        this._score = i.duration;\r\n    });\r\n    this._data = data.sort((i1, i2) => i1.duration < i2.duration ? 1 : -1).slice(0, MAX_PEERS);\r\n    return forkJoin(observers);\r\n  }\r\n  private _prepare() {\r\n    const step = Math.floor(70 / this._data.length), width = Math.min(15, Math.floor(80 / this._data.length / 2)), zero = 4 / 9;\r\n    let radius = 95;\r\n    const annotations: AnnotationModel[] = [];\r\n    const pointers: PointerModel[] = [];\r\n    let c = 0;\r\n    const palettes = this._session.accentPalette;\r\n    this._data.forEach((d, i) => {\r\n      pointers.push({\r\n        value: 0,\r\n        type: 'RangeBar',\r\n        color: palettes[c],\r\n        radius: `${radius + 5}%`,\r\n        animation: {\r\n          duration: 1500 * d.duration / this.max,\r\n          enable: true\r\n        },\r\n        pointerWidth: width\r\n      });\r\n      if (c === 9)\r\n        c = 0;\r\n      else\r\n        c++;\r\n      const duration = dayjs.duration(d.duration, 's');\r\n      const ratio = d.duration / this.max;\r\n      const days = duration.hours() > 0 ? `${Math.floor(duration.asDays())}:${duration.hours()}` : `${Math.floor(duration.asDays())}`;\r\n      annotations.push({\r\n        description: `${days}`,\r\n        content: `<span class=\"label\">${days}</span>`,\r\n        radius: `${radius + 1}%`,\r\n        angle: !this._session.inverse ? (ratio < zero ?\r\n          205 + Math.round(140 * ratio / zero) :\r\n          165 - Math.round(140 * (1 - ratio) / zero)) : (ratio < zero ?\r\n            205 + Math.round(140 * ratio / zero) :\r\n            165 - Math.round(140 * (1 - ratio) / zero)),\r\n        textStyle: {\r\n          opacity: 0.8,\r\n          fontFamily: FONT_FAMILY,\r\n          size: '10px'\r\n        },\r\n        zIndex: '1'\r\n      });\r\n      annotations.push({\r\n        description: `${d.name}`,\r\n        content: `<span class=\"label\">${d.name}</span>`,\r\n        radius: `${radius}%`,\r\n        angle: !this._session.inverse ? 195 + (radius - 95) / 3.14 : 195 + (radius - 95) / 3.14,\r\n        textStyle: {\r\n          opacity: 0.8,\r\n          fontFamily: FONT_FAMILY,\r\n          size: '10px'\r\n        },\r\n        zIndex: '1'\r\n      });\r\n      radius -= step;\r\n    });\r\n    const ranges: RangeModel[] = [];\r\n    if (this._standardHigh) {\r\n      ranges.push({\r\n        start: this._standardLow < this._standardHigh ? this._standardLow : 0,\r\n        legendText: this._translate.get('Standard'),\r\n        end: this._standardHigh,\r\n        startWidth: 6,\r\n        endWidth: 6,\r\n        color: this._session.getPrimery(400),\r\n        radius: `103%`\r\n      });\r\n    }\r\n    this.ranges = ranges,\r\n      this.annotations = annotations,\r\n      this.pointers = pointers;\r\n  }\r\n\r\n  private _draw() {\r\n    this.gauge && this.gauge.destroy();\r\n    this.gauge = new CircularGauge({\r\n      centerY: '45%',\r\n      centerX: '50%',\r\n      description: '',\r\n      width: this.width,\r\n      height: this.height,\r\n      background: 'transparent',\r\n      theme: this.theme,\r\n      tooltip: this.tooltip,\r\n      margin: this.margin,\r\n      enableRtl: false,\r\n      legendSettings: this.legendSettings,\r\n      tooltipRender: this.tooltipRender.bind(this),\r\n      axes: [{\r\n        radius: '90%', maximum: this.max, startAngle: 200, endAngle: 160, majorTicks: this.majorTicks,\r\n        labelStyle: this.labelStyle, lineStyle: this.lineStyle, minorTicks: this.minorTicks,\r\n        annotations: this.annotations, ranges: this.ranges, pointers: this.pointers, direction: this.direction\r\n      }]\r\n    }, this._elementRef.nativeElement);\r\n  }\r\n  private _refresh() {\r\n    const axis = this.gauge.axes[0];\r\n    axis.annotations = this.annotations;\r\n    axis.pointers = this.pointers;\r\n    axis.ranges = this.ranges;\r\n    this.gauge.refresh();\r\n  }\r\n  private _animate() {\r\n    setTimeout(() => this._data.forEach((p, i) =>\r\n      this.gauge.setPointerValue(0, i, p.duration)), 500);\r\n  }\r\n\r\n  tooltipRender(e: ITooltipRenderEventArgs) {\r\n    if (e.range)\r\n      e.content = e.range.start ? `${e.range.legendText} ${this._duration.transform(e.range.start)} - ${this._duration.transform(e.range.end)}`\r\n        : `${e.range.legendText} ${this._duration.transform(e.range.end)}`;\r\n    else\r\n      e.content = `${this._duration.transform(e.pointer.value)}`;\r\n  }\r\n  ngOnDestroy(): void {\r\n    this._destroy.next();\r\n    this._destroy.complete();\r\n  }\r\n}\r\ninterface PeerModel {\r\n  name: string;\r\n  userId: string;\r\n  /** seconds */\r\n  duration: number;\r\n  standard?: number;\r\n}\r\n\r\n"]}
253
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"peers-performance.widget.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/dashboard/score/peers-performance.widget.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnDestroy, ViewChild, ElementRef, HostBinding } from \"@angular/core\";\r\nimport { Directionality } from \"@angular/cdk/bidi\";\r\nimport { DurationFormatPipe } from \"../../core/pipes/duration-format.pipe\";\r\nimport { CircularGauge, RangeModel, AnnotationModel, PointerModel, TickModel, LabelModel, LineModel, GaugeDirection, Annotations, ITooltipRenderEventArgs, TooltipSettingsModel, MarginModel, GaugeTooltip, CircularGaugeComponent } from \"@syncfusion/ej2-angular-circulargauge\";\r\nimport { LegendSettingsModel } from \"@syncfusion/ej2-circulargauge/src/circular-gauge/legend/legend-model\";\r\nimport dayjs from 'dayjs';\r\nimport { Subject, Observable, forkJoin } from \"rxjs\";\r\nimport { takeUntil, map } from \"rxjs/operators\";\r\nimport { BizDoc } from \"../../core/decorators\";\r\nimport { WidgetComponent } from \"../../core/base\";\r\nimport { AccountService } from \"../../core/account.service\";\r\nimport { SessionService } from \"../../core/session.service\";\r\nimport { TranslateService } from \"../../core/translate.service\";\r\nimport { WidgetRef } from \"../widget-ref\";\r\nimport { FONT_FAMILY } from \"../../core/colors\";\r\n\r\nCircularGauge.Inject(Annotations, GaugeTooltip);\r\n\r\nconst MAX_PEERS = 10;\r\n@Component({\r\n  template: '',\r\n  //templateUrl: 'peers-performance.widget.html',\r\n  host: {\r\n    style: 'display: block',\r\n    dir: 'ltr'\r\n  }\r\n})\r\n@BizDoc({\r\n  selector: 'bizdoc-peers-performance'\r\n})\r\nexport class PeersPerformanceWidget implements WidgetComponent<PeerModel[]>, OnDestroy {\r\n  static nextId = 0;\r\n  @HostBinding()\r\n  readonly id = `peers-performance-${PeersPerformanceWidget.nextId++}`;\r\n  @ViewChild(CircularGaugeComponent) gauge: CircularGauge;\r\n  theme: 'Material' | 'MaterialDark' = this._session.theme.dark ? 'MaterialDark' : 'Material';\r\n  annotations: AnnotationModel[];\r\n  ranges: RangeModel[];\r\n  pointers: PointerModel[];\r\n  max = 0;\r\n  readonly direction: GaugeDirection = this._dir.value === 'ltr' ? 'ClockWise' : 'AntiClockWise';\r\n  readonly lineStyle: LineModel = { width: 0 };\r\n  readonly labelStyle: LabelModel = { font: { size: '0px' } };\r\n  readonly majorTicks: TickModel = { width: 0 };\r\n  readonly minorTicks: TickModel = { width: 0 };\r\n  readonly legendSettings: LegendSettingsModel = {\r\n    visible: true, position: 'Top', shape: 'Diamond', alignment: 'Center',\r\n    padding: 0,\r\n    margin: { top: 0, bottom: 20 },\r\n    location: { y: 0 },\r\n    textStyle: {\r\n      fontFamily: FONT_FAMILY\r\n    }\r\n  };\r\n  readonly tooltip: TooltipSettingsModel = {\r\n    enable: true, type: ['Range', 'Pointer'], textStyle: {\r\n      fontFamily: FONT_FAMILY\r\n    },\r\n    annotationSettings: {},\r\n    showAtMousePosition: false\r\n  };\r\n  readonly margin: MarginModel = { left: 0, top: 0, right: 0, bottom: 0 };\r\n  height: string;\r\n  width: string;\r\n  private _score: number;\r\n  private _standardHigh = 0;\r\n  private _standardLow = 0;\r\n  private _data: PeerModel[];\r\n  private readonly _destroy = new Subject<void>();\r\n  constructor(private _session: SessionService,\r\n    ref: WidgetRef,\r\n    private _elementRef: ElementRef,\r\n    private _service: AccountService,\r\n    private _dir: Directionality,\r\n    private _duration: DurationFormatPipe,\r\n    private _translate: TranslateService) {\r\n    _session.themeChange.pipe(takeUntil(this._destroy)).\r\n      subscribe(t => {\r\n        this.theme = t.dark ? 'MaterialDark' : 'Material';\r\n        this.gauge.theme = this.theme;\r\n        this._prepare();\r\n        this._refresh();\r\n        this._animate();\r\n      });\r\n    ref.resize.subscribe(d => {\r\n      this.height = `${d.height}px`;\r\n      this.width = `${d.width}px`;\r\n      if (this.gauge) {\r\n        this.gauge.height = this.height;\r\n        this.gauge.width = this.width;\r\n        this._animate();\r\n      }\r\n    });\r\n  }\r\n  onBind(data: PeerModel[]) {\r\n    this._decorare(data).subscribe(() => {\r\n      this._prepare();\r\n      if (!this.gauge) this._draw();\r\n      else this._refresh();\r\n      this._animate();\r\n    });\r\n  }\r\n  /**\r\n   * \r\n   * @param data\r\n   */\r\n  private _decorare(data: PeerModel[]): Observable<any> {\r\n    const observers: Observable<any>[] = [];\r\n    data.forEach(i => {\r\n      if (i.duration > this.max) this.max = i.duration;\r\n      if (i.userId === this._session.profile.userId) i.name = this._translate.get('You');\r\n      else {\r\n        const promise = this._service.get(i.userId).pipe(map(u =>\r\n          i.name = u.nick || u.name));\r\n        observers.push(promise);\r\n      }\r\n      if (i.standard) {\r\n        if (i.standard > this._standardHigh) this._standardHigh = i.standard;\r\n        if (this._standardLow === 0 || i.standard < this._standardLow) this._standardLow = i.standard;\r\n        if (i.standard > this.max) this.max = i.standard;\r\n      }\r\n      if (i.userId === this._session.profile.userId)\r\n        this._score = i.duration;\r\n    });\r\n    this._data = data.sort((i1, i2) => i1.duration < i2.duration ? 1 : -1).slice(0, MAX_PEERS);\r\n    return forkJoin(observers);\r\n  }\r\n  private _prepare() {\r\n    const step = Math.floor(70 / this._data.length), width = Math.min(15, Math.floor(80 / this._data.length / 2)), zero = 4 / 9;\r\n    let radius = 95;\r\n    const annotations: AnnotationModel[] = [];\r\n    const pointers: PointerModel[] = [];\r\n    let c = 0;\r\n    const palettes = this._session.accentPalette;\r\n    this._data.forEach((d, i) => {\r\n      pointers.push({\r\n        value: 0,\r\n        type: 'RangeBar',\r\n        color: palettes[c],\r\n        radius: `${radius + 5}%`,\r\n        animation: {\r\n          duration: 1500 * d.duration / this.max,\r\n          enable: true\r\n        },\r\n        pointerWidth: width\r\n      });\r\n      if (c === 9)\r\n        c = 0;\r\n      else\r\n        c++;\r\n      const duration = dayjs.duration(d.duration, 's');\r\n      const ratio = d.duration / this.max;\r\n      const days = duration.hours() > 0 ? `${Math.floor(duration.asDays())}:${duration.hours()}` : `${Math.floor(duration.asDays())}`;\r\n      annotations.push({\r\n        description: `${days}`,\r\n        content: `<span class=\"label\">${days}</span>`,\r\n        radius: `${radius + 1}%`,\r\n        angle: !this._session.inverse ? (ratio < zero ?\r\n          205 + Math.round(140 * ratio / zero) :\r\n          165 - Math.round(140 * (1 - ratio) / zero)) : (ratio < zero ?\r\n            205 + Math.round(140 * ratio / zero) :\r\n            165 - Math.round(140 * (1 - ratio) / zero)),\r\n        textStyle: {\r\n          opacity: 0.8,\r\n          fontFamily: FONT_FAMILY,\r\n          size: '10px'\r\n        },\r\n        zIndex: '1'\r\n      });\r\n      annotations.push({\r\n        description: `${d.name}`,\r\n        content: `<span class=\"label\">${d.name}</span>`,\r\n        radius: `${radius}%`,\r\n        angle: !this._session.inverse ? 195 + (radius - 95) / 3.14 : 195 + (radius - 95) / 3.14,\r\n        textStyle: {\r\n          opacity: 0.8,\r\n          fontFamily: FONT_FAMILY,\r\n          size: '10px'\r\n        },\r\n        zIndex: '1'\r\n      });\r\n      radius -= step;\r\n    });\r\n    const ranges: RangeModel[] = [];\r\n    if (this._standardHigh) {\r\n      ranges.push({\r\n        start: this._standardLow < this._standardHigh ? this._standardLow : 0,\r\n        legendText: this._translate.get('Standard'),\r\n        end: this._standardHigh,\r\n        startWidth: 6,\r\n        endWidth: 6,\r\n        color: this._session.getPrimery(400),\r\n        radius: `103%`\r\n      });\r\n    }\r\n    this.ranges = ranges,\r\n      this.annotations = annotations,\r\n      this.pointers = pointers;\r\n  }\r\n\r\n  private _draw() {\r\n    this.gauge && this.gauge.destroy();\r\n    this.gauge = new CircularGauge({\r\n      centerY: '45%',\r\n      centerX: '50%',\r\n      description: '',\r\n      width: this.width,\r\n      height: this.height,\r\n      background: 'transparent',\r\n      theme: this.theme,\r\n      tooltip: this.tooltip,\r\n      margin: this.margin,\r\n      enableRtl: false,\r\n      legendSettings: this.legendSettings,\r\n      tooltipRender: this.tooltipRender.bind(this),\r\n      axes: [{\r\n        radius: '90%', maximum: this.max, startAngle: 200, endAngle: 160, majorTicks: this.majorTicks,\r\n        labelStyle: this.labelStyle, lineStyle: this.lineStyle, minorTicks: this.minorTicks,\r\n        annotations: this.annotations, ranges: this.ranges, pointers: this.pointers, direction: this.direction\r\n      }]\r\n    }, this._elementRef.nativeElement);\r\n  }\r\n  private _refresh() {\r\n    const axis = this.gauge.axes[0];\r\n    axis.annotations = this.annotations;\r\n    axis.pointers = this.pointers;\r\n    axis.ranges = this.ranges;\r\n    this.gauge.refresh();\r\n  }\r\n  private _animate() {\r\n    setTimeout(() => this._data.forEach((p, i) =>\r\n      this.gauge.setPointerValue(0, i, p.duration)), 500);\r\n  }\r\n\r\n  tooltipRender(e: ITooltipRenderEventArgs) {\r\n    if (e.range)\r\n      e.content = e.range.start ? `${e.range.legendText} ${this._duration.transform(e.range.start)} - ${this._duration.transform(e.range.end)}`\r\n        : `${e.range.legendText} ${this._duration.transform(e.range.end)}`;\r\n    else\r\n      e.content = `${this._duration.transform(e.pointer.value)}`;\r\n  }\r\n  ngOnDestroy(): void {\r\n    this._destroy.next();\r\n    this._destroy.complete();\r\n  }\r\n}\r\ninterface PeerModel {\r\n  name: string;\r\n  userId: string;\r\n  /** seconds */\r\n  duration: number;\r\n  standard?: number;\r\n}\r\n\r\n"]}
@@ -3,7 +3,6 @@ import { Component, ViewChild, HostBinding } from "@angular/core";
3
3
  import { MatSort } from "@angular/material/sort";
4
4
  import { MatTableDataSource } from "@angular/material/table";
5
5
  import { Subject } from "rxjs";
6
- import dayjs from 'dayjs';
7
6
  import { BizDoc } from "../../core/decorators";
8
7
  import { listAnimation, itemAnimation } from "../../core/animations";
9
8
  import * as i0 from "@angular/core";
@@ -15,7 +14,8 @@ import * as i5 from "../../core/popup/tooltip.directive";
15
14
  import * as i6 from "@angular/common";
16
15
  import * as i7 from "@angular/cdk/bidi";
17
16
  import * as i8 from "../../core/pipes/translate.pipe";
18
- import * as i9 from "../../core/pipes/duration.pipe";
17
+ import * as i9 from "../../core/pipes/duration-format.pipe";
18
+ import * as i10 from "../../core/pipes/duration.pipe";
19
19
  let PendingResultsWidget = class PendingResultsWidget {
20
20
  constructor(ref) {
21
21
  this.columns = ['name', 'duration', 'standard', 'count'];
@@ -28,17 +28,13 @@ let PendingResultsWidget = class PendingResultsWidget {
28
28
  this.sort.direction = 'desc';
29
29
  this.dataSource.sort = this.sort;
30
30
  }
31
- asDays(seconds) {
32
- const duration = dayjs.duration(seconds, 's');
33
- return `${Math.floor(duration.asDays())}:${Math.round(duration.hours())}`;
34
- }
35
31
  ngOnDestroy() {
36
32
  this._destroy.next();
37
33
  this._destroy.complete();
38
34
  }
39
35
  };
40
36
  PendingResultsWidget.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.5", ngImport: i0, type: PendingResultsWidget, deps: [{ token: i1.WidgetRef }], target: i0.ɵɵFactoryTarget.Component });
41
- PendingResultsWidget.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.5", type: PendingResultsWidget, selector: "bizdoc-pending-results", host: { properties: { "style.height": "this.height" } }, viewQueries: [{ propertyName: "sort", first: true, predicate: MatSort, descendants: true }], ngImport: i0, template: "<table mat-table [dataSource]=\"dataSource\" matSort class=\"mat-elevation-z0\" @list>\r\n <ng-container matColumnDef=\"name\">\r\n <th mat-header-cell *matHeaderCellDef> {{'Name' | translate}} </th>\r\n <td mat-cell *matCellDef=\"let element\"> <bizdoc-identity-name [identity]='element.userId' chating=\"room\"></bizdoc-identity-name></td>\r\n </ng-container>\r\n\r\n <ng-container matColumnDef=\"duration\">\r\n <th mat-header-cell *matHeaderCellDef mat-sort-header> {{'Duration' | translate}} </th>\r\n <td mat-cell *matCellDef=\"let element\"> <span [bizdocTooltip]='asDays(element.duration)'>{{ element.duration | amDuration : 's' }}</span> </td>\r\n </ng-container>\r\n\r\n <ng-container matColumnDef=\"standard\">\r\n <th mat-header-cell *matHeaderCellDef mat-sort-header> {{'Standard' | translate}} </th>\r\n <td mat-cell *matCellDef=\"let element\"> <span *ngIf=\"element.standard\" [bizdocTooltip]=\"asDays(element.standard)\">{{ element.standard | amDuration: 's' }}</span> </td>\r\n </ng-container>\r\n\r\n <ng-container matColumnDef=\"count\">\r\n <th mat-header-cell *matHeaderCellDef> </th>\r\n <td mat-cell *matCellDef=\"let element\" dir=\"ltr\">\r\n <span class=\"range\">{{ element.processed }} / {{element.pending + element.processed}}</span></td>\r\n </ng-container>\r\n\r\n <tr mat-header-row *matHeaderRowDef=\"columns; sticky: true\"></tr>\r\n <tr mat-row *matRowDef=\"let row; columns: columns;\" @item></tr>\r\n</table>\r\n<style scoped> .range {\r\n white-space: nowrap;\r\n }\r\n</style>\r\n", styles: ["table{width:100%}td.text{text-overflow:ellipsis;max-width:100px;white-space:nowrap;overflow:hidden}:host{overflow:hidden;display:block}:host:hover{overflow-y:auto!important}\n", " .range {\n white-space: nowrap;\n }\n"], components: [{ type: i2.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { type: i3.IdentityName, selector: "bizdoc-identity-name", inputs: ["identity", "by", "chating"] }, { type: i4.MatSortHeader, selector: "[mat-sort-header]", inputs: ["disabled", "mat-sort-header", "arrowPosition", "start", "sortActionDescription", "disableClear"], exportAs: ["matSortHeader"] }, { type: i2.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { type: i2.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }], directives: [{ type: i4.MatSort, selector: "[matSort]", inputs: ["matSortDisabled", "matSortActive", "matSortStart", "matSortDirection", "matSortDisableClear"], outputs: ["matSortChange"], exportAs: ["matSort"] }, { type: i2.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { type: i2.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { type: i2.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { type: i2.MatCellDef, selector: "[matCellDef]" }, { type: i2.MatCell, selector: "mat-cell, td[mat-cell]" }, { type: i5.TooltipDirective, selector: "[bizdocTooltip]", inputs: ["bizdocTooltip", "bizdocTooltipTemplate", "bizdocTooltipContext", "bizdocTooltipPosition", "bizdocTooltipDuration", "bizdocTooltipDisabled"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.Dir, selector: "[dir]", inputs: ["dir"], outputs: ["dirChange"], exportAs: ["dir"] }, { type: i2.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { type: i2.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }], pipes: { "translate": i8.TranslatePipe, "amDuration": i9.DurationPipe }, animations: [
37
+ PendingResultsWidget.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.5", type: PendingResultsWidget, selector: "bizdoc-pending-results", host: { properties: { "style.height": "this.height" } }, viewQueries: [{ propertyName: "sort", first: true, predicate: MatSort, descendants: true }], ngImport: i0, template: "<table mat-table [dataSource]=\"dataSource\" matSort class=\"mat-elevation-z0\" @list>\r\n <ng-container matColumnDef=\"name\">\r\n <th mat-header-cell *matHeaderCellDef> {{'Name' | translate}} </th>\r\n <td mat-cell *matCellDef=\"let element\"> <bizdoc-identity-name [identity]='element.userId' chating=\"room\"></bizdoc-identity-name></td>\r\n </ng-container>\r\n\r\n <ng-container matColumnDef=\"duration\">\r\n <th mat-header-cell *matHeaderCellDef mat-sort-header> {{'Duration' | translate}} </th>\r\n <td mat-cell *matCellDef=\"let element\"> <span [bizdocTooltip]='element.duration|amDurationFormat'>{{ element.duration | amDuration : 's' }}</span> </td>\r\n </ng-container>\r\n\r\n <ng-container matColumnDef=\"standard\">\r\n <th mat-header-cell *matHeaderCellDef mat-sort-header> {{'Standard' | translate}} </th>\r\n <td mat-cell *matCellDef=\"let element\"> <span *ngIf=\"element.standard\" [bizdocTooltip]=\"element.standard|amDurationFormat\">{{ element.standard | amDuration: 's' }}</span> </td>\r\n </ng-container>\r\n\r\n <ng-container matColumnDef=\"count\">\r\n <th mat-header-cell *matHeaderCellDef> </th>\r\n <td mat-cell *matCellDef=\"let element\" dir=\"ltr\">\r\n <span class=\"range\">{{ element.processed }} / {{element.pending + element.processed}}</span>\r\n </td>\r\n </ng-container>\r\n\r\n <tr mat-header-row *matHeaderRowDef=\"columns; sticky: true\"></tr>\r\n <tr mat-row *matRowDef=\"let row; columns: columns;\" @item></tr>\r\n</table>\r\n<style scoped>\r\n .range {\r\n white-space: nowrap;\r\n }\r\n</style>\r\n", styles: ["table{width:100%}td.text{text-overflow:ellipsis;max-width:100px;white-space:nowrap;overflow:hidden}:host{overflow:hidden;display:block}:host:hover{overflow-y:auto!important}\n", "\n .range {\n white-space: nowrap;\n }\n"], components: [{ type: i2.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { type: i3.IdentityName, selector: "bizdoc-identity-name", inputs: ["identity", "by", "chating"] }, { type: i4.MatSortHeader, selector: "[mat-sort-header]", inputs: ["disabled", "mat-sort-header", "arrowPosition", "start", "sortActionDescription", "disableClear"], exportAs: ["matSortHeader"] }, { type: i2.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { type: i2.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }], directives: [{ type: i4.MatSort, selector: "[matSort]", inputs: ["matSortDisabled", "matSortActive", "matSortStart", "matSortDirection", "matSortDisableClear"], outputs: ["matSortChange"], exportAs: ["matSort"] }, { type: i2.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { type: i2.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { type: i2.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { type: i2.MatCellDef, selector: "[matCellDef]" }, { type: i2.MatCell, selector: "mat-cell, td[mat-cell]" }, { type: i5.TooltipDirective, selector: "[bizdocTooltip]", inputs: ["bizdocTooltip", "bizdocTooltipTemplate", "bizdocTooltipContext", "bizdocTooltipPosition", "bizdocTooltipDuration", "bizdocTooltipDisabled"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.Dir, selector: "[dir]", inputs: ["dir"], outputs: ["dirChange"], exportAs: ["dir"] }, { type: i2.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { type: i2.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }], pipes: { "translate": i8.TranslatePipe, "amDurationFormat": i9.DurationFormatPipe, "amDuration": i10.DurationPipe }, animations: [
42
38
  listAnimation,
43
39
  itemAnimation
44
40
  ] });
@@ -53,7 +49,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.5", ngImpor
53
49
  args: [{ selector: 'bizdoc-pending-results', animations: [
54
50
  listAnimation,
55
51
  itemAnimation
56
- ], template: "<table mat-table [dataSource]=\"dataSource\" matSort class=\"mat-elevation-z0\" @list>\r\n <ng-container matColumnDef=\"name\">\r\n <th mat-header-cell *matHeaderCellDef> {{'Name' | translate}} </th>\r\n <td mat-cell *matCellDef=\"let element\"> <bizdoc-identity-name [identity]='element.userId' chating=\"room\"></bizdoc-identity-name></td>\r\n </ng-container>\r\n\r\n <ng-container matColumnDef=\"duration\">\r\n <th mat-header-cell *matHeaderCellDef mat-sort-header> {{'Duration' | translate}} </th>\r\n <td mat-cell *matCellDef=\"let element\"> <span [bizdocTooltip]='asDays(element.duration)'>{{ element.duration | amDuration : 's' }}</span> </td>\r\n </ng-container>\r\n\r\n <ng-container matColumnDef=\"standard\">\r\n <th mat-header-cell *matHeaderCellDef mat-sort-header> {{'Standard' | translate}} </th>\r\n <td mat-cell *matCellDef=\"let element\"> <span *ngIf=\"element.standard\" [bizdocTooltip]=\"asDays(element.standard)\">{{ element.standard | amDuration: 's' }}</span> </td>\r\n </ng-container>\r\n\r\n <ng-container matColumnDef=\"count\">\r\n <th mat-header-cell *matHeaderCellDef> </th>\r\n <td mat-cell *matCellDef=\"let element\" dir=\"ltr\">\r\n <span class=\"range\">{{ element.processed }} / {{element.pending + element.processed}}</span></td>\r\n </ng-container>\r\n\r\n <tr mat-header-row *matHeaderRowDef=\"columns; sticky: true\"></tr>\r\n <tr mat-row *matRowDef=\"let row; columns: columns;\" @item></tr>\r\n</table>\r\n<style scoped> .range {\r\n white-space: nowrap;\r\n }\r\n</style>\r\n", styles: ["table{width:100%}td.text{text-overflow:ellipsis;max-width:100px;white-space:nowrap;overflow:hidden}:host{overflow:hidden;display:block}:host:hover{overflow-y:auto!important}\n", " .range {\n white-space: nowrap;\n }\n"] }]
52
+ ], template: "<table mat-table [dataSource]=\"dataSource\" matSort class=\"mat-elevation-z0\" @list>\r\n <ng-container matColumnDef=\"name\">\r\n <th mat-header-cell *matHeaderCellDef> {{'Name' | translate}} </th>\r\n <td mat-cell *matCellDef=\"let element\"> <bizdoc-identity-name [identity]='element.userId' chating=\"room\"></bizdoc-identity-name></td>\r\n </ng-container>\r\n\r\n <ng-container matColumnDef=\"duration\">\r\n <th mat-header-cell *matHeaderCellDef mat-sort-header> {{'Duration' | translate}} </th>\r\n <td mat-cell *matCellDef=\"let element\"> <span [bizdocTooltip]='element.duration|amDurationFormat'>{{ element.duration | amDuration : 's' }}</span> </td>\r\n </ng-container>\r\n\r\n <ng-container matColumnDef=\"standard\">\r\n <th mat-header-cell *matHeaderCellDef mat-sort-header> {{'Standard' | translate}} </th>\r\n <td mat-cell *matCellDef=\"let element\"> <span *ngIf=\"element.standard\" [bizdocTooltip]=\"element.standard|amDurationFormat\">{{ element.standard | amDuration: 's' }}</span> </td>\r\n </ng-container>\r\n\r\n <ng-container matColumnDef=\"count\">\r\n <th mat-header-cell *matHeaderCellDef> </th>\r\n <td mat-cell *matCellDef=\"let element\" dir=\"ltr\">\r\n <span class=\"range\">{{ element.processed }} / {{element.pending + element.processed}}</span>\r\n </td>\r\n </ng-container>\r\n\r\n <tr mat-header-row *matHeaderRowDef=\"columns; sticky: true\"></tr>\r\n <tr mat-row *matRowDef=\"let row; columns: columns;\" @item></tr>\r\n</table>\r\n<style scoped>\r\n .range {\r\n white-space: nowrap;\r\n }\r\n</style>\r\n", styles: ["table{width:100%}td.text{text-overflow:ellipsis;max-width:100px;white-space:nowrap;overflow:hidden}:host{overflow:hidden;display:block}:host:hover{overflow-y:auto!important}\n", "\n .range {\n white-space: nowrap;\n }\n"] }]
57
53
  }], ctorParameters: function () { return [{ type: i1.WidgetRef }]; }, propDecorators: { sort: [{
58
54
  type: ViewChild,
59
55
  args: [MatSort]
@@ -61,4 +57,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.5", ngImpor
61
57
  type: HostBinding,
62
58
  args: ['style.height']
63
59
  }] } });
64
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGVuZGluZy1yZXN1bHRzLndpZGdldC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnJhcmllcy9jb3JlL3NyYy9saWIvZGFzaGJvYXJkL3Njb3JlL3BlbmRpbmctcmVzdWx0cy53aWRnZXQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9saWJyYXJpZXMvY29yZS9zcmMvbGliL2Rhc2hib2FyZC9zY29yZS9wZW5kaW5nLXJlc3VsdHMud2lkZ2V0Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsU0FBUyxFQUFhLFdBQVcsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM3RSxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDakQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDN0QsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUMvQixPQUFPLEtBQUssTUFBTSxPQUFPLENBQUM7QUFDMUIsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBRS9DLE9BQU8sRUFBRSxhQUFhLEVBQUUsYUFBYSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7Ozs7Ozs7Ozs7O0lBZXhELG9CQUFvQixTQUFwQixvQkFBb0I7SUFPL0IsWUFDRSxHQUFjO1FBSlAsWUFBTyxHQUFHLENBQUMsTUFBTSxFQUFFLFVBQVUsRUFBRSxVQUFVLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFFNUMsYUFBUSxHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7UUFHOUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsTUFBTSxHQUFHLEdBQUcsQ0FBQyxDQUFDLE1BQU0sSUFBSSxDQUFDLENBQUM7SUFDM0QsQ0FBQztJQUNELE1BQU0sQ0FBQyxJQUFpQjtRQUN0QixJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksa0JBQWtCLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDL0MsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLEdBQUcsVUFBVSxDQUFDO1FBQzlCLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxHQUFHLE1BQU0sQ0FBQztRQUM3QixJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDO0lBQ25DLENBQUM7SUFDRCxNQUFNLENBQUMsT0FBZTtRQUNwQixNQUFNLFFBQVEsR0FBRyxLQUFLLENBQUMsUUFBUSxDQUFDLE9BQU8sRUFBRSxHQUFHLENBQUMsQ0FBQztRQUM5QyxPQUFPLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsTUFBTSxFQUFFLENBQUMsSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxLQUFLLEVBQUUsQ0FBQyxFQUFFLENBQUM7SUFDNUUsQ0FBQztJQUNELFdBQVc7UUFDVCxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ3JCLElBQUksQ0FBQyxRQUFRLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDM0IsQ0FBQztDQUNGLENBQUE7aUhBekJZLG9CQUFvQjtxR0FBcEIsb0JBQW9CLDZKQUNwQixPQUFPLGdEQ3ZCcEIsOGhEQTZCQSx5Z0VEZmM7UUFDVixhQUFhO1FBQ2IsYUFBYTtLQUNkO0FBS1Usb0JBQW9CO0lBSGhDLE1BQU0sQ0FBQztRQUNOLFFBQVEsRUFBRSx3QkFBd0I7S0FDbkMsQ0FBQztHQUNXLG9CQUFvQixDQXlCaEM7U0F6Qlksb0JBQW9COzJGQUFwQixvQkFBb0I7a0JBWmhDLFNBQVM7K0JBQ0Usd0JBQXdCLGNBR3RCO3dCQUNWLGFBQWE7d0JBQ2IsYUFBYTtxQkFDZDtnR0FNbUIsSUFBSTtzQkFBdkIsU0FBUzt1QkFBQyxPQUFPO2dCQUVsQixNQUFNO3NCQURMLFdBQVc7dUJBQUMsY0FBYyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgVmlld0NoaWxkLCBPbkRlc3Ryb3ksIEhvc3RCaW5kaW5nIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgTWF0U29ydCB9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9zb3J0XCI7XHJcbmltcG9ydCB7IE1hdFRhYmxlRGF0YVNvdXJjZSB9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC90YWJsZVwiO1xyXG5pbXBvcnQgeyBTdWJqZWN0IH0gZnJvbSBcInJ4anNcIjtcclxuaW1wb3J0IGRheWpzIGZyb20gJ2RheWpzJztcclxuaW1wb3J0IHsgQml6RG9jIH0gZnJvbSBcIi4uLy4uL2NvcmUvZGVjb3JhdG9yc1wiO1xyXG5pbXBvcnQgeyBXaWRnZXRDb21wb25lbnQgfSBmcm9tIFwiLi4vLi4vY29yZS9iYXNlXCI7XHJcbmltcG9ydCB7IGxpc3RBbmltYXRpb24sIGl0ZW1BbmltYXRpb24gfSBmcm9tIFwiLi4vLi4vY29yZS9hbmltYXRpb25zXCI7XHJcbmltcG9ydCB7IFdpZGdldFJlZiB9IGZyb20gXCIuLi93aWRnZXQtcmVmXCI7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2JpemRvYy1wZW5kaW5nLXJlc3VsdHMnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9wZW5kaW5nLXJlc3VsdHMud2lkZ2V0Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuLi9fdGFibGUud2lkZ2V0LnNjc3MnXSxcclxuICBhbmltYXRpb25zOiBbXHJcbiAgICBsaXN0QW5pbWF0aW9uLFxyXG4gICAgaXRlbUFuaW1hdGlvblxyXG4gIF1cclxufSlcclxuQEJpekRvYyh7XHJcbiAgc2VsZWN0b3I6ICdiaXpkb2MtcGVuZGluZy1yZXN1bHRzJ1xyXG59KVxyXG5leHBvcnQgY2xhc3MgUGVuZGluZ1Jlc3VsdHNXaWRnZXQgaW1wbGVtZW50cyBXaWRnZXRDb21wb25lbnQ8RGF0YU1vZGVsW10+LCBPbkRlc3Ryb3kge1xyXG4gIEBWaWV3Q2hpbGQoTWF0U29ydCkgc29ydDogTWF0U29ydDtcclxuICBASG9zdEJpbmRpbmcoJ3N0eWxlLmhlaWdodCcpXHJcbiAgaGVpZ2h0OiBzdHJpbmc7XHJcbiAgcmVhZG9ubHkgY29sdW1ucyA9IFsnbmFtZScsICdkdXJhdGlvbicsICdzdGFuZGFyZCcsICdjb3VudCddO1xyXG4gIGRhdGFTb3VyY2U6IE1hdFRhYmxlRGF0YVNvdXJjZTxEYXRhTW9kZWw+O1xyXG4gIHByaXZhdGUgcmVhZG9ubHkgX2Rlc3Ryb3kgPSBuZXcgU3ViamVjdDx2b2lkPigpO1xyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgcmVmOiBXaWRnZXRSZWYpIHtcclxuICAgIHJlZi5yZXNpemUuc3Vic2NyaWJlKGQgPT4gdGhpcy5oZWlnaHQgPSBgJHtkLmhlaWdodH1weGApO1xyXG4gIH1cclxuICBvbkJpbmQoZGF0YTogRGF0YU1vZGVsW10pIHtcclxuICAgIHRoaXMuZGF0YVNvdXJjZSA9IG5ldyBNYXRUYWJsZURhdGFTb3VyY2UoZGF0YSk7XHJcbiAgICB0aGlzLnNvcnQuYWN0aXZlID0gJ2R1cmF0aW9uJztcclxuICAgIHRoaXMuc29ydC5kaXJlY3Rpb24gPSAnZGVzYyc7XHJcbiAgICB0aGlzLmRhdGFTb3VyY2Uuc29ydCA9IHRoaXMuc29ydDtcclxuICB9XHJcbiAgYXNEYXlzKHNlY29uZHM6IG51bWJlcikge1xyXG4gICAgY29uc3QgZHVyYXRpb24gPSBkYXlqcy5kdXJhdGlvbihzZWNvbmRzLCAncycpO1xyXG4gICAgcmV0dXJuIGAke01hdGguZmxvb3IoZHVyYXRpb24uYXNEYXlzKCkpfToke01hdGgucm91bmQoZHVyYXRpb24uaG91cnMoKSl9YDtcclxuICB9XHJcbiAgbmdPbkRlc3Ryb3koKTogdm9pZCB7XHJcbiAgICB0aGlzLl9kZXN0cm95Lm5leHQoKTtcclxuICAgIHRoaXMuX2Rlc3Ryb3kuY29tcGxldGUoKTtcclxuICB9XHJcbn1cclxuXHJcbmludGVyZmFjZSBEYXRhTW9kZWwge1xyXG4gIG5hbWU6IHN0cmluZztcclxuICB1c2VySWQ6IHN0cmluZztcclxuICBwZW5kaW5nOiBudW1iZXI7XHJcbiAgcHJvY2Vzc2VkOiBudW1iZXI7XHJcbiAgZHVyYXRpb24/OiBudW1iZXI7XHJcbiAgc3RhbmRhcmQ/OiBudW1iZXI7XHJcbn1cclxuIiwiPHRhYmxlIG1hdC10YWJsZSBbZGF0YVNvdXJjZV09XCJkYXRhU291cmNlXCIgbWF0U29ydCBjbGFzcz1cIm1hdC1lbGV2YXRpb24tejBcIiBAbGlzdD5cclxuICA8bmctY29udGFpbmVyIG1hdENvbHVtbkRlZj1cIm5hbWVcIj5cclxuICAgIDx0aCBtYXQtaGVhZGVyLWNlbGwgKm1hdEhlYWRlckNlbGxEZWY+IHt7J05hbWUnIHwgdHJhbnNsYXRlfX0gPC90aD5cclxuICAgIDx0ZCBtYXQtY2VsbCAqbWF0Q2VsbERlZj1cImxldCBlbGVtZW50XCI+IDxiaXpkb2MtaWRlbnRpdHktbmFtZSBbaWRlbnRpdHldPSdlbGVtZW50LnVzZXJJZCcgY2hhdGluZz1cInJvb21cIj48L2JpemRvYy1pZGVudGl0eS1uYW1lPjwvdGQ+XHJcbiAgPC9uZy1jb250YWluZXI+XHJcblxyXG4gIDxuZy1jb250YWluZXIgbWF0Q29sdW1uRGVmPVwiZHVyYXRpb25cIj5cclxuICAgIDx0aCBtYXQtaGVhZGVyLWNlbGwgKm1hdEhlYWRlckNlbGxEZWYgbWF0LXNvcnQtaGVhZGVyPiB7eydEdXJhdGlvbicgfCB0cmFuc2xhdGV9fSA8L3RoPlxyXG4gICAgPHRkIG1hdC1jZWxsICptYXRDZWxsRGVmPVwibGV0IGVsZW1lbnRcIj4gPHNwYW4gW2JpemRvY1Rvb2x0aXBdPSdhc0RheXMoZWxlbWVudC5kdXJhdGlvbiknPnt7IGVsZW1lbnQuZHVyYXRpb24gfCBhbUR1cmF0aW9uIDogJ3MnIH19PC9zcGFuPiA8L3RkPlxyXG4gIDwvbmctY29udGFpbmVyPlxyXG5cclxuICA8bmctY29udGFpbmVyIG1hdENvbHVtbkRlZj1cInN0YW5kYXJkXCI+XHJcbiAgICA8dGggbWF0LWhlYWRlci1jZWxsICptYXRIZWFkZXJDZWxsRGVmIG1hdC1zb3J0LWhlYWRlcj4ge3snU3RhbmRhcmQnIHwgdHJhbnNsYXRlfX0gPC90aD5cclxuICAgIDx0ZCBtYXQtY2VsbCAqbWF0Q2VsbERlZj1cImxldCBlbGVtZW50XCI+IDxzcGFuICpuZ0lmPVwiZWxlbWVudC5zdGFuZGFyZFwiIFtiaXpkb2NUb29sdGlwXT1cImFzRGF5cyhlbGVtZW50LnN0YW5kYXJkKVwiPnt7IGVsZW1lbnQuc3RhbmRhcmQgfCBhbUR1cmF0aW9uOiAncycgfX08L3NwYW4+IDwvdGQ+XHJcbiAgPC9uZy1jb250YWluZXI+XHJcblxyXG4gIDxuZy1jb250YWluZXIgbWF0Q29sdW1uRGVmPVwiY291bnRcIj5cclxuICAgIDx0aCBtYXQtaGVhZGVyLWNlbGwgKm1hdEhlYWRlckNlbGxEZWY+IDwvdGg+XHJcbiAgICA8dGQgbWF0LWNlbGwgKm1hdENlbGxEZWY9XCJsZXQgZWxlbWVudFwiIGRpcj1cImx0clwiPlxyXG4gICAgICA8c3BhbiBjbGFzcz1cInJhbmdlXCI+e3sgZWxlbWVudC5wcm9jZXNzZWQgfX0gLyB7e2VsZW1lbnQucGVuZGluZyArIGVsZW1lbnQucHJvY2Vzc2VkfX08L3NwYW4+PC90ZD5cclxuICA8L25nLWNvbnRhaW5lcj5cclxuXHJcbiAgPHRyIG1hdC1oZWFkZXItcm93ICptYXRIZWFkZXJSb3dEZWY9XCJjb2x1bW5zOyBzdGlja3k6IHRydWVcIj48L3RyPlxyXG4gIDx0ciBtYXQtcm93ICptYXRSb3dEZWY9XCJsZXQgcm93OyBjb2x1bW5zOiBjb2x1bW5zO1wiIEBpdGVtPjwvdHI+XHJcbjwvdGFibGU+XHJcbjxzdHlsZSBzY29wZWQ+ICAucmFuZ2Uge1xyXG4gICAgd2hpdGUtc3BhY2U6IG5vd3JhcDtcclxuICB9XHJcbjwvc3R5bGU+XHJcbiJdfQ==
60
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGVuZGluZy1yZXN1bHRzLndpZGdldC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnJhcmllcy9jb3JlL3NyYy9saWIvZGFzaGJvYXJkL3Njb3JlL3BlbmRpbmctcmVzdWx0cy53aWRnZXQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9saWJyYXJpZXMvY29yZS9zcmMvbGliL2Rhc2hib2FyZC9zY29yZS9wZW5kaW5nLXJlc3VsdHMud2lkZ2V0Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsU0FBUyxFQUFhLFdBQVcsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM3RSxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDakQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDN0QsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUMvQixPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFFL0MsT0FBTyxFQUFFLGFBQWEsRUFBRSxhQUFhLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQzs7Ozs7Ozs7Ozs7O0lBZXhELG9CQUFvQixTQUFwQixvQkFBb0I7SUFPL0IsWUFDRSxHQUFjO1FBSlAsWUFBTyxHQUFHLENBQUMsTUFBTSxFQUFFLFVBQVUsRUFBRSxVQUFVLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFFNUMsYUFBUSxHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7UUFHOUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsTUFBTSxHQUFHLEdBQUcsQ0FBQyxDQUFDLE1BQU0sSUFBSSxDQUFDLENBQUM7SUFDM0QsQ0FBQztJQUNELE1BQU0sQ0FBQyxJQUFpQjtRQUN0QixJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksa0JBQWtCLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDL0MsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLEdBQUcsVUFBVSxDQUFDO1FBQzlCLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxHQUFHLE1BQU0sQ0FBQztRQUM3QixJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDO0lBQ25DLENBQUM7SUFDRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUNyQixJQUFJLENBQUMsUUFBUSxDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQzNCLENBQUM7Q0FDRixDQUFBO2lIQXJCWSxvQkFBb0I7cUdBQXBCLG9CQUFvQiw2SkFDcEIsT0FBTyxnREN0QnBCLDRqREErQkEsdWpFRGxCYztRQUNWLGFBQWE7UUFDYixhQUFhO0tBQ2Q7QUFLVSxvQkFBb0I7SUFIaEMsTUFBTSxDQUFDO1FBQ04sUUFBUSxFQUFFLHdCQUF3QjtLQUNuQyxDQUFDO0dBQ1csb0JBQW9CLENBcUJoQztTQXJCWSxvQkFBb0I7MkZBQXBCLG9CQUFvQjtrQkFaaEMsU0FBUzsrQkFDRSx3QkFBd0IsY0FHdEI7d0JBQ1YsYUFBYTt3QkFDYixhQUFhO3FCQUNkO2dHQU1tQixJQUFJO3NCQUF2QixTQUFTO3VCQUFDLE9BQU87Z0JBRWxCLE1BQU07c0JBREwsV0FBVzt1QkFBQyxjQUFjIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBWaWV3Q2hpbGQsIE9uRGVzdHJveSwgSG9zdEJpbmRpbmcgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBNYXRTb3J0IH0gZnJvbSBcIkBhbmd1bGFyL21hdGVyaWFsL3NvcnRcIjtcclxuaW1wb3J0IHsgTWF0VGFibGVEYXRhU291cmNlIH0gZnJvbSBcIkBhbmd1bGFyL21hdGVyaWFsL3RhYmxlXCI7XHJcbmltcG9ydCB7IFN1YmplY3QgfSBmcm9tIFwicnhqc1wiO1xyXG5pbXBvcnQgeyBCaXpEb2MgfSBmcm9tIFwiLi4vLi4vY29yZS9kZWNvcmF0b3JzXCI7XHJcbmltcG9ydCB7IFdpZGdldENvbXBvbmVudCB9IGZyb20gXCIuLi8uLi9jb3JlL2Jhc2VcIjtcclxuaW1wb3J0IHsgbGlzdEFuaW1hdGlvbiwgaXRlbUFuaW1hdGlvbiB9IGZyb20gXCIuLi8uLi9jb3JlL2FuaW1hdGlvbnNcIjtcclxuaW1wb3J0IHsgV2lkZ2V0UmVmIH0gZnJvbSBcIi4uL3dpZGdldC1yZWZcIjtcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnYml6ZG9jLXBlbmRpbmctcmVzdWx0cycsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL3BlbmRpbmctcmVzdWx0cy53aWRnZXQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4uL190YWJsZS53aWRnZXQuc2NzcyddLFxyXG4gIGFuaW1hdGlvbnM6IFtcclxuICAgIGxpc3RBbmltYXRpb24sXHJcbiAgICBpdGVtQW5pbWF0aW9uXHJcbiAgXVxyXG59KVxyXG5AQml6RG9jKHtcclxuICBzZWxlY3RvcjogJ2JpemRvYy1wZW5kaW5nLXJlc3VsdHMnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBQZW5kaW5nUmVzdWx0c1dpZGdldCBpbXBsZW1lbnRzIFdpZGdldENvbXBvbmVudDxEYXRhTW9kZWxbXT4sIE9uRGVzdHJveSB7XHJcbiAgQFZpZXdDaGlsZChNYXRTb3J0KSBzb3J0OiBNYXRTb3J0O1xyXG4gIEBIb3N0QmluZGluZygnc3R5bGUuaGVpZ2h0JylcclxuICBoZWlnaHQ6IHN0cmluZztcclxuICByZWFkb25seSBjb2x1bW5zID0gWyduYW1lJywgJ2R1cmF0aW9uJywgJ3N0YW5kYXJkJywgJ2NvdW50J107XHJcbiAgZGF0YVNvdXJjZTogTWF0VGFibGVEYXRhU291cmNlPERhdGFNb2RlbD47XHJcbiAgcHJpdmF0ZSByZWFkb25seSBfZGVzdHJveSA9IG5ldyBTdWJqZWN0PHZvaWQ+KCk7XHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICByZWY6IFdpZGdldFJlZikge1xyXG4gICAgcmVmLnJlc2l6ZS5zdWJzY3JpYmUoZCA9PiB0aGlzLmhlaWdodCA9IGAke2QuaGVpZ2h0fXB4YCk7XHJcbiAgfVxyXG4gIG9uQmluZChkYXRhOiBEYXRhTW9kZWxbXSkge1xyXG4gICAgdGhpcy5kYXRhU291cmNlID0gbmV3IE1hdFRhYmxlRGF0YVNvdXJjZShkYXRhKTtcclxuICAgIHRoaXMuc29ydC5hY3RpdmUgPSAnZHVyYXRpb24nO1xyXG4gICAgdGhpcy5zb3J0LmRpcmVjdGlvbiA9ICdkZXNjJztcclxuICAgIHRoaXMuZGF0YVNvdXJjZS5zb3J0ID0gdGhpcy5zb3J0O1xyXG4gIH1cclxuICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcclxuICAgIHRoaXMuX2Rlc3Ryb3kubmV4dCgpO1xyXG4gICAgdGhpcy5fZGVzdHJveS5jb21wbGV0ZSgpO1xyXG4gIH1cclxufVxyXG5cclxuaW50ZXJmYWNlIERhdGFNb2RlbCB7XHJcbiAgbmFtZTogc3RyaW5nO1xyXG4gIHVzZXJJZDogc3RyaW5nO1xyXG4gIHBlbmRpbmc6IG51bWJlcjtcclxuICBwcm9jZXNzZWQ6IG51bWJlcjtcclxuICBkdXJhdGlvbj86IG51bWJlcjtcclxuICBzdGFuZGFyZD86IG51bWJlcjtcclxufVxyXG4iLCI8dGFibGUgbWF0LXRhYmxlIFtkYXRhU291cmNlXT1cImRhdGFTb3VyY2VcIiBtYXRTb3J0IGNsYXNzPVwibWF0LWVsZXZhdGlvbi16MFwiIEBsaXN0PlxyXG4gIDxuZy1jb250YWluZXIgbWF0Q29sdW1uRGVmPVwibmFtZVwiPlxyXG4gICAgPHRoIG1hdC1oZWFkZXItY2VsbCAqbWF0SGVhZGVyQ2VsbERlZj4ge3snTmFtZScgfCB0cmFuc2xhdGV9fSA8L3RoPlxyXG4gICAgPHRkIG1hdC1jZWxsICptYXRDZWxsRGVmPVwibGV0IGVsZW1lbnRcIj4gPGJpemRvYy1pZGVudGl0eS1uYW1lIFtpZGVudGl0eV09J2VsZW1lbnQudXNlcklkJyBjaGF0aW5nPVwicm9vbVwiPjwvYml6ZG9jLWlkZW50aXR5LW5hbWU+PC90ZD5cclxuICA8L25nLWNvbnRhaW5lcj5cclxuXHJcbiAgPG5nLWNvbnRhaW5lciBtYXRDb2x1bW5EZWY9XCJkdXJhdGlvblwiPlxyXG4gICAgPHRoIG1hdC1oZWFkZXItY2VsbCAqbWF0SGVhZGVyQ2VsbERlZiBtYXQtc29ydC1oZWFkZXI+IHt7J0R1cmF0aW9uJyB8IHRyYW5zbGF0ZX19IDwvdGg+XHJcbiAgICA8dGQgbWF0LWNlbGwgKm1hdENlbGxEZWY9XCJsZXQgZWxlbWVudFwiPiA8c3BhbiBbYml6ZG9jVG9vbHRpcF09J2VsZW1lbnQuZHVyYXRpb258YW1EdXJhdGlvbkZvcm1hdCc+e3sgZWxlbWVudC5kdXJhdGlvbiB8IGFtRHVyYXRpb24gOiAncycgfX08L3NwYW4+IDwvdGQ+XHJcbiAgPC9uZy1jb250YWluZXI+XHJcblxyXG4gIDxuZy1jb250YWluZXIgbWF0Q29sdW1uRGVmPVwic3RhbmRhcmRcIj5cclxuICAgIDx0aCBtYXQtaGVhZGVyLWNlbGwgKm1hdEhlYWRlckNlbGxEZWYgbWF0LXNvcnQtaGVhZGVyPiB7eydTdGFuZGFyZCcgfCB0cmFuc2xhdGV9fSA8L3RoPlxyXG4gICAgPHRkIG1hdC1jZWxsICptYXRDZWxsRGVmPVwibGV0IGVsZW1lbnRcIj4gPHNwYW4gKm5nSWY9XCJlbGVtZW50LnN0YW5kYXJkXCIgW2JpemRvY1Rvb2x0aXBdPVwiZWxlbWVudC5zdGFuZGFyZHxhbUR1cmF0aW9uRm9ybWF0XCI+e3sgZWxlbWVudC5zdGFuZGFyZCB8IGFtRHVyYXRpb246ICdzJyB9fTwvc3Bhbj4gPC90ZD5cclxuICA8L25nLWNvbnRhaW5lcj5cclxuXHJcbiAgPG5nLWNvbnRhaW5lciBtYXRDb2x1bW5EZWY9XCJjb3VudFwiPlxyXG4gICAgPHRoIG1hdC1oZWFkZXItY2VsbCAqbWF0SGVhZGVyQ2VsbERlZj4gPC90aD5cclxuICAgIDx0ZCBtYXQtY2VsbCAqbWF0Q2VsbERlZj1cImxldCBlbGVtZW50XCIgZGlyPVwibHRyXCI+XHJcbiAgICAgIDxzcGFuIGNsYXNzPVwicmFuZ2VcIj57eyBlbGVtZW50LnByb2Nlc3NlZCB9fSAvIHt7ZWxlbWVudC5wZW5kaW5nICsgZWxlbWVudC5wcm9jZXNzZWR9fTwvc3Bhbj5cclxuICAgIDwvdGQ+XHJcbiAgPC9uZy1jb250YWluZXI+XHJcblxyXG4gIDx0ciBtYXQtaGVhZGVyLXJvdyAqbWF0SGVhZGVyUm93RGVmPVwiY29sdW1uczsgc3RpY2t5OiB0cnVlXCI+PC90cj5cclxuICA8dHIgbWF0LXJvdyAqbWF0Um93RGVmPVwibGV0IHJvdzsgY29sdW1uczogY29sdW1ucztcIiBAaXRlbT48L3RyPlxyXG48L3RhYmxlPlxyXG48c3R5bGUgc2NvcGVkPlxyXG4gIC5yYW5nZSB7XHJcbiAgICB3aGl0ZS1zcGFjZTogbm93cmFwO1xyXG4gIH1cclxuPC9zdHlsZT5cclxuIl19