@bizdoc/core 1.14.1 → 1.14.2

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.
@@ -177,8 +177,8 @@ let DocumentTraceComponent = class DocumentTraceComponent {
177
177
  this.form.valueChanges.pipe(takeUntil(this._destroy), debounceTime(200)).
178
178
  subscribe(this._list.bind(this));
179
179
  this._pane.queryParamsChange.subscribe(p => {
180
- const { id } = p;
181
- id && this._open(id.decodeId());
180
+ const { documentId } = p;
181
+ documentId && this._open(documentId.decodeId());
182
182
  });
183
183
  this._pane.resize.pipe(takeUntil(this._destroy)).subscribe(() => this.diagram?.refresh());
184
184
  }
@@ -261,7 +261,7 @@ let DocumentTraceComponent = class DocumentTraceComponent {
261
261
  });
262
262
  }
263
263
  open(item) {
264
- this._router.navigate([], { queryParams: { id: item.id.encodeId() } });
264
+ this._router.navigate([], { queryParams: { documentId: item.id.encodeId() } });
265
265
  }
266
266
  _timeline() {
267
267
  const items = [], submissions = [];
@@ -527,4 +527,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.1", ngImpor
527
527
  type: HostListener,
528
528
  args: ['window:keydown.f1', ['$event']]
529
529
  }] } });
530
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"document-trace.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/admin/document-trace/document-trace.component.ts","../../../../../../libraries/core/src/lib/admin/document-trace/document-trace.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewChild, OnInit, OnDestroy, Inject, HostListener, ElementRef, ChangeDetectorRef, TemplateRef } from '@angular/core';\r\nimport { trigger } from '@angular/animations';\r\nimport {\r\n  DiagramConstraints, PointPortModel, NodeConstraints, ScrollSettingsModel, SelectorModel, SelectorConstraints,\r\n  ToolBase, Diagram, MouseEventArgs, ConnectorModel, NodeModel, SnapSettingsModel, DiagramTools, TextModel, ConnectorConstraints, ISelectionChangeEventArgs, LayerModel, ConnectionPointOrigin, LayoutModel\r\n} from '@syncfusion/ej2-angular-diagrams';\r\nimport { FormBuilder } from '@angular/forms';\r\nimport { MatTableDataSource } from '@angular/material/table';\r\nimport { ProgressBarMode } from '@angular/material/progress-bar';\r\nimport { MatSort } from '@angular/material/sort';\r\nimport { MatInput } from '@angular/material/input';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil, debounceTime } from 'rxjs/operators';\r\nimport dayjs from 'dayjs';\r\nimport { IChangedEventArgs, RangeNavigator } from '@syncfusion/ej2-angular-charts';\r\nimport { BizDoc } from '../../core/decorators';\r\nimport { getWarn } from '../../core/functions';\r\nimport { GuideStep } from '../../core/models';\r\nimport { PromptService } from '../../core/prompt.service';\r\nimport { UtilityRef } from '../utility-ref';\r\nimport { DocumentInfo, FormService, RangeModel } from '../form/form.service';\r\nimport { TranslateService } from '../../core/translate.service';\r\nimport { GuideService } from '../../core/guide/guide.service';\r\nimport { PanesRouter } from '../../core/slots/router.service';\r\nimport { PaneRef } from '../../core/slots/pane-ref';\r\nimport { SessionService } from '../../core/session.service';\r\nimport { ConnectorData, DiagramInfo, MoveModel, NodeData, Timeline } from './timeline';\r\nimport { EnterExitRight } from '../../core/animations';\r\nimport { Popup } from '../../core/popup/popup.service';\r\nimport { ElementData, TraceElementComponent } from './trace-element.component';\r\nimport { OpenPolicy } from '../../core/configuration';\r\n\r\nconst WARNNING_PATH = 'M 13.763735,1.8433735 H 6.3037349 l -5.27,5.27 v 7.4599995 l 5.27,5.27 h 7.4600001 l 5.27,-5.27 V 7.1133735 Z m -3.73,14.2999995 c -0.7200001,0 -1.3000001,-0.58 -1.3000001,-1.3 0,-0.72 0.58,-1.3 1.3000001,-1.3 0.72,0 1.3,0.58 1.3,1.3 0,0.72 -0.58,1.3 -1.3,1.3 z m 1,-4.3 H 9.0337349 V 5.8433735 h 2.0000001 z',\r\n  JUMP_PATH = 'M 6,18 14.5,12 6,6 Z M 16,6 v 12 h 2 V 6 Z';\r\n\r\nfunction getPorts(): PointPortModel[] {\r\n  return [\r\n    { id: 'port1', shape: 'Circle', offset: { x: 0, y: 0.5 } },\r\n    { id: 'port2', shape: 'Circle', offset: { x: 0.5, y: 1 } },\r\n    { id: 'port3', shape: 'Circle', offset: { x: 1, y: 0.5 } },\r\n    { id: 'port4', shape: 'Circle', offset: { x: 0.5, y: 0 } }\r\n  ];\r\n}\r\n\r\nclass InfoTool extends ToolBase {\r\n  public mouseDown(args: MouseEventArgs): void {\r\n    if (this.diagram.selectedItems.nodes.length > 0) {\r\n      const node = this.diagram.selectedItems.nodes[0];\r\n      super.mouseDown(args)\r\n      this.tap.next(node);\r\n      this.inAction = true;\r\n    }\r\n  }\r\n  constructor(public diagram: Diagram, public tap: Subject<NodeModel>) {\r\n    super(diagram.commandHandler);\r\n  }\r\n}\r\n\r\n@Component({\r\n  templateUrl: './document-trace.component.html',\r\n  styleUrls: ['./document-trace.component.scss'],\r\n  host: {\r\n    class: 'pane'\r\n  }, animations: [trigger('element', EnterExitRight)]\r\n})\r\n@BizDoc({ selector: 'bizdoc-trace-utility' })\r\n/** workflow component*/\r\nexport class DocumentTraceComponent implements OnInit, OnDestroy {\r\n  @ViewChild('diagram') diagramElement: ElementRef<HTMLDivElement>;\r\n  theme = this._session.theme.dark ? 'MaterialDark' : 'Material';\r\n  accent = this._session.getAccent();\r\n  diagram: Diagram;\r\n  readonly form = this._fb.group({ search: null, formId: null });\r\n  model: DiagramInfo;\r\n  timeline: Timeline;\r\n  diagramConstraints: DiagramConstraints = DiagramConstraints.Default | DiagramConstraints.Bridging |\r\n    DiagramConstraints.LineRouting |\r\n    DiagramConstraints.Pan |\r\n    DiagramConstraints.Zoom;\r\n  diagramTool: DiagramTools = DiagramTools.SingleSelect;\r\n  public readonly layout = {\r\n    type: 'ComplexHierarchicalTree',\r\n    connectionPointOrigin: ConnectionPointOrigin.DifferentPoint,\r\n    horizontalSpacing: 50,\r\n    enableRouting: true,\r\n    verticalSpacing: 50,\r\n    horizontalAlignment: 'Center',\r\n    connectionDirection: 'Orientation',\r\n    orientation: 'TopToBottom'\r\n  } as LayoutModel;\r\n  readonly snapSettings: SnapSettingsModel = {\r\n  };\r\n  readonly scrollSettings: ScrollSettingsModel = {\r\n    minZoom: .5,\r\n    maxZoom: 2.5\r\n  };\r\n  private readonly _accentColor = this._session.getAccent(800);\r\n  private readonly _primeryColor = this._session.getPrimery();\r\n  public readonly selectedItems: SelectorModel = {\r\n    constraints: SelectorConstraints.UserHandle,\r\n    userHandles: [\r\n      {\r\n        name: 'info',\r\n        pathData: 'M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 15h-2v-6h2v6zm0-8h-2V7h2v2z',\r\n        visible: true,\r\n        offset: 0,\r\n        side: 'Right',\r\n        verticalAlignment: 'Bottom',\r\n        backgroundColor: 'transparent',\r\n        pathColor: this._primeryColor,\r\n        size: 40,\r\n        margin: { top: 0, bottom: 0, left: 0, right: 0 }\r\n      }\r\n    ]\r\n  };\r\n  public getCustomTool: Function = this.getTool.bind(this);\r\n  node: NodeModel;\r\n  private _start: number | Date;\r\n  private _end: number | Date;\r\n  private _infoRef: PaneRef<TraceElementComponent>;\r\n  public getTool(action: string): ToolBase {\r\n    let tool: ToolBase;\r\n    if (action === 'info') {\r\n      tool = new InfoTool(this.diagram, this._tap);\r\n    }\r\n    return tool;\r\n  }\r\n  mode: 'diagram' | 'browse' | null = 'browse';\r\n  range: (Date | number)[];\r\n  rangeData: RangeModel[];\r\n  loading: ProgressBarMode = 'query';\r\n  @ViewChild('args') filterArgs: TemplateRef<any>;\r\n  @ViewChild('search') searchInput: MatInput;\r\n  dataSource: MatTableDataSource<DocumentInfo>;\r\n  @ViewChild(MatSort) sort: MatSort;\r\n  @ViewChild(RangeNavigator) rangeNavigator: RangeNavigator;\r\n  readonly displayedColumns = ['number', 'subject', 'stateId'];\r\n  private _highLightedIds: string[] = [];\r\n  private readonly _tap = new Subject<NodeModel>();\r\n  private readonly _destroy = new Subject<void>();\r\n  private readonly _dateschange = new Subject<{ start: number | Date, end: number | Date }>();\r\n  /** workflow ctor */\r\n  constructor(\r\n    @Inject(UtilityRef)\r\n    private _utilityRef: UtilityRef<DiagramInfo, MoveModel, DiagramInfo, number>,\r\n    private _service: FormService,\r\n    private _session: SessionService,\r\n    private _pane: PaneRef<DocumentTraceComponent>,\r\n    private _router: PanesRouter,\r\n    private _sb: PromptService,\r\n    private _translate: TranslateService,\r\n    private _popup: Popup,\r\n    private _guide: GuideService,\r\n    private _cd: ChangeDetectorRef,\r\n    private _fb: FormBuilder) {\r\n  }\r\n  ngOnInit(): void {\r\n    const now = dayjs();\r\n    this._session.themeChange.pipe(takeUntil(this._destroy)).subscribe(t => {\r\n      this.theme = t.dark ? 'MaterialDark' : 'Material';\r\n      this.accent = this._session.getAccent();\r\n      //this.rangeNavigator.refresh();\r\n    });\r\n    this._service.range().subscribe(r => this.rangeData = r);\r\n    this._dateschange.pipe(takeUntil(this._destroy), debounceTime(200)).subscribe(r => {\r\n      this._start = r.start, this._end = r.end;\r\n      this._list();\r\n    });\r\n    this.range = [now.add(-2, 'w').toDate(),\r\n    now.toDate()];\r\n    this.form.valueChanges.pipe(takeUntil(this._destroy), debounceTime(200)).\r\n      subscribe(this._list.bind(this));\r\n    this._pane.queryParamsChange.subscribe(p => {\r\n      const { id } = p;\r\n      id && this._open((id as string).decodeId());\r\n    });\r\n    this._pane.resize.pipe(takeUntil(this._destroy)).subscribe(() =>\r\n      this.diagram?.refresh()\r\n    );\r\n  }\r\n  openFilter(evt: Event) {\r\n    this._popup.open(this.filterArgs, evt.target as HTMLButtonElement).opened.subscribe(() =>\r\n      this.searchInput.focus());\r\n  }\r\n  private _list() {\r\n    this.loading = 'query';\r\n    this._service.findAll({ ...this.form.value, start: this._start, end: this._end }).subscribe(l => {\r\n      this.dataSource = new MatTableDataSource(l);\r\n      this.dataSource.sort = this.sort;\r\n      this.loading = null;\r\n    });\r\n  }\r\n\r\n  public rangeChanged(args: IChangedEventArgs): void {\r\n    this._dateschange.next(args);\r\n  }\r\n  @HostListener('window:keydown.f1', ['$event'])\r\n  guide(evt?: Event | KeyboardEvent) {\r\n    const steps: GuideStep[] = [];\r\n    if (this.timeline) {\r\n      if (this.timeline.items.length > 1)\r\n        steps.push({\r\n          selector: '[data-help=timeline]',\r\n          content: this._translate.get('TraceTimelineHelp')\r\n        });\r\n      steps.push({\r\n        selector: 'g[id^=start]',\r\n        content: this._translate.get('TraceElementHelp'),\r\n      });\r\n    }\r\n    else steps.push({\r\n      selector: '[data-help=search]',\r\n      position: 'Below',\r\n      content: this._translate.get('TraceSearchHelp')\r\n    });\r\n    this._guide.start({\r\n      name: 'trace',\r\n      steps\r\n    });\r\n    evt && evt.preventDefault();\r\n  }\r\n  browse() {\r\n    this._router.navigate([]);\r\n    this._router.collapse();\r\n    this.mode = 'browse';\r\n    this._cd.detectChanges();\r\n    this.dataSource.sort = this.sort;\r\n  }\r\n  private _open(id: number) {\r\n    this.diagram?.destroy();\r\n    this.loading = 'buffer';\r\n    this._utilityRef.populate(id).subscribe(e => {\r\n      this._highLightedIds = [];\r\n      this.model = e;\r\n      this._timeline();\r\n      this.mode = 'diagram';\r\n      this.loading = null;\r\n      this._cd.detectChanges();\r\n      this.diagram = new Diagram({\r\n        width: '100%', height: '100%',\r\n        snapSettings: this.snapSettings,\r\n        layout: this.layout,\r\n        getConnectorDefaults: this.connDefaults,\r\n        selectedItems: this.selectedItems,\r\n        tool: this.diagramTool,\r\n        constraints: this.diagramConstraints,\r\n        getNodeDefaults: this.nodeDefaults,\r\n        scrollSettings: this.scrollSettings,\r\n        nodes: e.diagram.nodes,\r\n        connectors: e.diagram.connectors,\r\n        selectionChange: this.selectionChange.bind(this)\r\n      }, this.diagramElement.nativeElement);\r\n      this._version();\r\n      this._indicators();\r\n      this.diagram.fitToPage();\r\n\r\n    }, () => {\r\n      this.loading = null;\r\n      this._sb.error();\r\n    });\r\n  }\r\n  nodeDefaults = (node: NodeModel): NodeModel => {\r\n    const { indicator, virtual } = node.addInfo as NodeData || {};\r\n\r\n    if (indicator) {\r\n      node.constraints = NodeConstraints.PointerEvents | NodeConstraints.Tooltip,\r\n        node.style.strokeWidth = 0,\r\n        node.width = node.height = 15;\r\n    }\r\n    else if (node.id !== 'version') {\r\n      node.constraints = NodeConstraints.InConnect | NodeConstraints.OutConnect |\r\n        NodeConstraints.PointerEvents | NodeConstraints.Select;\r\n      this._decorateNode(node);\r\n      node.ports = getPorts();\r\n    }\r\n    return node;\r\n  }\r\n  public connDefaults = (connector: ConnectorModel) => {\r\n    const { virtual } = connector.addInfo as ConnectorData || {};\r\n    connector.constraints = ConnectorConstraints.ReadOnly & ~ConnectorConstraints.Select;\r\n\r\n    this._decorateConnector(connector);\r\n  }\r\n  open(item: DocumentInfo) {\r\n    this._router.navigate([], { queryParams: { id: item.id.encodeId() } });\r\n  }\r\n\r\n  private _timeline() {\r\n    const items = [], submissions: Date[] = [];\r\n    let minDate: Date, maxDate: Date, estimate: boolean;\r\n    this.model.log.forEach(l => {\r\n      const { time, userId } = l;\r\n      switch (l.type) {\r\n        case 'Submit':\r\n          submissions.push(time);\r\n          break;\r\n        default:\r\n      }\r\n      if (!items.find(t => t.time === time))\r\n        items.push({ time, userId });\r\n      if (!minDate || dayjs(time).isBefore(minDate)) minDate = time;\r\n      if (!maxDate || dayjs(time).isAfter(maxDate)) maxDate = time;\r\n      if (l.estimate) estimate = true;\r\n    });\r\n    this.timeline = {\r\n      items, minDate, maxDate,\r\n      submissions, estimate\r\n    } as any;\r\n    this._scope(submissions[submissions.length - 1]);\r\n  }\r\n  /**\r\n   * \r\n   * @param date\r\n   */\r\n  private _scope(date: Date) {\r\n    const startDate = this.timeline.submissions.reverse().\r\n      find(s => s <= date),\r\n      nextDate = this.timeline.submissions.find(s => s > date),\r\n      endDate = nextDate ? new Date(new Date(nextDate).valueOf() - 1).toJSON() as any : this.timeline.maxDate;\r\n    Object.assign(this.timeline, {\r\n      startDate,\r\n      endDate,\r\n      recipients: this.model.recipients.filter(r => r.received >= startDate && r.received <= endDate),\r\n      log: this.model.log.filter(l => l.time >= startDate && l.time <= endDate)\r\n    });\r\n  }\r\n  private _indicators() {\r\n    const indicators: NodeModel[] = [];\r\n    this.model.log.forEach(l => {\r\n      switch (l.type) {\r\n        case 'Node':\r\n          if (l.error)\r\n            indicators.push({\r\n              shape: {\r\n                type: 'Path',\r\n                data: WARNNING_PATH,\r\n                align: 'XMinYMax'\r\n              },\r\n              tooltip: {\r\n                content: l.error,\r\n                position: 'BottomCenter'\r\n              },\r\n              style: {\r\n                fill: getWarn(800)\r\n              },\r\n              addInfo: {\r\n                indicator: true,\r\n                parentId: l.nodeId\r\n              }\r\n            });\r\n          break;\r\n        case 'NodeJump':\r\n          //indicators.push({\r\n          //  shape: {\r\n          //    type: 'Path',\r\n          //    data: JUMP_PATH,\r\n          //    align: 'XMinYMax'\r\n          //  },\r\n          //  style: {\r\n          //    fill: 'black'\r\n          //  },\r\n          //  addInfo: {\r\n          //    indicator: true,\r\n          //    parentId: l.nodeId\r\n          //  }\r\n          //});\r\n          break;\r\n      }\r\n    });\r\n    this.diagram.removeLayer('indicators');\r\n    indicators.forEach(i => {\r\n      const parent = this.diagram.getNodeObject((i.addInfo as NodeData).parentId);\r\n      i.offsetX = parent.offsetX + parent.width / 2 - 15,\r\n        i.offsetY = parent.offsetY + parent.height / 2 - 15;\r\n      this.diagram.add(i);\r\n    });\r\n    this.diagram.addLayer({ id: 'indicators' }, indicators);\r\n  }\r\n  private _decorateNode(node: NodeModel) {\r\n    const log = this.timeline.log.filter(r => r.nodeId === node.id);\r\n\r\n    if (log.length) {\r\n      const recipients = this.timeline.recipients.filter(r => r.nodeId === node.id);\r\n\r\n      node.style.strokeColor = this._accentColor;\r\n      node.style.strokeDashArray = log.find(l => l.estimate) ? '3 2' : '';\r\n\r\n      node.style.fill = recipients.find(r => r.pending && !r.estimate) ? this._accentColor : 'white';\r\n    }\r\n    else\r\n      node.style.fill = 'white',\r\n        node.style.strokeColor = 'darkgray',\r\n        node.style.strokeDashArray = '6 2';\r\n  }\r\n  private _decorateConnector(connector: ConnectorModel) {\r\n    const log = this.timeline.log.filter(l => l.sourceId === connector.sourceID && l.targetId == connector.targetID);\r\n\r\n    if (log.length) {\r\n      connector.style.strokeColor = connector.targetDecorator.style.strokeColor = connector.targetDecorator.style.fill =\r\n        this._accentColor;\r\n      connector.style.strokeDashArray = log.find(l => l.estimate) ? '3 2' : '';\r\n    }\r\n    else\r\n      connector.style.strokeColor = connector.targetDecorator.style.strokeColor = connector.targetDecorator.style.fill = 'darkgray',\r\n        connector.style.strokeDashArray = '6 2';\r\n  }\r\n  private _version() {\r\n    this.diagram.removeLayer(\r\n      'version');\r\n    const version = {\r\n      id: 'version',\r\n      shape: {\r\n        type: 'Text',\r\n        content: this._translate.get('DiagramVersion', this.model.diagram.version)\r\n      },\r\n      offsetY: 5,\r\n      offsetX: 5,\r\n      style: {\r\n        fontSize: 50,\r\n        opacity: .1\r\n      },\r\n      constraints: NodeConstraints.ReadOnly\r\n    } as TextModel;\r\n    this.diagram.addLayer({\r\n      id: 'version',\r\n      objects: [\r\n        version]\r\n    } as LayerModel);\r\n    this.diagram.add(version);\r\n  }\r\n  selectionChange(evt: ISelectionChangeEventArgs) {\r\n    if (evt.state !== 'Changed') return;\r\n    this._unhighlight();\r\n    if (evt.newValue.length) {\r\n      let node = evt.newValue[0] as NodeModel;\r\n\r\n      const { indicator, parentId } = node.addInfo as NodeData || {};\r\n\r\n      if (indicator) {\r\n        node = this.diagram.getNodeObject(parentId);\r\n        this.diagram.select([node]);\r\n      }\r\n      else {\r\n        const ids = ((node as any).inEdges).concat((node as any).outEdges);\r\n        ids.push(node.id);\r\n        this._highlight(ids);\r\n      }\r\n      this.diagram.dataBind();\r\n      if (node) {\r\n        if (this._infoRef) this._infoRef.close();\r\n        this._router.navigate(TraceElementComponent, {\r\n          state: {\r\n            node,\r\n            timeline: this.timeline,\r\n            model: this.model,\r\n            utilityRef: this._utilityRef,\r\n          } as ElementData,\r\n          policy: OpenPolicy.Tab\r\n        }).then((e: PaneRef) => {\r\n          this._infoRef = e;\r\n          e.animation\r\n        });\r\n      }\r\n      else this._router.collapse();\r\n    }\r\n    else\r\n      this.node = null;\r\n  }\r\n  public highlightTime(time: Date) {\r\n    this.timeline.date = time;\r\n    this.diagram.clearSelection();\r\n    this._unhighlight();\r\n    if (time < this.timeline.startDate || time > this.timeline.endDate) {\r\n      this._scope(time);\r\n      for (let i = 0; i < this.diagram.nodes.length; i++)\r\n        this._decorateNode(this.diagram.nodes[i]);\r\n      for (let i = 0; i < this.diagram.connectors.length; i++)\r\n        this._decorateConnector(this.diagram.connectors[i]);\r\n    }\r\n\r\n    const ids = this.timeline.log.filter(l => l.nodeId && l.time === time).map(l => l.nodeId).\r\n      filter((v, i, a) => a.indexOf(v) === i);\r\n\r\n    this._highlight(ids);\r\n    this.diagram.dataBind();\r\n  }\r\n\r\n  pan() {\r\n    this.diagram.constraints = this.diagram.constraints | DiagramConstraints.Pan;\r\n    this.diagram.tool = DiagramTools.ZoomPan;\r\n  }\r\n  cursor() {\r\n    this.diagram.constraints = this.diagram.constraints & ~DiagramConstraints.Pan;\r\n    this.diagram.tool = DiagramTools.SingleSelect;\r\n  }\r\n  private _highlight(ids: string[]) {\r\n    for (let i = 0; i < ids.length; i++) {\r\n      const obj = this.diagram.getObject(ids[i]) as any;\r\n      if (obj.sourceID)\r\n        obj.style.strokeColor =\r\n          obj.targetDecorator.style.strokeColor =\r\n          obj.targetDecorator.style.fill = this._primeryColor;\r\n      else\r\n        obj.style.strokeColor = this._primeryColor;\r\n    }\r\n    this._highLightedIds = ids;\r\n  }\r\n\r\n  private _unhighlight(): void {\r\n    for (let i: number = this._highLightedIds.length - 1; i >= 0; i--) {\r\n      const obj = this.diagram.getObject(this._highLightedIds[i]) as any;\r\n      if (obj.sourceID)\r\n        this._decorateConnector(obj);\r\n      else\r\n        this._decorateNode(obj);\r\n    }\r\n    this._highLightedIds = [];\r\n  }\r\n  ngOnDestroy(): void {\r\n    this._destroy.next();\r\n    this._destroy.complete();\r\n  }\r\n}\r\n","<ng-container [ngSwitch]=\"mode\">\r\n  <!-- diagram -->\r\n  <div *ngSwitchCase=\"'diagram'\" class=\"column\" fxFlex>\r\n    <mat-toolbar>\r\n      <button mat-icon-button (click)=\"browse()\" [bizdocTooltip]=\"'Back' | translate\"><mat-icon class=\"mat-icon-rtl-mirror\">arrow_back</mat-icon></button>\r\n      |\r\n      <button mat-icon-button (click)=\"pan()\" [bizdocTooltip]=\"'Pan' | translate\"><span class=\"e-icons sf-icon-pan\"></span></button>\r\n      <button mat-icon-button (click)=\"cursor()\" [bizdocTooltip]=\"'Cursor' | translate\"><span class=\"e-icons sf-icon-cursor\"></span></button>\r\n      <span class=\"divider\"></span>\r\n      <button mat-icon-button (click)=\"guide()\" [bizdocTooltip]=\"'Help' | translate\"><mat-icon>help_outline</mat-icon></button>\r\n    </mat-toolbar>\r\n    <div class=\"row\" fxFlex>\r\n      <!-- timeline -->\r\n      <div class=\"timeline\" *ngIf=\"timeline?.items.length > 1\" data-help=\"timeline\">\r\n        <div *ngFor=\"let date of timeline.items; let last = last\" class=\"item\"\r\n             [class.active]=\"date.time === timeline.date\"\r\n             (click)=\"highlightTime(date.time)\" matRipple>\r\n          <div class=\"title\">\r\n            <ng-container *ngIf=\"!last || !timeline.estimate; else estimate\">\r\n              <span class=\"who\" *ngIf=\"userId\">\r\n                {{date.userId | userName | async }}\r\n              </span>\r\n              <br />\r\n              <span class=\"time\">\r\n                {{date.time | amDateFormat: 'MMM Do H:mm' }}\r\n              </span>\r\n            </ng-container>\r\n          </div>\r\n          <div class=\"indicator-container\">\r\n            <div class=\"indicator\"></div>\r\n          </div>\r\n        </div>\r\n      </div>\r\n      <div fxFlex #diagram dir=\"ltr\">\r\n      </div>\r\n    </div>\r\n  </div>\r\n  <!-- browse -->\r\n  <div *ngSwitchDefault fxFlex fxLayout=\"column\" fxFlexFill>\r\n    <mat-toolbar fxLayout=\"row\">\r\n      <span class=\"divider\"></span>\r\n      <button mat-icon-button (click)=\"openFilter($event)\" [bizdocTooltip]=\"'Filter'|translate\"><mat-icon>filter_list</mat-icon></button>\r\n    </mat-toolbar>\r\n    <mat-progress-bar [mode]=\"loading\" [style.visibility]=\"loading ? 'visible':'hidden'\"></mat-progress-bar>\r\n    <!-- table -->\r\n    <mat-table fxFlex [dataSource]=\"dataSource\" matSort>\r\n      <!-- Number column -->\r\n      <ng-container matColumnDef=\"number\">\r\n        <mat-header-cell *matHeaderCellDef mat-sort-header>{{'Number' | translate}}</mat-header-cell>\r\n        <mat-cell *matCellDef=\"let item\" class=\"data-column\"> {{item.number}} </mat-cell>\r\n      </ng-container>\r\n\r\n      <!-- Subject column -->\r\n      <ng-container matColumnDef=\"subject\">\r\n        <mat-header-cell *matHeaderCellDef mat-sort-header>{{'Subject' | translate}}</mat-header-cell>\r\n        <mat-cell *matCellDef=\"let item\" class=\"data-column\"> {{item.subject}} </mat-cell>\r\n      </ng-container>\r\n      <!-- StateId column -->\r\n      <ng-container matColumnDef=\"stateId\">\r\n        <mat-header-cell *matHeaderCellDef mat-sort-header=\"stateId\">{{'Status' | translate }}</mat-header-cell>\r\n        <mat-cell *matCellDef=\"let item\" class=\"data-column\">\r\n          <bizdoc-status [stateId]=\"item.stateId\"></bizdoc-status>\r\n        </mat-cell>\r\n      </ng-container>\r\n      <mat-header-row *matHeaderRowDef=\"displayedColumns; sticky: true\"></mat-header-row>\r\n      <mat-row *matRowDef=\"let item; columns: displayedColumns;\"\r\n               (click)=\"open(item)\">\r\n      </mat-row>\r\n    </mat-table>\r\n    <!-- range -->\r\n    <ejs-rangenavigator valueType='DateTime' [value]=range labelFormat='MMM-dd' background=\"transparent\"\r\n                        [theme]=\"theme\" labelIntersectAction='Hide' enableGrouping=\"false\"\r\n                        groupBy=\"Years\" intervalType='Days'\r\n                        (changed)='rangeChanged($event)'>\r\n      <e-rangenavigator-series-collection>\r\n        <e-rangenavigator-series [dataSource]='rangeData' [fill]=\"accent\" type='Area' xName='date' yName='count' width=2>\r\n        </e-rangenavigator-series>\r\n      </e-rangenavigator-series-collection>\r\n    </ejs-rangenavigator>\r\n  </div>\r\n</ng-container>\r\n<!-- args -->\r\n<ng-template #args>\r\n  <form autocomplete=\"off\" [formGroup]=\"form\" fxLayout=\"column\">\r\n    <mat-form-field>\r\n      <input matInput type=\"search\" #search formControlName=\"search\" data-help=\"search\" [placeholder]=\"'Number'|translate\" />\r\n      <mat-icon matSuffix class=\"mat-icon-rtl-mirror\">search</mat-icon>\r\n    </mat-form-field>\r\n    <mat-form-field>\r\n      <bizdoc-select type=\"forms\" [placeholder]=\"'Form'|translate\" formControlName=\"formId\"></bizdoc-select>\r\n    </mat-form-field>\r\n  </form>\r\n</ng-template>\r\n<ng-template #estimate>\r\n  {{'Estimate' | translate}}\r\n</ng-template>\r\n"]}
530
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"document-trace.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/admin/document-trace/document-trace.component.ts","../../../../../../libraries/core/src/lib/admin/document-trace/document-trace.component.html"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAE,SAAS,EAAqB,MAAM,EAAE,YAAY,EAA8C,MAAM,eAAe,CAAC;AAC1I,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAC9C,OAAO,EACL,kBAAkB,EAAkB,eAAe,EAAsC,mBAAmB,EAC5G,QAAQ,EAAE,OAAO,EAAgE,YAAY,EAAa,oBAAoB,EAAyC,qBAAqB,EAC7L,MAAM,kCAAkC,CAAC;AAE1C,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAE7D,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAEjD,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AACzD,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAqB,cAAc,EAAE,MAAM,gCAAgC,CAAC;AACnF,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAC/C,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAG/C,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAQ5C,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAEvD,OAAO,EAAe,qBAAqB,EAAE,MAAM,2BAA2B,CAAC;AAC/E,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEtD,MAAM,aAAa,GAAG,sTAAsT,EAC1U,SAAS,GAAG,4CAA4C,CAAC;AAE3D,SAAS,QAAQ;IACf,OAAO;QACL,EAAE,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,EAAE,EAAE;QAC1D,EAAE,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE;QAC1D,EAAE,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,EAAE,EAAE;QAC1D,EAAE,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE;KAC3D,CAAC;AACJ,CAAC;AAED,MAAM,QAAS,SAAQ,QAAQ;IAS7B,YAAmB,OAAgB,EAAS,GAAuB;QACjE,KAAK,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC;QADb,YAAO,GAAP,OAAO,CAAS;QAAS,QAAG,GAAH,GAAG,CAAoB;IAEnE,CAAC;IAVM,SAAS,CAAC,IAAoB;QACnC,IAAI,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;YAC/C,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YACjD,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,CAAA;YACrB,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACpB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;SACtB;IACH,CAAC;CAIF;IAWY,sBAAsB,SAAtB,sBAAsB;IA0EjC,oBAAoB;IACpB,YAEU,WAAoE,EACpE,QAAqB,EACrB,QAAwB,EACxB,KAAsC,EACtC,OAAoB,EACpB,GAAkB,EAClB,UAA4B,EAC5B,MAAa,EACb,MAAoB,EACpB,GAAsB,EACtB,GAAgB;QAVhB,gBAAW,GAAX,WAAW,CAAyD;QACpE,aAAQ,GAAR,QAAQ,CAAa;QACrB,aAAQ,GAAR,QAAQ,CAAgB;QACxB,UAAK,GAAL,KAAK,CAAiC;QACtC,YAAO,GAAP,OAAO,CAAa;QACpB,QAAG,GAAH,GAAG,CAAe;QAClB,eAAU,GAAV,UAAU,CAAkB;QAC5B,WAAM,GAAN,MAAM,CAAO;QACb,WAAM,GAAN,MAAM,CAAc;QACpB,QAAG,GAAH,GAAG,CAAmB;QACtB,QAAG,GAAH,GAAG,CAAa;QArF1B,UAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,UAAU,CAAC;QAC/D,WAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE,CAAC;QAE1B,SAAI,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC;QAG/D,uBAAkB,GAAuB,kBAAkB,CAAC,OAAO,GAAG,kBAAkB,CAAC,QAAQ;YAC/F,kBAAkB,CAAC,WAAW;YAC9B,kBAAkB,CAAC,GAAG;YACtB,kBAAkB,CAAC,IAAI,CAAC;QAC1B,gBAAW,GAAiB,YAAY,CAAC,YAAY,CAAC;QACtC,WAAM,GAAG;YACvB,IAAI,EAAE,yBAAyB;YAC/B,qBAAqB,EAAE,qBAAqB,CAAC,cAAc;YAC3D,iBAAiB,EAAE,EAAE;YACrB,aAAa,EAAE,IAAI;YACnB,eAAe,EAAE,EAAE;YACnB,mBAAmB,EAAE,QAAQ;YAC7B,mBAAmB,EAAE,aAAa;YAClC,WAAW,EAAE,aAAa;SACZ,CAAC;QACR,iBAAY,GAAsB,EAC1C,CAAC;QACO,mBAAc,GAAwB;YAC7C,OAAO,EAAE,EAAE;YACX,OAAO,EAAE,GAAG;SACb,CAAC;QACe,iBAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;QAC5C,kBAAa,GAAG,IAAI,CAAC,QAAQ,CAAC,UAAU,EAAE,CAAC;QAC5C,kBAAa,GAAkB;YAC7C,WAAW,EAAE,mBAAmB,CAAC,UAAU;YAC3C,WAAW,EAAE;gBACX;oBACE,IAAI,EAAE,MAAM;oBACZ,QAAQ,EAAE,kGAAkG;oBAC5G,OAAO,EAAE,IAAI;oBACb,MAAM,EAAE,CAAC;oBACT,IAAI,EAAE,OAAO;oBACb,iBAAiB,EAAE,QAAQ;oBAC3B,eAAe,EAAE,aAAa;oBAC9B,SAAS,EAAE,IAAI,CAAC,aAAa;oBAC7B,IAAI,EAAE,EAAE;oBACR,MAAM,EAAE,EAAE,GAAG,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE;iBACjD;aACF;SACF,CAAC;QACK,kBAAa,GAAa,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAYzD,SAAI,GAAgC,QAAQ,CAAC;QAG7C,YAAO,GAAoB,OAAO,CAAC;QAM1B,qBAAgB,GAAG,CAAC,QAAQ,EAAE,SAAS,EAAE,SAAS,CAAC,CAAC;QACrD,oBAAe,GAAa,EAAE,CAAC;QACtB,SAAI,GAAG,IAAI,OAAO,EAAa,CAAC;QAChC,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;QAC/B,iBAAY,GAAG,IAAI,OAAO,EAAgD,CAAC;QAyH5F,iBAAY,GAAG,CAAC,IAAe,EAAa,EAAE;YAC5C,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC,OAAmB,IAAI,EAAE,CAAC;YAE9D,IAAI,SAAS,EAAE;gBACb,IAAI,CAAC,WAAW,GAAG,eAAe,CAAC,aAAa,GAAG,eAAe,CAAC,OAAO;oBACxE,IAAI,CAAC,KAAK,CAAC,WAAW,GAAG,CAAC;oBAC1B,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;aACjC;iBACI,IAAI,IAAI,CAAC,EAAE,KAAK,SAAS,EAAE;gBAC9B,IAAI,CAAC,WAAW,GAAG,eAAe,CAAC,SAAS,GAAG,eAAe,CAAC,UAAU;oBACvE,eAAe,CAAC,aAAa,GAAG,eAAe,CAAC,MAAM,CAAC;gBACzD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;gBACzB,IAAI,CAAC,KAAK,GAAG,QAAQ,EAAE,CAAC;aACzB;YACD,OAAO,IAAI,CAAC;QACd,CAAC,CAAA;QACM,iBAAY,GAAG,CAAC,SAAyB,EAAE,EAAE;YAClD,MAAM,EAAE,OAAO,EAAE,GAAG,SAAS,CAAC,OAAwB,IAAI,EAAE,CAAC;YAC7D,SAAS,CAAC,WAAW,GAAG,oBAAoB,CAAC,QAAQ,GAAG,CAAC,oBAAoB,CAAC,MAAM,CAAC;YAErF,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC;QACrC,CAAC,CAAA;IA/HD,CAAC;IAnCM,OAAO,CAAC,MAAc;QAC3B,IAAI,IAAc,CAAC;QACnB,IAAI,MAAM,KAAK,MAAM,EAAE;YACrB,IAAI,GAAG,IAAI,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;SAC9C;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IA8BD,QAAQ;QACN,MAAM,GAAG,GAAG,KAAK,EAAE,CAAC;QACpB,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;YACrE,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,UAAU,CAAC;YAClD,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE,CAAC;YACxC,gCAAgC;QAClC,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC,CAAC;QACzD,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;YAChF,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,KAAK,EAAE,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC,GAAG,CAAC;YACzC,IAAI,CAAC,KAAK,EAAE,CAAC;QACf,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,KAAK,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,MAAM,EAAE;YACvC,GAAG,CAAC,MAAM,EAAE,CAAC,CAAC;QACd,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,YAAY,CAAC,GAAG,CAAC,CAAC;YACtE,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QACnC,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;YACzC,MAAM,EAAE,UAAU,EAAE,GAAG,CAAC,CAAC;YACzB,UAAU,IAAI,IAAI,CAAC,KAAK,CAAE,UAAqB,CAAC,QAAQ,EAAE,CAAC,CAAC;QAC9D,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE,CAC9D,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,CACxB,CAAC;IACJ,CAAC;IACD,UAAU,CAAC,GAAU;QACnB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,GAAG,CAAC,MAA2B,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,EAAE,CACvF,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC,CAAC;IAC9B,CAAC;IACO,KAAK;QACX,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,GAAG,EAAE,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;YAC9F,IAAI,CAAC,UAAU,GAAG,IAAI,kBAAkB,CAAC,CAAC,CAAC,CAAC;YAC5C,IAAI,CAAC,UAAU,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;YACjC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACtB,CAAC,CAAC,CAAC;IACL,CAAC;IAEM,YAAY,CAAC,IAAuB;QACzC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC/B,CAAC;IAED,KAAK,CAAC,GAA2B;QAC/B,MAAM,KAAK,GAAgB,EAAE,CAAC;QAC9B,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC;gBAChC,KAAK,CAAC,IAAI,CAAC;oBACT,QAAQ,EAAE,sBAAsB;oBAChC,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,mBAAmB,CAAC;iBAClD,CAAC,CAAC;YACL,KAAK,CAAC,IAAI,CAAC;gBACT,QAAQ,EAAE,cAAc;gBACxB,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,kBAAkB,CAAC;aACjD,CAAC,CAAC;SACJ;;YACI,KAAK,CAAC,IAAI,CAAC;gBACd,QAAQ,EAAE,oBAAoB;gBAC9B,QAAQ,EAAE,OAAO;gBACjB,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,iBAAiB,CAAC;aAChD,CAAC,CAAC;QACH,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;YAChB,IAAI,EAAE,OAAO;YACb,KAAK;SACN,CAAC,CAAC;QACH,GAAG,IAAI,GAAG,CAAC,cAAc,EAAE,CAAC;IAC9B,CAAC;IACD,MAAM;QACJ,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;QAC1B,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;QACxB,IAAI,CAAC,IAAI,GAAG,QAAQ,CAAC;QACrB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QACzB,IAAI,CAAC,UAAU,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;IACnC,CAAC;IACO,KAAK,CAAC,EAAU;QACtB,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,CAAC;QACxB,IAAI,CAAC,OAAO,GAAG,QAAQ,CAAC;QACxB,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;YAC1C,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;YAC1B,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;YACf,IAAI,CAAC,SAAS,EAAE,CAAC;YACjB,IAAI,CAAC,IAAI,GAAG,SAAS,CAAC;YACtB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;YACpB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;YACzB,IAAI,CAAC,OAAO,GAAG,IAAI,OAAO,CAAC;gBACzB,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM;gBAC7B,YAAY,EAAE,IAAI,CAAC,YAAY;gBAC/B,MAAM,EAAE,IAAI,CAAC,MAAM;gBACnB,oBAAoB,EAAE,IAAI,CAAC,YAAY;gBACvC,aAAa,EAAE,IAAI,CAAC,aAAa;gBACjC,IAAI,EAAE,IAAI,CAAC,WAAW;gBACtB,WAAW,EAAE,IAAI,CAAC,kBAAkB;gBACpC,eAAe,EAAE,IAAI,CAAC,YAAY;gBAClC,cAAc,EAAE,IAAI,CAAC,cAAc;gBACnC,KAAK,EAAE,CAAC,CAAC,OAAO,CAAC,KAAK;gBACtB,UAAU,EAAE,CAAC,CAAC,OAAO,CAAC,UAAU;gBAChC,eAAe,EAAE,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC;aACjD,EAAE,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC,CAAC;YACtC,IAAI,CAAC,QAAQ,EAAE,CAAC;YAChB,IAAI,CAAC,WAAW,EAAE,CAAC;YACnB,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,CAAC;QAE3B,CAAC,EAAE,GAAG,EAAE;YACN,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;YACpB,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,CAAC;QACnB,CAAC,CAAC,CAAC;IACL,CAAC;IAuBD,IAAI,CAAC,IAAkB;QACrB,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,EAAE,EAAE,WAAW,EAAE,EAAE,UAAU,EAAE,IAAI,CAAC,EAAE,CAAC,QAAQ,EAAE,EAAE,EAAE,CAAC,CAAC;IACjF,CAAC;IAEO,SAAS;QACf,MAAM,KAAK,GAAG,EAAE,EAAE,WAAW,GAAW,EAAE,CAAC;QAC3C,IAAI,OAAa,EAAE,OAAa,EAAE,QAAiB,CAAC;QACpD,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;YACzB,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,CAAC,CAAC;YAC3B,QAAQ,CAAC,CAAC,IAAI,EAAE;gBACd,KAAK,QAAQ;oBACX,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;oBACvB,MAAM;gBACR,QAAQ;aACT;YACD,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC;gBACnC,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,CAAC;YAC/B,IAAI,CAAC,OAAO,IAAI,KAAK,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC;gBAAE,OAAO,GAAG,IAAI,CAAC;YAC9D,IAAI,CAAC,OAAO,IAAI,KAAK,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC;gBAAE,OAAO,GAAG,IAAI,CAAC;YAC7D,IAAI,CAAC,CAAC,QAAQ;gBAAE,QAAQ,GAAG,IAAI,CAAC;QAClC,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,QAAQ,GAAG;YACd,KAAK,EAAE,OAAO,EAAE,OAAO;YACvB,WAAW,EAAE,QAAQ;SACf,CAAC;QACT,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC;IACnD,CAAC;IACD;;;OAGG;IACK,MAAM,CAAC,IAAU;QACvB,MAAM,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,OAAO,EAAE;YACnD,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,IAAI,CAAC,EACpB,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,EACxD,OAAO,GAAG,QAAQ,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,CAAC,MAAM,EAAS,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC;QAC1G,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,EAAE;YAC3B,SAAS;YACT,OAAO;YACP,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,IAAI,SAAS,IAAI,CAAC,CAAC,QAAQ,IAAI,OAAO,CAAC;YAC/F,GAAG,EAAE,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,IAAI,SAAS,IAAI,CAAC,CAAC,IAAI,IAAI,OAAO,CAAC;SAC1E,CAAC,CAAC;IACL,CAAC;IACO,WAAW;QACjB,MAAM,UAAU,GAAgB,EAAE,CAAC;QACnC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;YACzB,QAAQ,CAAC,CAAC,IAAI,EAAE;gBACd,KAAK,MAAM;oBACT,IAAI,CAAC,CAAC,KAAK;wBACT,UAAU,CAAC,IAAI,CAAC;4BACd,KAAK,EAAE;gCACL,IAAI,EAAE,MAAM;gCACZ,IAAI,EAAE,aAAa;gCACnB,KAAK,EAAE,UAAU;6BAClB;4BACD,OAAO,EAAE;gCACP,OAAO,EAAE,CAAC,CAAC,KAAK;gCAChB,QAAQ,EAAE,cAAc;6BACzB;4BACD,KAAK,EAAE;gCACL,IAAI,EAAE,OAAO,CAAC,GAAG,CAAC;6BACnB;4BACD,OAAO,EAAE;gCACP,SAAS,EAAE,IAAI;gCACf,QAAQ,EAAE,CAAC,CAAC,MAAM;6BACnB;yBACF,CAAC,CAAC;oBACL,MAAM;gBACR,KAAK,UAAU;oBACb,mBAAmB;oBACnB,YAAY;oBACZ,mBAAmB;oBACnB,sBAAsB;oBACtB,uBAAuB;oBACvB,MAAM;oBACN,YAAY;oBACZ,mBAAmB;oBACnB,MAAM;oBACN,cAAc;oBACd,sBAAsB;oBACtB,wBAAwB;oBACxB,KAAK;oBACL,KAAK;oBACL,MAAM;aACT;QACH,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC;QACvC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;YACrB,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAE,CAAC,CAAC,OAAoB,CAAC,QAAQ,CAAC,CAAC;YAC5E,CAAC,CAAC,OAAO,GAAG,MAAM,CAAC,OAAO,GAAG,MAAM,CAAC,KAAK,GAAG,CAAC,GAAG,EAAE;gBAChD,CAAC,CAAC,OAAO,GAAG,MAAM,CAAC,OAAO,GAAG,MAAM,CAAC,MAAM,GAAG,CAAC,GAAG,EAAE,CAAC;YACtD,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACtB,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,EAAE,EAAE,YAAY,EAAE,EAAE,UAAU,CAAC,CAAC;IAC1D,CAAC;IACO,aAAa,CAAC,IAAe;QACnC,MAAM,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,IAAI,CAAC,EAAE,CAAC,CAAC;QAEhE,IAAI,GAAG,CAAC,MAAM,EAAE;YACd,MAAM,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,IAAI,CAAC,EAAE,CAAC,CAAC;YAE9E,IAAI,CAAC,KAAK,CAAC,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC;YAC3C,IAAI,CAAC,KAAK,CAAC,eAAe,GAAG,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;YAEpE,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,OAAO,CAAC;SAChG;;YAEC,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,OAAO;gBACvB,IAAI,CAAC,KAAK,CAAC,WAAW,GAAG,UAAU;gBACnC,IAAI,CAAC,KAAK,CAAC,eAAe,GAAG,KAAK,CAAC;IACzC,CAAC;IACO,kBAAkB,CAAC,SAAyB;QAClD,MAAM,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,SAAS,CAAC,QAAQ,IAAI,CAAC,CAAC,QAAQ,IAAI,SAAS,CAAC,QAAQ,CAAC,CAAC;QAEjH,IAAI,GAAG,CAAC,MAAM,EAAE;YACd,SAAS,CAAC,KAAK,CAAC,WAAW,GAAG,SAAS,CAAC,eAAe,CAAC,KAAK,CAAC,WAAW,GAAG,SAAS,CAAC,eAAe,CAAC,KAAK,CAAC,IAAI;gBAC9G,IAAI,CAAC,YAAY,CAAC;YACpB,SAAS,CAAC,KAAK,CAAC,eAAe,GAAG,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;SAC1E;;YAEC,SAAS,CAAC,KAAK,CAAC,WAAW,GAAG,SAAS,CAAC,eAAe,CAAC,KAAK,CAAC,WAAW,GAAG,SAAS,CAAC,eAAe,CAAC,KAAK,CAAC,IAAI,GAAG,UAAU;gBAC3H,SAAS,CAAC,KAAK,CAAC,eAAe,GAAG,KAAK,CAAC;IAC9C,CAAC;IACO,QAAQ;QACd,IAAI,CAAC,OAAO,CAAC,WAAW,CACtB,SAAS,CAAC,CAAC;QACb,MAAM,OAAO,GAAG;YACd,EAAE,EAAE,SAAS;YACb,KAAK,EAAE;gBACL,IAAI,EAAE,MAAM;gBACZ,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,gBAAgB,EAAE,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC;aAC3E;YACD,OAAO,EAAE,CAAC;YACV,OAAO,EAAE,CAAC;YACV,KAAK,EAAE;gBACL,QAAQ,EAAE,EAAE;gBACZ,OAAO,EAAE,EAAE;aACZ;YACD,WAAW,EAAE,eAAe,CAAC,QAAQ;SACzB,CAAC;QACf,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC;YACpB,EAAE,EAAE,SAAS;YACb,OAAO,EAAE;gBACP,OAAO;aAAC;SACG,CAAC,CAAC;QACjB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;IAC5B,CAAC;IACD,eAAe,CAAC,GAA8B;QAC5C,IAAI,GAAG,CAAC,KAAK,KAAK,SAAS;YAAE,OAAO;QACpC,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,IAAI,GAAG,CAAC,QAAQ,CAAC,MAAM,EAAE;YACvB,IAAI,IAAI,GAAG,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAc,CAAC;YAExC,MAAM,EAAE,SAAS,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAC,OAAmB,IAAI,EAAE,CAAC;YAE/D,IAAI,SAAS,EAAE;gBACb,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;gBAC5C,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;aAC7B;iBACI;gBACH,MAAM,GAAG,GAAG,CAAE,IAAY,CAAC,OAAO,CAAC,CAAC,MAAM,CAAE,IAAY,CAAC,QAAQ,CAAC,CAAC;gBACnE,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;gBAClB,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;aACtB;YACD,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;YACxB,IAAI,IAAI,EAAE;gBACR,IAAI,IAAI,CAAC,QAAQ;oBAAE,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;gBACzC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,qBAAqB,EAAE;oBAC3C,KAAK,EAAE;wBACL,IAAI;wBACJ,QAAQ,EAAE,IAAI,CAAC,QAAQ;wBACvB,KAAK,EAAE,IAAI,CAAC,KAAK;wBACjB,UAAU,EAAE,IAAI,CAAC,WAAW;qBACd;oBAChB,MAAM,EAAE,UAAU,CAAC,GAAG;iBACvB,CAAC,CAAC,IAAI,CAAC,CAAC,CAAU,EAAE,EAAE;oBACrB,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC;oBAClB,CAAC,CAAC,SAAS,CAAA;gBACb,CAAC,CAAC,CAAC;aACJ;;gBACI,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;SAC9B;;YAEC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;IACrB,CAAC;IACM,aAAa,CAAC,IAAU;QAC7B,IAAI,CAAC,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC;QAC1B,IAAI,CAAC,OAAO,CAAC,cAAc,EAAE,CAAC;QAC9B,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,IAAI,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,IAAI,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE;YAClE,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;YAClB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE;gBAChD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;YAC5C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE;gBACrD,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;SACvD;QAED,MAAM,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,IAAI,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC;YACvF,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;QAE1C,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;QACrB,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;IAC1B,CAAC;IAED,GAAG;QACD,IAAI,CAAC,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,GAAG,kBAAkB,CAAC,GAAG,CAAC;QAC7E,IAAI,CAAC,OAAO,CAAC,IAAI,GAAG,YAAY,CAAC,OAAO,CAAC;IAC3C,CAAC;IACD,MAAM;QACJ,IAAI,CAAC,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,GAAG,CAAC,kBAAkB,CAAC,GAAG,CAAC;QAC9E,IAAI,CAAC,OAAO,CAAC,IAAI,GAAG,YAAY,CAAC,YAAY,CAAC;IAChD,CAAC;IACO,UAAU,CAAC,GAAa;QAC9B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YACnC,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,CAAQ,CAAC;YAClD,IAAI,GAAG,CAAC,QAAQ;gBACd,GAAG,CAAC,KAAK,CAAC,WAAW;oBACnB,GAAG,CAAC,eAAe,CAAC,KAAK,CAAC,WAAW;wBACrC,GAAG,CAAC,eAAe,CAAC,KAAK,CAAC,IAAI,GAAG,IAAI,CAAC,aAAa,CAAC;;gBAEtD,GAAG,CAAC,KAAK,CAAC,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC;SAC9C;QACD,IAAI,CAAC,eAAe,GAAG,GAAG,CAAC;IAC7B,CAAC;IAEO,YAAY;QAClB,KAAK,IAAI,CAAC,GAAW,IAAI,CAAC,eAAe,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE;YACjE,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,CAAQ,CAAC;YACnE,IAAI,GAAG,CAAC,QAAQ;gBACd,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC;;gBAE7B,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;SAC3B;QACD,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;IAC5B,CAAC;IACD,WAAW;QACT,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;CACF,CAAA;mHAvcY,sBAAsB,kBA4EvB,UAAU;uGA5ET,sBAAsB,0bAmEtB,OAAO,iFACP,cAAc,gDCvI3B,43JAgGA,q9NDjCiB,CAAC,OAAO,CAAC,SAAS,EAAE,cAAc,CAAC,CAAC;AAIxC,sBAAsB;IAFlC,MAAM,CAAC,EAAE,QAAQ,EAAE,sBAAsB,EAAE,CAAC;IAC7C,wBAAwB;GACX,sBAAsB,CAuclC;SAvcY,sBAAsB;2FAAtB,sBAAsB;kBATlC,SAAS;2BAGF;wBACJ,KAAK,EAAE,MAAM;qBACd,cAAc,CAAC,OAAO,CAAC,SAAS,EAAE,cAAc,CAAC,CAAC;;0BAgFhD,MAAM;2BAAC,UAAU;uTA3EE,cAAc;sBAAnC,SAAS;uBAAC,SAAS;gBA+DD,UAAU;sBAA5B,SAAS;uBAAC,MAAM;gBACI,WAAW;sBAA/B,SAAS;uBAAC,QAAQ;gBAEC,IAAI;sBAAvB,SAAS;uBAAC,OAAO;gBACS,cAAc;sBAAxC,SAAS;uBAAC,cAAc;gBA8DzB,KAAK;sBADJ,YAAY;uBAAC,mBAAmB,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import { Component, ViewChild, OnInit, OnDestroy, Inject, HostListener, ElementRef, ChangeDetectorRef, TemplateRef } from '@angular/core';\r\nimport { trigger } from '@angular/animations';\r\nimport {\r\n  DiagramConstraints, PointPortModel, NodeConstraints, ScrollSettingsModel, SelectorModel, SelectorConstraints,\r\n  ToolBase, Diagram, MouseEventArgs, ConnectorModel, NodeModel, SnapSettingsModel, DiagramTools, TextModel, ConnectorConstraints, ISelectionChangeEventArgs, LayerModel, ConnectionPointOrigin, LayoutModel\r\n} from '@syncfusion/ej2-angular-diagrams';\r\nimport { FormBuilder } from '@angular/forms';\r\nimport { MatTableDataSource } from '@angular/material/table';\r\nimport { ProgressBarMode } from '@angular/material/progress-bar';\r\nimport { MatSort } from '@angular/material/sort';\r\nimport { MatInput } from '@angular/material/input';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil, debounceTime } from 'rxjs/operators';\r\nimport dayjs from 'dayjs';\r\nimport { IChangedEventArgs, RangeNavigator } from '@syncfusion/ej2-angular-charts';\r\nimport { BizDoc } from '../../core/decorators';\r\nimport { getWarn } from '../../core/functions';\r\nimport { GuideStep } from '../../core/models';\r\nimport { PromptService } from '../../core/prompt.service';\r\nimport { UtilityRef } from '../utility-ref';\r\nimport { DocumentInfo, FormService, RangeModel } from '../form/form.service';\r\nimport { TranslateService } from '../../core/translate.service';\r\nimport { GuideService } from '../../core/guide/guide.service';\r\nimport { PanesRouter } from '../../core/slots/router.service';\r\nimport { PaneRef } from '../../core/slots/pane-ref';\r\nimport { SessionService } from '../../core/session.service';\r\nimport { ConnectorData, DiagramInfo, MoveModel, NodeData, Timeline } from './timeline';\r\nimport { EnterExitRight } from '../../core/animations';\r\nimport { Popup } from '../../core/popup/popup.service';\r\nimport { ElementData, TraceElementComponent } from './trace-element.component';\r\nimport { OpenPolicy } from '../../core/configuration';\r\n\r\nconst WARNNING_PATH = 'M 13.763735,1.8433735 H 6.3037349 l -5.27,5.27 v 7.4599995 l 5.27,5.27 h 7.4600001 l 5.27,-5.27 V 7.1133735 Z m -3.73,14.2999995 c -0.7200001,0 -1.3000001,-0.58 -1.3000001,-1.3 0,-0.72 0.58,-1.3 1.3000001,-1.3 0.72,0 1.3,0.58 1.3,1.3 0,0.72 -0.58,1.3 -1.3,1.3 z m 1,-4.3 H 9.0337349 V 5.8433735 h 2.0000001 z',\r\n  JUMP_PATH = 'M 6,18 14.5,12 6,6 Z M 16,6 v 12 h 2 V 6 Z';\r\n\r\nfunction getPorts(): PointPortModel[] {\r\n  return [\r\n    { id: 'port1', shape: 'Circle', offset: { x: 0, y: 0.5 } },\r\n    { id: 'port2', shape: 'Circle', offset: { x: 0.5, y: 1 } },\r\n    { id: 'port3', shape: 'Circle', offset: { x: 1, y: 0.5 } },\r\n    { id: 'port4', shape: 'Circle', offset: { x: 0.5, y: 0 } }\r\n  ];\r\n}\r\n\r\nclass InfoTool extends ToolBase {\r\n  public mouseDown(args: MouseEventArgs): void {\r\n    if (this.diagram.selectedItems.nodes.length > 0) {\r\n      const node = this.diagram.selectedItems.nodes[0];\r\n      super.mouseDown(args)\r\n      this.tap.next(node);\r\n      this.inAction = true;\r\n    }\r\n  }\r\n  constructor(public diagram: Diagram, public tap: Subject<NodeModel>) {\r\n    super(diagram.commandHandler);\r\n  }\r\n}\r\n\r\n@Component({\r\n  templateUrl: './document-trace.component.html',\r\n  styleUrls: ['./document-trace.component.scss'],\r\n  host: {\r\n    class: 'pane'\r\n  }, animations: [trigger('element', EnterExitRight)]\r\n})\r\n@BizDoc({ selector: 'bizdoc-trace-utility' })\r\n/** workflow component*/\r\nexport class DocumentTraceComponent implements OnInit, OnDestroy {\r\n  @ViewChild('diagram') diagramElement: ElementRef<HTMLDivElement>;\r\n  theme = this._session.theme.dark ? 'MaterialDark' : 'Material';\r\n  accent = this._session.getAccent();\r\n  diagram: Diagram;\r\n  readonly form = this._fb.group({ search: null, formId: null });\r\n  model: DiagramInfo;\r\n  timeline: Timeline;\r\n  diagramConstraints: DiagramConstraints = DiagramConstraints.Default | DiagramConstraints.Bridging |\r\n    DiagramConstraints.LineRouting |\r\n    DiagramConstraints.Pan |\r\n    DiagramConstraints.Zoom;\r\n  diagramTool: DiagramTools = DiagramTools.SingleSelect;\r\n  public readonly layout = {\r\n    type: 'ComplexHierarchicalTree',\r\n    connectionPointOrigin: ConnectionPointOrigin.DifferentPoint,\r\n    horizontalSpacing: 50,\r\n    enableRouting: true,\r\n    verticalSpacing: 50,\r\n    horizontalAlignment: 'Center',\r\n    connectionDirection: 'Orientation',\r\n    orientation: 'TopToBottom'\r\n  } as LayoutModel;\r\n  readonly snapSettings: SnapSettingsModel = {\r\n  };\r\n  readonly scrollSettings: ScrollSettingsModel = {\r\n    minZoom: .5,\r\n    maxZoom: 2.5\r\n  };\r\n  private readonly _accentColor = this._session.getAccent(800);\r\n  private readonly _primeryColor = this._session.getPrimery();\r\n  public readonly selectedItems: SelectorModel = {\r\n    constraints: SelectorConstraints.UserHandle,\r\n    userHandles: [\r\n      {\r\n        name: 'info',\r\n        pathData: 'M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 15h-2v-6h2v6zm0-8h-2V7h2v2z',\r\n        visible: true,\r\n        offset: 0,\r\n        side: 'Right',\r\n        verticalAlignment: 'Bottom',\r\n        backgroundColor: 'transparent',\r\n        pathColor: this._primeryColor,\r\n        size: 40,\r\n        margin: { top: 0, bottom: 0, left: 0, right: 0 }\r\n      }\r\n    ]\r\n  };\r\n  public getCustomTool: Function = this.getTool.bind(this);\r\n  node: NodeModel;\r\n  private _start: number | Date;\r\n  private _end: number | Date;\r\n  private _infoRef: PaneRef<TraceElementComponent>;\r\n  public getTool(action: string): ToolBase {\r\n    let tool: ToolBase;\r\n    if (action === 'info') {\r\n      tool = new InfoTool(this.diagram, this._tap);\r\n    }\r\n    return tool;\r\n  }\r\n  mode: 'diagram' | 'browse' | null = 'browse';\r\n  range: (Date | number)[];\r\n  rangeData: RangeModel[];\r\n  loading: ProgressBarMode = 'query';\r\n  @ViewChild('args') filterArgs: TemplateRef<any>;\r\n  @ViewChild('search') searchInput: MatInput;\r\n  dataSource: MatTableDataSource<DocumentInfo>;\r\n  @ViewChild(MatSort) sort: MatSort;\r\n  @ViewChild(RangeNavigator) rangeNavigator: RangeNavigator;\r\n  readonly displayedColumns = ['number', 'subject', 'stateId'];\r\n  private _highLightedIds: string[] = [];\r\n  private readonly _tap = new Subject<NodeModel>();\r\n  private readonly _destroy = new Subject<void>();\r\n  private readonly _dateschange = new Subject<{ start: number | Date, end: number | Date }>();\r\n  /** workflow ctor */\r\n  constructor(\r\n    @Inject(UtilityRef)\r\n    private _utilityRef: UtilityRef<DiagramInfo, MoveModel, DiagramInfo, number>,\r\n    private _service: FormService,\r\n    private _session: SessionService,\r\n    private _pane: PaneRef<DocumentTraceComponent>,\r\n    private _router: PanesRouter,\r\n    private _sb: PromptService,\r\n    private _translate: TranslateService,\r\n    private _popup: Popup,\r\n    private _guide: GuideService,\r\n    private _cd: ChangeDetectorRef,\r\n    private _fb: FormBuilder) {\r\n  }\r\n  ngOnInit(): void {\r\n    const now = dayjs();\r\n    this._session.themeChange.pipe(takeUntil(this._destroy)).subscribe(t => {\r\n      this.theme = t.dark ? 'MaterialDark' : 'Material';\r\n      this.accent = this._session.getAccent();\r\n      //this.rangeNavigator.refresh();\r\n    });\r\n    this._service.range().subscribe(r => this.rangeData = r);\r\n    this._dateschange.pipe(takeUntil(this._destroy), debounceTime(200)).subscribe(r => {\r\n      this._start = r.start, this._end = r.end;\r\n      this._list();\r\n    });\r\n    this.range = [now.add(-2, 'w').toDate(),\r\n    now.toDate()];\r\n    this.form.valueChanges.pipe(takeUntil(this._destroy), debounceTime(200)).\r\n      subscribe(this._list.bind(this));\r\n    this._pane.queryParamsChange.subscribe(p => {\r\n      const { documentId } = p;\r\n      documentId && this._open((documentId as string).decodeId());\r\n    });\r\n    this._pane.resize.pipe(takeUntil(this._destroy)).subscribe(() =>\r\n      this.diagram?.refresh()\r\n    );\r\n  }\r\n  openFilter(evt: Event) {\r\n    this._popup.open(this.filterArgs, evt.target as HTMLButtonElement).opened.subscribe(() =>\r\n      this.searchInput.focus());\r\n  }\r\n  private _list() {\r\n    this.loading = 'query';\r\n    this._service.findAll({ ...this.form.value, start: this._start, end: this._end }).subscribe(l => {\r\n      this.dataSource = new MatTableDataSource(l);\r\n      this.dataSource.sort = this.sort;\r\n      this.loading = null;\r\n    });\r\n  }\r\n\r\n  public rangeChanged(args: IChangedEventArgs): void {\r\n    this._dateschange.next(args);\r\n  }\r\n  @HostListener('window:keydown.f1', ['$event'])\r\n  guide(evt?: Event | KeyboardEvent) {\r\n    const steps: GuideStep[] = [];\r\n    if (this.timeline) {\r\n      if (this.timeline.items.length > 1)\r\n        steps.push({\r\n          selector: '[data-help=timeline]',\r\n          content: this._translate.get('TraceTimelineHelp')\r\n        });\r\n      steps.push({\r\n        selector: 'g[id^=start]',\r\n        content: this._translate.get('TraceElementHelp'),\r\n      });\r\n    }\r\n    else steps.push({\r\n      selector: '[data-help=search]',\r\n      position: 'Below',\r\n      content: this._translate.get('TraceSearchHelp')\r\n    });\r\n    this._guide.start({\r\n      name: 'trace',\r\n      steps\r\n    });\r\n    evt && evt.preventDefault();\r\n  }\r\n  browse() {\r\n    this._router.navigate([]);\r\n    this._router.collapse();\r\n    this.mode = 'browse';\r\n    this._cd.detectChanges();\r\n    this.dataSource.sort = this.sort;\r\n  }\r\n  private _open(id: number) {\r\n    this.diagram?.destroy();\r\n    this.loading = 'buffer';\r\n    this._utilityRef.populate(id).subscribe(e => {\r\n      this._highLightedIds = [];\r\n      this.model = e;\r\n      this._timeline();\r\n      this.mode = 'diagram';\r\n      this.loading = null;\r\n      this._cd.detectChanges();\r\n      this.diagram = new Diagram({\r\n        width: '100%', height: '100%',\r\n        snapSettings: this.snapSettings,\r\n        layout: this.layout,\r\n        getConnectorDefaults: this.connDefaults,\r\n        selectedItems: this.selectedItems,\r\n        tool: this.diagramTool,\r\n        constraints: this.diagramConstraints,\r\n        getNodeDefaults: this.nodeDefaults,\r\n        scrollSettings: this.scrollSettings,\r\n        nodes: e.diagram.nodes,\r\n        connectors: e.diagram.connectors,\r\n        selectionChange: this.selectionChange.bind(this)\r\n      }, this.diagramElement.nativeElement);\r\n      this._version();\r\n      this._indicators();\r\n      this.diagram.fitToPage();\r\n\r\n    }, () => {\r\n      this.loading = null;\r\n      this._sb.error();\r\n    });\r\n  }\r\n  nodeDefaults = (node: NodeModel): NodeModel => {\r\n    const { indicator, virtual } = node.addInfo as NodeData || {};\r\n\r\n    if (indicator) {\r\n      node.constraints = NodeConstraints.PointerEvents | NodeConstraints.Tooltip,\r\n        node.style.strokeWidth = 0,\r\n        node.width = node.height = 15;\r\n    }\r\n    else if (node.id !== 'version') {\r\n      node.constraints = NodeConstraints.InConnect | NodeConstraints.OutConnect |\r\n        NodeConstraints.PointerEvents | NodeConstraints.Select;\r\n      this._decorateNode(node);\r\n      node.ports = getPorts();\r\n    }\r\n    return node;\r\n  }\r\n  public connDefaults = (connector: ConnectorModel) => {\r\n    const { virtual } = connector.addInfo as ConnectorData || {};\r\n    connector.constraints = ConnectorConstraints.ReadOnly & ~ConnectorConstraints.Select;\r\n\r\n    this._decorateConnector(connector);\r\n  }\r\n  open(item: DocumentInfo) {\r\n    this._router.navigate([], { queryParams: { documentId: item.id.encodeId() } });\r\n  }\r\n\r\n  private _timeline() {\r\n    const items = [], submissions: Date[] = [];\r\n    let minDate: Date, maxDate: Date, estimate: boolean;\r\n    this.model.log.forEach(l => {\r\n      const { time, userId } = l;\r\n      switch (l.type) {\r\n        case 'Submit':\r\n          submissions.push(time);\r\n          break;\r\n        default:\r\n      }\r\n      if (!items.find(t => t.time === time))\r\n        items.push({ time, userId });\r\n      if (!minDate || dayjs(time).isBefore(minDate)) minDate = time;\r\n      if (!maxDate || dayjs(time).isAfter(maxDate)) maxDate = time;\r\n      if (l.estimate) estimate = true;\r\n    });\r\n    this.timeline = {\r\n      items, minDate, maxDate,\r\n      submissions, estimate\r\n    } as any;\r\n    this._scope(submissions[submissions.length - 1]);\r\n  }\r\n  /**\r\n   * \r\n   * @param date\r\n   */\r\n  private _scope(date: Date) {\r\n    const startDate = this.timeline.submissions.reverse().\r\n      find(s => s <= date),\r\n      nextDate = this.timeline.submissions.find(s => s > date),\r\n      endDate = nextDate ? new Date(new Date(nextDate).valueOf() - 1).toJSON() as any : this.timeline.maxDate;\r\n    Object.assign(this.timeline, {\r\n      startDate,\r\n      endDate,\r\n      recipients: this.model.recipients.filter(r => r.received >= startDate && r.received <= endDate),\r\n      log: this.model.log.filter(l => l.time >= startDate && l.time <= endDate)\r\n    });\r\n  }\r\n  private _indicators() {\r\n    const indicators: NodeModel[] = [];\r\n    this.model.log.forEach(l => {\r\n      switch (l.type) {\r\n        case 'Node':\r\n          if (l.error)\r\n            indicators.push({\r\n              shape: {\r\n                type: 'Path',\r\n                data: WARNNING_PATH,\r\n                align: 'XMinYMax'\r\n              },\r\n              tooltip: {\r\n                content: l.error,\r\n                position: 'BottomCenter'\r\n              },\r\n              style: {\r\n                fill: getWarn(800)\r\n              },\r\n              addInfo: {\r\n                indicator: true,\r\n                parentId: l.nodeId\r\n              }\r\n            });\r\n          break;\r\n        case 'NodeJump':\r\n          //indicators.push({\r\n          //  shape: {\r\n          //    type: 'Path',\r\n          //    data: JUMP_PATH,\r\n          //    align: 'XMinYMax'\r\n          //  },\r\n          //  style: {\r\n          //    fill: 'black'\r\n          //  },\r\n          //  addInfo: {\r\n          //    indicator: true,\r\n          //    parentId: l.nodeId\r\n          //  }\r\n          //});\r\n          break;\r\n      }\r\n    });\r\n    this.diagram.removeLayer('indicators');\r\n    indicators.forEach(i => {\r\n      const parent = this.diagram.getNodeObject((i.addInfo as NodeData).parentId);\r\n      i.offsetX = parent.offsetX + parent.width / 2 - 15,\r\n        i.offsetY = parent.offsetY + parent.height / 2 - 15;\r\n      this.diagram.add(i);\r\n    });\r\n    this.diagram.addLayer({ id: 'indicators' }, indicators);\r\n  }\r\n  private _decorateNode(node: NodeModel) {\r\n    const log = this.timeline.log.filter(r => r.nodeId === node.id);\r\n\r\n    if (log.length) {\r\n      const recipients = this.timeline.recipients.filter(r => r.nodeId === node.id);\r\n\r\n      node.style.strokeColor = this._accentColor;\r\n      node.style.strokeDashArray = log.find(l => l.estimate) ? '3 2' : '';\r\n\r\n      node.style.fill = recipients.find(r => r.pending && !r.estimate) ? this._accentColor : 'white';\r\n    }\r\n    else\r\n      node.style.fill = 'white',\r\n        node.style.strokeColor = 'darkgray',\r\n        node.style.strokeDashArray = '6 2';\r\n  }\r\n  private _decorateConnector(connector: ConnectorModel) {\r\n    const log = this.timeline.log.filter(l => l.sourceId === connector.sourceID && l.targetId == connector.targetID);\r\n\r\n    if (log.length) {\r\n      connector.style.strokeColor = connector.targetDecorator.style.strokeColor = connector.targetDecorator.style.fill =\r\n        this._accentColor;\r\n      connector.style.strokeDashArray = log.find(l => l.estimate) ? '3 2' : '';\r\n    }\r\n    else\r\n      connector.style.strokeColor = connector.targetDecorator.style.strokeColor = connector.targetDecorator.style.fill = 'darkgray',\r\n        connector.style.strokeDashArray = '6 2';\r\n  }\r\n  private _version() {\r\n    this.diagram.removeLayer(\r\n      'version');\r\n    const version = {\r\n      id: 'version',\r\n      shape: {\r\n        type: 'Text',\r\n        content: this._translate.get('DiagramVersion', this.model.diagram.version)\r\n      },\r\n      offsetY: 5,\r\n      offsetX: 5,\r\n      style: {\r\n        fontSize: 50,\r\n        opacity: .1\r\n      },\r\n      constraints: NodeConstraints.ReadOnly\r\n    } as TextModel;\r\n    this.diagram.addLayer({\r\n      id: 'version',\r\n      objects: [\r\n        version]\r\n    } as LayerModel);\r\n    this.diagram.add(version);\r\n  }\r\n  selectionChange(evt: ISelectionChangeEventArgs) {\r\n    if (evt.state !== 'Changed') return;\r\n    this._unhighlight();\r\n    if (evt.newValue.length) {\r\n      let node = evt.newValue[0] as NodeModel;\r\n\r\n      const { indicator, parentId } = node.addInfo as NodeData || {};\r\n\r\n      if (indicator) {\r\n        node = this.diagram.getNodeObject(parentId);\r\n        this.diagram.select([node]);\r\n      }\r\n      else {\r\n        const ids = ((node as any).inEdges).concat((node as any).outEdges);\r\n        ids.push(node.id);\r\n        this._highlight(ids);\r\n      }\r\n      this.diagram.dataBind();\r\n      if (node) {\r\n        if (this._infoRef) this._infoRef.close();\r\n        this._router.navigate(TraceElementComponent, {\r\n          state: {\r\n            node,\r\n            timeline: this.timeline,\r\n            model: this.model,\r\n            utilityRef: this._utilityRef,\r\n          } as ElementData,\r\n          policy: OpenPolicy.Tab\r\n        }).then((e: PaneRef) => {\r\n          this._infoRef = e;\r\n          e.animation\r\n        });\r\n      }\r\n      else this._router.collapse();\r\n    }\r\n    else\r\n      this.node = null;\r\n  }\r\n  public highlightTime(time: Date) {\r\n    this.timeline.date = time;\r\n    this.diagram.clearSelection();\r\n    this._unhighlight();\r\n    if (time < this.timeline.startDate || time > this.timeline.endDate) {\r\n      this._scope(time);\r\n      for (let i = 0; i < this.diagram.nodes.length; i++)\r\n        this._decorateNode(this.diagram.nodes[i]);\r\n      for (let i = 0; i < this.diagram.connectors.length; i++)\r\n        this._decorateConnector(this.diagram.connectors[i]);\r\n    }\r\n\r\n    const ids = this.timeline.log.filter(l => l.nodeId && l.time === time).map(l => l.nodeId).\r\n      filter((v, i, a) => a.indexOf(v) === i);\r\n\r\n    this._highlight(ids);\r\n    this.diagram.dataBind();\r\n  }\r\n\r\n  pan() {\r\n    this.diagram.constraints = this.diagram.constraints | DiagramConstraints.Pan;\r\n    this.diagram.tool = DiagramTools.ZoomPan;\r\n  }\r\n  cursor() {\r\n    this.diagram.constraints = this.diagram.constraints & ~DiagramConstraints.Pan;\r\n    this.diagram.tool = DiagramTools.SingleSelect;\r\n  }\r\n  private _highlight(ids: string[]) {\r\n    for (let i = 0; i < ids.length; i++) {\r\n      const obj = this.diagram.getObject(ids[i]) as any;\r\n      if (obj.sourceID)\r\n        obj.style.strokeColor =\r\n          obj.targetDecorator.style.strokeColor =\r\n          obj.targetDecorator.style.fill = this._primeryColor;\r\n      else\r\n        obj.style.strokeColor = this._primeryColor;\r\n    }\r\n    this._highLightedIds = ids;\r\n  }\r\n\r\n  private _unhighlight(): void {\r\n    for (let i: number = this._highLightedIds.length - 1; i >= 0; i--) {\r\n      const obj = this.diagram.getObject(this._highLightedIds[i]) as any;\r\n      if (obj.sourceID)\r\n        this._decorateConnector(obj);\r\n      else\r\n        this._decorateNode(obj);\r\n    }\r\n    this._highLightedIds = [];\r\n  }\r\n  ngOnDestroy(): void {\r\n    this._destroy.next();\r\n    this._destroy.complete();\r\n  }\r\n}\r\n","<ng-container [ngSwitch]=\"mode\">\r\n  <!-- diagram -->\r\n  <div *ngSwitchCase=\"'diagram'\" class=\"column\" fxFlex>\r\n    <mat-toolbar>\r\n      <button mat-icon-button (click)=\"browse()\" [bizdocTooltip]=\"'Back' | translate\"><mat-icon class=\"mat-icon-rtl-mirror\">arrow_back</mat-icon></button>\r\n      |\r\n      <button mat-icon-button (click)=\"pan()\" [bizdocTooltip]=\"'Pan' | translate\"><span class=\"e-icons sf-icon-pan\"></span></button>\r\n      <button mat-icon-button (click)=\"cursor()\" [bizdocTooltip]=\"'Cursor' | translate\"><span class=\"e-icons sf-icon-cursor\"></span></button>\r\n      <span class=\"divider\"></span>\r\n      <button mat-icon-button (click)=\"guide()\" [bizdocTooltip]=\"'Help' | translate\"><mat-icon>help_outline</mat-icon></button>\r\n    </mat-toolbar>\r\n    <div class=\"row\" fxFlex>\r\n      <!-- timeline -->\r\n      <div class=\"timeline\" *ngIf=\"timeline?.items.length > 1\" data-help=\"timeline\">\r\n        <div *ngFor=\"let date of timeline.items; let last = last\" class=\"item\"\r\n             [class.active]=\"date.time === timeline.date\"\r\n             (click)=\"highlightTime(date.time)\" matRipple>\r\n          <div class=\"title\">\r\n            <ng-container *ngIf=\"!last || !timeline.estimate; else estimate\">\r\n              <span class=\"who\" *ngIf=\"userId\">\r\n                {{date.userId | userName | async }}\r\n              </span>\r\n              <br />\r\n              <span class=\"time\">\r\n                {{date.time | amDateFormat: 'MMM Do H:mm' }}\r\n              </span>\r\n            </ng-container>\r\n          </div>\r\n          <div class=\"indicator-container\">\r\n            <div class=\"indicator\"></div>\r\n          </div>\r\n        </div>\r\n      </div>\r\n      <div fxFlex #diagram dir=\"ltr\">\r\n      </div>\r\n    </div>\r\n  </div>\r\n  <!-- browse -->\r\n  <div *ngSwitchDefault fxFlex fxLayout=\"column\" fxFlexFill>\r\n    <mat-toolbar fxLayout=\"row\">\r\n      <span class=\"divider\"></span>\r\n      <button mat-icon-button (click)=\"openFilter($event)\" [bizdocTooltip]=\"'Filter'|translate\"><mat-icon>filter_list</mat-icon></button>\r\n    </mat-toolbar>\r\n    <mat-progress-bar [mode]=\"loading\" [style.visibility]=\"loading ? 'visible':'hidden'\"></mat-progress-bar>\r\n    <!-- table -->\r\n    <mat-table fxFlex [dataSource]=\"dataSource\" matSort>\r\n      <!-- Number column -->\r\n      <ng-container matColumnDef=\"number\">\r\n        <mat-header-cell *matHeaderCellDef mat-sort-header>{{'Number' | translate}}</mat-header-cell>\r\n        <mat-cell *matCellDef=\"let item\" class=\"data-column\"> {{item.number}} </mat-cell>\r\n      </ng-container>\r\n\r\n      <!-- Subject column -->\r\n      <ng-container matColumnDef=\"subject\">\r\n        <mat-header-cell *matHeaderCellDef mat-sort-header>{{'Subject' | translate}}</mat-header-cell>\r\n        <mat-cell *matCellDef=\"let item\" class=\"data-column\"> {{item.subject}} </mat-cell>\r\n      </ng-container>\r\n      <!-- StateId column -->\r\n      <ng-container matColumnDef=\"stateId\">\r\n        <mat-header-cell *matHeaderCellDef mat-sort-header=\"stateId\">{{'Status' | translate }}</mat-header-cell>\r\n        <mat-cell *matCellDef=\"let item\" class=\"data-column\">\r\n          <bizdoc-status [stateId]=\"item.stateId\"></bizdoc-status>\r\n        </mat-cell>\r\n      </ng-container>\r\n      <mat-header-row *matHeaderRowDef=\"displayedColumns; sticky: true\"></mat-header-row>\r\n      <mat-row *matRowDef=\"let item; columns: displayedColumns;\"\r\n               (click)=\"open(item)\">\r\n      </mat-row>\r\n    </mat-table>\r\n    <!-- range -->\r\n    <ejs-rangenavigator valueType='DateTime' [value]=range labelFormat='MMM-dd' background=\"transparent\"\r\n                        [theme]=\"theme\" labelIntersectAction='Hide' enableGrouping=\"false\"\r\n                        groupBy=\"Years\" intervalType='Days'\r\n                        (changed)='rangeChanged($event)'>\r\n      <e-rangenavigator-series-collection>\r\n        <e-rangenavigator-series [dataSource]='rangeData' [fill]=\"accent\" type='Area' xName='date' yName='count' width=2>\r\n        </e-rangenavigator-series>\r\n      </e-rangenavigator-series-collection>\r\n    </ejs-rangenavigator>\r\n  </div>\r\n</ng-container>\r\n<!-- args -->\r\n<ng-template #args>\r\n  <form autocomplete=\"off\" [formGroup]=\"form\" fxLayout=\"column\">\r\n    <mat-form-field>\r\n      <input matInput type=\"search\" #search formControlName=\"search\" data-help=\"search\" [placeholder]=\"'Number'|translate\" />\r\n      <mat-icon matSuffix class=\"mat-icon-rtl-mirror\">search</mat-icon>\r\n    </mat-form-field>\r\n    <mat-form-field>\r\n      <bizdoc-select type=\"forms\" [placeholder]=\"'Form'|translate\" formControlName=\"formId\"></bizdoc-select>\r\n    </mat-form-field>\r\n  </form>\r\n</ng-template>\r\n<ng-template #estimate>\r\n  {{'Estimate' | translate}}\r\n</ng-template>\r\n"]}
@@ -0,0 +1,86 @@
1
+ import { ViewChild } from "@angular/core";
2
+ import { Component, Inject } from "@angular/core";
3
+ import { Validators } from "@angular/forms";
4
+ import { MAT_DIALOG_DATA } from "@angular/material/dialog";
5
+ import { MatInput } from "@angular/material/input";
6
+ import { takeUntil, filter, switchMap, map } from "rxjs";
7
+ import { isString } from "../../core/functions";
8
+ import * as i0 from "@angular/core";
9
+ import * as i1 from "../../core/account.service";
10
+ import * as i2 from "@angular/material/dialog";
11
+ import * as i3 from "@angular/forms";
12
+ import * as i4 from "@angular/material/slide-toggle";
13
+ import * as i5 from "@angular/material/form-field";
14
+ import * as i6 from "@angular/material/autocomplete";
15
+ import * as i7 from "@angular/material/core";
16
+ import * as i8 from "@angular/material/datepicker";
17
+ import * as i9 from "@angular/material/button";
18
+ import * as i10 from "@angular/flex-layout/flex";
19
+ import * as i11 from "@angular/material/input";
20
+ import * as i12 from "@angular/common";
21
+ import * as i13 from "../../core/pipes/translate.pipe";
22
+ export class OutOfOfficeDialog {
23
+ constructor(_accounts, _dialogRef, _fb, _data) {
24
+ this._accounts = _accounts;
25
+ this._dialogRef = _dialogRef;
26
+ this._fb = _fb;
27
+ this._data = _data;
28
+ this.userCtrl = this._fb.control(null);
29
+ this.form = this._fb.group({
30
+ active: this._fb.control(false),
31
+ substitueId: this._fb.control(null, Validators.required),
32
+ from: this._fb.control(null),
33
+ to: this._fb.control(null)
34
+ });
35
+ this.userDisplay = (item) => {
36
+ return item ? item.name : null;
37
+ };
38
+ }
39
+ get model() { return this._data.outOfOffice; }
40
+ ngOnInit() {
41
+ this.users$ = this.userCtrl.valueChanges.pipe(takeUntil(this._dialogRef.afterClosed()), filter(v => isString(v)), switchMap(v => this._accounts.findAll(v)), map(r => r.filter(u => u.id !== this._data.userId)));
42
+ this.form.patchValue(this.model);
43
+ !this.model.from &&
44
+ this.form.controls['to'].disable({ emitEvent: false });
45
+ this.model.substitueId &&
46
+ this._accounts.get(this.model.substitueId).subscribe(u => this.userCtrl.setValue(u, { emitEvent: false }));
47
+ this.form.controls['active'].
48
+ valueChanges.pipe(takeUntil(this._dialogRef.afterClosed())).
49
+ subscribe(active => {
50
+ if (active) {
51
+ this.form.controls['from'].enable({ emitEvent: false });
52
+ this.form.controls['from'].value && this.form.controls['to'].enable({ emitEvent: false });
53
+ this.userCtrl.enable();
54
+ this.userInput.focus();
55
+ }
56
+ else {
57
+ this.form.controls['from'].disable({ emitEvent: false });
58
+ this.form.controls['to'].disable({ emitEvent: false });
59
+ this.userCtrl.disable({ emitEvent: false });
60
+ }
61
+ });
62
+ this.form.controls['from'].valueChanges.pipe(takeUntil(this._dialogRef.afterClosed())).
63
+ subscribe(v => {
64
+ if (v)
65
+ this.form.controls['to'].enable({ emitEvent: false });
66
+ else
67
+ this.form.controls['to'].disable({ emitEvent: false });
68
+ });
69
+ }
70
+ setId(event) {
71
+ this.form.controls['substitueId'].setValue(event.option.value.id);
72
+ }
73
+ }
74
+ OutOfOfficeDialog.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.1", ngImport: i0, type: OutOfOfficeDialog, deps: [{ token: i1.AccountService }, { token: i2.MatDialogRef }, { token: i3.FormBuilder }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component });
75
+ OutOfOfficeDialog.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.1", type: OutOfOfficeDialog, selector: "ng-component", viewQueries: [{ propertyName: "userInput", first: true, predicate: ["userInput"], descendants: true, read: MatInput }], ngImport: i0, template: "<h2 mat-dialog-title>{{'OutOfOffice' | translate }}</h2>\r\n<mat-dialog-content>\r\n <form autocomplete=\"off\" fxLayout=\"column\" [formGroup]=\"form\">\r\n <mat-slide-toggle formControlName=\"active\">{{'Active' | translate}}</mat-slide-toggle>\r\n <br />\r\n <mat-form-field fxFlex>\r\n <input matInput [formControl]=\"userCtrl\" type=\"search\" [matAutocomplete]=\"sauto\" #userInput\r\n [placeholder]=\"'Associate' | translate\" [required]=\"form.value.active\" />\r\n <mat-autocomplete #sauto=\"matAutocomplete\" [displayWith]=\"userDisplay\"\r\n (optionSelected)=\"setId($event)\">\r\n <mat-option *ngFor=\"let u of users$ | async\" [value]=\"u\">\r\n <span>{{u.name}}</span>\r\n </mat-option>\r\n </mat-autocomplete>\r\n </mat-form-field>\r\n <div>\r\n <mat-form-field>\r\n <input matInput [matDatepicker]=\"from\" formControlName=\"from\" placeholder=\"{{'From'| translate}}\" />\r\n <mat-datepicker-toggle [for]=\"from\" matSuffix></mat-datepicker-toggle>\r\n <mat-datepicker #from></mat-datepicker>\r\n </mat-form-field>\r\n &nbsp;\r\n <mat-form-field>\r\n <input matInput [matDatepicker]=\"to\" formControlName=\"to\" [min]=\"form.value?.from\" placeholder=\"{{'To'| translate}}\" />\r\n <mat-datepicker-toggle [for]=\"to\" matSuffix></mat-datepicker-toggle>\r\n <mat-datepicker #to></mat-datepicker>\r\n </mat-form-field>\r\n </div>\r\n </form>\r\n</mat-dialog-content>\r\n<mat-dialog-actions>\r\n <button mat-button [mat-dialog-close]=\"form.value\" color=\"primary\" [disabled]=\"!form.valid\">{{'OK' | translate}}</button>\r\n <button mat-button mat-dialog-close>{{'Cancel' | translate}}</button>\r\n</mat-dialog-actions>\r\n", components: [{ type: i4.MatSlideToggle, selector: "mat-slide-toggle", inputs: ["disabled", "disableRipple", "color", "tabIndex", "name", "id", "labelPosition", "aria-label", "aria-labelledby", "aria-describedby", "required", "checked"], outputs: ["change", "toggleChange"], exportAs: ["matSlideToggle"] }, { type: i5.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { type: i6.MatAutocomplete, selector: "mat-autocomplete", inputs: ["disableRipple"], exportAs: ["matAutocomplete"] }, { type: i7.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { type: i8.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { type: i8.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { type: i9.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }], directives: [{ type: i2.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { type: i2.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i10.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { type: i10.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { type: i11.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i6.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { type: i3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i3.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { type: i12.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i8.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { type: i5.MatSuffix, selector: "[matSuffix]" }, { type: i2.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]" }, { type: i2.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }], pipes: { "translate": i13.TranslatePipe, "async": i12.AsyncPipe } });
76
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.1", ngImport: i0, type: OutOfOfficeDialog, decorators: [{
77
+ type: Component,
78
+ args: [{ template: "<h2 mat-dialog-title>{{'OutOfOffice' | translate }}</h2>\r\n<mat-dialog-content>\r\n <form autocomplete=\"off\" fxLayout=\"column\" [formGroup]=\"form\">\r\n <mat-slide-toggle formControlName=\"active\">{{'Active' | translate}}</mat-slide-toggle>\r\n <br />\r\n <mat-form-field fxFlex>\r\n <input matInput [formControl]=\"userCtrl\" type=\"search\" [matAutocomplete]=\"sauto\" #userInput\r\n [placeholder]=\"'Associate' | translate\" [required]=\"form.value.active\" />\r\n <mat-autocomplete #sauto=\"matAutocomplete\" [displayWith]=\"userDisplay\"\r\n (optionSelected)=\"setId($event)\">\r\n <mat-option *ngFor=\"let u of users$ | async\" [value]=\"u\">\r\n <span>{{u.name}}</span>\r\n </mat-option>\r\n </mat-autocomplete>\r\n </mat-form-field>\r\n <div>\r\n <mat-form-field>\r\n <input matInput [matDatepicker]=\"from\" formControlName=\"from\" placeholder=\"{{'From'| translate}}\" />\r\n <mat-datepicker-toggle [for]=\"from\" matSuffix></mat-datepicker-toggle>\r\n <mat-datepicker #from></mat-datepicker>\r\n </mat-form-field>\r\n &nbsp;\r\n <mat-form-field>\r\n <input matInput [matDatepicker]=\"to\" formControlName=\"to\" [min]=\"form.value?.from\" placeholder=\"{{'To'| translate}}\" />\r\n <mat-datepicker-toggle [for]=\"to\" matSuffix></mat-datepicker-toggle>\r\n <mat-datepicker #to></mat-datepicker>\r\n </mat-form-field>\r\n </div>\r\n </form>\r\n</mat-dialog-content>\r\n<mat-dialog-actions>\r\n <button mat-button [mat-dialog-close]=\"form.value\" color=\"primary\" [disabled]=\"!form.valid\">{{'OK' | translate}}</button>\r\n <button mat-button mat-dialog-close>{{'Cancel' | translate}}</button>\r\n</mat-dialog-actions>\r\n" }]
79
+ }], ctorParameters: function () { return [{ type: i1.AccountService }, { type: i2.MatDialogRef }, { type: i3.FormBuilder }, { type: undefined, decorators: [{
80
+ type: Inject,
81
+ args: [MAT_DIALOG_DATA]
82
+ }] }]; }, propDecorators: { userInput: [{
83
+ type: ViewChild,
84
+ args: ['userInput', { read: MatInput }]
85
+ }] } });
86
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"outofoffice.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/admin/profiler/outofoffice.component.ts","../../../../../../libraries/core/src/lib/admin/profiler/outofoffice.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ViewChild } from \"@angular/core\";\r\nimport { Component, OnInit, Inject } from \"@angular/core\";\r\nimport { AbstractControl, FormGroup, FormBuilder, Validators } from \"@angular/forms\";\r\nimport { MatAutocompleteSelectedEvent } from \"@angular/material/autocomplete\";\r\nimport { MatDialogRef, MAT_DIALOG_DATA } from \"@angular/material/dialog\";\r\nimport { MatInput } from \"@angular/material/input\";\r\nimport { Observable, takeUntil, startWith, tap, filter, switchMap, map } from \"rxjs\";\r\nimport { AccountService } from \"../../core/account.service\";\r\nimport { isString } from \"../../core/functions\";\r\nimport { OutOfOfficeSettings, UserInfo } from \"../../core/models\";\r\nimport { SessionService } from \"../../core/session.service\";\r\n\r\nexport interface OutOfOfficeData {\r\n  userId: string;\r\n  outOfOffice: OutOfOfficeSettings;\r\n}\r\n\r\n@Component({ templateUrl: 'outofoffice.component.html' })\r\nexport class OutOfOfficeDialog implements OnInit {\r\n  readonly userCtrl = this._fb.control(null);\r\n  @ViewChild('userInput', { read: MatInput }) userInput: MatInput;\r\n  readonly form = this._fb.group({\r\n    active: this._fb.control(false),\r\n    substitueId: this._fb.control(null, Validators.required),\r\n    from: this._fb.control(null),\r\n    to: this._fb.control(null)\r\n  });\r\n  users$: Observable<UserInfo[]>;\r\n  get model() { return this._data.outOfOffice }\r\n\r\n  constructor(private _accounts: AccountService,\r\n    private _dialogRef: MatDialogRef<OutOfOfficeDialog>,\r\n    private _fb: FormBuilder,\r\n    @Inject(MAT_DIALOG_DATA)\r\n    private _data: OutOfOfficeData\r\n  ) {\r\n  }\r\n  ngOnInit(): void {\r\n    this.users$ = this.userCtrl.valueChanges.pipe(takeUntil(this._dialogRef.afterClosed()),\r\n      filter(v => isString(v)),\r\n      switchMap(v => this._accounts.findAll(v)),\r\n      map(r => r.filter(u => u.id !== this._data.userId)));\r\n    this.form.patchValue(this.model);\r\n    !this.model.from &&\r\n      this.form.controls['to'].disable({ emitEvent: false });\r\n    this.model.substitueId &&\r\n      this._accounts.get(this.model.substitueId).subscribe(u =>\r\n        this.userCtrl.setValue(u, { emitEvent: false }));\r\n    this.form.controls['active'].\r\n      valueChanges.pipe(takeUntil(this._dialogRef.afterClosed())).\r\n      subscribe(active => {\r\n        if (active) {\r\n          this.form.controls['from'].enable({ emitEvent: false });\r\n          this.form.controls['from'].value && this.form.controls['to'].enable({ emitEvent: false });\r\n          this.userCtrl.enable();\r\n          this.userInput.focus();\r\n        }\r\n        else {\r\n          this.form.controls['from'].disable({ emitEvent: false });\r\n          this.form.controls['to'].disable({ emitEvent: false });\r\n          this.userCtrl.disable({ emitEvent: false });\r\n        }\r\n      });\r\n    this.form.controls['from'].valueChanges.pipe(takeUntil(this._dialogRef.afterClosed())).\r\n      subscribe(v => {\r\n        if (v)\r\n          this.form.controls['to'].enable({ emitEvent: false });\r\n        else\r\n          this.form.controls['to'].disable({ emitEvent: false });\r\n      });\r\n  }\r\n  userDisplay = (item: UserInfo) => {\r\n    return item ? item.name : null;\r\n  }\r\n  setId(event: MatAutocompleteSelectedEvent) {\r\n    this.form.controls['substitueId'].setValue((event.option.value as UserInfo).id);\r\n  }\r\n}\r\n","<h2 mat-dialog-title>{{'OutOfOffice' | translate }}</h2>\r\n<mat-dialog-content>\r\n  <form autocomplete=\"off\" fxLayout=\"column\" [formGroup]=\"form\">\r\n    <mat-slide-toggle formControlName=\"active\">{{'Active' | translate}}</mat-slide-toggle>\r\n    <br />\r\n    <mat-form-field fxFlex>\r\n      <input matInput [formControl]=\"userCtrl\" type=\"search\" [matAutocomplete]=\"sauto\" #userInput\r\n             [placeholder]=\"'Associate' | translate\" [required]=\"form.value.active\" />\r\n      <mat-autocomplete #sauto=\"matAutocomplete\" [displayWith]=\"userDisplay\"\r\n                        (optionSelected)=\"setId($event)\">\r\n        <mat-option *ngFor=\"let u of users$ | async\" [value]=\"u\">\r\n          <span>{{u.name}}</span>\r\n        </mat-option>\r\n      </mat-autocomplete>\r\n    </mat-form-field>\r\n    <div>\r\n      <mat-form-field>\r\n        <input matInput [matDatepicker]=\"from\" formControlName=\"from\" placeholder=\"{{'From'| translate}}\" />\r\n        <mat-datepicker-toggle [for]=\"from\" matSuffix></mat-datepicker-toggle>\r\n        <mat-datepicker #from></mat-datepicker>\r\n      </mat-form-field>\r\n      &nbsp;\r\n      <mat-form-field>\r\n        <input matInput [matDatepicker]=\"to\" formControlName=\"to\" [min]=\"form.value?.from\" placeholder=\"{{'To'| translate}}\" />\r\n        <mat-datepicker-toggle [for]=\"to\" matSuffix></mat-datepicker-toggle>\r\n        <mat-datepicker #to></mat-datepicker>\r\n      </mat-form-field>\r\n    </div>\r\n  </form>\r\n</mat-dialog-content>\r\n<mat-dialog-actions>\r\n  <button mat-button [mat-dialog-close]=\"form.value\" color=\"primary\" [disabled]=\"!form.valid\">{{'OK' | translate}}</button>\r\n  <button mat-button mat-dialog-close>{{'Cancel' | translate}}</button>\r\n</mat-dialog-actions>\r\n"]}