@bizdoc/core 1.14.1 → 1.14.5

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 (35) hide show
  1. package/assets/themes/brown.min.css +1 -1
  2. package/assets/themes/dark.min.css +1 -1
  3. package/assets/themes/deep-purple-light-blue.min.css +1 -1
  4. package/assets/themes/deep-purple-teal.min.css +1 -1
  5. package/assets/themes/default.min.css +1 -1
  6. package/assets/themes/green.min.css +1 -1
  7. package/assets/themes/indigo.min.css +1 -1
  8. package/esm2020/lib/admin/document-trace/document-trace.component.mjs +6 -4
  9. package/esm2020/lib/admin/profiler/outofoffice.component.mjs +155 -0
  10. package/esm2020/lib/admin/profiler/profiler.component.mjs +75 -46
  11. package/esm2020/lib/compose/version-compare/version-compare.directive.mjs +3 -3
  12. package/esm2020/lib/core/models.mjs +1 -1
  13. package/esm2020/lib/core/slots/pane-ref.mjs +46 -28
  14. package/esm2020/lib/core/slots/slots.component.mjs +28 -25
  15. package/esm2020/lib/core/translations.mjs +4 -2
  16. package/esm2020/lib/cube/cube-info.service.mjs +2 -2
  17. package/esm2020/lib/cube/explore/explore-items.component.mjs +2 -2
  18. package/esm2020/lib/options/options.component.mjs +37 -16
  19. package/esm2020/lib/reports/report-viewer.component.mjs +2 -2
  20. package/esm2020/lib/system.module.mjs +8 -6
  21. package/esm2020/public-api.mjs +2 -2
  22. package/fesm2015/bizdoc-core.mjs +341 -134
  23. package/fesm2015/bizdoc-core.mjs.map +1 -1
  24. package/fesm2020/bizdoc-core.mjs +331 -130
  25. package/fesm2020/bizdoc-core.mjs.map +1 -1
  26. package/lib/admin/profiler/outofoffice.component.d.ts +48 -0
  27. package/lib/admin/profiler/profiler.component.d.ts +20 -11
  28. package/lib/core/models.d.ts +2 -2
  29. package/lib/core/slots/pane-ref.d.ts +32 -12
  30. package/lib/core/slots/slots.component.d.ts +1 -1
  31. package/lib/core/translations.d.ts +2 -0
  32. package/lib/options/options.component.d.ts +4 -3
  33. package/lib/system.module.d.ts +24 -23
  34. package/package.json +16 -16
  35. package/public-api.d.ts +1 -1
@@ -110,7 +110,7 @@ export class ExploreItemsComponent {
110
110
  const numberFormat = this._service.numberFormat, columns = this.columns.filter(c => !c.hidden), rows = [{
111
111
  index: 1,
112
112
  cells: columns.map((c, i) => ({
113
- index: i + 1, value: c.label,
113
+ index: i + 1, value: c.label || c.name,
114
114
  style: {
115
115
  bold: true
116
116
  }
@@ -183,4 +183,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.1", ngImpor
183
183
  type: ViewChild,
184
184
  args: [MatPaginator, { static: true }]
185
185
  }] } });
186
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"explore-items.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/cube/explore/explore-items.component.ts","../../../../../../libraries/core/src/lib/cube/explore/explore-items.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,SAAS,EAAE,KAAK,EAA4B,MAAM,EAAE,YAAY,EAAqB,MAAM,eAAe,CAAC;AAC/H,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAC7D,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AACjD,OAAO,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAC3D,OAAO,EAAE,QAAQ,EAA0B,MAAM,8BAA8B,CAAC;AAChF,OAAO,EAAmB,SAAS,EAAW,MAAM,mBAAmB,CAAC;AAIxE,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AAErE,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAChD,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,YAAY,EAAE,MAAM,MAAM,CAAC;;;;;;;;;;;;AAGpC,MAAM,SAAS,GAAG,EAAE,EAAE,gBAAgB,GAAG,CAAC,CAAC;AAU3C,0BAA0B;AAC1B,MAAM,OAAO,qBAAqB;IA6BhC,sBAAsB;IACtB,YACU,QAAqB,EACrB,GAAkB,EAClB,QAAwB,EACxB,UAA4B;QAH5B,aAAQ,GAAR,QAAQ,CAAa;QACrB,QAAG,GAAH,GAAG,CAAe;QAClB,aAAQ,GAAR,QAAQ,CAAgB;QACxB,eAAU,GAAV,UAAU,CAAkB;QAjC7B,oBAAe,GAAG,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC;QAcjC,YAAO,GAAG,IAAI,YAAY,EAAoB,CAAC;QAC/C,SAAI,GAAG,IAAI,YAAY,EAAE,CAAC;QAEpC,YAAO,GAAY,KAAK,CAAC;QACf,kBAAa,GAAG,IAAI,YAAY,EAAW,CAAC;QAO9C,cAAS,GAAG,IAAI,OAAO,EAAW,CAAC;QASlD,IAAI,CAAC,SAAS,GAAG,QAAQ,EAAE,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,SAAS,CAAC;IAC7D,CAAC;IAhCD,IAAW,QAAQ;QACjB,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IACD,IACW,QAAQ,CAAC,KAAa;QAC/B,IAAI,KAAK;YAAE,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IACpC,CAAC;IA2BD,QAAQ;QACN,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC;IACnG,CAAC;IACD,OAAO,KAAK,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAErC,WAAW,CAAC,CAAgB;QAC1B,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,IAAI,CAAC,CAAC;QACzE,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC;QAC5C,IAAI,CAAC,KAAK,EAAE,CAAC;IACf,CAAC;IACD,MAAM;IACE,KAAK;QACX,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC1B,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;YAC/D,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;YACzD,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,GAAG,CAAC,CAAC;YAChC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,IAAI,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;gBAC5F,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;gBAChF,IAAI,IAAI,CAAC,KAAK,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE;oBACjC,IAAI,CAAC,KAAK,CAAC,IAAI;wBACb,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,SAAS,IAAI,CAAC,CAAC,CAAC,MAAM;wBACtD,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,SAAS,CAAC,CAAC;wBAC3C,OAAO,CAAC,CAAC,CAAC,EAAE,CACV,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC,CAC/C,CAAC;oBACJ,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,KAAK,CAAC,CAAC;oBAClE,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,CAAC,KAAK,EAAE,IAAI,EAAE,SAAS,CAAC,QAAQ,EAAE,CAAC,CAAC;oBAC9E,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;oBACvB,IAAI,CAAC,gBAAgB,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;oBACjD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;oBACtB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;iBACzB;qBACI;oBACH,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;oBACvB,IAAI,CAAC,gBAAgB;wBACnB,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC;4BACtC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;oBACrB,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;oBAC1B,IAAI,CAAC,UAAU,GAAG,QAAQ,KAAK,IAAI,CAAC;iBACrC;gBACD,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;YACtB,CAAC,EAAE,GAAG,EAAE;gBACN,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBAC3B,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,CAAC;YACnB,CAAC,CAAC,CAAC;QACP,CAAC,EAAE,GAAG,EAAE;YACN,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC3B,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,CAAC;QACnB,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,WAAW,CAAC,IAAW;QAC7B,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;QAClB,IAAI,CAAC,UAAU,GAAG,IAAI,kBAAkB,CAAC,IAAI,CAAC,CAAC;QAC/C,IAAI,CAAC,UAAU,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;QACjC,IAAI,CAAC,UAAU,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC;QAC3C,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC3B,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;IACnB,CAAC;IACD,MAAM,CAAC,IAAS;QACd,IAAI,CAAC,IAAI,CAAC,SAAS;YAAE,OAAO;QAC5B,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;QACpE,IAAI,CAAC,IAAI,CAAC,MAAM;YAAE,MAAM,oDAAoD,CAAC;QAC7E,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;IACxD,CAAC;IACD,WAAW;QACT,MAAM,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,YAAY,EAC7C,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,EAC7C,IAAI,GAAG,CAAC;gBACN,KAAK,EAAE,CAAC;gBACR,KAAK,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;oBAC5B,KAAK,EAAE,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC,KAAK;oBAC5B,KAAK,EAAE;wBACL,IAAI,EAAE,IAAI;qBACX;iBACO,CAAA,CAAC;aACZ,CAAU,CAAC;QACd,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,CACpC;YACE,KAAK,EAAE,CAAC,GAAG,CAAC;YACZ,KAAK,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;gBAC1B,MAAM,QAAQ,GAAG,CAAC,CAAC,IAAI,KAAK,UAAU,CAAC;gBACvC,OAAO;oBACL,IAAI,EAAE,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM;oBAClC,KAAK,EAAE,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;oBAC9B,KAAK,EAAE;wBACL,YAAY;wBACZ,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS;qBACvC;iBACM,CAAC;YACZ,CAAC,CACA;SACK,CAAC,CAAC,CAAC;QAEb,MAAM,IAAI,GAAG,IAAI,QAAQ,CACvB;YACE,UAAU,EAAE;gBACV;oBACE,SAAS,EAAE,IAAI,CAAC,QAAQ,CAAC,OAAO;oBAChC,IAAI,EAAE,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,CAAC;oBACtC,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,GAAG,EAAa,CAAA,CAAC;oBACxE,IAAI;iBACQ;aACf;SACF,EACD,MAAM,CACP,CAAC;QAEF,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC;YACxC,SAAS,CAAC,CAAC,CAAC,EAAE,CACZ,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;IAClD,CAAC;IACD,WAAW;QACT,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC;IAC/B,CAAC;;kHAvJU,qBAAqB;sGAArB,qBAAqB,kSAoBrB,OAAO,4EACP,YAAY,mFChDzB,87CAyBA,2nEDHc;QACV,aAAa;QACb,aAAa;KAAC;2FAGL,qBAAqB;kBATjC,SAAS;+BACE,qBAAqB,cAGnB;wBACV,aAAa;wBACb,aAAa;qBAAC;0LAWL,QAAQ;sBADlB,KAAK;gBAIG,IAAI;sBAAZ,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACa,OAAO;sBAAzB,MAAM;gBACY,IAAI;sBAAtB,MAAM;gBAEE,OAAO;sBAAf,KAAK;gBACa,aAAa;sBAA/B,MAAM;gBACa,IAAI;sBAAvB,SAAS;uBAAC,OAAO;gBACyB,SAAS;sBAAnD,SAAS;uBAAC,YAAY,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE","sourcesContent":["import { Component, ViewChild, Input, OnChanges, SimpleChanges, Output, EventEmitter, OnDestroy, OnInit } from '@angular/core';\r\nimport { MatTableDataSource } from '@angular/material/table';\r\nimport { MatSort } from '@angular/material/sort';\r\nimport { MatPaginator } from '@angular/material/paginator';\r\nimport { Workbook, Worksheet, Column, Row } from '@syncfusion/ej2-excel-export';\r\nimport { Cube, FieldInfo, FieldType, AxesMap } from '../../core/models';\r\nimport { CubeService } from '../cube.service';\r\nimport { PromptService } from '../../core/prompt.service';\r\nimport { TranslateService } from '../../core/translate.service';\r\nimport { itemAnimation, listAnimation } from '../../core/animations';\r\nimport { SessionService } from '../../core/session.service';\r\nimport { isMobile } from '../../core/functions';\r\nimport { Subject } from 'rxjs';\r\nimport { debounceTime } from 'rxjs';\r\nimport { ScopeType } from '../../core/configuration';\r\n\r\nconst PAGE_SIZE = 14, MOBILE_PAGE_SIZE = 8;\r\n\r\n@Component({\r\n  selector: 'bizdoc-cube-explore',\r\n  templateUrl: './explore-items.component.html',\r\n  styleUrls: ['./explore-items.component.scss'],\r\n  animations: [\r\n    listAnimation,\r\n    itemAnimation]\r\n})\r\n/** drill-down component*/\r\nexport class ExploreItemsComponent implements OnInit, OnChanges, OnDestroy {\r\n  readonly CURRENCY_FORMAT = this._service.digitsInfo;\r\n  private _pageSize;\r\n  private _data: any[];\r\n  public get pageSize() {\r\n    return this._pageSize;\r\n  }\r\n  @Input()\r\n  public set pageSize(value: number) {\r\n    if (value) this._pageSize = value;\r\n  }\r\n  @Input() cube!: string;\r\n  @Input() index?: string;\r\n  @Input() scope?: ScopeType;\r\n  @Input() axes!: AxesMap;\r\n  @Output() readonly explore = new EventEmitter<ExploreItemEvent>();\r\n  @Output() readonly load = new EventEmitter();\r\n  dataSource: MatTableDataSource<any>;\r\n  @Input() loading: boolean = false;\r\n  @Output() readonly loadingChange = new EventEmitter<boolean>();\r\n  @ViewChild(MatSort) sort: MatSort;\r\n  @ViewChild(MatPaginator, { static: true }) paginator: MatPaginator;\r\n  columns: FieldInfo[];\r\n  selectable: boolean;\r\n  displayedColumns: string[];\r\n  currencyCode: string;\r\n  private readonly _loading$ = new Subject<boolean>();\r\n  private _template: string;\r\n  private _cube: Cube;\r\n  /** drill-down ctor */\r\n  constructor(\r\n    private _service: CubeService,\r\n    private _sb: PromptService,\r\n    private _session: SessionService,\r\n    private _translate: TranslateService) {\r\n    this._pageSize = isMobile() ? MOBILE_PAGE_SIZE : PAGE_SIZE;\r\n  }\r\n  ngOnInit(): void {\r\n    this._loading$.pipe(debounceTime(200)).subscribe(v => this.loadingChange.emit(this.loading = v));\r\n  }\r\n  refresh() { this.ngOnChanges(null); }\r\n\r\n  ngOnChanges(_: SimpleChanges): void {\r\n    this._cube = this._session.profile.cubes.find(c => c.name === this.cube);\r\n    this.currencyCode = this._cube.currencyCode;\r\n    this._view();\r\n  }\r\n  /** */\r\n  private _view() {\r\n    this._loading$.next(true);\r\n    (this.index ? this._service.resolveIndex(this.cube, this.index) :\r\n      this._service.resolve(this.cube, this.axes)).subscribe(e => {\r\n        const { columns, template } = e;\r\n        (this.index ? this._service.indices(this.cube, this.index, this.axes, { scope: this.scope }) :\r\n          this._service.explore(this.cube, this.axes, { scope: this.scope })).subscribe(r => {\r\n            if (this.index && !columns.length) {\r\n              this._cube.axes.\r\n                filter(a => this.axes[a.name] === undefined && !a.hidden &&\r\n                  r.find(row => row[a.name] !== undefined)).\r\n                forEach(a =>\r\n                  columns.push({ name: a.name, label: a.title })\r\n                );\r\n              const index = this._cube.indices.find(i => i.name === this.index);\r\n              columns.push({ name: 'value', label: index.title, type: FieldType.Currency });\r\n              this.columns = columns;\r\n              this.displayedColumns = columns.map(c => c.name);\r\n              this._template = null;\r\n              this.selectable = false;\r\n            }\r\n            else {\r\n              this.columns = columns;\r\n              this.displayedColumns =\r\n                columns.filter(c => !c.hidden && !c.key).\r\n                  map(c => c.name);\r\n              this._template = template;\r\n              this.selectable = template !== null;\r\n            }\r\n            this._datasource(r);\r\n          }, () => {\r\n            this._loading$.next(false);\r\n            this._sb.error();\r\n          });\r\n      }, () => {\r\n        this._loading$.next(false);\r\n        this._sb.error();\r\n      });\r\n  }\r\n\r\n  private _datasource(data: any[]) {\r\n    this._data = data;\r\n    this.dataSource = new MatTableDataSource(data);\r\n    this.dataSource.sort = this.sort;\r\n    this.dataSource.paginator = this.paginator;\r\n    this._loading$.next(false);\r\n    this.load.emit();\r\n  }\r\n  expand(item: any) {\r\n    if (!this._template) return;\r\n    const keys = this.columns.filter(f => f.key).map(f => item[f.name]);\r\n    if (!keys.length) throw 'no column with Key attribute in IBrowseable model.';\r\n    this.explore.emit({ keys, template: this._template });\r\n  }\r\n  exportExcel() {\r\n    const numberFormat = this._service.numberFormat,\r\n      columns = this.columns.filter(c => !c.hidden),\r\n      rows = [{\r\n        index: 1,\r\n        cells: columns.map((c, i) => ({\r\n          index: i + 1, value: c.label,\r\n          style: {\r\n            bold: true\r\n          }\r\n        } as Cell))\r\n      }] as Row[];\r\n    this._data.forEach((r, i) => rows.push(\r\n      {\r\n        index: i + 2,\r\n        cells: columns.map((c, j) => {\r\n          const isnumber = c.type === 'Currency';\r\n          return {\r\n            type: isnumber ? 'number' : 'text',\r\n            index: j + 1, value: r[c.name],\r\n            style: {\r\n              numberFormat,\r\n              hAlign: isnumber ? 'right' : 'general'\r\n            }\r\n          } as Cell;\r\n        }\r\n        )\r\n      } as Row));\r\n\r\n    const book = new Workbook(\r\n      {\r\n        worksheets: [\r\n          {\r\n            enableRtl: this._session.inverse,\r\n            name: this._translate.get('SheetN', 1),\r\n            columns: columns.map((_, i) => ({ index: i + 1, width: 250 } as Column)),\r\n            rows\r\n          } as Worksheet\r\n        ],\r\n      },\r\n      'xlsx'\r\n    );\r\n\r\n    this._service.nameOf(this.axes, this.cube).\r\n      subscribe(o =>\r\n        book.save(`${this._cube.title} ${o}.xlsx`));\r\n  }\r\n  ngOnDestroy(): void {\r\n    this._loading$.unsubscribe();\r\n  }\r\n}\r\nexport interface ExploreItemEvent {\r\n  keys: (string | number)[];\r\n  template: string;\r\n}\r\ninterface Cell { }\r\n","<mat-table matSort [dataSource]=\"dataSource\" @list>\r\n  <ng-container [matColumnDef]=\"c.name\" *ngFor=\"let c of columns\">\r\n    <mat-header-cell *matHeaderCellDef mat-sort-header>{{c.label || c.name}}</mat-header-cell>\r\n    <mat-cell *matCellDef=\"let element\" [class.figure]=\"c.type === 'Currency'\">\r\n      <ng-container [ngSwitch]=\"c.type\">\r\n        <ng-container *ngSwitchCase=\"'Date'\">\r\n          {{element[c.name] | amDateFormat: 'll'}}\r\n        </ng-container>\r\n        <ng-container *ngSwitchCase=\"'Number'\">\r\n          {{element[c.name] | number }}\r\n        </ng-container>\r\n        <ng-container *ngSwitchCase=\"'Currency'\">\r\n          {{element[c.name] | currency : (element.currencyCode || currencyCode) : 'symbol' : CURRENCY_FORMAT }}\r\n        </ng-container>\r\n        <mat-checkbox [checked]=\"element.model[c.name]\" disabled=\"true\" *ngSwitchCase=\"'Boolean'\"></mat-checkbox>\r\n        <ng-container *ngSwitchDefault>\r\n          {{element[c.name] }}\r\n        </ng-container>\r\n      </ng-container>\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 element; columns: displayedColumns;\" (click)=\"expand(element)\" [class.selectable]=\"selectable\" @item></mat-row>\r\n</mat-table>\r\n<mat-paginator #paginator [pageSize]=\"pageSize\" hidePageSize style=\"display: none\"></mat-paginator>\r\n"]}
186
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"explore-items.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/cube/explore/explore-items.component.ts","../../../../../../libraries/core/src/lib/cube/explore/explore-items.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewChild, Input, OnChanges, SimpleChanges, Output, EventEmitter, OnDestroy, OnInit } from '@angular/core';\r\nimport { MatTableDataSource } from '@angular/material/table';\r\nimport { MatSort } from '@angular/material/sort';\r\nimport { MatPaginator } from '@angular/material/paginator';\r\nimport { Workbook, Worksheet, Column, Row } from '@syncfusion/ej2-excel-export';\r\nimport { Cube, FieldInfo, FieldType, AxesMap } from '../../core/models';\r\nimport { CubeService } from '../cube.service';\r\nimport { PromptService } from '../../core/prompt.service';\r\nimport { TranslateService } from '../../core/translate.service';\r\nimport { itemAnimation, listAnimation } from '../../core/animations';\r\nimport { SessionService } from '../../core/session.service';\r\nimport { isMobile } from '../../core/functions';\r\nimport { Subject } from 'rxjs';\r\nimport { debounceTime } from 'rxjs';\r\nimport { ScopeType } from '../../core/configuration';\r\n\r\nconst PAGE_SIZE = 14, MOBILE_PAGE_SIZE = 8;\r\n\r\n@Component({\r\n  selector: 'bizdoc-cube-explore',\r\n  templateUrl: './explore-items.component.html',\r\n  styleUrls: ['./explore-items.component.scss'],\r\n  animations: [\r\n    listAnimation,\r\n    itemAnimation]\r\n})\r\n/** drill-down component*/\r\nexport class ExploreItemsComponent implements OnInit, OnChanges, OnDestroy {\r\n  readonly CURRENCY_FORMAT = this._service.digitsInfo;\r\n  private _pageSize;\r\n  private _data: any[];\r\n  public get pageSize() {\r\n    return this._pageSize;\r\n  }\r\n  @Input()\r\n  public set pageSize(value: number) {\r\n    if (value) this._pageSize = value;\r\n  }\r\n  @Input() cube!: string;\r\n  @Input() index?: string;\r\n  @Input() scope?: ScopeType;\r\n  @Input() axes!: AxesMap;\r\n  @Output() readonly explore = new EventEmitter<ExploreItemEvent>();\r\n  @Output() readonly load = new EventEmitter();\r\n  dataSource: MatTableDataSource<any>;\r\n  @Input() loading: boolean = false;\r\n  @Output() readonly loadingChange = new EventEmitter<boolean>();\r\n  @ViewChild(MatSort) sort: MatSort;\r\n  @ViewChild(MatPaginator, { static: true }) paginator: MatPaginator;\r\n  columns: FieldInfo[];\r\n  selectable: boolean;\r\n  displayedColumns: string[];\r\n  currencyCode: string;\r\n  private readonly _loading$ = new Subject<boolean>();\r\n  private _template: string;\r\n  private _cube: Cube;\r\n  /** drill-down ctor */\r\n  constructor(\r\n    private _service: CubeService,\r\n    private _sb: PromptService,\r\n    private _session: SessionService,\r\n    private _translate: TranslateService) {\r\n    this._pageSize = isMobile() ? MOBILE_PAGE_SIZE : PAGE_SIZE;\r\n  }\r\n  ngOnInit(): void {\r\n    this._loading$.pipe(debounceTime(200)).subscribe(v => this.loadingChange.emit(this.loading = v));\r\n  }\r\n  refresh() { this.ngOnChanges(null); }\r\n\r\n  ngOnChanges(_: SimpleChanges): void {\r\n    this._cube = this._session.profile.cubes.find(c => c.name === this.cube);\r\n    this.currencyCode = this._cube.currencyCode;\r\n    this._view();\r\n  }\r\n  /** */\r\n  private _view() {\r\n    this._loading$.next(true);\r\n    (this.index ? this._service.resolveIndex(this.cube, this.index) :\r\n      this._service.resolve(this.cube, this.axes)).subscribe(e => {\r\n        const { columns, template } = e;\r\n        (this.index ? this._service.indices(this.cube, this.index, this.axes, { scope: this.scope }) :\r\n          this._service.explore(this.cube, this.axes, { scope: this.scope })).subscribe(r => {\r\n            if (this.index && !columns.length) {\r\n              this._cube.axes.\r\n                filter(a => this.axes[a.name] === undefined && !a.hidden &&\r\n                  r.find(row => row[a.name] !== undefined)).\r\n                forEach(a =>\r\n                  columns.push({ name: a.name, label: a.title })\r\n                );\r\n              const index = this._cube.indices.find(i => i.name === this.index);\r\n              columns.push({ name: 'value', label: index.title, type: FieldType.Currency });\r\n              this.columns = columns;\r\n              this.displayedColumns = columns.map(c => c.name);\r\n              this._template = null;\r\n              this.selectable = false;\r\n            }\r\n            else {\r\n              this.columns = columns;\r\n              this.displayedColumns =\r\n                columns.filter(c => !c.hidden && !c.key).\r\n                  map(c => c.name);\r\n              this._template = template;\r\n              this.selectable = template !== null;\r\n            }\r\n            this._datasource(r);\r\n          }, () => {\r\n            this._loading$.next(false);\r\n            this._sb.error();\r\n          });\r\n      }, () => {\r\n        this._loading$.next(false);\r\n        this._sb.error();\r\n      });\r\n  }\r\n\r\n  private _datasource(data: any[]) {\r\n    this._data = data;\r\n    this.dataSource = new MatTableDataSource(data);\r\n    this.dataSource.sort = this.sort;\r\n    this.dataSource.paginator = this.paginator;\r\n    this._loading$.next(false);\r\n    this.load.emit();\r\n  }\r\n  expand(item: any) {\r\n    if (!this._template) return;\r\n    const keys = this.columns.filter(f => f.key).map(f => item[f.name]);\r\n    if (!keys.length) throw 'no column with Key attribute in IBrowseable model.';\r\n    this.explore.emit({ keys, template: this._template });\r\n  }\r\n  exportExcel() {\r\n    const numberFormat = this._service.numberFormat,\r\n      columns = this.columns.filter(c => !c.hidden),\r\n      rows = [{\r\n        index: 1,\r\n        cells: columns.map((c, i) => ({\r\n          index: i + 1, value: c.label || c.name,\r\n          style: {\r\n            bold: true\r\n          }\r\n        } as Cell))\r\n      }] as Row[];\r\n    this._data.forEach((r, i) => rows.push(\r\n      {\r\n        index: i + 2,\r\n        cells: columns.map((c, j) => {\r\n          const isnumber = c.type === 'Currency';\r\n          return {\r\n            type: isnumber ? 'number' : 'text',\r\n            index: j + 1, value: r[c.name],\r\n            style: {\r\n              numberFormat,\r\n              hAlign: isnumber ? 'right' : 'general'\r\n            }\r\n          } as Cell;\r\n        }\r\n        )\r\n      } as Row));\r\n\r\n    const book = new Workbook(\r\n      {\r\n        worksheets: [\r\n          {\r\n            enableRtl: this._session.inverse,\r\n            name: this._translate.get('SheetN', 1),\r\n            columns: columns.map((_, i) => ({ index: i + 1, width: 250 } as Column)),\r\n            rows\r\n          } as Worksheet\r\n        ],\r\n      },\r\n      'xlsx'\r\n    );\r\n\r\n    this._service.nameOf(this.axes, this.cube).\r\n      subscribe(o =>\r\n        book.save(`${this._cube.title} ${o}.xlsx`));\r\n  }\r\n  ngOnDestroy(): void {\r\n    this._loading$.unsubscribe();\r\n  }\r\n}\r\nexport interface ExploreItemEvent {\r\n  keys: (string | number)[];\r\n  template: string;\r\n}\r\ninterface Cell { }\r\n","<mat-table matSort [dataSource]=\"dataSource\" @list>\r\n  <ng-container [matColumnDef]=\"c.name\" *ngFor=\"let c of columns\">\r\n    <mat-header-cell *matHeaderCellDef mat-sort-header>{{c.label || c.name}}</mat-header-cell>\r\n    <mat-cell *matCellDef=\"let element\" [class.figure]=\"c.type === 'Currency'\">\r\n      <ng-container [ngSwitch]=\"c.type\">\r\n        <ng-container *ngSwitchCase=\"'Date'\">\r\n          {{element[c.name] | amDateFormat: 'll'}}\r\n        </ng-container>\r\n        <ng-container *ngSwitchCase=\"'Number'\">\r\n          {{element[c.name] | number }}\r\n        </ng-container>\r\n        <ng-container *ngSwitchCase=\"'Currency'\">\r\n          {{element[c.name] | currency : (element.currencyCode || currencyCode) : 'symbol' : CURRENCY_FORMAT }}\r\n        </ng-container>\r\n        <mat-checkbox [checked]=\"element.model[c.name]\" disabled=\"true\" *ngSwitchCase=\"'Boolean'\"></mat-checkbox>\r\n        <ng-container *ngSwitchDefault>\r\n          {{element[c.name] }}\r\n        </ng-container>\r\n      </ng-container>\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 element; columns: displayedColumns;\" (click)=\"expand(element)\" [class.selectable]=\"selectable\" @item></mat-row>\r\n</mat-table>\r\n<mat-paginator #paginator [pageSize]=\"pageSize\" hidePageSize style=\"display: none\"></mat-paginator>\r\n"]}
@@ -1,10 +1,12 @@
1
1
  import { Component, ViewChild, InjectionToken, Inject } from '@angular/core';
2
- import { Subject, merge, of } from 'rxjs';
2
+ import { Subject, merge } from 'rxjs';
3
3
  import { debounceTime, takeUntil, filter, map, switchMap, tap } from 'rxjs/operators';
4
4
  import { MatExpansionPanel } from '@angular/material/expansion';
5
- import { COMMA, ENTER } from '@angular/cdk/keycodes';
5
+ import { MatChipInput } from '@angular/material/chips';
6
+ import { COMMA, ENTER, SEMICOLON } from '@angular/cdk/keycodes';
6
7
  import { BIZDOC_CONFIG } from '../core/configuration';
7
8
  import { isString } from '../core/functions';
9
+ import { MatInput } from '@angular/material/input';
8
10
  import * as i0 from "@angular/core";
9
11
  import * as i1 from "@angular/cdk/overlay";
10
12
  import * as i2 from "@angular/forms";
@@ -25,6 +27,7 @@ import * as i16 from "../core/popup/tooltip.directive";
25
27
  import * as i17 from "@angular/material/input";
26
28
  import * as i18 from "@angular/common";
27
29
  import * as i19 from "../core/pipes/translate.pipe";
30
+ import * as i20 from "../core/pipes/user-name.pipe";
28
31
  export const OPTION_PANEL = new InjectionToken('options');
29
32
  /** options component*/
30
33
  export class OptionsComponent {
@@ -46,7 +49,7 @@ export class OptionsComponent {
46
49
  this.language = this._fb.control(this._session.language);
47
50
  this.aRIA = this._fb.control(this._session.aria);
48
51
  this.languages = this._session.languages;
49
- this.gusers = this._fb.control(null);
52
+ this.gusers = this._fb.control([]);
50
53
  this.substitueId = this._fb.control(null);
51
54
  this.form = this._fb.group({
52
55
  notifications: this._fb.group({
@@ -80,8 +83,7 @@ export class OptionsComponent {
80
83
  users: this._fb.control(null, this._requiredValidator)
81
84
  })
82
85
  });
83
- this.separatorKeysCodes = [ENTER, COMMA];
84
- this._me = this._session.userId;
86
+ this.separatorKeysCodes = [ENTER, COMMA, SEMICOLON];
85
87
  this.display = (item) => {
86
88
  return item ? item.name : null;
87
89
  };
@@ -117,17 +119,33 @@ export class OptionsComponent {
117
119
  emails.controls['active'].valueChanges.pipe(takeUntil(this._destroy)).
118
120
  subscribe(active => this._toggle(emails, active, 'mail', 'chat', 'notifications', 'events'));
119
121
  grantAccess.controls['active'].valueChanges.pipe(takeUntil(this._destroy)).
120
- subscribe(active => active ? this.gusers.enable() : this.gusers.enable());
122
+ subscribe(active => {
123
+ if (active) {
124
+ this.gusers.enable();
125
+ this.grantInput.focus();
126
+ }
127
+ else
128
+ this.gusers.enable();
129
+ });
121
130
  outOfOffice.controls['active'].valueChanges.pipe(takeUntil(this._destroy)).
122
131
  subscribe(active => {
123
- active ? this.substitueId.enable() : this.substitueId.disable();
132
+ if (active) {
133
+ this.substitueId.enable();
134
+ this.substitueInput.focus();
135
+ }
136
+ else
137
+ this.substitueId.disable();
124
138
  this._toggle(outOfOffice, active, 'from');
125
139
  this._toggle(outOfOffice, active && outOfOffice.controls['from'].value, 'to');
126
140
  });
127
141
  outOfOffice.controls['from'].valueChanges.pipe(takeUntil(this._destroy)).
128
142
  subscribe(from => this._toggle(outOfOffice, from !== null, 'to'));
129
- this.gusers$ = this.gusers.valueChanges.pipe(takeUntil(this._destroy), switchMap(v => isString(v) ? this._accounts.findAll(v) : of([])), map(r => r.filter(u => u.id !== this._me)));
130
- this.susers$ = this.substitueId.valueChanges.pipe(takeUntil(this._destroy), tap(v => !v && outOfOffice.controls['substitueId'].setValue(null)), switchMap(v => isString(v) ? this._accounts.findAll(v) : of([])), map(r => r.filter(u => u.id !== this._me)));
143
+ this.gusers$ = this.gusers.valueChanges.pipe(takeUntil(this._destroy), filter(v => isString(v)), debounceTime(100), switchMap(v => this._accounts.findAll(v)), map(r => {
144
+ const exclude = grantAccess.value.users?.slice() || [];
145
+ exclude.push(this._session.profile.userId);
146
+ return r.filter(u => exclude.indexOf(u.id) < 0);
147
+ }));
148
+ this.susers$ = this.substitueId.valueChanges.pipe(takeUntil(this._destroy), tap(v => !v && outOfOffice.controls['substitueId'].setValue(null)), filter(v => isString(v)), switchMap(v => this._accounts.findAll(v)), map(r => r.filter(u => u.id !== this._session.profile.userId)));
131
149
  if (options.outOfOffice.substitueId)
132
150
  this._accounts.get(options.outOfOffice.substitueId).subscribe(u => this.substitueId.setValue(u, { emitEvent: false }));
133
151
  if (this._option)
@@ -152,9 +170,6 @@ export class OptionsComponent {
152
170
  toggleSound() {
153
171
  this.form.controls['notifications'].controls['sound'].setValue(!this.options.notifications.sound);
154
172
  }
155
- nameOf(id) {
156
- return this._accounts.get(id).pipe(map(u => u.name));
157
- }
158
173
  addTag(event) {
159
174
  const input = event.input;
160
175
  const value = event.value;
@@ -207,21 +222,27 @@ export class OptionsComponent {
207
222
  }
208
223
  }
209
224
  OptionsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.1", ngImport: i0, type: OptionsComponent, deps: [{ token: OPTION_PANEL }, { token: i1.OverlayRef }, { token: i2.FormBuilder }, { token: i3.AccountService }, { token: i4.PromptService }, { token: i5.SessionService }, { token: BIZDOC_CONFIG }], target: i0.ɵɵFactoryTarget.Component });
210
- OptionsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.1", type: OptionsComponent, selector: "bizdoc-options", viewQueries: [{ propertyName: "outOfOffice", first: true, predicate: ["outOfOffice"], descendants: true, read: MatExpansionPanel, static: true }, { propertyName: "notifications", first: true, predicate: ["notifications"], descendants: true, read: MatExpansionPanel, static: true }], ngImport: i0, template: "<form [formGroup]=\"form\" autocomplete=\"off\">\r\n <mat-accordion>\r\n <mat-expansion-panel #notifications>\r\n <mat-expansion-panel-header>\r\n <mat-panel-title>\r\n {{'Notifications' | translate}}\r\n </mat-panel-title>\r\n <mat-panel-description>\r\n <!--<mat-icon>notifications</mat-icon>-->\r\n </mat-panel-description>\r\n </mat-expansion-panel-header>\r\n <div formGroupName=\"notifications\" fxLayout=\"column\">\r\n <div fxLayout=\"row\">\r\n <mat-slide-toggle formControlName=\"active\">{{'Active' | translate}}</mat-slide-toggle>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button (click)=\"toggleSound()\" [bizdocTooltip]=\"'Sound'|translate\"><mat-icon>{{options.notifications.sound ? 'volume_up' : 'volume_off'}}</mat-icon></button>\r\n </div>\r\n <br />\r\n <mat-slide-toggle formControlName=\"myDocumentStateChange\">{{'MyStateChange' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"anyDocumentStateChange\">{{'AnyStateChange' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"commentMyDocument\">{{'CommentMyDocument' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"commentAnyDocument\">{{'CommentAnyDocument' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"likes\" [style.display]=\"voating?'':'none'\">{{'LikedComment' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"tagged\">{{'TaggedInComments' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"upcomingEvents\">{{'UpcomingEvents' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"cubeAnomaly\">{{'CubeAnomaly' | translate}}</mat-slide-toggle>\r\n </div>\r\n </mat-expansion-panel>\r\n <mat-expansion-panel #emails>\r\n <mat-expansion-panel-header>\r\n <mat-panel-title>\r\n {{'Emails' | translate}}\r\n </mat-panel-title>\r\n <mat-panel-description>\r\n <!--<mat-icon>alternate_email</mat-icon>-->\r\n </mat-panel-description>\r\n </mat-expansion-panel-header>\r\n <div formGroupName=\"emails\" fxLayout=\"column\">\r\n <mat-slide-toggle formControlName=\"active\">{{'Active' | translate}}</mat-slide-toggle>\r\n <br />\r\n <mat-slide-toggle formControlName=\"mail\">{{'Mails' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"chat\">{{'Conversations' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"notifications\">{{'EmailNotifications' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"events\">{{'AlarmEvents' | translate}}</mat-slide-toggle>\r\n </div>\r\n </mat-expansion-panel>\r\n <mat-expansion-panel #outOfOffice>\r\n <mat-expansion-panel-header>\r\n <mat-panel-title>\r\n {{'OutOfOffice' | translate}}\r\n </mat-panel-title>\r\n <mat-panel-description>\r\n <!--<mat-icon>trending_flat</mat-icon>-->\r\n <!--{{'OutOfOfficeTip' | translate}}-->\r\n </mat-panel-description>\r\n </mat-expansion-panel-header>\r\n <div formGroupName=\"outOfOffice\" fxLayout=\"column\">\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]=\"substitueId\" type=\"search\" [matAutocomplete]=\"sauto\"\r\n [placeholder]=\"'Associate' | translate\" [required]=\"form.value.outOfOffice.active\" />\r\n <mat-autocomplete #sauto=\"matAutocomplete\" [displayWith]=\"display\"\r\n (optionSelected)=\"setSubstitute($event)\">\r\n <mat-option *ngFor=\"let u of susers$ | async\" [value]=\"u\">\r\n <span>{{u.name}}</span>\r\n </mat-option>\r\n </mat-autocomplete>\r\n <mat-hint>{{'OutOfOfficeTip' | translate}}</mat-hint>\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.outOfOffice?.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 </div>\r\n </mat-expansion-panel>\r\n <mat-expansion-panel #grantAccess>\r\n <mat-expansion-panel-header>\r\n <mat-panel-title>\r\n {{'GrantAccess' | translate}}\r\n </mat-panel-title>\r\n <mat-panel-description>\r\n <!--<mat-icon>account_circle</mat-icon>-->\r\n </mat-panel-description>\r\n </mat-expansion-panel-header>\r\n <div formGroupName=\"grantAccess\" class=\"grant-section\">\r\n <mat-slide-toggle formControlName=\"active\">{{'Active' | translate}}</mat-slide-toggle>\r\n <mat-form-field>\r\n <mat-chip-list #grantList [attr.aria-label]=\"\">\r\n <mat-chip *ngFor=\"let u of (form.value.grantAccess.users || [])\"\r\n [removable]=\"form.value.grantAccess.active\"\r\n (removed)=\"removeGrant(u)\">\r\n {{nameOf(u) | async}}\r\n <mat-icon matChipRemove *ngIf=\"form.value.grantAccess.active\">cancel</mat-icon>\r\n </mat-chip>\r\n <input [formControl]=\"gusers\" placeholder=\"{{'Users'| translate}}\"\r\n #grantInput\r\n [matAutocomplete]=\"grantAuto\"\r\n [matChipInputFor]=\"grantList\"\r\n [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\">\r\n </mat-chip-list>\r\n <mat-autocomplete #grantAuto=\"matAutocomplete\" (optionSelected)=\"addGrant(grantInput, $event)\">\r\n <mat-option *ngFor=\"let u of gusers$ | async\" [value]=\"u.id\">\r\n {{u.name}}\r\n <span *ngIf=\"u.email\">&nbsp; - {{u.email}}</span>\r\n </mat-option>\r\n </mat-autocomplete>\r\n <mat-hint>{{'GrantTip' | translate}}</mat-hint>\r\n </mat-form-field>\r\n </div>\r\n </mat-expansion-panel>\r\n <mat-expansion-panel #preferences>\r\n <mat-expansion-panel-header>\r\n <mat-panel-title>\r\n {{'Preferences' | translate}}\r\n </mat-panel-title>\r\n <mat-panel-description>\r\n <!--<mat-icon></mat-icon>-->\r\n </mat-panel-description>\r\n </mat-expansion-panel-header>\r\n <div fxLayout=\"column\">\r\n <mat-form-field>\r\n <mat-chip-list #chips [selectable]=\"false\" multiple>\r\n <mat-chip *ngFor=\"let item of form.value.tags\"\r\n [removable]=\"true\" (removed)=\"removeTag(item)\">\r\n {{item}}\r\n <mat-icon matChipRemove>cancel</mat-icon>\r\n </mat-chip>\r\n <input [placeholder]=\"'Tags'|translate\"\r\n [matChipInputFor]=\"chips\"\r\n [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\"\r\n [matChipInputAddOnBlur]=\"true\"\r\n (matChipInputTokenEnd)=\"addTag($event)\">\r\n </mat-chip-list>\r\n </mat-form-field>\r\n <mat-slide-toggle [formControl]=\"aRIA\">{{'ARIA' | translate}}</mat-slide-toggle>\r\n </div>\r\n </mat-expansion-panel>\r\n </mat-accordion>\r\n</form>\r\n", styles: [":host{max-width:80vw}.grant-section{display:flex;flex-direction:column}\n"], components: [{ type: i6.MatExpansionPanel, selector: "mat-expansion-panel", inputs: ["disabled", "expanded", "hideToggle", "togglePosition"], outputs: ["opened", "closed", "expandedChange", "afterExpand", "afterCollapse"], exportAs: ["matExpansionPanel"] }, { type: i6.MatExpansionPanelHeader, selector: "mat-expansion-panel-header", inputs: ["tabIndex", "expandedHeight", "collapsedHeight"] }, { type: i7.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: i8.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"] }, { type: i9.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i10.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { type: i11.MatAutocomplete, selector: "mat-autocomplete", inputs: ["disableRipple"], exportAs: ["matAutocomplete"] }, { type: i12.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { type: i13.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { type: i13.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { type: i14.MatChipList, selector: "mat-chip-list", inputs: ["errorStateMatcher", "multiple", "compareWith", "value", "required", "placeholder", "disabled", "aria-orientation", "selectable", "tabIndex"], outputs: ["change", "valueChange"], exportAs: ["matChipList"] }], directives: [{ type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i6.MatAccordion, selector: "mat-accordion", inputs: ["multi", "hideToggle", "displayMode", "togglePosition"], exportAs: ["matAccordion"] }, { type: i6.MatExpansionPanelTitle, selector: "mat-panel-title" }, { type: i6.MatExpansionPanelDescription, selector: "mat-panel-description" }, { type: i2.FormGroupName, selector: "[formGroupName]", inputs: ["formGroupName"] }, { type: i15.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: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { type: i16.TooltipDirective, selector: "[bizdocTooltip]", inputs: ["bizdocTooltip", "bizdocTooltipTemplate", "bizdocTooltipContext", "bizdocTooltipPosition", "bizdocTooltipDuration", "bizdocTooltipDisabled"] }, { type: i15.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: i17.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: i2.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: i11.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { type: i18.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i10.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { type: i13.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { type: i10.MatSuffix, selector: "[matSuffix]" }, { type: i14.MatChip, selector: "mat-basic-chip, [mat-basic-chip], mat-chip, [mat-chip]", inputs: ["color", "disableRipple", "tabIndex", "selected", "value", "selectable", "disabled", "removable"], outputs: ["selectionChange", "destroyed", "removed"], exportAs: ["matChip"] }, { type: i18.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i14.MatChipRemove, selector: "[matChipRemove]" }, { type: i14.MatChipInput, selector: "input[matChipInputFor]", inputs: ["matChipInputFor", "matChipInputAddOnBlur", "matChipInputSeparatorKeyCodes", "placeholder", "id", "disabled"], outputs: ["matChipInputTokenEnd"], exportAs: ["matChipInput", "matChipInputFor"] }], pipes: { "translate": i19.TranslatePipe, "async": i18.AsyncPipe } });
225
+ OptionsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.1", type: OptionsComponent, selector: "bizdoc-options", viewQueries: [{ propertyName: "substitueInput", first: true, predicate: ["substitueInput"], descendants: true, read: MatInput }, { propertyName: "grantInput", first: true, predicate: ["grantInput"], descendants: true, read: MatChipInput }, { propertyName: "outOfOffice", first: true, predicate: ["outOfOffice"], descendants: true, read: MatExpansionPanel, static: true }, { propertyName: "notifications", first: true, predicate: ["notifications"], descendants: true, read: MatExpansionPanel, static: true }], ngImport: i0, template: "<form [formGroup]=\"form\" autocomplete=\"off\">\r\n <mat-accordion>\r\n <mat-expansion-panel #notifications>\r\n <mat-expansion-panel-header>\r\n <mat-panel-title>\r\n {{'Notifications' | translate}}\r\n </mat-panel-title>\r\n <mat-panel-description>\r\n <!--<mat-icon>notifications</mat-icon>-->\r\n </mat-panel-description>\r\n </mat-expansion-panel-header>\r\n <div formGroupName=\"notifications\" fxLayout=\"column\">\r\n <div fxLayout=\"row\">\r\n <mat-slide-toggle formControlName=\"active\">{{'Active' | translate}}</mat-slide-toggle>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button (click)=\"toggleSound()\" [bizdocTooltip]=\"'Sound'|translate\"><mat-icon>{{options.notifications.sound ? 'volume_up' : 'volume_off'}}</mat-icon></button>\r\n </div>\r\n <br />\r\n <mat-slide-toggle formControlName=\"myDocumentStateChange\">{{'MyStateChange' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"anyDocumentStateChange\">{{'AnyStateChange' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"commentMyDocument\">{{'CommentMyDocument' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"commentAnyDocument\">{{'CommentAnyDocument' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"likes\" [style.display]=\"voating?'':'none'\">{{'LikedComment' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"tagged\">{{'TaggedInComments' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"upcomingEvents\">{{'UpcomingEvents' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"cubeAnomaly\">{{'CubeAnomaly' | translate}}</mat-slide-toggle>\r\n </div>\r\n </mat-expansion-panel>\r\n <mat-expansion-panel #emails>\r\n <mat-expansion-panel-header>\r\n <mat-panel-title>\r\n {{'Emails' | translate}}\r\n </mat-panel-title>\r\n <mat-panel-description>\r\n <!--<mat-icon>alternate_email</mat-icon>-->\r\n </mat-panel-description>\r\n </mat-expansion-panel-header>\r\n <div formGroupName=\"emails\" fxLayout=\"column\">\r\n <mat-slide-toggle formControlName=\"active\">{{'Active' | translate}}</mat-slide-toggle>\r\n <br />\r\n <mat-slide-toggle formControlName=\"mail\">{{'Mails' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"chat\">{{'Conversations' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"notifications\">{{'EmailNotifications' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"events\">{{'AlarmEvents' | translate}}</mat-slide-toggle>\r\n </div>\r\n </mat-expansion-panel>\r\n <mat-expansion-panel #outOfOffice>\r\n <mat-expansion-panel-header>\r\n <mat-panel-title>\r\n {{'OutOfOffice' | translate}}\r\n </mat-panel-title>\r\n <mat-panel-description>\r\n <!--<mat-icon>trending_flat</mat-icon>-->\r\n <!--{{'OutOfOfficeTip' | translate}}-->\r\n </mat-panel-description>\r\n </mat-expansion-panel-header>\r\n <div formGroupName=\"outOfOffice\" fxLayout=\"column\">\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]=\"substitueId\" type=\"search\" [matAutocomplete]=\"sauto\" #substitueInput\r\n [placeholder]=\"'Associate' | translate\" [required]=\"form.value.outOfOffice.active\" />\r\n <mat-autocomplete #sauto=\"matAutocomplete\" [displayWith]=\"display\"\r\n (optionSelected)=\"setSubstitute($event)\">\r\n <mat-option *ngFor=\"let u of susers$ | async\" [value]=\"u\">\r\n <span>{{u.name}}</span>\r\n </mat-option>\r\n </mat-autocomplete>\r\n <mat-hint>{{'OutOfOfficeTip' | translate}}</mat-hint>\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.outOfOffice?.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 </div>\r\n </mat-expansion-panel>\r\n <mat-expansion-panel #grantAccess>\r\n <mat-expansion-panel-header>\r\n <mat-panel-title>\r\n {{'GrantAccess' | translate}}\r\n </mat-panel-title>\r\n <mat-panel-description>\r\n <!--<mat-icon>account_circle</mat-icon>-->\r\n </mat-panel-description>\r\n </mat-expansion-panel-header>\r\n <div formGroupName=\"grantAccess\" class=\"grant-section\">\r\n <mat-slide-toggle formControlName=\"active\">{{'Active' | translate}}</mat-slide-toggle>\r\n <mat-form-field>\r\n <mat-chip-list #grantList [attr.aria-label]=\"\" [disabled]=\"!form.value.grantAccess.active\">\r\n <mat-chip *ngFor=\"let u of form.value.grantAccess.users || []\"\r\n (removed)=\"removeGrant(u)\">\r\n {{u | userName | async}}\r\n <mat-icon matChipRemove>cancel</mat-icon>\r\n </mat-chip>\r\n <input [formControl]=\"gusers\" placeholder=\"{{'Users'| translate}}\"\r\n #grantInput\r\n [matAutocomplete]=\"grantAuto\"\r\n [matChipInputFor]=\"grantList\"\r\n [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\">\r\n </mat-chip-list>\r\n <mat-autocomplete #grantAuto=\"matAutocomplete\" (optionSelected)=\"addGrant(grantInput, $event)\">\r\n <mat-option *ngFor=\"let u of gusers$ | async\" [value]=\"u.id\">\r\n {{u.name}}\r\n <span *ngIf=\"u.email\">&nbsp; - {{u.email}}</span>\r\n </mat-option>\r\n </mat-autocomplete>\r\n <mat-hint>{{'GrantTip' | translate}}</mat-hint>\r\n </mat-form-field>\r\n </div>\r\n </mat-expansion-panel>\r\n <mat-expansion-panel #preferences>\r\n <mat-expansion-panel-header>\r\n <mat-panel-title>\r\n {{'Preferences' | translate}}\r\n </mat-panel-title>\r\n <mat-panel-description>\r\n <!--<mat-icon></mat-icon>-->\r\n </mat-panel-description>\r\n </mat-expansion-panel-header>\r\n <div fxLayout=\"column\">\r\n <mat-form-field>\r\n <mat-chip-list #chips [selectable]=\"false\" multiple>\r\n <mat-chip *ngFor=\"let item of form.value.tags\"\r\n [removable]=\"true\" (removed)=\"removeTag(item)\">\r\n {{item}}\r\n <mat-icon matChipRemove>cancel</mat-icon>\r\n </mat-chip>\r\n <input [placeholder]=\"'Tags'|translate\"\r\n [matChipInputFor]=\"chips\"\r\n [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\"\r\n [matChipInputAddOnBlur]=\"true\"\r\n (matChipInputTokenEnd)=\"addTag($event)\">\r\n </mat-chip-list>\r\n </mat-form-field>\r\n <mat-slide-toggle [formControl]=\"aRIA\">{{'ARIA' | translate}}</mat-slide-toggle>\r\n </div>\r\n </mat-expansion-panel>\r\n </mat-accordion>\r\n</form>\r\n", styles: [":host{max-width:80vw}.grant-section{display:flex;flex-direction:column}\n"], components: [{ type: i6.MatExpansionPanel, selector: "mat-expansion-panel", inputs: ["disabled", "expanded", "hideToggle", "togglePosition"], outputs: ["opened", "closed", "expandedChange", "afterExpand", "afterCollapse"], exportAs: ["matExpansionPanel"] }, { type: i6.MatExpansionPanelHeader, selector: "mat-expansion-panel-header", inputs: ["tabIndex", "expandedHeight", "collapsedHeight"] }, { type: i7.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: i8.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"] }, { type: i9.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i10.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { type: i11.MatAutocomplete, selector: "mat-autocomplete", inputs: ["disableRipple"], exportAs: ["matAutocomplete"] }, { type: i12.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { type: i13.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { type: i13.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { type: i14.MatChipList, selector: "mat-chip-list", inputs: ["errorStateMatcher", "multiple", "compareWith", "value", "required", "placeholder", "disabled", "aria-orientation", "selectable", "tabIndex"], outputs: ["change", "valueChange"], exportAs: ["matChipList"] }], directives: [{ type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i6.MatAccordion, selector: "mat-accordion", inputs: ["multi", "hideToggle", "displayMode", "togglePosition"], exportAs: ["matAccordion"] }, { type: i6.MatExpansionPanelTitle, selector: "mat-panel-title" }, { type: i6.MatExpansionPanelDescription, selector: "mat-panel-description" }, { type: i2.FormGroupName, selector: "[formGroupName]", inputs: ["formGroupName"] }, { type: i15.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: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { type: i16.TooltipDirective, selector: "[bizdocTooltip]", inputs: ["bizdocTooltip", "bizdocTooltipTemplate", "bizdocTooltipContext", "bizdocTooltipPosition", "bizdocTooltipDuration", "bizdocTooltipDisabled"] }, { type: i15.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: i17.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: i2.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: i11.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { type: i18.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i10.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { type: i13.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { type: i10.MatSuffix, selector: "[matSuffix]" }, { type: i14.MatChip, selector: "mat-basic-chip, [mat-basic-chip], mat-chip, [mat-chip]", inputs: ["color", "disableRipple", "tabIndex", "selected", "value", "selectable", "disabled", "removable"], outputs: ["selectionChange", "destroyed", "removed"], exportAs: ["matChip"] }, { type: i14.MatChipRemove, selector: "[matChipRemove]" }, { type: i14.MatChipInput, selector: "input[matChipInputFor]", inputs: ["matChipInputFor", "matChipInputAddOnBlur", "matChipInputSeparatorKeyCodes", "placeholder", "id", "disabled"], outputs: ["matChipInputTokenEnd"], exportAs: ["matChipInput", "matChipInputFor"] }, { type: i18.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "translate": i19.TranslatePipe, "async": i18.AsyncPipe, "userName": i20.UserNamePipe } });
211
226
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.1", ngImport: i0, type: OptionsComponent, decorators: [{
212
227
  type: Component,
213
- args: [{ selector: 'bizdoc-options', template: "<form [formGroup]=\"form\" autocomplete=\"off\">\r\n <mat-accordion>\r\n <mat-expansion-panel #notifications>\r\n <mat-expansion-panel-header>\r\n <mat-panel-title>\r\n {{'Notifications' | translate}}\r\n </mat-panel-title>\r\n <mat-panel-description>\r\n <!--<mat-icon>notifications</mat-icon>-->\r\n </mat-panel-description>\r\n </mat-expansion-panel-header>\r\n <div formGroupName=\"notifications\" fxLayout=\"column\">\r\n <div fxLayout=\"row\">\r\n <mat-slide-toggle formControlName=\"active\">{{'Active' | translate}}</mat-slide-toggle>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button (click)=\"toggleSound()\" [bizdocTooltip]=\"'Sound'|translate\"><mat-icon>{{options.notifications.sound ? 'volume_up' : 'volume_off'}}</mat-icon></button>\r\n </div>\r\n <br />\r\n <mat-slide-toggle formControlName=\"myDocumentStateChange\">{{'MyStateChange' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"anyDocumentStateChange\">{{'AnyStateChange' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"commentMyDocument\">{{'CommentMyDocument' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"commentAnyDocument\">{{'CommentAnyDocument' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"likes\" [style.display]=\"voating?'':'none'\">{{'LikedComment' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"tagged\">{{'TaggedInComments' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"upcomingEvents\">{{'UpcomingEvents' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"cubeAnomaly\">{{'CubeAnomaly' | translate}}</mat-slide-toggle>\r\n </div>\r\n </mat-expansion-panel>\r\n <mat-expansion-panel #emails>\r\n <mat-expansion-panel-header>\r\n <mat-panel-title>\r\n {{'Emails' | translate}}\r\n </mat-panel-title>\r\n <mat-panel-description>\r\n <!--<mat-icon>alternate_email</mat-icon>-->\r\n </mat-panel-description>\r\n </mat-expansion-panel-header>\r\n <div formGroupName=\"emails\" fxLayout=\"column\">\r\n <mat-slide-toggle formControlName=\"active\">{{'Active' | translate}}</mat-slide-toggle>\r\n <br />\r\n <mat-slide-toggle formControlName=\"mail\">{{'Mails' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"chat\">{{'Conversations' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"notifications\">{{'EmailNotifications' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"events\">{{'AlarmEvents' | translate}}</mat-slide-toggle>\r\n </div>\r\n </mat-expansion-panel>\r\n <mat-expansion-panel #outOfOffice>\r\n <mat-expansion-panel-header>\r\n <mat-panel-title>\r\n {{'OutOfOffice' | translate}}\r\n </mat-panel-title>\r\n <mat-panel-description>\r\n <!--<mat-icon>trending_flat</mat-icon>-->\r\n <!--{{'OutOfOfficeTip' | translate}}-->\r\n </mat-panel-description>\r\n </mat-expansion-panel-header>\r\n <div formGroupName=\"outOfOffice\" fxLayout=\"column\">\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]=\"substitueId\" type=\"search\" [matAutocomplete]=\"sauto\"\r\n [placeholder]=\"'Associate' | translate\" [required]=\"form.value.outOfOffice.active\" />\r\n <mat-autocomplete #sauto=\"matAutocomplete\" [displayWith]=\"display\"\r\n (optionSelected)=\"setSubstitute($event)\">\r\n <mat-option *ngFor=\"let u of susers$ | async\" [value]=\"u\">\r\n <span>{{u.name}}</span>\r\n </mat-option>\r\n </mat-autocomplete>\r\n <mat-hint>{{'OutOfOfficeTip' | translate}}</mat-hint>\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.outOfOffice?.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 </div>\r\n </mat-expansion-panel>\r\n <mat-expansion-panel #grantAccess>\r\n <mat-expansion-panel-header>\r\n <mat-panel-title>\r\n {{'GrantAccess' | translate}}\r\n </mat-panel-title>\r\n <mat-panel-description>\r\n <!--<mat-icon>account_circle</mat-icon>-->\r\n </mat-panel-description>\r\n </mat-expansion-panel-header>\r\n <div formGroupName=\"grantAccess\" class=\"grant-section\">\r\n <mat-slide-toggle formControlName=\"active\">{{'Active' | translate}}</mat-slide-toggle>\r\n <mat-form-field>\r\n <mat-chip-list #grantList [attr.aria-label]=\"\">\r\n <mat-chip *ngFor=\"let u of (form.value.grantAccess.users || [])\"\r\n [removable]=\"form.value.grantAccess.active\"\r\n (removed)=\"removeGrant(u)\">\r\n {{nameOf(u) | async}}\r\n <mat-icon matChipRemove *ngIf=\"form.value.grantAccess.active\">cancel</mat-icon>\r\n </mat-chip>\r\n <input [formControl]=\"gusers\" placeholder=\"{{'Users'| translate}}\"\r\n #grantInput\r\n [matAutocomplete]=\"grantAuto\"\r\n [matChipInputFor]=\"grantList\"\r\n [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\">\r\n </mat-chip-list>\r\n <mat-autocomplete #grantAuto=\"matAutocomplete\" (optionSelected)=\"addGrant(grantInput, $event)\">\r\n <mat-option *ngFor=\"let u of gusers$ | async\" [value]=\"u.id\">\r\n {{u.name}}\r\n <span *ngIf=\"u.email\">&nbsp; - {{u.email}}</span>\r\n </mat-option>\r\n </mat-autocomplete>\r\n <mat-hint>{{'GrantTip' | translate}}</mat-hint>\r\n </mat-form-field>\r\n </div>\r\n </mat-expansion-panel>\r\n <mat-expansion-panel #preferences>\r\n <mat-expansion-panel-header>\r\n <mat-panel-title>\r\n {{'Preferences' | translate}}\r\n </mat-panel-title>\r\n <mat-panel-description>\r\n <!--<mat-icon></mat-icon>-->\r\n </mat-panel-description>\r\n </mat-expansion-panel-header>\r\n <div fxLayout=\"column\">\r\n <mat-form-field>\r\n <mat-chip-list #chips [selectable]=\"false\" multiple>\r\n <mat-chip *ngFor=\"let item of form.value.tags\"\r\n [removable]=\"true\" (removed)=\"removeTag(item)\">\r\n {{item}}\r\n <mat-icon matChipRemove>cancel</mat-icon>\r\n </mat-chip>\r\n <input [placeholder]=\"'Tags'|translate\"\r\n [matChipInputFor]=\"chips\"\r\n [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\"\r\n [matChipInputAddOnBlur]=\"true\"\r\n (matChipInputTokenEnd)=\"addTag($event)\">\r\n </mat-chip-list>\r\n </mat-form-field>\r\n <mat-slide-toggle [formControl]=\"aRIA\">{{'ARIA' | translate}}</mat-slide-toggle>\r\n </div>\r\n </mat-expansion-panel>\r\n </mat-accordion>\r\n</form>\r\n", styles: [":host{max-width:80vw}.grant-section{display:flex;flex-direction:column}\n"] }]
228
+ args: [{ selector: 'bizdoc-options', template: "<form [formGroup]=\"form\" autocomplete=\"off\">\r\n <mat-accordion>\r\n <mat-expansion-panel #notifications>\r\n <mat-expansion-panel-header>\r\n <mat-panel-title>\r\n {{'Notifications' | translate}}\r\n </mat-panel-title>\r\n <mat-panel-description>\r\n <!--<mat-icon>notifications</mat-icon>-->\r\n </mat-panel-description>\r\n </mat-expansion-panel-header>\r\n <div formGroupName=\"notifications\" fxLayout=\"column\">\r\n <div fxLayout=\"row\">\r\n <mat-slide-toggle formControlName=\"active\">{{'Active' | translate}}</mat-slide-toggle>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button (click)=\"toggleSound()\" [bizdocTooltip]=\"'Sound'|translate\"><mat-icon>{{options.notifications.sound ? 'volume_up' : 'volume_off'}}</mat-icon></button>\r\n </div>\r\n <br />\r\n <mat-slide-toggle formControlName=\"myDocumentStateChange\">{{'MyStateChange' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"anyDocumentStateChange\">{{'AnyStateChange' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"commentMyDocument\">{{'CommentMyDocument' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"commentAnyDocument\">{{'CommentAnyDocument' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"likes\" [style.display]=\"voating?'':'none'\">{{'LikedComment' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"tagged\">{{'TaggedInComments' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"upcomingEvents\">{{'UpcomingEvents' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"cubeAnomaly\">{{'CubeAnomaly' | translate}}</mat-slide-toggle>\r\n </div>\r\n </mat-expansion-panel>\r\n <mat-expansion-panel #emails>\r\n <mat-expansion-panel-header>\r\n <mat-panel-title>\r\n {{'Emails' | translate}}\r\n </mat-panel-title>\r\n <mat-panel-description>\r\n <!--<mat-icon>alternate_email</mat-icon>-->\r\n </mat-panel-description>\r\n </mat-expansion-panel-header>\r\n <div formGroupName=\"emails\" fxLayout=\"column\">\r\n <mat-slide-toggle formControlName=\"active\">{{'Active' | translate}}</mat-slide-toggle>\r\n <br />\r\n <mat-slide-toggle formControlName=\"mail\">{{'Mails' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"chat\">{{'Conversations' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"notifications\">{{'EmailNotifications' | translate}}</mat-slide-toggle>\r\n <mat-slide-toggle formControlName=\"events\">{{'AlarmEvents' | translate}}</mat-slide-toggle>\r\n </div>\r\n </mat-expansion-panel>\r\n <mat-expansion-panel #outOfOffice>\r\n <mat-expansion-panel-header>\r\n <mat-panel-title>\r\n {{'OutOfOffice' | translate}}\r\n </mat-panel-title>\r\n <mat-panel-description>\r\n <!--<mat-icon>trending_flat</mat-icon>-->\r\n <!--{{'OutOfOfficeTip' | translate}}-->\r\n </mat-panel-description>\r\n </mat-expansion-panel-header>\r\n <div formGroupName=\"outOfOffice\" fxLayout=\"column\">\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]=\"substitueId\" type=\"search\" [matAutocomplete]=\"sauto\" #substitueInput\r\n [placeholder]=\"'Associate' | translate\" [required]=\"form.value.outOfOffice.active\" />\r\n <mat-autocomplete #sauto=\"matAutocomplete\" [displayWith]=\"display\"\r\n (optionSelected)=\"setSubstitute($event)\">\r\n <mat-option *ngFor=\"let u of susers$ | async\" [value]=\"u\">\r\n <span>{{u.name}}</span>\r\n </mat-option>\r\n </mat-autocomplete>\r\n <mat-hint>{{'OutOfOfficeTip' | translate}}</mat-hint>\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.outOfOffice?.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 </div>\r\n </mat-expansion-panel>\r\n <mat-expansion-panel #grantAccess>\r\n <mat-expansion-panel-header>\r\n <mat-panel-title>\r\n {{'GrantAccess' | translate}}\r\n </mat-panel-title>\r\n <mat-panel-description>\r\n <!--<mat-icon>account_circle</mat-icon>-->\r\n </mat-panel-description>\r\n </mat-expansion-panel-header>\r\n <div formGroupName=\"grantAccess\" class=\"grant-section\">\r\n <mat-slide-toggle formControlName=\"active\">{{'Active' | translate}}</mat-slide-toggle>\r\n <mat-form-field>\r\n <mat-chip-list #grantList [attr.aria-label]=\"\" [disabled]=\"!form.value.grantAccess.active\">\r\n <mat-chip *ngFor=\"let u of form.value.grantAccess.users || []\"\r\n (removed)=\"removeGrant(u)\">\r\n {{u | userName | async}}\r\n <mat-icon matChipRemove>cancel</mat-icon>\r\n </mat-chip>\r\n <input [formControl]=\"gusers\" placeholder=\"{{'Users'| translate}}\"\r\n #grantInput\r\n [matAutocomplete]=\"grantAuto\"\r\n [matChipInputFor]=\"grantList\"\r\n [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\">\r\n </mat-chip-list>\r\n <mat-autocomplete #grantAuto=\"matAutocomplete\" (optionSelected)=\"addGrant(grantInput, $event)\">\r\n <mat-option *ngFor=\"let u of gusers$ | async\" [value]=\"u.id\">\r\n {{u.name}}\r\n <span *ngIf=\"u.email\">&nbsp; - {{u.email}}</span>\r\n </mat-option>\r\n </mat-autocomplete>\r\n <mat-hint>{{'GrantTip' | translate}}</mat-hint>\r\n </mat-form-field>\r\n </div>\r\n </mat-expansion-panel>\r\n <mat-expansion-panel #preferences>\r\n <mat-expansion-panel-header>\r\n <mat-panel-title>\r\n {{'Preferences' | translate}}\r\n </mat-panel-title>\r\n <mat-panel-description>\r\n <!--<mat-icon></mat-icon>-->\r\n </mat-panel-description>\r\n </mat-expansion-panel-header>\r\n <div fxLayout=\"column\">\r\n <mat-form-field>\r\n <mat-chip-list #chips [selectable]=\"false\" multiple>\r\n <mat-chip *ngFor=\"let item of form.value.tags\"\r\n [removable]=\"true\" (removed)=\"removeTag(item)\">\r\n {{item}}\r\n <mat-icon matChipRemove>cancel</mat-icon>\r\n </mat-chip>\r\n <input [placeholder]=\"'Tags'|translate\"\r\n [matChipInputFor]=\"chips\"\r\n [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\"\r\n [matChipInputAddOnBlur]=\"true\"\r\n (matChipInputTokenEnd)=\"addTag($event)\">\r\n </mat-chip-list>\r\n </mat-form-field>\r\n <mat-slide-toggle [formControl]=\"aRIA\">{{'ARIA' | translate}}</mat-slide-toggle>\r\n </div>\r\n </mat-expansion-panel>\r\n </mat-accordion>\r\n</form>\r\n", styles: [":host{max-width:80vw}.grant-section{display:flex;flex-direction:column}\n"] }]
214
229
  }], ctorParameters: function () { return [{ type: undefined, decorators: [{
215
230
  type: Inject,
216
231
  args: [OPTION_PANEL]
217
232
  }] }, { type: i1.OverlayRef }, { type: i2.FormBuilder }, { type: i3.AccountService }, { type: i4.PromptService }, { type: i5.SessionService }, { type: undefined, decorators: [{
218
233
  type: Inject,
219
234
  args: [BIZDOC_CONFIG]
220
- }] }]; }, propDecorators: { outOfOffice: [{
235
+ }] }]; }, propDecorators: { substitueInput: [{
236
+ type: ViewChild,
237
+ args: ['substitueInput', { read: MatInput }]
238
+ }], grantInput: [{
239
+ type: ViewChild,
240
+ args: ['grantInput', { read: MatChipInput }]
241
+ }], outOfOffice: [{
221
242
  type: ViewChild,
222
243
  args: ['outOfOffice', { read: MatExpansionPanel, static: true }]
223
244
  }], notifications: [{
224
245
  type: ViewChild,
225
246
  args: ['notifications', { read: MatExpansionPanel, static: true }]
226
247
  }] } });
227
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"options.component.js","sourceRoot":"","sources":["../../../../../libraries/core/src/lib/options/options.component.ts","../../../../../libraries/core/src/lib/options/options.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, OnDestroy, ViewChild, InjectionToken, Inject } from '@angular/core';\r\nimport { AbstractControl, FormBuilder, FormGroup } from '@angular/forms';\r\nimport { Subject, Observable, merge, of } from 'rxjs';\r\nimport { debounceTime, takeUntil, filter, map, switchMap, tap } from 'rxjs/operators';\r\nimport { OverlayRef } from '@angular/cdk/overlay';\r\nimport { MatExpansionPanel } from '@angular/material/expansion';\r\nimport { MatChipInputEvent } from '@angular/material/chips';\r\nimport { COMMA, ENTER } from '@angular/cdk/keycodes';\r\nimport { MatAutocompleteSelectedEvent } from '@angular/material/autocomplete';\r\nimport { BIZDOC_CONFIG, BizDocConfig } from '../core/configuration';\r\nimport { isString } from '../core/functions';\r\nimport { Options, UserInfo } from '../core/models';\r\nimport { AccountService } from '../core/account.service';\r\nimport { SessionService } from '../core/session.service';\r\nimport { PromptService } from '../core/prompt.service';\r\n\r\nexport type OptionType = 'notifications' | 'outofoffice' | 'emails' | 'grantaccess';\r\n\r\nexport const OPTION_PANEL = new InjectionToken<OptionData>('options');\r\n\r\ninterface OptionData {\r\n  open: OptionType;\r\n}\r\n\r\n@Component({\r\n  selector: 'bizdoc-options',\r\n  templateUrl: './options.component.html',\r\n  styleUrls: ['./options.component.scss']\r\n})\r\n/** options component*/\r\nexport class OptionsComponent implements OnInit, OnDestroy {\r\n  private readonly _destroy = new Subject<void>();\r\n  private _requiredValidator = (control: AbstractControl): { [key: string]: any } | null => {\r\n    const parent = (control.parent as FormGroup);\r\n    if (parent && parent.controls['active'].value && !control.value) return {\r\n      required: true\r\n    }\r\n  }\r\n  readonly language = this._fb.control(this._session.language);\r\n  readonly aRIA = this._fb.control(this._session.aria);\r\n  readonly languages = this._session.languages;\r\n  readonly gusers = this._fb.control(null);\r\n  readonly substitueId = this._fb.control(null);\r\n  readonly form = this._fb.group({\r\n    notifications: this._fb.group({\r\n      active: this._fb.control(false),\r\n      likes: this._fb.control(false),\r\n      commentMyDocument: this._fb.control(false),\r\n      commentAnyDocument: this._fb.control(false),\r\n      upcomingEvents: this._fb.control(false),\r\n      tagged: this._fb.control(false),\r\n      anyDocumentStateChange: this._fb.control(false),\r\n      myDocumentStateChange: this._fb.control(false),\r\n      cubeAnomaly: this._fb.control(false),\r\n      sound: this._fb.control(false),\r\n    }),\r\n    tags: this._fb.control(null),\r\n    emails: this._fb.group({\r\n      active: this._fb.control(false),\r\n      mail: this._fb.control(false),\r\n      chat: this._fb.control(false),\r\n      notifications: this._fb.control(false),\r\n      events: this._fb.control(false)\r\n    }),\r\n    outOfOffice: this._fb.group({\r\n      active: this._fb.control(false),\r\n      substitueId: this._fb.control(null, this._requiredValidator),\r\n      from: this._fb.control(null),\r\n      to: this._fb.control(null)\r\n    }),\r\n    grantAccess: this._fb.group({\r\n      active: this._fb.control(false),\r\n      users: this._fb.control(null, this._requiredValidator)\r\n    })\r\n  });\r\n  susers$: Observable<UserInfo[]>;\r\n  gusers$: Observable<UserInfo[]>;\r\n  voating: boolean;\r\n  options: Options;\r\n  readonly separatorKeysCodes: number[] = [ENTER, COMMA];\r\n  @ViewChild('outOfOffice', { read: MatExpansionPanel, static: true }) outOfOffice: MatExpansionPanel;\r\n  @ViewChild('notifications', { read: MatExpansionPanel, static: true }) notifications: MatExpansionPanel;\r\n  private readonly _me = this._session.userId;\r\n  /** options ctor */\r\n  constructor(@Inject(OPTION_PANEL) private _option: OptionData, overlayRef: OverlayRef, private _fb: FormBuilder,\r\n    private _accounts: AccountService, private _sb: PromptService,\r\n    private _session: SessionService,\r\n    @Inject(BIZDOC_CONFIG) config: BizDocConfig) {\r\n    this.voating = !config.comments || config.comments.voting !== false;\r\n    merge(overlayRef.keydownEvents().pipe(filter(k => k.keyCode === 27)), overlayRef.backdropClick()).\r\n      subscribe(() => overlayRef.dispose());\r\n  }\r\n  ngOnInit(): void {\r\n    this.aRIA.valueChanges.pipe(takeUntil(this._destroy)).\r\n      subscribe(v => this._session.aria = v);\r\n    this.language.valueChanges.subscribe(v => this._session.language = v);\r\n    const outOfOffice = this.form.controls['outOfOffice'] as FormGroup;\r\n    const grantAccess = this.form.controls['grantAccess'] as FormGroup;\r\n    const notifications = this.form.controls['notifications'] as FormGroup;\r\n    const emails = this.form.controls['emails'] as FormGroup;\r\n    const options = this.options = this._session.profile.options;\r\n    this.form.patchValue(options, { emitEvent: false });\r\n    if (!options.notifications.active)\r\n      this._toggle(notifications, false, 'likes',\r\n        'commentMyDocument',\r\n        'commentAnyDocument',\r\n        'upcomingEvents',\r\n        'tagged',\r\n        'anyDocumentStateChange',\r\n        'myDocumentStateChange',\r\n        'cubeAnomaly');\r\n    if (!options.emails.active)\r\n      this._toggle(emails, false, 'mail',\r\n        'chat',\r\n        'notifications',\r\n        'events');\r\n    if (!options.grantAccess.active)\r\n      this.gusers.disable();\r\n    if (!options.outOfOffice.active) {\r\n      this.substitueId.disable();\r\n      this._toggle(outOfOffice, false, 'from', 'to');\r\n    }\r\n    else if (!options.outOfOffice.from)\r\n      this._toggle(outOfOffice, false, 'to');\r\n    // change\r\n    notifications.controls['active'].valueChanges.pipe(takeUntil(this._destroy)).\r\n      subscribe(active => this._toggle(notifications, active, 'likes',\r\n        'commentMyDocument',\r\n        'commentAnyDocument',\r\n        'upcomingEvents',\r\n        'tagged',\r\n        'anyDocumentStateChange',\r\n        'myDocumentStateChange',\r\n        'cubeAnomaly'));\r\n    emails.controls['active'].valueChanges.pipe(takeUntil(this._destroy)).\r\n      subscribe(active => this._toggle(emails, active, 'mail',\r\n        'chat',\r\n        'notifications',\r\n        'events'));\r\n    grantAccess.controls['active'].valueChanges.pipe(takeUntil(this._destroy)).\r\n      subscribe(active => active ? this.gusers.enable() : this.gusers.enable());\r\n    outOfOffice.controls['active'].valueChanges.pipe(takeUntil(this._destroy)).\r\n      subscribe(active => {\r\n        active ? this.substitueId.enable() : this.substitueId.disable();\r\n        this._toggle(outOfOffice, active, 'from');\r\n        this._toggle(outOfOffice, active && outOfOffice.controls['from'].value, 'to');\r\n      });\r\n    outOfOffice.controls['from'].valueChanges.pipe(takeUntil(this._destroy)).\r\n      subscribe(from =>\r\n        this._toggle(outOfOffice, from !== null, 'to'));\r\n    this.gusers$ = this.gusers.valueChanges.pipe(takeUntil(this._destroy),\r\n      switchMap(v => isString(v) ? this._accounts.findAll(v) : of([])),\r\n      map(r => r.filter(u => u.id !== this._me)));\r\n    this.susers$ = this.substitueId.valueChanges.pipe(takeUntil(this._destroy),\r\n      tap(v =>\r\n        !v && outOfOffice.controls['substitueId'].setValue(null)\r\n      ),\r\n      switchMap(v => isString(v) ? this._accounts.findAll(v) : of([])),\r\n      map(r => r.filter(u => u.id !== this._me)));\r\n    if (options.outOfOffice.substitueId)\r\n      this._accounts.get(options.outOfOffice.substitueId).subscribe(u =>\r\n        this.substitueId.setValue(u, { emitEvent: false }));\r\n    if (this._option)\r\n      switch (this._option.open) {\r\n        case 'outofoffice':\r\n          this.outOfOffice.open();\r\n          break;\r\n        default:\r\n          this.notifications.open();\r\n      }\r\n    this.form.valueChanges.pipe(debounceTime(200), takeUntil(this._destroy)).subscribe(() =>\r\n      this.form.valid &&\r\n      this._session.update(this.form.getRawValue()).subscribe(undefined, () => this._sb.error()));\r\n  }\r\n  private _toggle(group: FormGroup, active: boolean, ...controls: string[]) {\r\n    controls.forEach(name => {\r\n      if (!active) group.controls[name].disable({ emitEvent: false });\r\n      else group.controls[name].enable({ emitEvent: false });\r\n    });\r\n  }\r\n  toggleSound() {\r\n    (this.form.controls['notifications'] as FormGroup).controls['sound'].setValue(!this.options.notifications.sound);\r\n  }\r\n  nameOf(id: string) {\r\n    return this._accounts.get(id).pipe(map(u => u.name));\r\n  }\r\n  display = (item: UserInfo) => {\r\n    return item ? item.name : null;\r\n  }\r\n\r\n  addTag(event: MatChipInputEvent) {\r\n    const input = event.input;\r\n    const value = event.value;\r\n\r\n    // Add our fruit\r\n    if ((value || '').trim()) {\r\n      this.options.tags.push(value.trim());\r\n      this.form.patchValue({});\r\n    }\r\n\r\n    // Reset the input value \r\n    if (input) {\r\n      input.value = '';\r\n    }\r\n  }\r\n  removeTag(tag: string) {\r\n    this.options.tags.remove(tag);\r\n    this.form.patchValue({});\r\n  }\r\n  /**\r\n   * \r\n   * @param id\r\n   */\r\n  removeGrant(id: string): void {\r\n    const users = this.form.value.grantAccess.users as string[];\r\n    const index = users.indexOf(id);\r\n\r\n    if (index >= 0)\r\n      users.splice(index, 1);\r\n    this.form.patchValue({});\r\n  }\r\n  /**\r\n   * \r\n   * @param inp\r\n   * @param event\r\n   */\r\n  addGrant(inp: HTMLInputElement, event: MatAutocompleteSelectedEvent): void {\r\n    const users = this.form.value.grantAccess.users as string[];\r\n    const id = event.option.value as string;\r\n    if (!users)\r\n      (this.form.controls['grantAccess'] as FormGroup).controls['users'].setValue([id]);\r\n    else\r\n      users.push(id);\r\n    inp.value = '';\r\n    this.form.patchValue({});\r\n  }\r\n  setSubstitute(event: MatAutocompleteSelectedEvent) {\r\n    (this.form.controls['outOfOffice'] as FormGroup).controls['substitueId'].setValue((event.option.value as UserInfo).id);\r\n  }\r\n  ngOnDestroy(): void {\r\n    this._destroy.next();\r\n    this._destroy.complete();\r\n  }\r\n}\r\n","<form [formGroup]=\"form\" autocomplete=\"off\">\r\n  <mat-accordion>\r\n    <mat-expansion-panel #notifications>\r\n      <mat-expansion-panel-header>\r\n        <mat-panel-title>\r\n          {{'Notifications' | translate}}\r\n        </mat-panel-title>\r\n        <mat-panel-description>\r\n          <!--<mat-icon>notifications</mat-icon>-->\r\n        </mat-panel-description>\r\n      </mat-expansion-panel-header>\r\n      <div formGroupName=\"notifications\" fxLayout=\"column\">\r\n        <div fxLayout=\"row\">\r\n          <mat-slide-toggle formControlName=\"active\">{{'Active' | translate}}</mat-slide-toggle>\r\n          <span class=\"divider\"></span>\r\n          <button mat-icon-button (click)=\"toggleSound()\" [bizdocTooltip]=\"'Sound'|translate\"><mat-icon>{{options.notifications.sound ? 'volume_up' : 'volume_off'}}</mat-icon></button>\r\n        </div>\r\n        <br />\r\n        <mat-slide-toggle formControlName=\"myDocumentStateChange\">{{'MyStateChange' | translate}}</mat-slide-toggle>\r\n        <mat-slide-toggle formControlName=\"anyDocumentStateChange\">{{'AnyStateChange' | translate}}</mat-slide-toggle>\r\n        <mat-slide-toggle formControlName=\"commentMyDocument\">{{'CommentMyDocument' | translate}}</mat-slide-toggle>\r\n        <mat-slide-toggle formControlName=\"commentAnyDocument\">{{'CommentAnyDocument' | translate}}</mat-slide-toggle>\r\n        <mat-slide-toggle formControlName=\"likes\" [style.display]=\"voating?'':'none'\">{{'LikedComment' | translate}}</mat-slide-toggle>\r\n        <mat-slide-toggle formControlName=\"tagged\">{{'TaggedInComments' | translate}}</mat-slide-toggle>\r\n        <mat-slide-toggle formControlName=\"upcomingEvents\">{{'UpcomingEvents' | translate}}</mat-slide-toggle>\r\n        <mat-slide-toggle formControlName=\"cubeAnomaly\">{{'CubeAnomaly' | translate}}</mat-slide-toggle>\r\n      </div>\r\n    </mat-expansion-panel>\r\n    <mat-expansion-panel #emails>\r\n      <mat-expansion-panel-header>\r\n        <mat-panel-title>\r\n          {{'Emails' | translate}}\r\n        </mat-panel-title>\r\n        <mat-panel-description>\r\n          <!--<mat-icon>alternate_email</mat-icon>-->\r\n        </mat-panel-description>\r\n      </mat-expansion-panel-header>\r\n      <div formGroupName=\"emails\" fxLayout=\"column\">\r\n        <mat-slide-toggle formControlName=\"active\">{{'Active' | translate}}</mat-slide-toggle>\r\n        <br />\r\n        <mat-slide-toggle formControlName=\"mail\">{{'Mails' | translate}}</mat-slide-toggle>\r\n        <mat-slide-toggle formControlName=\"chat\">{{'Conversations' | translate}}</mat-slide-toggle>\r\n        <mat-slide-toggle formControlName=\"notifications\">{{'EmailNotifications' | translate}}</mat-slide-toggle>\r\n        <mat-slide-toggle formControlName=\"events\">{{'AlarmEvents' | translate}}</mat-slide-toggle>\r\n      </div>\r\n    </mat-expansion-panel>\r\n    <mat-expansion-panel #outOfOffice>\r\n      <mat-expansion-panel-header>\r\n        <mat-panel-title>\r\n          {{'OutOfOffice' | translate}}\r\n        </mat-panel-title>\r\n        <mat-panel-description>\r\n          <!--<mat-icon>trending_flat</mat-icon>-->\r\n          <!--{{'OutOfOfficeTip' | translate}}-->\r\n        </mat-panel-description>\r\n      </mat-expansion-panel-header>\r\n      <div formGroupName=\"outOfOffice\" fxLayout=\"column\">\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]=\"substitueId\" type=\"search\" [matAutocomplete]=\"sauto\"\r\n                 [placeholder]=\"'Associate' | translate\" [required]=\"form.value.outOfOffice.active\" />\r\n          <mat-autocomplete #sauto=\"matAutocomplete\" [displayWith]=\"display\"\r\n                            (optionSelected)=\"setSubstitute($event)\">\r\n            <mat-option *ngFor=\"let u of susers$ | async\" [value]=\"u\">\r\n              <span>{{u.name}}</span>\r\n            </mat-option>\r\n          </mat-autocomplete>\r\n          <mat-hint>{{'OutOfOfficeTip' | translate}}</mat-hint>\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.outOfOffice?.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      </div>\r\n    </mat-expansion-panel>\r\n    <mat-expansion-panel #grantAccess>\r\n      <mat-expansion-panel-header>\r\n        <mat-panel-title>\r\n          {{'GrantAccess' | translate}}\r\n        </mat-panel-title>\r\n        <mat-panel-description>\r\n          <!--<mat-icon>account_circle</mat-icon>-->\r\n        </mat-panel-description>\r\n      </mat-expansion-panel-header>\r\n      <div formGroupName=\"grantAccess\" class=\"grant-section\">\r\n        <mat-slide-toggle formControlName=\"active\">{{'Active' | translate}}</mat-slide-toggle>\r\n        <mat-form-field>\r\n          <mat-chip-list #grantList [attr.aria-label]=\"\">\r\n            <mat-chip *ngFor=\"let u of (form.value.grantAccess.users || [])\"\r\n                      [removable]=\"form.value.grantAccess.active\"\r\n                      (removed)=\"removeGrant(u)\">\r\n              {{nameOf(u) | async}}\r\n              <mat-icon matChipRemove *ngIf=\"form.value.grantAccess.active\">cancel</mat-icon>\r\n            </mat-chip>\r\n            <input [formControl]=\"gusers\" placeholder=\"{{'Users'| translate}}\"\r\n                   #grantInput\r\n                   [matAutocomplete]=\"grantAuto\"\r\n                   [matChipInputFor]=\"grantList\"\r\n                   [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\">\r\n          </mat-chip-list>\r\n          <mat-autocomplete #grantAuto=\"matAutocomplete\" (optionSelected)=\"addGrant(grantInput, $event)\">\r\n            <mat-option *ngFor=\"let u of gusers$ | async\" [value]=\"u.id\">\r\n              {{u.name}}\r\n              <span *ngIf=\"u.email\">&nbsp; - {{u.email}}</span>\r\n            </mat-option>\r\n          </mat-autocomplete>\r\n          <mat-hint>{{'GrantTip' | translate}}</mat-hint>\r\n        </mat-form-field>\r\n      </div>\r\n    </mat-expansion-panel>\r\n    <mat-expansion-panel #preferences>\r\n      <mat-expansion-panel-header>\r\n        <mat-panel-title>\r\n          {{'Preferences' | translate}}\r\n        </mat-panel-title>\r\n        <mat-panel-description>\r\n          <!--<mat-icon></mat-icon>-->\r\n        </mat-panel-description>\r\n      </mat-expansion-panel-header>\r\n      <div fxLayout=\"column\">\r\n        <mat-form-field>\r\n          <mat-chip-list #chips [selectable]=\"false\" multiple>\r\n            <mat-chip *ngFor=\"let item of form.value.tags\"\r\n                      [removable]=\"true\" (removed)=\"removeTag(item)\">\r\n              {{item}}\r\n              <mat-icon matChipRemove>cancel</mat-icon>\r\n            </mat-chip>\r\n            <input [placeholder]=\"'Tags'|translate\"\r\n                   [matChipInputFor]=\"chips\"\r\n                   [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\"\r\n                   [matChipInputAddOnBlur]=\"true\"\r\n                   (matChipInputTokenEnd)=\"addTag($event)\">\r\n          </mat-chip-list>\r\n        </mat-form-field>\r\n        <mat-slide-toggle [formControl]=\"aRIA\">{{'ARIA' | translate}}</mat-slide-toggle>\r\n      </div>\r\n    </mat-expansion-panel>\r\n  </mat-accordion>\r\n</form>\r\n"]}
248
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"options.component.js","sourceRoot":"","sources":["../../../../../libraries/core/src/lib/options/options.component.ts","../../../../../libraries/core/src/lib/options/options.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, OnDestroy, ViewChild, InjectionToken, Inject } from '@angular/core';\r\nimport { AbstractControl, FormBuilder, FormGroup } from '@angular/forms';\r\nimport { Subject, Observable, merge, of } from 'rxjs';\r\nimport { debounceTime, takeUntil, filter, map, switchMap, tap } from 'rxjs/operators';\r\nimport { OverlayRef } from '@angular/cdk/overlay';\r\nimport { MatExpansionPanel } from '@angular/material/expansion';\r\nimport { MatChipInput, MatChipInputEvent } from '@angular/material/chips';\r\nimport { COMMA, ENTER, SEMICOLON } from '@angular/cdk/keycodes';\r\nimport { MatAutocompleteSelectedEvent } from '@angular/material/autocomplete';\r\nimport { BIZDOC_CONFIG, BizDocConfig } from '../core/configuration';\r\nimport { isString } from '../core/functions';\r\nimport { Options, UserInfo } from '../core/models';\r\nimport { AccountService } from '../core/account.service';\r\nimport { SessionService } from '../core/session.service';\r\nimport { PromptService } from '../core/prompt.service';\r\nimport { MatInput } from '@angular/material/input';\r\n\r\nexport type OptionType = 'notifications' | 'outofoffice' | 'emails' | 'grantaccess';\r\n\r\nexport const OPTION_PANEL = new InjectionToken<OptionData>('options');\r\n\r\ninterface OptionData {\r\n  open: OptionType;\r\n}\r\n\r\n@Component({\r\n  selector: 'bizdoc-options',\r\n  templateUrl: './options.component.html',\r\n  styleUrls: ['./options.component.scss']\r\n})\r\n/** options component*/\r\nexport class OptionsComponent implements OnInit, OnDestroy {\r\n  private readonly _destroy = new Subject<void>();\r\n  private _requiredValidator = (control: AbstractControl): { [key: string]: any } | null => {\r\n    const parent = (control.parent as FormGroup);\r\n    if (parent && parent.controls['active'].value && !control.value) return {\r\n      required: true\r\n    }\r\n  }\r\n  @ViewChild('substitueInput', { read: MatInput }) substitueInput: MatInput;\r\n  @ViewChild('grantInput', { read: MatChipInput }) grantInput: MatChipInput;\r\n  readonly language = this._fb.control(this._session.language);\r\n  readonly aRIA = this._fb.control(this._session.aria);\r\n  readonly languages = this._session.languages;\r\n  readonly gusers = this._fb.control([]);\r\n  readonly substitueId = this._fb.control(null);\r\n  readonly form = this._fb.group({\r\n    notifications: this._fb.group({\r\n      active: this._fb.control(false),\r\n      likes: this._fb.control(false),\r\n      commentMyDocument: this._fb.control(false),\r\n      commentAnyDocument: this._fb.control(false),\r\n      upcomingEvents: this._fb.control(false),\r\n      tagged: this._fb.control(false),\r\n      anyDocumentStateChange: this._fb.control(false),\r\n      myDocumentStateChange: this._fb.control(false),\r\n      cubeAnomaly: this._fb.control(false),\r\n      sound: this._fb.control(false),\r\n    }),\r\n    tags: this._fb.control(null),\r\n    emails: this._fb.group({\r\n      active: this._fb.control(false),\r\n      mail: this._fb.control(false),\r\n      chat: this._fb.control(false),\r\n      notifications: this._fb.control(false),\r\n      events: this._fb.control(false)\r\n    }),\r\n    outOfOffice: this._fb.group({\r\n      active: this._fb.control(false),\r\n      substitueId: this._fb.control(null, this._requiredValidator),\r\n      from: this._fb.control(null),\r\n      to: this._fb.control(null)\r\n    }),\r\n    grantAccess: this._fb.group({\r\n      active: this._fb.control(false),\r\n      users: this._fb.control(null, this._requiredValidator)\r\n    })\r\n  });\r\n  susers$: Observable<UserInfo[]>;\r\n  gusers$: Observable<UserInfo[]>;\r\n  voating: boolean;\r\n  options: Options;\r\n  readonly separatorKeysCodes: number[] = [ENTER, COMMA, SEMICOLON];\r\n  @ViewChild('outOfOffice', { read: MatExpansionPanel, static: true }) outOfOffice: MatExpansionPanel;\r\n  @ViewChild('notifications', { read: MatExpansionPanel, static: true }) notifications: MatExpansionPanel;\r\n  /** options ctor */\r\n  constructor(@Inject(OPTION_PANEL) private _option: OptionData, overlayRef: OverlayRef, private _fb: FormBuilder,\r\n    private _accounts: AccountService, private _sb: PromptService,\r\n    private _session: SessionService,\r\n    @Inject(BIZDOC_CONFIG) config: BizDocConfig) {\r\n    this.voating = !config.comments || config.comments.voting !== false;\r\n    merge(overlayRef.keydownEvents().pipe(filter(k => k.keyCode === 27)), overlayRef.backdropClick()).\r\n      subscribe(() => overlayRef.dispose());\r\n  }\r\n  ngOnInit(): void {\r\n    this.aRIA.valueChanges.pipe(takeUntil(this._destroy)).\r\n      subscribe(v => this._session.aria = v);\r\n    this.language.valueChanges.subscribe(v => this._session.language = v);\r\n    const outOfOffice = this.form.controls['outOfOffice'] as FormGroup;\r\n    const grantAccess = this.form.controls['grantAccess'] as FormGroup;\r\n    const notifications = this.form.controls['notifications'] as FormGroup;\r\n    const emails = this.form.controls['emails'] as FormGroup;\r\n    const options = this.options = this._session.profile.options;\r\n    this.form.patchValue(options, { emitEvent: false });\r\n    if (!options.notifications.active)\r\n      this._toggle(notifications, false, 'likes',\r\n        'commentMyDocument',\r\n        'commentAnyDocument',\r\n        'upcomingEvents',\r\n        'tagged',\r\n        'anyDocumentStateChange',\r\n        'myDocumentStateChange',\r\n        'cubeAnomaly');\r\n    if (!options.emails.active)\r\n      this._toggle(emails, false, 'mail',\r\n        'chat',\r\n        'notifications',\r\n        'events');\r\n    if (!options.grantAccess.active)\r\n      this.gusers.disable();\r\n    if (!options.outOfOffice.active) {\r\n      this.substitueId.disable();\r\n      this._toggle(outOfOffice, false, 'from', 'to');\r\n    }\r\n    else if (!options.outOfOffice.from)\r\n      this._toggle(outOfOffice, false, 'to');\r\n    // change\r\n    notifications.controls['active'].valueChanges.pipe(takeUntil(this._destroy)).\r\n      subscribe(active =>\r\n        this._toggle(notifications, active, 'likes',\r\n          'commentMyDocument',\r\n          'commentAnyDocument',\r\n          'upcomingEvents',\r\n          'tagged',\r\n          'anyDocumentStateChange',\r\n          'myDocumentStateChange',\r\n          'cubeAnomaly'));\r\n    emails.controls['active'].valueChanges.pipe(takeUntil(this._destroy)).\r\n      subscribe(active => this._toggle(emails, active, 'mail',\r\n        'chat',\r\n        'notifications',\r\n        'events'));\r\n    grantAccess.controls['active'].valueChanges.pipe(takeUntil(this._destroy)).\r\n      subscribe(active => {\r\n        if (active) {\r\n          this.gusers.enable();\r\n          this.grantInput.focus();\r\n        }\r\n        else this.gusers.enable();\r\n      });\r\n    outOfOffice.controls['active'].valueChanges.pipe(takeUntil(this._destroy)).\r\n      subscribe(active => {\r\n        if (active) {\r\n          this.substitueId.enable();\r\n          this.substitueInput.focus();\r\n        }\r\n        else\r\n          this.substitueId.disable();\r\n        this._toggle(outOfOffice, active, 'from');\r\n        this._toggle(outOfOffice, active && outOfOffice.controls['from'].value, 'to');\r\n      });\r\n    outOfOffice.controls['from'].valueChanges.pipe(takeUntil(this._destroy)).\r\n      subscribe(from =>\r\n        this._toggle(outOfOffice, from !== null, 'to'));\r\n    this.gusers$ = this.gusers.valueChanges.pipe(takeUntil(this._destroy),\r\n      filter(v => isString(v)),\r\n      debounceTime(100),\r\n      switchMap(v => this._accounts.findAll(v)),\r\n      map(r => {\r\n        const exclude = (grantAccess.value.users as string[])?.slice() || [];\r\n        exclude.push(this._session.profile.userId);\r\n        return r.filter(u => exclude.indexOf(u.id) < 0);\r\n      }));\r\n    this.susers$ = this.substitueId.valueChanges.pipe(takeUntil(this._destroy),\r\n      tap(v =>\r\n        !v && outOfOffice.controls['substitueId'].setValue(null)\r\n      ),\r\n      filter(v => isString(v)),\r\n      switchMap(v => this._accounts.findAll(v)),\r\n      map(r => r.filter(u => u.id !== this._session.profile.userId)));\r\n    if (options.outOfOffice.substitueId)\r\n      this._accounts.get(options.outOfOffice.substitueId).subscribe(u =>\r\n        this.substitueId.setValue(u, { emitEvent: false }));\r\n    if (this._option)\r\n      switch (this._option.open) {\r\n        case 'outofoffice':\r\n          this.outOfOffice.open();\r\n          break;\r\n        default:\r\n          this.notifications.open();\r\n      }\r\n    this.form.valueChanges.pipe(debounceTime(200), takeUntil(this._destroy)).subscribe(() =>\r\n      this.form.valid &&\r\n      this._session.update(this.form.getRawValue()).subscribe(undefined, () => this._sb.error()));\r\n  }\r\n  private _toggle(group: FormGroup, active: boolean, ...controls: string[]) {\r\n    controls.forEach(name => {\r\n      if (!active) group.controls[name].disable({ emitEvent: false });\r\n      else group.controls[name].enable({ emitEvent: false });\r\n    });\r\n  }\r\n  toggleSound() {\r\n    (this.form.controls['notifications'] as FormGroup).controls['sound'].setValue(!this.options.notifications.sound);\r\n  }\r\n  display = (item: UserInfo) => {\r\n    return item ? item.name : null;\r\n  }\r\n\r\n  addTag(event: MatChipInputEvent) {\r\n    const input = event.input;\r\n    const value = event.value;\r\n\r\n    // Add our fruit\r\n    if ((value || '').trim()) {\r\n      this.options.tags.push(value.trim());\r\n      this.form.patchValue({});\r\n    }\r\n\r\n    // Reset the input value \r\n    if (input) {\r\n      input.value = '';\r\n    }\r\n  }\r\n  removeTag(tag: string) {\r\n    this.options.tags.remove(tag);\r\n    this.form.patchValue({});\r\n  }\r\n  /**\r\n   * \r\n   * @param id\r\n   */\r\n  removeGrant(id: string): void {\r\n    const users = this.form.value.grantAccess.users as string[];\r\n    const index = users.indexOf(id);\r\n\r\n    if (index >= 0)\r\n      users.splice(index, 1);\r\n    this.form.patchValue({});\r\n  }\r\n  /**\r\n   * \r\n   * @param inp\r\n   * @param event\r\n   */\r\n  addGrant(inp: HTMLInputElement, event: MatAutocompleteSelectedEvent): void {\r\n    const users = this.form.value.grantAccess.users as string[];\r\n    const id = event.option.value as string;\r\n    if (!users)\r\n      (this.form.controls['grantAccess'] as FormGroup).controls['users'].setValue([id]);\r\n    else\r\n      users.push(id);\r\n    inp.value = '';\r\n    this.form.patchValue({});\r\n  }\r\n  setSubstitute(event: MatAutocompleteSelectedEvent) {\r\n    (this.form.controls['outOfOffice'] as FormGroup).controls['substitueId'].setValue((event.option.value as UserInfo).id);\r\n  }\r\n  ngOnDestroy(): void {\r\n    this._destroy.next();\r\n    this._destroy.complete();\r\n  }\r\n}\r\n","<form [formGroup]=\"form\" autocomplete=\"off\">\r\n  <mat-accordion>\r\n    <mat-expansion-panel #notifications>\r\n      <mat-expansion-panel-header>\r\n        <mat-panel-title>\r\n          {{'Notifications' | translate}}\r\n        </mat-panel-title>\r\n        <mat-panel-description>\r\n          <!--<mat-icon>notifications</mat-icon>-->\r\n        </mat-panel-description>\r\n      </mat-expansion-panel-header>\r\n      <div formGroupName=\"notifications\" fxLayout=\"column\">\r\n        <div fxLayout=\"row\">\r\n          <mat-slide-toggle formControlName=\"active\">{{'Active' | translate}}</mat-slide-toggle>\r\n          <span class=\"divider\"></span>\r\n          <button mat-icon-button (click)=\"toggleSound()\" [bizdocTooltip]=\"'Sound'|translate\"><mat-icon>{{options.notifications.sound ? 'volume_up' : 'volume_off'}}</mat-icon></button>\r\n        </div>\r\n        <br />\r\n        <mat-slide-toggle formControlName=\"myDocumentStateChange\">{{'MyStateChange' | translate}}</mat-slide-toggle>\r\n        <mat-slide-toggle formControlName=\"anyDocumentStateChange\">{{'AnyStateChange' | translate}}</mat-slide-toggle>\r\n        <mat-slide-toggle formControlName=\"commentMyDocument\">{{'CommentMyDocument' | translate}}</mat-slide-toggle>\r\n        <mat-slide-toggle formControlName=\"commentAnyDocument\">{{'CommentAnyDocument' | translate}}</mat-slide-toggle>\r\n        <mat-slide-toggle formControlName=\"likes\" [style.display]=\"voating?'':'none'\">{{'LikedComment' | translate}}</mat-slide-toggle>\r\n        <mat-slide-toggle formControlName=\"tagged\">{{'TaggedInComments' | translate}}</mat-slide-toggle>\r\n        <mat-slide-toggle formControlName=\"upcomingEvents\">{{'UpcomingEvents' | translate}}</mat-slide-toggle>\r\n        <mat-slide-toggle formControlName=\"cubeAnomaly\">{{'CubeAnomaly' | translate}}</mat-slide-toggle>\r\n      </div>\r\n    </mat-expansion-panel>\r\n    <mat-expansion-panel #emails>\r\n      <mat-expansion-panel-header>\r\n        <mat-panel-title>\r\n          {{'Emails' | translate}}\r\n        </mat-panel-title>\r\n        <mat-panel-description>\r\n          <!--<mat-icon>alternate_email</mat-icon>-->\r\n        </mat-panel-description>\r\n      </mat-expansion-panel-header>\r\n      <div formGroupName=\"emails\" fxLayout=\"column\">\r\n        <mat-slide-toggle formControlName=\"active\">{{'Active' | translate}}</mat-slide-toggle>\r\n        <br />\r\n        <mat-slide-toggle formControlName=\"mail\">{{'Mails' | translate}}</mat-slide-toggle>\r\n        <mat-slide-toggle formControlName=\"chat\">{{'Conversations' | translate}}</mat-slide-toggle>\r\n        <mat-slide-toggle formControlName=\"notifications\">{{'EmailNotifications' | translate}}</mat-slide-toggle>\r\n        <mat-slide-toggle formControlName=\"events\">{{'AlarmEvents' | translate}}</mat-slide-toggle>\r\n      </div>\r\n    </mat-expansion-panel>\r\n    <mat-expansion-panel #outOfOffice>\r\n      <mat-expansion-panel-header>\r\n        <mat-panel-title>\r\n          {{'OutOfOffice' | translate}}\r\n        </mat-panel-title>\r\n        <mat-panel-description>\r\n          <!--<mat-icon>trending_flat</mat-icon>-->\r\n          <!--{{'OutOfOfficeTip' | translate}}-->\r\n        </mat-panel-description>\r\n      </mat-expansion-panel-header>\r\n      <div formGroupName=\"outOfOffice\" fxLayout=\"column\">\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]=\"substitueId\" type=\"search\" [matAutocomplete]=\"sauto\" #substitueInput\r\n                 [placeholder]=\"'Associate' | translate\" [required]=\"form.value.outOfOffice.active\" />\r\n          <mat-autocomplete #sauto=\"matAutocomplete\" [displayWith]=\"display\"\r\n                            (optionSelected)=\"setSubstitute($event)\">\r\n            <mat-option *ngFor=\"let u of susers$ | async\" [value]=\"u\">\r\n              <span>{{u.name}}</span>\r\n            </mat-option>\r\n          </mat-autocomplete>\r\n          <mat-hint>{{'OutOfOfficeTip' | translate}}</mat-hint>\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.outOfOffice?.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      </div>\r\n    </mat-expansion-panel>\r\n    <mat-expansion-panel #grantAccess>\r\n      <mat-expansion-panel-header>\r\n        <mat-panel-title>\r\n          {{'GrantAccess' | translate}}\r\n        </mat-panel-title>\r\n        <mat-panel-description>\r\n          <!--<mat-icon>account_circle</mat-icon>-->\r\n        </mat-panel-description>\r\n      </mat-expansion-panel-header>\r\n      <div formGroupName=\"grantAccess\" class=\"grant-section\">\r\n        <mat-slide-toggle formControlName=\"active\">{{'Active' | translate}}</mat-slide-toggle>\r\n        <mat-form-field>\r\n          <mat-chip-list #grantList [attr.aria-label]=\"\" [disabled]=\"!form.value.grantAccess.active\">\r\n            <mat-chip *ngFor=\"let u of form.value.grantAccess.users || []\"\r\n                      (removed)=\"removeGrant(u)\">\r\n              {{u | userName | async}}\r\n              <mat-icon matChipRemove>cancel</mat-icon>\r\n            </mat-chip>\r\n            <input [formControl]=\"gusers\" placeholder=\"{{'Users'| translate}}\"\r\n                   #grantInput\r\n                   [matAutocomplete]=\"grantAuto\"\r\n                   [matChipInputFor]=\"grantList\"\r\n                   [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\">\r\n          </mat-chip-list>\r\n          <mat-autocomplete #grantAuto=\"matAutocomplete\" (optionSelected)=\"addGrant(grantInput, $event)\">\r\n            <mat-option *ngFor=\"let u of gusers$ | async\" [value]=\"u.id\">\r\n              {{u.name}}\r\n              <span *ngIf=\"u.email\">&nbsp; - {{u.email}}</span>\r\n            </mat-option>\r\n          </mat-autocomplete>\r\n          <mat-hint>{{'GrantTip' | translate}}</mat-hint>\r\n        </mat-form-field>\r\n      </div>\r\n    </mat-expansion-panel>\r\n    <mat-expansion-panel #preferences>\r\n      <mat-expansion-panel-header>\r\n        <mat-panel-title>\r\n          {{'Preferences' | translate}}\r\n        </mat-panel-title>\r\n        <mat-panel-description>\r\n          <!--<mat-icon></mat-icon>-->\r\n        </mat-panel-description>\r\n      </mat-expansion-panel-header>\r\n      <div fxLayout=\"column\">\r\n        <mat-form-field>\r\n          <mat-chip-list #chips [selectable]=\"false\" multiple>\r\n            <mat-chip *ngFor=\"let item of form.value.tags\"\r\n                      [removable]=\"true\" (removed)=\"removeTag(item)\">\r\n              {{item}}\r\n              <mat-icon matChipRemove>cancel</mat-icon>\r\n            </mat-chip>\r\n            <input [placeholder]=\"'Tags'|translate\"\r\n                   [matChipInputFor]=\"chips\"\r\n                   [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\"\r\n                   [matChipInputAddOnBlur]=\"true\"\r\n                   (matChipInputTokenEnd)=\"addTag($event)\">\r\n          </mat-chip-list>\r\n        </mat-form-field>\r\n        <mat-slide-toggle [formControl]=\"aRIA\">{{'ARIA' | translate}}</mat-slide-toggle>\r\n      </div>\r\n    </mat-expansion-panel>\r\n  </mat-accordion>\r\n</form>\r\n"]}