@bizdoc/core 1.14.4 → 1.14.8

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 (52) hide show
  1. package/assets/bizdoc-schema.json +7 -2
  2. package/esm2020/lib/admin/document-trace/document-trace.component.mjs +2 -2
  3. package/esm2020/lib/admin/form/workflow/workflow.component.mjs +2 -2
  4. package/esm2020/lib/admin/profiler/profiler.component.mjs +3 -11
  5. package/esm2020/lib/app.component.mjs +4 -3
  6. package/esm2020/lib/browse/browse.pane.component.mjs +3 -4
  7. package/esm2020/lib/compose/compose.pane.component.mjs +4 -3
  8. package/esm2020/lib/compose/trace/trace.pane.component.mjs +2 -2
  9. package/esm2020/lib/core/configuration.mjs +5 -5
  10. package/esm2020/lib/core/guide/guide.component.mjs +27 -15
  11. package/esm2020/lib/core/guide/help-tip.component.mjs +58 -0
  12. package/esm2020/lib/core/router.mjs +3 -1
  13. package/esm2020/lib/core/slots/pane-ref.mjs +35 -29
  14. package/esm2020/lib/core/slots/router.directive.mjs +3 -5
  15. package/esm2020/lib/core/slots/router.service.mjs +1 -4
  16. package/esm2020/lib/core/slots/slots.component.mjs +129 -93
  17. package/esm2020/lib/cube/cube-view.component.mjs +2 -2
  18. package/esm2020/lib/cube/matrix/matrix.base.mjs +1 -1
  19. package/esm2020/lib/cube/matrix/matrix.pane.component.mjs +1 -1
  20. package/esm2020/lib/cube/view.pane.component.mjs +5 -5
  21. package/esm2020/lib/dashboard/dashboard.component.mjs +25 -17
  22. package/esm2020/lib/dashboard/widget-item.component.mjs +2 -1
  23. package/esm2020/lib/reports/report-viewer.component.mjs +1 -1
  24. package/esm2020/lib/reports/report.pane.component.mjs +2 -2
  25. package/esm2020/lib/scheduler/scheduler.pane.component.mjs +2 -2
  26. package/esm2020/lib/shared.module.mjs +4 -3
  27. package/esm2020/lib/views/view-item.component.mjs +3 -2
  28. package/esm2020/lib/views/views.component.mjs +11 -3
  29. package/esm2020/lib/views/views.pane.component.mjs +14 -10
  30. package/esm2020/public-api.mjs +2 -2
  31. package/fesm2015/bizdoc-core.mjs +347 -241
  32. package/fesm2015/bizdoc-core.mjs.map +1 -1
  33. package/fesm2020/bizdoc-core.mjs +348 -240
  34. package/fesm2020/bizdoc-core.mjs.map +1 -1
  35. package/lib/admin/profiler/profiler.component.d.ts +0 -1
  36. package/lib/core/configuration.d.ts +4 -4
  37. package/lib/core/guide/guide.component.d.ts +2 -2
  38. package/lib/core/guide/help-tip.component.d.ts +16 -0
  39. package/lib/core/router.d.ts +2 -0
  40. package/lib/core/slots/pane-ref.d.ts +47 -45
  41. package/lib/core/slots/router.service.d.ts +2 -3
  42. package/lib/core/slots/slots.component.d.ts +21 -14
  43. package/lib/cube/matrix/matrix.base.d.ts +2 -2
  44. package/lib/cube/matrix/matrix.pane.component.d.ts +14 -1
  45. package/lib/dashboard/dashboard.component.d.ts +6 -2
  46. package/lib/dashboard/widget-item.component.d.ts +2 -0
  47. package/lib/shared.module.d.ts +183 -182
  48. package/lib/views/view-item.component.d.ts +2 -0
  49. package/lib/views/views.component.d.ts +4 -0
  50. package/lib/views/views.pane.component.d.ts +3 -2
  51. package/package.json +1 -1
  52. package/public-api.d.ts +1 -1
@@ -68,7 +68,8 @@ export class ComposePaneComponent {
68
68
  else
69
69
  container.classList.remove('drag');
70
70
  });
71
- this._pane.fullscreenChange.subscribe(f => this.expendable = !f);
71
+ this.expendable = !this._pane.expanded;
72
+ this._pane.expandeding.subscribe(e => this.expendable = !e);
72
73
  }
73
74
  close() {
74
75
  this._pane.close();
@@ -87,7 +88,7 @@ export class ComposePaneComponent {
87
88
  this.form.save().subscribe();
88
89
  }
89
90
  saved() {
90
- this._pane.refresh();
91
+ this._pane.recycle();
91
92
  }
92
93
  navComments() {
93
94
  this._navigate('comments').then(paneRef => {
@@ -201,4 +202,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.1", ngImpor
201
202
  type: HostListener,
202
203
  args: ['document:keydown', ['$event']]
203
204
  }] } });
204
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"compose.pane.component.js","sourceRoot":"","sources":["../../../../../libraries/core/src/lib/compose/compose.pane.component.ts","../../../../../libraries/core/src/lib/compose/compose.pane.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostListener, OnDestroy, ViewChild, ElementRef, OnInit, Inject } from '@angular/core';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { RecipientModel } from '../core/models';\r\nimport { PanesRouter } from '../core/slots/router.service';\r\nimport { PaneRef } from '../core/slots/pane-ref';\r\nimport { CommentsPaneComponent } from './comments/Comments.pane.component';\r\nimport { ComposeFormComponent } from './form.component';\r\nimport { ViewMode } from '../core/base';\r\nimport { MailboxService } from '../core/mailbox.service';\r\nimport { SessionService } from '../core/session.service';\r\nimport { BizDocConfig, BIZDOC_CONFIG, OpenPolicy } from '../core/configuration';\r\n\r\n@Component({\r\n  selector: 'bizdoc-compose.pane',\r\n  templateUrl: './compose.pane.component.html',\r\n  styleUrls: ['./compose.pane.component.scss'],\r\n  host: {\r\n    class: 'pane'\r\n  }\r\n})\r\n/** compose component responsible for editing a form */\r\nexport class ComposePaneComponent implements OnInit, OnDestroy {\r\n  @ViewChild(ComposeFormComponent, { static: true }) form: ComposeFormComponent;\r\n  @ViewChild('dropable', { static: true, read: ElementRef }) dropableElement: ElementRef;\r\n  model: RecipientModel<any>;\r\n  newCommentsCount: number;\r\n  working: boolean;\r\n  dirty: boolean;\r\n  valid: boolean;\r\n  mode: ViewMode;\r\n  expendable: boolean;\r\n  readonly enableAnalysis: boolean;\r\n  private readonly _dragDrop = new Subject<boolean>();\r\n  private readonly _destroy = new Subject<void>();\r\n  /** compose ctor */\r\n  constructor(\r\n    private _session: SessionService,\r\n    private _mailbox: MailboxService,\r\n    private _pane: PaneRef<ComposePaneComponent>,\r\n    private _router: PanesRouter,\r\n    @Inject(BIZDOC_CONFIG) config: BizDocConfig) {\r\n    this.enableAnalysis = _session.profile.views.length > 0;\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this._pane.dataChange.subscribe(d => {\r\n      if (this.model == d.item) return;\r\n      this.model = d.item;\r\n      const form = this._session.profile.forms.find(f => f.name === this.model.formId);\r\n      this._pane.icon = form.icon;\r\n      if (this.model.draft) {\r\n        this.mode = 'compose';\r\n        //setTimeout(()=>this._pane.expand());\r\n      }\r\n      else\r\n        this.mode = 'preview';\r\n      this.newCommentsCount = this.model.unreadComments;\r\n      this._pane.title = this._pane.group = `#${this.model.number}`;\r\n    });\r\n    this._pane.queryParamsChange.subscribe(p => {\r\n      const { page } = p;\r\n      if (page !== undefined) {\r\n        //   const pagen = parseInt(page);\r\n        //  this.form.navigate(isNaN(pagen) ? page : pagen);\r\n      }\r\n    });\r\n    this._mailbox.changed.pipe(takeUntil(this._destroy)).subscribe(e => {\r\n      if (e.id === this.model.id && !this.working) {\r\n        if (e.folderId && e.folderId !== this.model.folderId) this._close();\r\n      }\r\n    });\r\n    this._mailbox.deleted.pipe(takeUntil(this._destroy)).subscribe(e =>\r\n      e === this.model.id && !this.working &&\r\n      this._close()\r\n    );\r\n    const container = this.dropableElement.nativeElement;\r\n    this._dragDrop.subscribe(ok => {\r\n      if (ok) container.classList.add('drag');\r\n      else container.classList.remove('drag');\r\n    });\r\n    this._pane.fullscreenChange.subscribe(f =>\r\n      this.expendable = !f);\r\n  }\r\n  close() {\r\n    this._pane.close();\r\n  }\r\n  edit() {\r\n    this.mode = 'compose';\r\n    this.expendable && this.expand();\r\n  }\r\n  expand() {\r\n    this._pane.expand();\r\n  }\r\n  change() {\r\n    this._pane.focus();\r\n  }\r\n  save() {\r\n    this.form.save().subscribe();\r\n  }\r\n  saved() {\r\n    this._pane.refresh();\r\n  }\r\n  navComments() {\r\n    this._navigate('comments').then(paneRef => {\r\n      (paneRef.instance as CommentsPaneComponent).comments.change.\r\n        pipe(takeUntil(this._destroy)).subscribe(() =>\r\n          this.newCommentsCount = (paneRef.instance as CommentsPaneComponent).\r\n            comments.unreadComments);\r\n    });\r\n  }\r\n  navTrace() {\r\n    this._navigate('trace')\r\n  }\r\n  private _navigate(command: string) {\r\n    return this._router.navigate([command], {\r\n      pathMode: 'relative',\r\n      relativeTo: this._pane,\r\n      policy: OpenPolicy.Toggle\r\n    });\r\n  }\r\n  @HostListener('document:drop', ['$event'])\r\n  handleDocumentDrop(event: KeyboardEvent) {\r\n    event.stopPropagation();\r\n    event.preventDefault();\r\n  }\r\n  @HostListener('drop', ['$event'])\r\n  handleDrop(event: DragEvent) {\r\n    event.preventDefault();\r\n    this._dragDrop.next(false);\r\n    const { items } = event.dataTransfer;\r\n    const arr: File[] = [];\r\n    for (let i = 0; i < items.length; i++) {\r\n      const file = items[i].getAsFile();\r\n      arr.push(file);\r\n    }\r\n    this.form.upload(arr).subscribe();\r\n  }\r\n  @HostListener('dragenter', ['$event'])\r\n  handleEnter(event: DragEvent) {\r\n    event.preventDefault();\r\n    this._dragDrop.next(true);\r\n  }\r\n  @HostListener('dragleave', ['$event'])\r\n  handleLeave(event: DragEvent) {\r\n    event.preventDefault();\r\n    this._dragDrop.next(false);\r\n  }\r\n  @HostListener('dragover', ['$event'])\r\n  handleOver(event: DragEvent) {\r\n    event.preventDefault();\r\n    this._dragDrop.next(true);\r\n  }\r\n  /**\r\n   * Ctrl-s save\r\n   * @param event\r\n   */\r\n  @HostListener('document:keydown', ['$event'])\r\n  handleKeydown(event: KeyboardEvent) {\r\n    if (event.ctrlKey && (event.which === 83 || event.which === 115)) {\r\n      if (this.dirty && !this.working)\r\n        this.save();\r\n      event.preventDefault();\r\n    }\r\n  }\r\n  discard() {\r\n    this.form.discard().subscribe(this._close.bind(this))\r\n  }\r\n  send(action: string) {\r\n    this.form.send(action).subscribe(this._close.bind(this));\r\n  }\r\n  submit() {\r\n    this.form.submit().subscribe(this._close.bind(this))\r\n  }\r\n  private _close() {\r\n    this.form.dirty = false;\r\n    this._pane.close();\r\n  }\r\n  ngOnDestroy(): void {\r\n    this._dragDrop.complete();\r\n\r\n    this._destroy.next();\r\n    this._destroy.complete();\r\n  }\r\n  view() {\r\n    this._navigate('views')\r\n  }\r\n}\r\n","<mat-toolbar class=\"nav-toolbar\">\r\n  <button mat-icon-button color=\"primary\" (click)=\"form.back()\" [bizdocTooltip]=\"'Back'|translate\" *ngIf=\"form.page !== undefined\" tabindex=\"1\">\r\n    <mat-icon class=\"mat-icon-rtl-mirror\">arrow_back</mat-icon>\r\n  </button>\r\n  <button mat-stroked-button color=\"primary\" *ngIf=\"model.draft\" data-help=\"submit\"\r\n          (click)=\"submit()\" [disabled]=\"!valid||working\">\r\n    <span>{{'Submit' | translate}}</span>\r\n  </button>\r\n  <button mat-stroked-button color=\"primary\" *ngIf=\"form.actions.length === 1\" [attr.data-help]=\"'action-'+form.actions[0].name\" (click)=\"send(model.actions[0])\" [disabled]=\"!valid||working\">\r\n    <span>{{form.actions[0].title}}</span>\r\n  </button>\r\n  <button mat-stroked-button data-help=\"send\" color=\"primary\" *ngIf=\"form.actions.length > 1\" [matMenuTriggerFor]=\"actionMenu\" [disabled]=\"!valid||working\">\r\n    <span>{{'Send' | translate}}</span>\r\n  </button>\r\n  <!-- action -->\r\n  <mat-menu #actionMenu>\r\n    <ng-template matMenuContent>\r\n      <ng-container *ngFor=\"let a of form.actions; let i = index\">\r\n        <mat-divider *ngIf=\"i > 0 && form.actions[i - 1].group !== a.group\"></mat-divider>\r\n        <button mat-menu-item (click)=\"send(a.name)\">{{a.title}}</button>\r\n      </ng-container>\r\n    </ng-template>\r\n  </mat-menu>\r\n  <button mat-icon-button (click)=\"save()\" data-help=\"save\" [disabled]=\"!dirty||working\" [bizdocTooltip]=\"'Save'|translate\" *ngIf=\"mode === 'compose'\">\r\n    <mat-icon>save</mat-icon>\r\n  </button>\r\n  <button mat-icon-button data-help=\"tag\" (click)=\"form.tag($event)\" [bizdocTooltip]=\"'Tags' | translate\" [disabled]=\"working\"><mat-icon class=\"filled\">{{model.tags && model.tags.length ?'bookmark':'bookmark_border'}}</mat-icon></button>\r\n  <button mat-icon-button data-help=\"flag\" [bizdocTooltip]=\"'Flagged'| translate\" [disabled]=\"working\" (click)=\"form.flag()\"><mat-icon [class.document-flag]=\"model.flag\">{{model.flag ? 'star' : 'star_border'}}</mat-icon></button>\r\n  <button mat-icon-button (click)=\"form.attach()\" data-help=\"attach\" [bizdocTooltip]=\"'AttachFile' | translate\" [disabled]=\"working\"><mat-icon>attach_file</mat-icon></button>\r\n  <button mat-icon-button [disabled]=\"working\" data-help=\"edit\" (click)=\"edit()\" [bizdocTooltip]=\"'Edit' | translate\" *ngIf=\"mode !== 'compose' && model.pending && !model.completed\"><mat-icon>create</mat-icon></button>\r\n  <span class=\"divider\"></span>\r\n  <button mat-icon-button (click)=\"navTrace()\" [bizdocTooltip]=\"'Trace' | translate\" tabindex=\"1\"><mat-icon>timeline</mat-icon></button>\r\n  <button mat-icon-button (click)=\"navComments()\" data-help=\"comments\" [bizdocTooltip]=\"'Comments' | translate\" [matBadge]=\"newCommentsCount\" [matBadgeHidden]=\"!newCommentsCount\" matBadgeColor=\"accent\">\r\n    <mat-icon [class.filled]=\"model.comments.length > 0\">format_quote</mat-icon>\r\n  </button>\r\n  <button mat-icon-button (click)=\"view()\" [bizdocTooltip]=\"'View' | translate\" [attr.aria-label]=\"'View' | translate\" *ngIf=\"enableAnalysis\" class=\"tool\"><mat-icon>data_usage</mat-icon></button>\r\n  <button mat-icon-button (click)=\"expand()\" [bizdocTooltip]=\"'Expand' | translate\" *ngIf=\"expendable\" [attr.aria-label]=\"'Expand' | translate\"><mat-icon>open_in_new</mat-icon></button>\r\n  <button mat-icon-button [matMenuTriggerFor]=\"optionsMenu\" [bizdocTooltip]=\"'Options' | translate\" [attr.aria-label]=\"'Options' | translate\"><mat-icon>more_vert</mat-icon></button>\r\n  <mat-menu #optionsMenu=\"matMenu\">\r\n    <ng-template matMenuContent>\r\n      <button mat-menu-item (click)=\"form.copy()\" [disabled]=\"working\">\r\n        <!--<mat-icon>content_copy</mat-icon>-->\r\n        <span>{{'Copy' | translate}}</span>\r\n      </button>\r\n      <button mat-menu-item (click)=\"discard()\" *ngIf=\"model.draft && !model.issued\" [disabled]=\"working\">\r\n        <!--<mat-icon>delete_outlined</mat-icon>-->\r\n        <span>{{'Discard' | translate}}</span>\r\n      </button>\r\n      <ng-container *ngIf=\"form.help\">\r\n        <mat-divider></mat-divider>\r\n        <button mat-menu-item (click)=\"form.guide(form.help)\">\r\n          <!--<mat-icon>help_outline</mat-icon>-->\r\n          <span>{{'Help' | translate}}</span>\r\n        </button>\r\n      </ng-container>\r\n      <mat-divider></mat-divider>\r\n      <button mat-menu-item (click)=\"close()\"><!--<mat-icon></mat-icon>--><span>{{'Close'| translate}}</span></button>\r\n    </ng-template>\r\n  </mat-menu>\r\n</mat-toolbar>\r\n<div class=\"file-dropable\" #dropable>\r\n  <bizdoc-form [model]=model #form\r\n               (modelChange)=\"change()\"\r\n               (saved)=\"saved()\"\r\n               (validChange)=\"valid=$event\"\r\n               (workingChange)=\"working=$event\"\r\n               (dirtyChange)=\"dirty=$event\" [mode]=\"mode\"></bizdoc-form>\r\n</div>\r\n"]}
205
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"compose.pane.component.js","sourceRoot":"","sources":["../../../../../libraries/core/src/lib/compose/compose.pane.component.ts","../../../../../libraries/core/src/lib/compose/compose.pane.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostListener, OnDestroy, ViewChild, ElementRef, OnInit, Inject } from '@angular/core';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { RecipientModel } from '../core/models';\r\nimport { PanesRouter } from '../core/slots/router.service';\r\nimport { PaneRef } from '../core/slots/pane-ref';\r\nimport { CommentsPaneComponent } from './comments/Comments.pane.component';\r\nimport { ComposeFormComponent } from './form.component';\r\nimport { ViewMode } from '../core/base';\r\nimport { MailboxService } from '../core/mailbox.service';\r\nimport { SessionService } from '../core/session.service';\r\nimport { BizDocConfig, BIZDOC_CONFIG, OpenPolicy } from '../core/configuration';\r\n\r\n@Component({\r\n  selector: 'bizdoc-compose.pane',\r\n  templateUrl: './compose.pane.component.html',\r\n  styleUrls: ['./compose.pane.component.scss'],\r\n  host: {\r\n    class: 'pane'\r\n  }\r\n})\r\n/** compose component responsible for editing a form */\r\nexport class ComposePaneComponent implements OnInit, OnDestroy {\r\n  @ViewChild(ComposeFormComponent, { static: true }) form: ComposeFormComponent;\r\n  @ViewChild('dropable', { static: true, read: ElementRef }) dropableElement: ElementRef;\r\n  model: RecipientModel<any>;\r\n  newCommentsCount: number;\r\n  working: boolean;\r\n  dirty: boolean;\r\n  valid: boolean;\r\n  mode: ViewMode;\r\n  expendable: boolean;\r\n  readonly enableAnalysis: boolean;\r\n  private readonly _dragDrop = new Subject<boolean>();\r\n  private readonly _destroy = new Subject<void>();\r\n  /** compose ctor */\r\n  constructor(\r\n    private _session: SessionService,\r\n    private _mailbox: MailboxService,\r\n    private _pane: PaneRef<ComposePaneComponent>,\r\n    private _router: PanesRouter,\r\n    @Inject(BIZDOC_CONFIG) config: BizDocConfig) {\r\n    this.enableAnalysis = _session.profile.views.length > 0;\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this._pane.dataChange.subscribe(d => {\r\n      if (this.model == d.item) return;\r\n      this.model = d.item;\r\n      const form = this._session.profile.forms.find(f => f.name === this.model.formId);\r\n      this._pane.icon = form.icon;\r\n      if (this.model.draft) {\r\n        this.mode = 'compose';\r\n        //setTimeout(()=>this._pane.expand());\r\n      }\r\n      else\r\n        this.mode = 'preview';\r\n      this.newCommentsCount = this.model.unreadComments;\r\n      this._pane.title = this._pane.group = `#${this.model.number}`;\r\n    });\r\n    this._pane.queryParamsChange.subscribe(p => {\r\n      const { page } = p;\r\n      if (page !== undefined) {\r\n        //   const pagen = parseInt(page);\r\n        //  this.form.navigate(isNaN(pagen) ? page : pagen);\r\n      }\r\n    });\r\n    this._mailbox.changed.pipe(takeUntil(this._destroy)).subscribe(e => {\r\n      if (e.id === this.model.id && !this.working) {\r\n        if (e.folderId && e.folderId !== this.model.folderId) this._close();\r\n      }\r\n    });\r\n    this._mailbox.deleted.pipe(takeUntil(this._destroy)).subscribe(e =>\r\n      e === this.model.id && !this.working &&\r\n      this._close()\r\n    );\r\n    const container = this.dropableElement.nativeElement;\r\n    this._dragDrop.subscribe(ok => {\r\n      if (ok) container.classList.add('drag');\r\n      else container.classList.remove('drag');\r\n    });\r\n    this.expendable = !this._pane.expanded;\r\n    this._pane.expandeding.subscribe(e => this.expendable = !e);\r\n  }\r\n  close() {\r\n    this._pane.close();\r\n  }\r\n  edit() {\r\n    this.mode = 'compose';\r\n    this.expendable && this.expand();\r\n  }\r\n  expand() {\r\n    this._pane.expand();\r\n  }\r\n  change() {\r\n    this._pane.focus();\r\n  }\r\n  save() {\r\n    this.form.save().subscribe();\r\n  }\r\n  saved() {\r\n    this._pane.recycle();\r\n  }\r\n  navComments() {\r\n    this._navigate('comments').then(paneRef => {\r\n      (paneRef.instance as CommentsPaneComponent).comments.change.\r\n        pipe(takeUntil(this._destroy)).subscribe(() =>\r\n          this.newCommentsCount = (paneRef.instance as CommentsPaneComponent).\r\n            comments.unreadComments);\r\n    });\r\n  }\r\n  navTrace() {\r\n    this._navigate('trace')\r\n  }\r\n  private _navigate(command: string) {\r\n    return this._router.navigate([command], {\r\n      pathMode: 'relative',\r\n      relativeTo: this._pane,\r\n      policy: OpenPolicy.Toggle\r\n    });\r\n  }\r\n  @HostListener('document:drop', ['$event'])\r\n  handleDocumentDrop(event: KeyboardEvent) {\r\n    event.stopPropagation();\r\n    event.preventDefault();\r\n  }\r\n  @HostListener('drop', ['$event'])\r\n  handleDrop(event: DragEvent) {\r\n    event.preventDefault();\r\n    this._dragDrop.next(false);\r\n    const { items } = event.dataTransfer;\r\n    const arr: File[] = [];\r\n    for (let i = 0; i < items.length; i++) {\r\n      const file = items[i].getAsFile();\r\n      arr.push(file);\r\n    }\r\n    this.form.upload(arr).subscribe();\r\n  }\r\n  @HostListener('dragenter', ['$event'])\r\n  handleEnter(event: DragEvent) {\r\n    event.preventDefault();\r\n    this._dragDrop.next(true);\r\n  }\r\n  @HostListener('dragleave', ['$event'])\r\n  handleLeave(event: DragEvent) {\r\n    event.preventDefault();\r\n    this._dragDrop.next(false);\r\n  }\r\n  @HostListener('dragover', ['$event'])\r\n  handleOver(event: DragEvent) {\r\n    event.preventDefault();\r\n    this._dragDrop.next(true);\r\n  }\r\n  /**\r\n   * Ctrl-s save\r\n   * @param event\r\n   */\r\n  @HostListener('document:keydown', ['$event'])\r\n  handleKeydown(event: KeyboardEvent) {\r\n    if (event.ctrlKey && (event.which === 83 || event.which === 115)) {\r\n      if (this.dirty && !this.working)\r\n        this.save();\r\n      event.preventDefault();\r\n    }\r\n  }\r\n  discard() {\r\n    this.form.discard().subscribe(this._close.bind(this))\r\n  }\r\n  send(action: string) {\r\n    this.form.send(action).subscribe(this._close.bind(this));\r\n  }\r\n  submit() {\r\n    this.form.submit().subscribe(this._close.bind(this))\r\n  }\r\n  private _close() {\r\n    this.form.dirty = false;\r\n    this._pane.close();\r\n  }\r\n  ngOnDestroy(): void {\r\n    this._dragDrop.complete();\r\n\r\n    this._destroy.next();\r\n    this._destroy.complete();\r\n  }\r\n  view() {\r\n    this._navigate('views')\r\n  }\r\n}\r\n","<mat-toolbar class=\"nav-toolbar\">\r\n  <button mat-icon-button color=\"primary\" (click)=\"form.back()\" [bizdocTooltip]=\"'Back'|translate\" *ngIf=\"form.page !== undefined\" tabindex=\"1\">\r\n    <mat-icon class=\"mat-icon-rtl-mirror\">arrow_back</mat-icon>\r\n  </button>\r\n  <button mat-stroked-button color=\"primary\" *ngIf=\"model.draft\" data-help=\"submit\"\r\n          (click)=\"submit()\" [disabled]=\"!valid||working\">\r\n    <span>{{'Submit' | translate}}</span>\r\n  </button>\r\n  <button mat-stroked-button color=\"primary\" *ngIf=\"form.actions.length === 1\" [attr.data-help]=\"'action-'+form.actions[0].name\" (click)=\"send(model.actions[0])\" [disabled]=\"!valid||working\">\r\n    <span>{{form.actions[0].title}}</span>\r\n  </button>\r\n  <button mat-stroked-button data-help=\"send\" color=\"primary\" *ngIf=\"form.actions.length > 1\" [matMenuTriggerFor]=\"actionMenu\" [disabled]=\"!valid||working\">\r\n    <span>{{'Send' | translate}}</span>\r\n  </button>\r\n  <!-- action -->\r\n  <mat-menu #actionMenu>\r\n    <ng-template matMenuContent>\r\n      <ng-container *ngFor=\"let a of form.actions; let i = index\">\r\n        <mat-divider *ngIf=\"i > 0 && form.actions[i - 1].group !== a.group\"></mat-divider>\r\n        <button mat-menu-item (click)=\"send(a.name)\">{{a.title}}</button>\r\n      </ng-container>\r\n    </ng-template>\r\n  </mat-menu>\r\n  <button mat-icon-button (click)=\"save()\" data-help=\"save\" [disabled]=\"!dirty||working\" [bizdocTooltip]=\"'Save'|translate\" *ngIf=\"mode === 'compose'\">\r\n    <mat-icon>save</mat-icon>\r\n  </button>\r\n  <button mat-icon-button data-help=\"tag\" (click)=\"form.tag($event)\" [bizdocTooltip]=\"'Tags' | translate\" [disabled]=\"working\"><mat-icon class=\"filled\">{{model.tags && model.tags.length ?'bookmark':'bookmark_border'}}</mat-icon></button>\r\n  <button mat-icon-button data-help=\"flag\" [bizdocTooltip]=\"'Flagged'| translate\" [disabled]=\"working\" (click)=\"form.flag()\"><mat-icon [class.document-flag]=\"model.flag\">{{model.flag ? 'star' : 'star_border'}}</mat-icon></button>\r\n  <button mat-icon-button (click)=\"form.attach()\" data-help=\"attach\" [bizdocTooltip]=\"'AttachFile' | translate\" [disabled]=\"working\"><mat-icon>attach_file</mat-icon></button>\r\n  <button mat-icon-button [disabled]=\"working\" data-help=\"edit\" (click)=\"edit()\" [bizdocTooltip]=\"'Edit' | translate\" *ngIf=\"mode !== 'compose' && model.pending && !model.completed\"><mat-icon>create</mat-icon></button>\r\n  <span class=\"divider\"></span>\r\n  <button mat-icon-button (click)=\"navTrace()\" [bizdocTooltip]=\"'Trace' | translate\" tabindex=\"1\"><mat-icon>timeline</mat-icon></button>\r\n  <button mat-icon-button (click)=\"navComments()\" data-help=\"comments\" [bizdocTooltip]=\"'Comments' | translate\" [matBadge]=\"newCommentsCount\" [matBadgeHidden]=\"!newCommentsCount\" matBadgeColor=\"accent\">\r\n    <mat-icon [class.filled]=\"model.comments.length > 0\">format_quote</mat-icon>\r\n  </button>\r\n  <button mat-icon-button (click)=\"view()\" [bizdocTooltip]=\"'View' | translate\" [attr.aria-label]=\"'View' | translate\" *ngIf=\"enableAnalysis\" class=\"tool\"><mat-icon>data_usage</mat-icon></button>\r\n  <button mat-icon-button (click)=\"expand()\" [bizdocTooltip]=\"'Expand' | translate\" *ngIf=\"expendable\" [attr.aria-label]=\"'Expand' | translate\"><mat-icon>open_in_new</mat-icon></button>\r\n  <button mat-icon-button [matMenuTriggerFor]=\"optionsMenu\" [bizdocTooltip]=\"'Options' | translate\" [attr.aria-label]=\"'Options' | translate\"><mat-icon>more_vert</mat-icon></button>\r\n  <mat-menu #optionsMenu=\"matMenu\">\r\n    <ng-template matMenuContent>\r\n      <button mat-menu-item (click)=\"form.copy()\" [disabled]=\"working\">\r\n        <!--<mat-icon>content_copy</mat-icon>-->\r\n        <span>{{'Copy' | translate}}</span>\r\n      </button>\r\n      <button mat-menu-item (click)=\"discard()\" *ngIf=\"model.draft && !model.issued\" [disabled]=\"working\">\r\n        <!--<mat-icon>delete_outlined</mat-icon>-->\r\n        <span>{{'Discard' | translate}}</span>\r\n      </button>\r\n      <ng-container *ngIf=\"form.help\">\r\n        <mat-divider></mat-divider>\r\n        <button mat-menu-item (click)=\"form.guide(form.help)\">\r\n          <!--<mat-icon>help_outline</mat-icon>-->\r\n          <span>{{'Help' | translate}}</span>\r\n        </button>\r\n      </ng-container>\r\n      <mat-divider></mat-divider>\r\n      <button mat-menu-item (click)=\"close()\"><!--<mat-icon></mat-icon>--><span>{{'Close'| translate}}</span></button>\r\n    </ng-template>\r\n  </mat-menu>\r\n</mat-toolbar>\r\n<div class=\"file-dropable\" #dropable>\r\n  <bizdoc-form [model]=model #form\r\n               (modelChange)=\"change()\"\r\n               (saved)=\"saved()\"\r\n               (validChange)=\"valid=$event\"\r\n               (workingChange)=\"working=$event\"\r\n               (dirtyChange)=\"dirty=$event\" [mode]=\"mode\"></bizdoc-form>\r\n</div>\r\n"]}
@@ -22,7 +22,7 @@ export class TracePaneComponent {
22
22
  this.model = d['item'];
23
23
  this._pane.group = `#${this.model.number}`;
24
24
  });
25
- this._pane.resize.subscribe(() => {
25
+ this._pane.resized.subscribe(() => {
26
26
  this.flow.resize();
27
27
  });
28
28
  }
@@ -49,4 +49,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.1", ngImpor
49
49
  type: ViewChild,
50
50
  args: [FlowViewComponent, { static: true }]
51
51
  }] } });
52
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhY2UucGFuZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJyYXJpZXMvY29yZS9zcmMvbGliL2NvbXBvc2UvdHJhY2UvdHJhY2UucGFuZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9saWJyYXJpZXMvY29yZS9zcmMvbGliL2NvbXBvc2UvdHJhY2UvdHJhY2UucGFuZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFVLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUs3RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNyRCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQzs7Ozs7OztBQVN2RCxNQUFNLE9BQU8sa0JBQWtCO0lBSTdCLFlBQVksU0FBMkIsRUFDN0IsS0FBa0MsRUFDbEMsT0FBb0I7UUFEcEIsVUFBSyxHQUFMLEtBQUssQ0FBNkI7UUFDbEMsWUFBTyxHQUFQLE9BQU8sQ0FBYTtRQUU1QixLQUFLLENBQUMsS0FBSyxHQUFHLFNBQVMsQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDdkMsQ0FBQztJQUNELFFBQVE7UUFDTixJQUFJLENBQUMsS0FBSyxDQUFDLFVBQVUsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLEVBQUU7WUFDbEMsSUFBSSxJQUFJLENBQUMsS0FBSyxJQUFJLENBQUMsQ0FBQyxNQUFNLENBQUMsRUFBRTtnQkFDM0IsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLEVBQUUsQ0FBQztnQkFDckIsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQzthQUNyQjtZQUNELElBQUksQ0FBQyxLQUFLLEdBQUcsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1lBQ3ZCLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxHQUFHLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLEVBQUUsQ0FBQztRQUM3QyxDQUFDLENBQUMsQ0FBQztRQUNILElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUU7WUFDL0IsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztRQUNyQixDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFDRCxPQUFPLENBQUMsSUFBVTtRQUNoQixJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDLElBQUksRUFBRSxTQUFTLEVBQUUsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsT0FBTyxFQUFFLENBQUMsUUFBUSxFQUFFLENBQUMsRUFBRTtZQUM1RSxVQUFVLEVBQUUsSUFBSSxDQUFDLEtBQUs7WUFDdEIsS0FBSyxFQUFFO2dCQUNMLElBQUksRUFBRSxJQUFJLENBQUMsS0FBSzthQUNqQjtTQUNGLENBQUMsQ0FBQztJQUNMLENBQUM7OytHQTlCVSxrQkFBa0I7bUdBQWxCLGtCQUFrQiw2SEFFbEIsa0JBQWtCLHFGQUNsQixpQkFBaUIsOERDbEI5QixnSkFHQTsyRkRZYSxrQkFBa0I7a0JBUDlCLFNBQVM7MkJBR0Y7d0JBQ0osS0FBSyxFQUFFLE1BQU07cUJBQ2Q7dUpBSWdELEtBQUs7c0JBQXJELFNBQVM7dUJBQUMsa0JBQWtCLEVBQUUsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFO2dCQUNDLElBQUk7c0JBQW5ELFNBQVM7dUJBQUMsaUJBQWlCLEVBQUUsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQsIFZpZXdDaGlsZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBEb2N1bWVudE1vZGVsIH0gZnJvbSAnLi4vLi4vY29yZS9tb2RlbHMnO1xyXG5pbXBvcnQgeyBQYW5lc1JvdXRlciB9IGZyb20gJy4uLy4uL2NvcmUvc2xvdHMvcm91dGVyLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBQYW5lUmVmIH0gZnJvbSAnLi4vLi4vY29yZS9zbG90cy9wYW5lLXJlZic7XHJcbmltcG9ydCB7IFRyYW5zbGF0ZVNlcnZpY2UgfSBmcm9tICcuLi8uLi9jb3JlL3RyYW5zbGF0ZS5zZXJ2aWNlJztcclxuaW1wb3J0IHsgRmxvd1ZpZXdDb21wb25lbnQgfSBmcm9tICcuL2Zsb3cuY29tcG9uZW50JztcclxuaW1wb3J0IHsgVHJhY2VWaWV3Q29tcG9uZW50IH0gZnJvbSAnLi90cmFjZS5jb21wb25lbnQnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgdGVtcGxhdGVVcmw6ICcuL3RyYWNlLnBhbmUuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL3RyYWNlLnBhbmUuY29tcG9uZW50LnNjc3MnXSxcclxuICBob3N0OiB7XHJcbiAgICBjbGFzczogJ3BhbmUnXHJcbiAgfVxyXG59KVxyXG5leHBvcnQgY2xhc3MgVHJhY2VQYW5lQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcclxuICBtb2RlbDogRG9jdW1lbnRNb2RlbDxhbnk+O1xyXG4gIEBWaWV3Q2hpbGQoVHJhY2VWaWV3Q29tcG9uZW50LCB7IHN0YXRpYzogdHJ1ZSB9KSB0cmFjZTogVHJhY2VWaWV3Q29tcG9uZW50O1xyXG4gIEBWaWV3Q2hpbGQoRmxvd1ZpZXdDb21wb25lbnQsIHsgc3RhdGljOiB0cnVlIH0pIGZsb3c6IEZsb3dWaWV3Q29tcG9uZW50O1xyXG4gIGNvbnN0cnVjdG9yKHRyYW5zbGF0ZTogVHJhbnNsYXRlU2VydmljZSxcclxuICAgIHByaXZhdGUgX3BhbmU6IFBhbmVSZWY8VHJhY2VQYW5lQ29tcG9uZW50PixcclxuICAgIHByaXZhdGUgX3JvdXRlcjogUGFuZXNSb3V0ZXJcclxuICApIHtcclxuICAgIF9wYW5lLnRpdGxlID0gdHJhbnNsYXRlLmdldCgnVHJhY2UnKTtcclxuICB9XHJcbiAgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgICB0aGlzLl9wYW5lLmRhdGFDaGFuZ2Uuc3Vic2NyaWJlKGQgPT4ge1xyXG4gICAgICBpZiAodGhpcy5tb2RlbCA9PSBkWydpdGVtJ10pIHtcclxuICAgICAgICB0aGlzLnRyYWNlLnJlZnJlc2goKTtcclxuICAgICAgICB0aGlzLmZsb3cucmVmcmVzaCgpO1xyXG4gICAgICB9XHJcbiAgICAgIHRoaXMubW9kZWwgPSBkWydpdGVtJ107XHJcbiAgICAgIHRoaXMuX3BhbmUuZ3JvdXAgPSBgIyR7dGhpcy5tb2RlbC5udW1iZXJ9YDtcclxuICAgIH0pO1xyXG4gICAgdGhpcy5fcGFuZS5yZXNpemUuc3Vic2NyaWJlKCgpID0+IHtcclxuICAgICAgdGhpcy5mbG93LnJlc2l6ZSgpO1xyXG4gICAgfSk7XHJcbiAgfVxyXG4gIHZlcnNpb24odGltZTogRGF0ZSkge1xyXG4gICAgdGhpcy5fcm91dGVyLm5hdmlnYXRlKFsnLi4nLCAndmVyc2lvbicsIG5ldyBEYXRlKHRpbWUpLnZhbHVlT2YoKS5lbmNvZGVJZCgpXSwge1xyXG4gICAgICByZWxhdGl2ZVRvOiB0aGlzLl9wYW5lLFxyXG4gICAgICBzdGF0ZToge1xyXG4gICAgICAgIGl0ZW06IHRoaXMubW9kZWxcclxuICAgICAgfVxyXG4gICAgfSk7XHJcbiAgfVxyXG59XHJcbiIsIjxiaXpkb2MtdHJhY2UgW21vZGVsXT1cIm1vZGVsXCIgKHZlcnNpb25TZWxlY3RlZCk9XCJ2ZXJzaW9uKCRldmVudClcIj48L2JpemRvYy10cmFjZT5cclxuXHJcbjxiaXpkb2MtZmxvdyBbbW9kZWxdPVwibW9kZWxcIj48L2JpemRvYy1mbG93PlxyXG4iXX0=
52
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhY2UucGFuZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJyYXJpZXMvY29yZS9zcmMvbGliL2NvbXBvc2UvdHJhY2UvdHJhY2UucGFuZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9saWJyYXJpZXMvY29yZS9zcmMvbGliL2NvbXBvc2UvdHJhY2UvdHJhY2UucGFuZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFVLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUs3RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNyRCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQzs7Ozs7OztBQVN2RCxNQUFNLE9BQU8sa0JBQWtCO0lBSTdCLFlBQVksU0FBMkIsRUFDN0IsS0FBa0MsRUFDbEMsT0FBb0I7UUFEcEIsVUFBSyxHQUFMLEtBQUssQ0FBNkI7UUFDbEMsWUFBTyxHQUFQLE9BQU8sQ0FBYTtRQUU1QixLQUFLLENBQUMsS0FBSyxHQUFHLFNBQVMsQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDdkMsQ0FBQztJQUNELFFBQVE7UUFDTixJQUFJLENBQUMsS0FBSyxDQUFDLFVBQVUsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLEVBQUU7WUFDbEMsSUFBSSxJQUFJLENBQUMsS0FBSyxJQUFJLENBQUMsQ0FBQyxNQUFNLENBQUMsRUFBRTtnQkFDM0IsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLEVBQUUsQ0FBQztnQkFDckIsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQzthQUNyQjtZQUNELElBQUksQ0FBQyxLQUFLLEdBQUcsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1lBQ3ZCLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxHQUFHLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLEVBQUUsQ0FBQztRQUM3QyxDQUFDLENBQUMsQ0FBQztRQUNILElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUU7WUFDaEMsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztRQUNyQixDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFDRCxPQUFPLENBQUMsSUFBVTtRQUNoQixJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDLElBQUksRUFBRSxTQUFTLEVBQUUsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsT0FBTyxFQUFFLENBQUMsUUFBUSxFQUFFLENBQUMsRUFBRTtZQUM1RSxVQUFVLEVBQUUsSUFBSSxDQUFDLEtBQUs7WUFDdEIsS0FBSyxFQUFFO2dCQUNMLElBQUksRUFBRSxJQUFJLENBQUMsS0FBSzthQUNqQjtTQUNGLENBQUMsQ0FBQztJQUNMLENBQUM7OytHQTlCVSxrQkFBa0I7bUdBQWxCLGtCQUFrQiw2SEFFbEIsa0JBQWtCLHFGQUNsQixpQkFBaUIsOERDbEI5QixnSkFHQTsyRkRZYSxrQkFBa0I7a0JBUDlCLFNBQVM7MkJBR0Y7d0JBQ0osS0FBSyxFQUFFLE1BQU07cUJBQ2Q7dUpBSWdELEtBQUs7c0JBQXJELFNBQVM7dUJBQUMsa0JBQWtCLEVBQUUsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFO2dCQUNDLElBQUk7c0JBQW5ELFNBQVM7dUJBQUMsaUJBQWlCLEVBQUUsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQsIFZpZXdDaGlsZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBEb2N1bWVudE1vZGVsIH0gZnJvbSAnLi4vLi4vY29yZS9tb2RlbHMnO1xyXG5pbXBvcnQgeyBQYW5lc1JvdXRlciB9IGZyb20gJy4uLy4uL2NvcmUvc2xvdHMvcm91dGVyLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBQYW5lUmVmIH0gZnJvbSAnLi4vLi4vY29yZS9zbG90cy9wYW5lLXJlZic7XHJcbmltcG9ydCB7IFRyYW5zbGF0ZVNlcnZpY2UgfSBmcm9tICcuLi8uLi9jb3JlL3RyYW5zbGF0ZS5zZXJ2aWNlJztcclxuaW1wb3J0IHsgRmxvd1ZpZXdDb21wb25lbnQgfSBmcm9tICcuL2Zsb3cuY29tcG9uZW50JztcclxuaW1wb3J0IHsgVHJhY2VWaWV3Q29tcG9uZW50IH0gZnJvbSAnLi90cmFjZS5jb21wb25lbnQnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgdGVtcGxhdGVVcmw6ICcuL3RyYWNlLnBhbmUuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL3RyYWNlLnBhbmUuY29tcG9uZW50LnNjc3MnXSxcclxuICBob3N0OiB7XHJcbiAgICBjbGFzczogJ3BhbmUnXHJcbiAgfVxyXG59KVxyXG5leHBvcnQgY2xhc3MgVHJhY2VQYW5lQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcclxuICBtb2RlbDogRG9jdW1lbnRNb2RlbDxhbnk+O1xyXG4gIEBWaWV3Q2hpbGQoVHJhY2VWaWV3Q29tcG9uZW50LCB7IHN0YXRpYzogdHJ1ZSB9KSB0cmFjZTogVHJhY2VWaWV3Q29tcG9uZW50O1xyXG4gIEBWaWV3Q2hpbGQoRmxvd1ZpZXdDb21wb25lbnQsIHsgc3RhdGljOiB0cnVlIH0pIGZsb3c6IEZsb3dWaWV3Q29tcG9uZW50O1xyXG4gIGNvbnN0cnVjdG9yKHRyYW5zbGF0ZTogVHJhbnNsYXRlU2VydmljZSxcclxuICAgIHByaXZhdGUgX3BhbmU6IFBhbmVSZWY8VHJhY2VQYW5lQ29tcG9uZW50PixcclxuICAgIHByaXZhdGUgX3JvdXRlcjogUGFuZXNSb3V0ZXJcclxuICApIHtcclxuICAgIF9wYW5lLnRpdGxlID0gdHJhbnNsYXRlLmdldCgnVHJhY2UnKTtcclxuICB9XHJcbiAgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgICB0aGlzLl9wYW5lLmRhdGFDaGFuZ2Uuc3Vic2NyaWJlKGQgPT4ge1xyXG4gICAgICBpZiAodGhpcy5tb2RlbCA9PSBkWydpdGVtJ10pIHtcclxuICAgICAgICB0aGlzLnRyYWNlLnJlZnJlc2goKTtcclxuICAgICAgICB0aGlzLmZsb3cucmVmcmVzaCgpO1xyXG4gICAgICB9XHJcbiAgICAgIHRoaXMubW9kZWwgPSBkWydpdGVtJ107XHJcbiAgICAgIHRoaXMuX3BhbmUuZ3JvdXAgPSBgIyR7dGhpcy5tb2RlbC5udW1iZXJ9YDtcclxuICAgIH0pO1xyXG4gICAgdGhpcy5fcGFuZS5yZXNpemVkLnN1YnNjcmliZSgoKSA9PiB7XHJcbiAgICAgIHRoaXMuZmxvdy5yZXNpemUoKTtcclxuICAgIH0pO1xyXG4gIH1cclxuICB2ZXJzaW9uKHRpbWU6IERhdGUpIHtcclxuICAgIHRoaXMuX3JvdXRlci5uYXZpZ2F0ZShbJy4uJywgJ3ZlcnNpb24nLCBuZXcgRGF0ZSh0aW1lKS52YWx1ZU9mKCkuZW5jb2RlSWQoKV0sIHtcclxuICAgICAgcmVsYXRpdmVUbzogdGhpcy5fcGFuZSxcclxuICAgICAgc3RhdGU6IHtcclxuICAgICAgICBpdGVtOiB0aGlzLm1vZGVsXHJcbiAgICAgIH1cclxuICAgIH0pO1xyXG4gIH1cclxufVxyXG4iLCI8Yml6ZG9jLXRyYWNlIFttb2RlbF09XCJtb2RlbFwiICh2ZXJzaW9uU2VsZWN0ZWQpPVwidmVyc2lvbigkZXZlbnQpXCI+PC9iaXpkb2MtdHJhY2U+XHJcblxyXG48Yml6ZG9jLWZsb3cgW21vZGVsXT1cIm1vZGVsXCI+PC9iaXpkb2MtZmxvdz5cclxuIl19
@@ -7,11 +7,11 @@ export var OpenPolicy;
7
7
  OpenPolicy[OpenPolicy["Defer"] = 4] = "Defer";
8
8
  OpenPolicy[OpenPolicy["Pinnable"] = 8] = "Pinnable";
9
9
  OpenPolicy[OpenPolicy["Stretch"] = 16] = "Stretch";
10
- OpenPolicy[OpenPolicy["Tab"] = 32] = "Tab";
11
- OpenPolicy[OpenPolicy["Dialog"] = 96] = "Dialog";
12
- OpenPolicy[OpenPolicy["Expandable"] = 128] = "Expandable";
13
- OpenPolicy[OpenPolicy["Toggle"] = 256] = "Toggle";
10
+ OpenPolicy[OpenPolicy["Expandable"] = 32] = "Expandable";
11
+ OpenPolicy[OpenPolicy["Toggle"] = 64] = "Toggle";
12
+ OpenPolicy[OpenPolicy["Tab"] = 128] = "Tab";
13
+ OpenPolicy[OpenPolicy["Dialog"] = 384] = "Dialog";
14
14
  OpenPolicy[OpenPolicy["Dismissable"] = 512] = "Dismissable";
15
15
  })(OpenPolicy || (OpenPolicy = {}));
16
16
  export const DEFAULT_POLICY = OpenPolicy.Pane;
17
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlndXJhdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnJhcmllcy9jb3JlL3NyYy9saWIvY29yZS9jb25maWd1cmF0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQVEsTUFBTSxlQUFlLENBQUM7QUFJckQsTUFBTSxDQUFDLE1BQU0sYUFBYSxHQUFHLElBQUksY0FBYyxDQUFlLFFBQVEsQ0FBQyxDQUFDO0FBdUJ4RSxNQUFNLENBQU4sSUFBWSxVQVdYO0FBWEQsV0FBWSxVQUFVO0lBQ3BCLDJDQUFhLENBQUE7SUFDYiw2Q0FBYyxDQUFBO0lBQ2QsNkNBQWMsQ0FBQTtJQUNkLG1EQUFpQixDQUFBO0lBQ2pCLGtEQUFnQixDQUFBO0lBQ2hCLDBDQUFZLENBQUE7SUFDWixnREFBZ0MsQ0FBQTtJQUNoQyx5REFBbUIsQ0FBQTtJQUNuQixpREFBZSxDQUFBO0lBQ2YsMkRBQW9CLENBQUE7QUFDdEIsQ0FBQyxFQVhXLFVBQVUsS0FBVixVQUFVLFFBV3JCO0FBRUQsTUFBTSxDQUFDLE1BQU0sY0FBYyxHQUFHLFVBQVUsQ0FBQyxJQUFJLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3Rpb25Ub2tlbiwgVHlwZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XHJcbmltcG9ydCB7IEZvbGRlckNvbHVtbiB9IGZyb20gJy4vbW9kZWxzJztcclxuXHJcbmV4cG9ydCBjb25zdCBCSVpET0NfQ09ORklHID0gbmV3IEluamVjdGlvblRva2VuPEJpekRvY0NvbmZpZz4oJ2JpemRvYycpO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBQYW5lUm91dGUge1xyXG4gIHBhdGg6IHN0cmluZztcclxuICBndWlkZT86IHN0cmluZztcclxuICBjb21wb25lbnQ/OiBUeXBlPGFueT47XHJcbiAgcmVzb2x2ZT86IHsgW2tleTogc3RyaW5nXTogVHlwZTxQYW5lUmVzb2x2ZTxhbnk+PiB9O1xyXG4gIGNhbkRpc21pc3M/OiBUeXBlPENhbkRpc21pc3M8YW55Pj47XHJcbiAgaWNvbj86IHN0cmluZztcclxuICBoZWxwPzogc3RyaW5nO1xyXG4gIGNoaWxkcmVuPzogUGFuZVJvdXRlW107XHJcbiAgcG9saWN5PzogT3BlblBvbGljeTtcclxufVxyXG5cclxuZXhwb3J0IHR5cGUgUGFyYW1NYXAgPSB7IFtrZXk6IHN0cmluZ106IGFueSB9O1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBQYW5lUmVzb2x2ZTxUPiB7XHJcbiAgb25SZXNvbHZlKHBhcmFtczogUGFyYW1NYXAsIHF1ZXJ5UGFyYW1zPzogUGFyYW1NYXApOiBPYnNlcnZhYmxlPFQ+IHwgUHJvbWlzZTxUPiB8IFQ7XHJcbn1cclxuZXhwb3J0IGludGVyZmFjZSBDYW5EaXNtaXNzPFQ+IHtcclxuICBvbkRpc21pc3MoY29tcG9uZW50OiBUKTogYm9vbGVhbiB8IFByb21pc2U8Ym9vbGVhbj4gfCBPYnNlcnZhYmxlPGJvb2xlYW4+O1xyXG59XHJcblxyXG5leHBvcnQgZW51bSBPcGVuUG9saWN5IHtcclxuICBQYW5lID0gMSA8PCAwLFxyXG4gIENsZWFyID0gMSA8PCAxLFxyXG4gIERlZmVyID0gMSA8PCAyLFxyXG4gIFBpbm5hYmxlID0gMSA8PCAzLFxyXG4gIFN0cmV0Y2ggPSAxIDw8IDQsXHJcbiAgVGFiID0gMSA8PCA1LFxyXG4gIERpYWxvZyA9IDEgPDwgNiB8IE9wZW5Qb2xpY3kuVGFiLFxyXG4gIEV4cGFuZGFibGUgPSAxIDw8IDcsXHJcbiAgVG9nZ2xlID0gMSA8PCA4LFxyXG4gIERpc21pc3NhYmxlID0gMSA8PCA5LFxyXG59XHJcblxyXG5leHBvcnQgY29uc3QgREVGQVVMVF9QT0xJQ1kgPSBPcGVuUG9saWN5LlBhbmU7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEJpekRvY0NoaWxkQ29uZmlnIHtcclxuICBjb21wb25lbnRzOiBUeXBlPGFueT5bXTtcclxuICByb3V0ZXM/OiBQYW5lUm91dGVbXTtcclxufVxyXG5leHBvcnQgaW50ZXJmYWNlIFRoZW1lIHtcclxuICBuYW1lOiBzdHJpbmc7XHJcbiAgcHJpbWFyeTogc3RyaW5nO1xyXG4gIGFjY2VudDogc3RyaW5nO1xyXG4gIGNvbG9yOiBzdHJpbmc7XHJcbiAgZGFyaz86IGJvb2xlYW5cclxufVxyXG5cclxuLyoqIEJpekRvYyBhcHAgb3B0aW9ucyAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIEJpekRvY0NvbmZpZyB7XHJcbiAgY3VycmVuY3lDb2RlPzogc3RyaW5nO1xyXG4gIC8qKiBhdmFpbGFibGUgdXNlciBpbnRlcmZhY2UgbGFuZ3VhZ2VzICovXHJcbiAgdGhlbWVzPzogVGhlbWVbXTtcclxuICBsYW5ndWFnZXM/OiBzdHJpbmdbXTtcclxuICBhcHBUaXRsZT86IHN0cmluZztcclxuICBmaXJlYmFzZT86IEZpcmViYXNlU2V0dGluZ3M7XHJcbiAgY2hhdGluZz86IENoYXRTZXR0aW5ncyB8IGJvb2xlYW47XHJcbiAgY29tbWVudHM/OiBDb21tZW50c1NldHRpbmdzO1xyXG4gIG1hcHM/OiBHb29nbGVNYXBzU2V0dGluZ3MgfCBib29sZWFuO1xyXG4gIGZvcm1hdHM/OiBGb3JtYXRzU2V0dGluZ3M7XHJcbiAgcm91dGVzPzogUGFuZVJvdXRlW107XHJcbiAgY29tcG9uZW50czogVHlwZTxhbnk+W107XHJcbiAgc2NoZWR1bGVyPzogU2NoZWR1bGVyU2V0dGluZ3MgfCBib29sZWFuO1xyXG4gIGZvbGRlcnM/OiBGb2xkZXJzU2V0dGluZ3M7XHJcbiAgYW5hbHlzaXM/OiBBbmFseXNpc1NldHRpbmdzIHwgYm9vbGVhbjtcclxufVxyXG5leHBvcnQgdHlwZSBTY29wZVR5cGUgPSAncGF0dGVybnMnIHwgJ3Bvc2l0aW9ucyc7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEFuYWx5c2lzU2V0dGluZ3Mge1xyXG59XHJcbmV4cG9ydFxyXG4gIGludGVyZmFjZSBTY2hlZHVsZXJTZXR0aW5ncyB7XHJcblxyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEZvbGRlcnNTZXR0aW5ncyB7XHJcbiAgY3ViZT86IHN0cmluZztcclxuICBheGVzPzogc3RyaW5nW107XHJcbiAgY29sdW1ucz86IEZvbGRlckNvbHVtbltdO1xyXG59XHJcbmV4cG9ydCBpbnRlcmZhY2UgRm9ybWF0c1NldHRpbmdzIHtcclxuICBkYXRlPzogc3RyaW5nO1xyXG4gIGRhdGVUaW1lPzogc3RyaW5nO1xyXG4gIGZyYWN0aW9uRGlnaXRzPzogbnVtYmVyO1xyXG59XHJcbmV4cG9ydCBpbnRlcmZhY2UgQ29tbWVudHNTZXR0aW5ncyB7XHJcbiAgcHJlc2VydmVEcmFmdD86IGJvb2xlYW47XHJcbiAgdm90aW5nPzogYm9vbGVhbjtcclxufVxyXG5leHBvcnQgaW50ZXJmYWNlIENoYXRTZXR0aW5ncyB7XHJcbiAgcHJlc2VydmVEcmFmdD86IGJvb2xlYW47XHJcbiAgYXBwPzogc3RyaW5nIHwgQ2hhdExhdW5jaGVyRm47XHJcbn1cclxuZXhwb3J0IGRlY2xhcmUgaW50ZXJmYWNlIENoYXRMYXVuY2hlckZuIHtcclxuICAoaWRlbnRpdHk6IHN0cmluZyk6IHZvaWQ7XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgRmlyZWJhc2VTZXR0aW5ncyB7XHJcbiAgYXBpS2V5OiBzdHJpbmc7XHJcbiAgdmFwaWRLZXk/OiBzdHJpbmc7XHJcbiAgcHJvamVjdElkOiBzdHJpbmc7XHJcbiAgc2VuZGVySWQ6IHN0cmluZztcclxuICBhcHBJZDogc3RyaW5nO1xyXG4gIC8qKiBtaWxsaXNlY29uZGVzIGJlZm9yZSB1c2VyIGlzIHByb21wdCB0byBhcHByb3ZlIHJlY2VpdmluZyBtZXNzYWdlcyAqL1xyXG4gIGdyYWNlPzogbnVtYmVyO1xyXG59XHJcbmV4cG9ydCBpbnRlcmZhY2UgR29vZ2xlTWFwc1NldHRpbmdzIHtcclxuICBhcGlLZXk6IHN0cmluZztcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBjb25maWd1cmF0aW9uIHsgfVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBTaGFyZWRDb25maWcge1xyXG4gIG1hcHM/OiBHb29nbGVNYXBzU2V0dGluZ3MgfCBib29sZWFuO1xyXG4gIGZvcm1hdHM/OiBGb3JtYXRzU2V0dGluZ3M7XHJcblxyXG4gIHJvdXRpbmc/OiAnbmcnIHwgJ3BhbmUnXHJcbn1cclxuIl19
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlndXJhdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnJhcmllcy9jb3JlL3NyYy9saWIvY29yZS9jb25maWd1cmF0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQVEsTUFBTSxlQUFlLENBQUM7QUFJckQsTUFBTSxDQUFDLE1BQU0sYUFBYSxHQUFHLElBQUksY0FBYyxDQUFlLFFBQVEsQ0FBQyxDQUFDO0FBdUJ4RSxNQUFNLENBQU4sSUFBWSxVQVdYO0FBWEQsV0FBWSxVQUFVO0lBQ3BCLDJDQUFhLENBQUE7SUFDYiw2Q0FBYyxDQUFBO0lBQ2QsNkNBQWMsQ0FBQTtJQUNkLG1EQUFpQixDQUFBO0lBQ2pCLGtEQUFnQixDQUFBO0lBQ2hCLHdEQUFtQixDQUFBO0lBQ25CLGdEQUFlLENBQUE7SUFDZiwyQ0FBWSxDQUFBO0lBQ1osaURBQWdDLENBQUE7SUFDaEMsMkRBQW9CLENBQUE7QUFDdEIsQ0FBQyxFQVhXLFVBQVUsS0FBVixVQUFVLFFBV3JCO0FBRUQsTUFBTSxDQUFDLE1BQU0sY0FBYyxHQUFHLFVBQVUsQ0FBQyxJQUFJLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3Rpb25Ub2tlbiwgVHlwZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XHJcbmltcG9ydCB7IEZvbGRlckNvbHVtbiB9IGZyb20gJy4vbW9kZWxzJztcclxuXHJcbmV4cG9ydCBjb25zdCBCSVpET0NfQ09ORklHID0gbmV3IEluamVjdGlvblRva2VuPEJpekRvY0NvbmZpZz4oJ2JpemRvYycpO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBQYW5lUm91dGUge1xyXG4gIHBhdGg6IHN0cmluZztcclxuICBndWlkZT86IHN0cmluZztcclxuICBjb21wb25lbnQ/OiBUeXBlPGFueT47XHJcbiAgcmVzb2x2ZT86IHsgW2tleTogc3RyaW5nXTogVHlwZTxQYW5lUmVzb2x2ZTxhbnk+PiB9O1xyXG4gIGNhbkRpc21pc3M/OiBUeXBlPENhbkRpc21pc3M8YW55Pj47XHJcbiAgaWNvbj86IHN0cmluZztcclxuICBoZWxwPzogc3RyaW5nO1xyXG4gIGNoaWxkcmVuPzogUGFuZVJvdXRlW107XHJcbiAgcG9saWN5PzogT3BlblBvbGljeTtcclxufVxyXG5cclxuZXhwb3J0IHR5cGUgUGFyYW1NYXAgPSB7IFtrZXk6IHN0cmluZ106IGFueSB9O1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBQYW5lUmVzb2x2ZTxUPiB7XHJcbiAgb25SZXNvbHZlKHBhcmFtczogUGFyYW1NYXAsIHF1ZXJ5UGFyYW1zPzogUGFyYW1NYXApOiBPYnNlcnZhYmxlPFQ+IHwgUHJvbWlzZTxUPiB8IFQ7XHJcbn1cclxuZXhwb3J0IGludGVyZmFjZSBDYW5EaXNtaXNzPFQ+IHtcclxuICBvbkRpc21pc3MoY29tcG9uZW50OiBUKTogYm9vbGVhbiB8IFByb21pc2U8Ym9vbGVhbj4gfCBPYnNlcnZhYmxlPGJvb2xlYW4+O1xyXG59XHJcblxyXG5leHBvcnQgZW51bSBPcGVuUG9saWN5IHtcclxuICBQYW5lID0gMSA8PCAwLFxyXG4gIENsZWFyID0gMSA8PCAxLFxyXG4gIERlZmVyID0gMSA8PCAyLFxyXG4gIFBpbm5hYmxlID0gMSA8PCAzLFxyXG4gIFN0cmV0Y2ggPSAxIDw8IDQsXHJcbiAgRXhwYW5kYWJsZSA9IDEgPDwgNSxcclxuICBUb2dnbGUgPSAxIDw8IDYsXHJcbiAgVGFiID0gMSA8PCA3LFxyXG4gIERpYWxvZyA9IDEgPDwgOCB8IE9wZW5Qb2xpY3kuVGFiLFxyXG4gIERpc21pc3NhYmxlID0gMSA8PCA5LFxyXG59XHJcblxyXG5leHBvcnQgY29uc3QgREVGQVVMVF9QT0xJQ1kgPSBPcGVuUG9saWN5LlBhbmU7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEJpekRvY0NoaWxkQ29uZmlnIHtcclxuICBjb21wb25lbnRzOiBUeXBlPGFueT5bXTtcclxuICByb3V0ZXM/OiBQYW5lUm91dGVbXTtcclxufVxyXG5leHBvcnQgaW50ZXJmYWNlIFRoZW1lIHtcclxuICBuYW1lOiBzdHJpbmc7XHJcbiAgcHJpbWFyeTogc3RyaW5nO1xyXG4gIGFjY2VudDogc3RyaW5nO1xyXG4gIGNvbG9yOiBzdHJpbmc7XHJcbiAgZGFyaz86IGJvb2xlYW5cclxufVxyXG5cclxuLyoqIEJpekRvYyBhcHAgb3B0aW9ucyAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIEJpekRvY0NvbmZpZyB7XHJcbiAgY3VycmVuY3lDb2RlPzogc3RyaW5nO1xyXG4gIC8qKiBhdmFpbGFibGUgdXNlciBpbnRlcmZhY2UgbGFuZ3VhZ2VzICovXHJcbiAgdGhlbWVzPzogVGhlbWVbXTtcclxuICBsYW5ndWFnZXM/OiBzdHJpbmdbXTtcclxuICBhcHBUaXRsZT86IHN0cmluZztcclxuICBmaXJlYmFzZT86IEZpcmViYXNlU2V0dGluZ3M7XHJcbiAgY2hhdGluZz86IENoYXRTZXR0aW5ncyB8IGJvb2xlYW47XHJcbiAgY29tbWVudHM/OiBDb21tZW50c1NldHRpbmdzO1xyXG4gIG1hcHM/OiBHb29nbGVNYXBzU2V0dGluZ3MgfCBib29sZWFuO1xyXG4gIGZvcm1hdHM/OiBGb3JtYXRzU2V0dGluZ3M7XHJcbiAgcm91dGVzPzogUGFuZVJvdXRlW107XHJcbiAgY29tcG9uZW50czogVHlwZTxhbnk+W107XHJcbiAgc2NoZWR1bGVyPzogU2NoZWR1bGVyU2V0dGluZ3MgfCBib29sZWFuO1xyXG4gIGZvbGRlcnM/OiBGb2xkZXJzU2V0dGluZ3M7XHJcbiAgYW5hbHlzaXM/OiBBbmFseXNpc1NldHRpbmdzIHwgYm9vbGVhbjtcclxufVxyXG5leHBvcnQgdHlwZSBTY29wZVR5cGUgPSAncGF0dGVybnMnIHwgJ3Bvc2l0aW9ucyc7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEFuYWx5c2lzU2V0dGluZ3Mge1xyXG59XHJcbmV4cG9ydFxyXG4gIGludGVyZmFjZSBTY2hlZHVsZXJTZXR0aW5ncyB7XHJcblxyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEZvbGRlcnNTZXR0aW5ncyB7XHJcbiAgY3ViZT86IHN0cmluZztcclxuICBheGVzPzogc3RyaW5nW107XHJcbiAgY29sdW1ucz86IEZvbGRlckNvbHVtbltdO1xyXG59XHJcbmV4cG9ydCBpbnRlcmZhY2UgRm9ybWF0c1NldHRpbmdzIHtcclxuICBkYXRlPzogc3RyaW5nO1xyXG4gIGRhdGVUaW1lPzogc3RyaW5nO1xyXG4gIGZyYWN0aW9uRGlnaXRzPzogbnVtYmVyO1xyXG59XHJcbmV4cG9ydCBpbnRlcmZhY2UgQ29tbWVudHNTZXR0aW5ncyB7XHJcbiAgcHJlc2VydmVEcmFmdD86IGJvb2xlYW47XHJcbiAgdm90aW5nPzogYm9vbGVhbjtcclxufVxyXG5leHBvcnQgaW50ZXJmYWNlIENoYXRTZXR0aW5ncyB7XHJcbiAgcHJlc2VydmVEcmFmdD86IGJvb2xlYW47XHJcbiAgYXBwPzogc3RyaW5nIHwgQ2hhdExhdW5jaGVyRm47XHJcbn1cclxuZXhwb3J0IGRlY2xhcmUgaW50ZXJmYWNlIENoYXRMYXVuY2hlckZuIHtcclxuICAoaWRlbnRpdHk6IHN0cmluZyk6IHZvaWQ7XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgRmlyZWJhc2VTZXR0aW5ncyB7XHJcbiAgYXBpS2V5OiBzdHJpbmc7XHJcbiAgdmFwaWRLZXk/OiBzdHJpbmc7XHJcbiAgcHJvamVjdElkOiBzdHJpbmc7XHJcbiAgc2VuZGVySWQ6IHN0cmluZztcclxuICBhcHBJZDogc3RyaW5nO1xyXG4gIC8qKiBtaWxsaXNlY29uZGVzIGJlZm9yZSB1c2VyIGlzIHByb21wdCB0byBhcHByb3ZlIHJlY2VpdmluZyBtZXNzYWdlcyAqL1xyXG4gIGdyYWNlPzogbnVtYmVyO1xyXG59XHJcbmV4cG9ydCBpbnRlcmZhY2UgR29vZ2xlTWFwc1NldHRpbmdzIHtcclxuICBhcGlLZXk6IHN0cmluZztcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBjb25maWd1cmF0aW9uIHsgfVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBTaGFyZWRDb25maWcge1xyXG4gIG1hcHM/OiBHb29nbGVNYXBzU2V0dGluZ3MgfCBib29sZWFuO1xyXG4gIGZvcm1hdHM/OiBGb3JtYXRzU2V0dGluZ3M7XHJcblxyXG4gIHJvdXRpbmc/OiAnbmcnIHwgJ3BhbmUnXHJcbn1cclxuIl19
@@ -97,21 +97,30 @@ export class GuideComponent {
97
97
  this._overlay = _overlay;
98
98
  this._ngRouter = _ngRouter;
99
99
  this._overlayRef = _overlayRef;
100
- this.index = 0;
100
+ this.index = -1;
101
101
  this.count = this._data.steps.length;
102
102
  this.working = true;
103
103
  }
104
104
  ngOnInit() {
105
- this._move(0);
105
+ if (this._data.name) {
106
+ const lastindex = localStorage.getItem(this._data.name + '_guide_step');
107
+ if (lastindex) {
108
+ this.index = Number.parseInt(lastindex);
109
+ }
110
+ }
111
+ this._moveBy(1);
106
112
  }
107
113
  /**
108
114
  *
109
- * @param i
115
+ * @param steps
110
116
  */
111
- _move(i) {
112
- const index = this.index + i;
113
- if (index < 0 || index == this.count)
117
+ _moveBy(steps) {
118
+ const index = this.index + steps;
119
+ if (index < 0 || index > this.count - 1) {
120
+ localStorage.removeItem(this._data.name + '_guide_step');
114
121
  return;
122
+ }
123
+ this._data.name && localStorage.setItem(this._data.name + '_guide_step', this.index.toString());
115
124
  this.working = true;
116
125
  const step = this._data.steps[index];
117
126
  const { selector, position, navigate, simulate } = step, promisses = [];
@@ -122,8 +131,11 @@ export class GuideComponent {
122
131
  let positionStrategy;
123
132
  if (selector) {
124
133
  const element = document.querySelector(selector);
125
- if (!element)
126
- throw `Guide ${this._data.name} step ${this.index} selector '${selector}' not found.`;
134
+ if (!element) {
135
+ console.warn(`Guide ${this._data.name} selector '${selector}' not found. skipping.`);
136
+ this._moveBy(steps);
137
+ return;
138
+ }
127
139
  let positions;
128
140
  switch (position) {
129
141
  case 'Above':
@@ -177,10 +189,10 @@ export class GuideComponent {
177
189
  if (!this.working)
178
190
  switch (evt.keyCode) {
179
191
  case LEFT_ARROW:
180
- this._move(this._session.direction === 'ltr' ? -1 : 1);
192
+ this._moveBy(this._session.direction === 'ltr' ? -1 : 1);
181
193
  break;
182
194
  case RIGHT_ARROW:
183
- this._move(this._session.direction === 'ltr' ? 1 : -1);
195
+ this._moveBy(this._session.direction === 'ltr' ? 1 : -1);
184
196
  break;
185
197
  case ESCAPE:
186
198
  this.close();
@@ -189,17 +201,17 @@ export class GuideComponent {
189
201
  }
190
202
  }
191
203
  next() {
192
- this._move(1);
204
+ this._moveBy(1);
193
205
  }
194
206
  prev() {
195
- this._move(-1);
207
+ this._moveBy(-1);
196
208
  }
197
209
  close() {
198
210
  this._overlayRef.detach();
199
211
  }
200
212
  }
201
213
  GuideComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.1", ngImport: i0, type: GuideComponent, deps: [{ token: TOUR_TOKEN }, { token: i1.SessionService }, { token: i2.Overlay }, { token: i3.Router }, { token: i2.OverlayRef }], target: i0.ɵɵFactoryTarget.Component });
202
- GuideComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.1", type: GuideComponent, selector: "ng-component", host: { listeners: { "window:keydown": "keydown($event)" } }, ngImport: i0, template: "<div class=\"container\" [style.display]=\"step ? '': 'none'\" cdkTrapFocus>\r\n <div fxLayout=\"column\" class=\"content\">\r\n <div fxLayout=\"row\">\r\n <h2 *ngIf=\"step?.title\" class=\"mat-h2\">{{step?.title}}</h2>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button (click)=\"close()\" *ngIf=\"index < count - 1\"><mat-icon>close</mat-icon></button>\r\n </div>\r\n <p class=\"mat-body\" [innerHTML]=\"step?.content | sanitizeHtml\">\r\n </p>\r\n <div fxLayout=\"row\">\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button (click)=\"prev()\" [disabled]=\"index === 0 || working\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_left</mat-icon></button>\r\n <button mat-icon-button (click)=\"next()\" [disabled]=\"index === count - 1 || working\" cdkFocusInitial><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_right</mat-icon></button>\r\n <button mat-button (click)=\"close()\" *ngIf=\"index === count - 1\">{{'GuideFinish'|translate}}</button>\r\n </div>\r\n </div>\r\n <div class=\"tooltip-container\">\r\n <div class=\"tooltip\"></div>\r\n </div>\r\n</div>\r\n", components: [{ type: i4.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: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i6.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: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "sanitizeHtml": i8.SanitizeHtmlPipe, "translate": i9.TranslatePipe }, animations: [trigger('body', [
214
+ GuideComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.1", type: GuideComponent, selector: "ng-component", host: { listeners: { "window:keydown": "keydown($event)" } }, ngImport: i0, template: "<div class=\"container\" [style.display]=\"step ? '': 'none'\" cdkTrapFocus>\r\n <div fxLayout=\"column\" class=\"content\">\r\n <div fxLayout=\"row\">\r\n <h2 *ngIf=\"step?.title\" class=\"mat-h2\">{{step?.title}}</h2>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button (click)=\"close()\" *ngIf=\"index < count - 1\"><mat-icon>close</mat-icon></button>\r\n </div>\r\n <p class=\"mat-body\" [innerHTML]=\"step?.content | sanitizeHtml\">\r\n </p>\r\n <div fxLayout=\"row\">\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button (click)=\"prev()\" [disabled]=\"index < 1 || working\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_left</mat-icon></button>\r\n <button mat-icon-button (click)=\"next()\" [disabled]=\"index >= count - 1 || working\" cdkFocusInitial><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_right</mat-icon></button>\r\n <button mat-button (click)=\"close()\" *ngIf=\"index >= count - 1\">{{'GuideFinish'|translate}}</button>\r\n </div>\r\n </div>\r\n <div class=\"tooltip-container\">\r\n <div class=\"tooltip\"></div>\r\n </div>\r\n</div>\r\n", components: [{ type: i4.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: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i6.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: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "sanitizeHtml": i8.SanitizeHtmlPipe, "translate": i9.TranslatePipe }, animations: [trigger('body', [
203
215
  state('here', style({ width: '*', height: '*' })),
204
216
  transition('*<=>*', animate('250ms', style({})))
205
217
  ])] });
@@ -208,7 +220,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.1", ngImpor
208
220
  args: [{ animations: [trigger('body', [
209
221
  state('here', style({ width: '*', height: '*' })),
210
222
  transition('*<=>*', animate('250ms', style({})))
211
- ])], template: "<div class=\"container\" [style.display]=\"step ? '': 'none'\" cdkTrapFocus>\r\n <div fxLayout=\"column\" class=\"content\">\r\n <div fxLayout=\"row\">\r\n <h2 *ngIf=\"step?.title\" class=\"mat-h2\">{{step?.title}}</h2>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button (click)=\"close()\" *ngIf=\"index < count - 1\"><mat-icon>close</mat-icon></button>\r\n </div>\r\n <p class=\"mat-body\" [innerHTML]=\"step?.content | sanitizeHtml\">\r\n </p>\r\n <div fxLayout=\"row\">\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button (click)=\"prev()\" [disabled]=\"index === 0 || working\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_left</mat-icon></button>\r\n <button mat-icon-button (click)=\"next()\" [disabled]=\"index === count - 1 || working\" cdkFocusInitial><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_right</mat-icon></button>\r\n <button mat-button (click)=\"close()\" *ngIf=\"index === count - 1\">{{'GuideFinish'|translate}}</button>\r\n </div>\r\n </div>\r\n <div class=\"tooltip-container\">\r\n <div class=\"tooltip\"></div>\r\n </div>\r\n</div>\r\n" }]
223
+ ])], template: "<div class=\"container\" [style.display]=\"step ? '': 'none'\" cdkTrapFocus>\r\n <div fxLayout=\"column\" class=\"content\">\r\n <div fxLayout=\"row\">\r\n <h2 *ngIf=\"step?.title\" class=\"mat-h2\">{{step?.title}}</h2>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button (click)=\"close()\" *ngIf=\"index < count - 1\"><mat-icon>close</mat-icon></button>\r\n </div>\r\n <p class=\"mat-body\" [innerHTML]=\"step?.content | sanitizeHtml\">\r\n </p>\r\n <div fxLayout=\"row\">\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button (click)=\"prev()\" [disabled]=\"index < 1 || working\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_left</mat-icon></button>\r\n <button mat-icon-button (click)=\"next()\" [disabled]=\"index >= count - 1 || working\" cdkFocusInitial><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_right</mat-icon></button>\r\n <button mat-button (click)=\"close()\" *ngIf=\"index >= count - 1\">{{'GuideFinish'|translate}}</button>\r\n </div>\r\n </div>\r\n <div class=\"tooltip-container\">\r\n <div class=\"tooltip\"></div>\r\n </div>\r\n</div>\r\n" }]
212
224
  }], ctorParameters: function () { return [{ type: undefined, decorators: [{
213
225
  type: Inject,
214
226
  args: [TOUR_TOKEN]
@@ -216,4 +228,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.1", ngImpor
216
228
  type: HostListener,
217
229
  args: ['window:keydown', ['$event']]
218
230
  }] } });
219
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"guide.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/core/guide/guide.component.ts","../../../../../../libraries/core/src/lib/core/guide/guide.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Component, OnInit, ElementRef, InjectionToken, HostListener } from '@angular/core';\r\nimport { Overlay, OverlayRef, PositionStrategy, ConnectedPosition } from \"@angular/cdk/overlay\";\r\nimport { trigger, state, style, transition, animate } from '@angular/animations';\r\nimport { Directionality } from '@angular/cdk/bidi';\r\nimport { ESCAPE, LEFT_ARROW, RIGHT_ARROW } from '@angular/cdk/keycodes';\r\nimport { GuideStep, Guide } from '../models';\r\nimport { outOfBound } from '../functions';\r\nimport { Router } from '@angular/router';\r\nimport { SessionService } from '../session.service';\r\n\r\nexport const TOUR_TOKEN = new InjectionToken<Guide>('guide');\r\n\r\nconst BELOW: ConnectedPosition[] = [{\r\n  originX: 'start',\r\n  originY: 'bottom',\r\n  overlayX: 'start',\r\n  overlayY: 'top',\r\n  panelClass: ['below', 'start']\r\n}, {\r\n  originX: 'center',\r\n  originY: 'bottom',\r\n  overlayX: 'center',\r\n  overlayY: 'top',\r\n  panelClass: ['below', 'center']\r\n}, {\r\n  originX: 'end',\r\n  originY: 'bottom',\r\n  overlayX: 'end',\r\n  overlayY: 'top',\r\n  panelClass: ['below', 'end']\r\n}],\r\n  ABOVE: ConnectedPosition[] = [{\r\n    originX: 'start',\r\n    originY: 'top',\r\n    overlayX: 'start',\r\n    overlayY: 'bottom',\r\n    panelClass: ['above', 'start']\r\n  },\r\n  {\r\n    originX: 'center',\r\n    originY: 'top',\r\n    overlayX: 'center',\r\n    overlayY: 'bottom',\r\n    panelClass: ['above', 'center']\r\n  },\r\n  {\r\n    originX: 'start',\r\n    originY: 'top',\r\n    overlayX: 'end',\r\n    overlayY: 'bottom',\r\n    panelClass: ['above', 'end']\r\n  }],\r\n  AFTER: ConnectedPosition[] = [{\r\n    originX: 'end',\r\n    originY: 'top',\r\n    overlayX: 'start',\r\n    overlayY: 'top',\r\n    panelClass: ['after', 'start']\r\n  },\r\n  {\r\n    originX: 'end',\r\n    originY: 'center',\r\n    overlayX: 'start',\r\n    overlayY: 'center',\r\n    panelClass: ['after', 'center']\r\n  },\r\n  {\r\n    originX: 'end',\r\n    originY: 'bottom',\r\n    overlayX: 'start',\r\n    overlayY: 'bottom',\r\n    panelClass: ['after', 'end']\r\n  }],\r\n  BEFORE: ConnectedPosition[] = [{\r\n    originX: 'start',\r\n    originY: 'top',\r\n    overlayX: 'end',\r\n    overlayY: 'top',\r\n    panelClass: ['before', 'start']\r\n  }, {\r\n    originX: 'start',\r\n    originY: 'center',\r\n    overlayX: 'end',\r\n    overlayY: 'center',\r\n    panelClass: ['before', 'center']\r\n  }, {\r\n    originX: 'start',\r\n    originY: 'center',\r\n    overlayX: 'end',\r\n    overlayY: 'bottom',\r\n    panelClass: ['before', 'end']\r\n  }];\r\n\r\n@Component({\r\n  templateUrl: './guide.component.html',\r\n  animations: [trigger('body', [\r\n    state('here', style({ width: '*', height: '*' })),\r\n    transition('*<=>*', animate('250ms', style({})))])]\r\n})\r\nexport class GuideComponent implements OnInit {\r\n  step: GuideStep;\r\n  index = 0;\r\n  readonly count: number = this._data.steps.length;\r\n  working = true;\r\n  constructor(\r\n    @Inject(TOUR_TOKEN)\r\n    private _data: Guide,\r\n    private _session: SessionService,\r\n    private _overlay: Overlay,\r\n    private _ngRouter: Router,\r\n    private _overlayRef: OverlayRef) {\r\n  }\r\n  ngOnInit(): void {\r\n    this._move(0);\r\n  }\r\n  /**\r\n   * \r\n   * @param i\r\n   */\r\n  private _move(i: 0 | 1 | -1) {\r\n    const index = this.index + i;\r\n    if (index < 0 || index == this.count) return;\r\n    this.working = true;\r\n    const step = this._data.steps[index];\r\n    const { selector, position, navigate, simulate } = step, promisses: Promise<any>[] = [];\r\n    if (navigate) {\r\n      const promise = this._ngRouter.navigateByUrl(navigate);\r\n      promisses.push(promise);\r\n    }\r\n    let positionStrategy: PositionStrategy;\r\n    if (selector) {\r\n      const element = document.querySelector(selector) as HTMLElement;\r\n      if (!element)\r\n        throw `Guide ${this._data.name} step ${this.index} selector '${selector}' not found.`;\r\n\r\n      let positions: ConnectedPosition[];\r\n      switch (position) {\r\n        case 'Above':\r\n          positions = [...ABOVE, ...BELOW, ...AFTER, ...BEFORE];\r\n          break;\r\n        case 'End':\r\n          positions = [...AFTER, ...BEFORE, ...BELOW, ...ABOVE];\r\n          break;\r\n        case 'Start':\r\n          positions = [...BEFORE, ...AFTER, ...BELOW, ...ABOVE];\r\n          break;\r\n        case 'Below':\r\n          positions = [...BELOW, ...BEFORE, ...ABOVE, ...AFTER];\r\n          break;\r\n        default:\r\n          positions = [...BEFORE, ...BELOW, ...ABOVE, ...AFTER];\r\n      }\r\n      positionStrategy = this._overlay.position().\r\n        flexibleConnectedTo(new ElementRef(element)).\r\n        withPositions(positions).\r\n        withGrowAfterOpen();\r\n      if (outOfBound(element)) {\r\n        promisses.push(new Promise<any>(resolve => {\r\n          const task = setInterval(() => {\r\n            if (!outOfBound(element)) {\r\n              clearInterval(task);\r\n              resolve(null);\r\n            }\r\n          }, 150);\r\n        }));\r\n        element.scrollIntoView({ behavior: 'smooth' });\r\n      }\r\n      simulate &&\r\n        promisses.push(new Promise(resolve => {\r\n          element.click();\r\n          resolve(null);\r\n        }));\r\n    }\r\n    else positionStrategy = this._overlay.position().global().centerVertically().centerHorizontally();\r\n\r\n    const complete = () => {\r\n      this.index = index;\r\n      this.step = step;\r\n      this.working = false;\r\n      this._overlayRef.updatePositionStrategy(positionStrategy);\r\n      this._overlayRef.updatePosition();\r\n    };\r\n    promisses.length ? Promise.all(promisses).then(() => complete()) : complete();\r\n  }\r\n  @HostListener('window:keydown', ['$event'])\r\n  keydown(evt: KeyboardEvent) {\r\n    if (!this.working)\r\n      switch (evt.keyCode) {\r\n        case LEFT_ARROW:\r\n          this._move(this._session.direction === 'ltr' ? -1 : 1);\r\n          break;\r\n        case RIGHT_ARROW:\r\n          this._move(this._session.direction === 'ltr' ? 1 : -1);\r\n          break;\r\n        case ESCAPE:\r\n          this.close();\r\n          evt.stopPropagation();\r\n          break;\r\n      }\r\n  }\r\n  next() {\r\n    this._move(1);\r\n  }\r\n  prev() {\r\n    this._move(-1);\r\n  }\r\n  close() {\r\n    this._overlayRef.detach();\r\n  }\r\n}\r\n","<div class=\"container\" [style.display]=\"step ? '': 'none'\" cdkTrapFocus>\r\n  <div fxLayout=\"column\" class=\"content\">\r\n    <div fxLayout=\"row\">\r\n      <h2 *ngIf=\"step?.title\" class=\"mat-h2\">{{step?.title}}</h2>\r\n      <span class=\"divider\"></span>\r\n      <button mat-icon-button (click)=\"close()\" *ngIf=\"index < count - 1\"><mat-icon>close</mat-icon></button>\r\n    </div>\r\n    <p class=\"mat-body\" [innerHTML]=\"step?.content | sanitizeHtml\">\r\n    </p>\r\n    <div fxLayout=\"row\">\r\n      <span class=\"divider\"></span>\r\n      <button mat-icon-button (click)=\"prev()\" [disabled]=\"index === 0 || working\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_left</mat-icon></button>\r\n      <button mat-icon-button (click)=\"next()\" [disabled]=\"index === count - 1 || working\" cdkFocusInitial><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_right</mat-icon></button>\r\n      <button mat-button (click)=\"close()\" *ngIf=\"index === count - 1\">{{'GuideFinish'|translate}}</button>\r\n    </div>\r\n  </div>\r\n  <div class=\"tooltip-container\">\r\n    <div class=\"tooltip\"></div>\r\n  </div>\r\n</div>\r\n"]}
231
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"guide.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/core/guide/guide.component.ts","../../../../../../libraries/core/src/lib/core/guide/guide.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Component, OnInit, ElementRef, InjectionToken, HostListener } from '@angular/core';\r\nimport { Overlay, OverlayRef, PositionStrategy, ConnectedPosition } from \"@angular/cdk/overlay\";\r\nimport { trigger, state, style, transition, animate } from '@angular/animations';\r\nimport { Directionality } from '@angular/cdk/bidi';\r\nimport { ESCAPE, LEFT_ARROW, RIGHT_ARROW } from '@angular/cdk/keycodes';\r\nimport { GuideStep, Guide } from '../models';\r\nimport { outOfBound } from '../functions';\r\nimport { Router } from '@angular/router';\r\nimport { SessionService } from '../session.service';\r\n\r\nexport const TOUR_TOKEN = new InjectionToken<Guide>('guide');\r\n\r\nconst BELOW: ConnectedPosition[] = [{\r\n  originX: 'start',\r\n  originY: 'bottom',\r\n  overlayX: 'start',\r\n  overlayY: 'top',\r\n  panelClass: ['below', 'start']\r\n}, {\r\n  originX: 'center',\r\n  originY: 'bottom',\r\n  overlayX: 'center',\r\n  overlayY: 'top',\r\n  panelClass: ['below', 'center']\r\n}, {\r\n  originX: 'end',\r\n  originY: 'bottom',\r\n  overlayX: 'end',\r\n  overlayY: 'top',\r\n  panelClass: ['below', 'end']\r\n}],\r\n  ABOVE: ConnectedPosition[] = [{\r\n    originX: 'start',\r\n    originY: 'top',\r\n    overlayX: 'start',\r\n    overlayY: 'bottom',\r\n    panelClass: ['above', 'start']\r\n  },\r\n  {\r\n    originX: 'center',\r\n    originY: 'top',\r\n    overlayX: 'center',\r\n    overlayY: 'bottom',\r\n    panelClass: ['above', 'center']\r\n  },\r\n  {\r\n    originX: 'start',\r\n    originY: 'top',\r\n    overlayX: 'end',\r\n    overlayY: 'bottom',\r\n    panelClass: ['above', 'end']\r\n  }],\r\n  AFTER: ConnectedPosition[] = [{\r\n    originX: 'end',\r\n    originY: 'top',\r\n    overlayX: 'start',\r\n    overlayY: 'top',\r\n    panelClass: ['after', 'start']\r\n  },\r\n  {\r\n    originX: 'end',\r\n    originY: 'center',\r\n    overlayX: 'start',\r\n    overlayY: 'center',\r\n    panelClass: ['after', 'center']\r\n  },\r\n  {\r\n    originX: 'end',\r\n    originY: 'bottom',\r\n    overlayX: 'start',\r\n    overlayY: 'bottom',\r\n    panelClass: ['after', 'end']\r\n  }],\r\n  BEFORE: ConnectedPosition[] = [{\r\n    originX: 'start',\r\n    originY: 'top',\r\n    overlayX: 'end',\r\n    overlayY: 'top',\r\n    panelClass: ['before', 'start']\r\n  }, {\r\n    originX: 'start',\r\n    originY: 'center',\r\n    overlayX: 'end',\r\n    overlayY: 'center',\r\n    panelClass: ['before', 'center']\r\n  }, {\r\n    originX: 'start',\r\n    originY: 'center',\r\n    overlayX: 'end',\r\n    overlayY: 'bottom',\r\n    panelClass: ['before', 'end']\r\n  }];\r\n\r\n@Component({\r\n  templateUrl: './guide.component.html',\r\n  animations: [trigger('body', [\r\n    state('here', style({ width: '*', height: '*' })),\r\n    transition('*<=>*', animate('250ms', style({})))])]\r\n})\r\nexport class GuideComponent implements OnInit {\r\n  step: GuideStep;\r\n  index = -1;\r\n  readonly count: number = this._data.steps.length;\r\n  working = true;\r\n  constructor(\r\n    @Inject(TOUR_TOKEN)\r\n    private _data: Guide,\r\n    private _session: SessionService,\r\n    private _overlay: Overlay,\r\n    private _ngRouter: Router,\r\n    private _overlayRef: OverlayRef) {\r\n  }\r\n  ngOnInit(): void {\r\n    if (this._data.name) {\r\n      const lastindex = localStorage.getItem(this._data.name + '_guide_step');\r\n      if (lastindex) {\r\n        this.index = Number.parseInt(lastindex);\r\n      }\r\n    }\r\n    this._moveBy(1);\r\n  }\r\n  /**\r\n   * \r\n   * @param steps\r\n   */\r\n  private _moveBy(steps: 1 | -1) {\r\n    const index = this.index + steps;\r\n    if (index < 0 || index > this.count - 1) {\r\n      localStorage.removeItem(this._data.name + '_guide_step');\r\n      return;\r\n    }\r\n    this._data.name && localStorage.setItem(this._data.name + '_guide_step', this.index.toString());\r\n    this.working = true;\r\n    const step = this._data.steps[index];\r\n    const { selector, position, navigate, simulate } = step, promisses: Promise<any>[] = [];\r\n    if (navigate) {\r\n      const promise = this._ngRouter.navigateByUrl(navigate);\r\n      promisses.push(promise);\r\n    }\r\n    let positionStrategy: PositionStrategy;\r\n    if (selector) {\r\n      const element = document.querySelector(selector) as HTMLElement;\r\n      if (!element) {\r\n        console.warn(`Guide ${this._data.name} selector '${selector}' not found. skipping.`);\r\n        this._moveBy(steps);\r\n        return;\r\n      }\r\n      let positions: ConnectedPosition[];\r\n      switch (position) {\r\n        case 'Above':\r\n          positions = [...ABOVE, ...BELOW, ...AFTER, ...BEFORE];\r\n          break;\r\n        case 'End':\r\n          positions = [...AFTER, ...BEFORE, ...BELOW, ...ABOVE];\r\n          break;\r\n        case 'Start':\r\n          positions = [...BEFORE, ...AFTER, ...BELOW, ...ABOVE];\r\n          break;\r\n        case 'Below':\r\n          positions = [...BELOW, ...BEFORE, ...ABOVE, ...AFTER];\r\n          break;\r\n        default:\r\n          positions = [...BEFORE, ...BELOW, ...ABOVE, ...AFTER];\r\n      }\r\n      positionStrategy = this._overlay.position().\r\n        flexibleConnectedTo(new ElementRef(element)).\r\n        withPositions(positions).\r\n        withGrowAfterOpen();\r\n      if (outOfBound(element)) {\r\n        promisses.push(new Promise<any>(resolve => {\r\n          const task = setInterval(() => {\r\n            if (!outOfBound(element)) {\r\n              clearInterval(task);\r\n              resolve(null);\r\n            }\r\n          }, 150);\r\n        }));\r\n        element.scrollIntoView({ behavior: 'smooth' });\r\n      }\r\n      simulate &&\r\n        promisses.push(new Promise(resolve => {\r\n          element.click();\r\n          resolve(null);\r\n        }));\r\n    }\r\n    else positionStrategy = this._overlay.position().global().centerVertically().centerHorizontally();\r\n\r\n    const complete = () => {\r\n      this.index = index;\r\n      this.step = step;\r\n      this.working = false;\r\n      this._overlayRef.updatePositionStrategy(positionStrategy);\r\n      this._overlayRef.updatePosition();\r\n    };\r\n    promisses.length ? Promise.all(promisses).then(() => complete()) : complete();\r\n  }\r\n  @HostListener('window:keydown', ['$event'])\r\n  keydown(evt: KeyboardEvent) {\r\n    if (!this.working)\r\n      switch (evt.keyCode) {\r\n        case LEFT_ARROW:\r\n          this._moveBy(this._session.direction === 'ltr' ? -1 : 1);\r\n          break;\r\n        case RIGHT_ARROW:\r\n          this._moveBy(this._session.direction === 'ltr' ? 1 : -1);\r\n          break;\r\n        case ESCAPE:\r\n          this.close();\r\n          evt.stopPropagation();\r\n          break;\r\n      }\r\n  }\r\n  next() {\r\n    this._moveBy(1);\r\n  }\r\n  prev() {\r\n    this._moveBy(-1);\r\n  }\r\n  close() {\r\n    this._overlayRef.detach();\r\n  }\r\n}\r\n","<div class=\"container\" [style.display]=\"step ? '': 'none'\" cdkTrapFocus>\r\n  <div fxLayout=\"column\" class=\"content\">\r\n    <div fxLayout=\"row\">\r\n      <h2 *ngIf=\"step?.title\" class=\"mat-h2\">{{step?.title}}</h2>\r\n      <span class=\"divider\"></span>\r\n      <button mat-icon-button (click)=\"close()\" *ngIf=\"index < count - 1\"><mat-icon>close</mat-icon></button>\r\n    </div>\r\n    <p class=\"mat-body\" [innerHTML]=\"step?.content | sanitizeHtml\">\r\n    </p>\r\n    <div fxLayout=\"row\">\r\n      <span class=\"divider\"></span>\r\n      <button mat-icon-button (click)=\"prev()\" [disabled]=\"index < 1 || working\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_left</mat-icon></button>\r\n      <button mat-icon-button (click)=\"next()\" [disabled]=\"index >= count - 1 || working\" cdkFocusInitial><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_right</mat-icon></button>\r\n      <button mat-button (click)=\"close()\" *ngIf=\"index >= count - 1\">{{'GuideFinish'|translate}}</button>\r\n    </div>\r\n  </div>\r\n  <div class=\"tooltip-container\">\r\n    <div class=\"tooltip\"></div>\r\n  </div>\r\n</div>\r\n"]}
@@ -0,0 +1,58 @@
1
+ import { Component, Input } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "./guide.service";
4
+ import * as i2 from "@angular/material/icon";
5
+ import * as i3 from "@angular/material/button";
6
+ import * as i4 from "@angular/common";
7
+ import * as i5 from "@angular/flex-layout/flex";
8
+ import * as i6 from "../popup/tooltip.directive";
9
+ import * as i7 from "../pipes/translate.pipe";
10
+ /** */
11
+ export class HelpTipComponent {
12
+ constructor(_guide) {
13
+ this._guide = _guide;
14
+ }
15
+ ngOnInit() {
16
+ this.showTip = localStorage.getItem(this.name + '-tip') !== '1';
17
+ const guide = this._guide.guides.find(g => g.name === this.name);
18
+ this._message = guide.title;
19
+ }
20
+ open(evt) {
21
+ this._guide.start(this.name);
22
+ }
23
+ dismiss() {
24
+ localStorage.setItem(this.name + 'tip', '1');
25
+ this.showTip = false;
26
+ }
27
+ }
28
+ HelpTipComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.1", ngImport: i0, type: HelpTipComponent, deps: [{ token: i1.GuideService }], target: i0.ɵɵFactoryTarget.Component });
29
+ HelpTipComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.1", type: HelpTipComponent, selector: "bizdoc-help-tip", inputs: { name: "name" }, ngImport: i0, template: `
30
+ <p fxLayout="row" class="form-help-tip" *ngIf="showTip">
31
+ <mat-icon>help_outline</mat-icon> &nbsp;<span (click)="open($event)" [innerHTML]="'HelpTip'|translate: _message" class="mat-body-1"></span>
32
+ <button mat-icon-button (click)="dismiss()" [bizdocTooltip]="'Dismiss'|translate"><mat-icon inline>close</mat-icon></button>
33
+ </p>
34
+ `, isInline: true, styles: [".form-help-tip{align-items:center;border:1px rgb(0 0 0 / 38%) solid;margin:10px;border-radius:3px;padding:0 8px}\n"], components: [{ type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i3.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.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: i6.TooltipDirective, selector: "[bizdocTooltip]", inputs: ["bizdocTooltip", "bizdocTooltipTemplate", "bizdocTooltipContext", "bizdocTooltipPosition", "bizdocTooltipDuration", "bizdocTooltipDisabled"] }], pipes: { "translate": i7.TranslatePipe } });
35
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.1", ngImport: i0, type: HelpTipComponent, decorators: [{
36
+ type: Component,
37
+ args: [{
38
+ template: `
39
+ <p fxLayout="row" class="form-help-tip" *ngIf="showTip">
40
+ <mat-icon>help_outline</mat-icon> &nbsp;<span (click)="open($event)" [innerHTML]="'HelpTip'|translate: _message" class="mat-body-1"></span>
41
+ <button mat-icon-button (click)="dismiss()" [bizdocTooltip]="'Dismiss'|translate"><mat-icon inline>close</mat-icon></button>
42
+ </p>
43
+ `,
44
+ styles: [`
45
+ .form-help-tip {
46
+ align-items: center;
47
+ border: 1px rgb(0 0 0 / 38%) solid;
48
+ margin: 10px;
49
+ border-radius: 3px 3px;
50
+ padding: 0 8px;
51
+ }
52
+ `],
53
+ selector: 'bizdoc-help-tip'
54
+ }]
55
+ }], ctorParameters: function () { return [{ type: i1.GuideService }]; }, propDecorators: { name: [{
56
+ type: Input
57
+ }] } });
58
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscC10aXAuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicmFyaWVzL2NvcmUvc3JjL2xpYi9jb3JlL2d1aWRlL2hlbHAtdGlwLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQzs7Ozs7Ozs7O0FBR3pELE9BQU87QUFtQlAsTUFBTSxPQUFPLGdCQUFnQjtJQUszQixZQUNVLE1BQW9CO1FBQXBCLFdBQU0sR0FBTixNQUFNLENBQWM7SUFDMUIsQ0FBQztJQUNMLFFBQVE7UUFDTixJQUFJLENBQUMsT0FBTyxHQUFHLFlBQVksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksR0FBRyxNQUFNLENBQUMsS0FBSyxHQUFHLENBQUM7UUFDaEUsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksS0FBSyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDakUsSUFBSSxDQUFDLFFBQVEsR0FBRyxLQUFLLENBQUMsS0FBSyxDQUFDO0lBQzlCLENBQUM7SUFDRCxJQUFJLENBQUMsR0FBZTtRQUNsQixJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDL0IsQ0FBQztJQUNELE9BQU87UUFDTCxZQUFZLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLEdBQUcsS0FBSyxFQUFFLEdBQUcsQ0FBQyxDQUFDO1FBQzdDLElBQUksQ0FBQyxPQUFPLEdBQUcsS0FBSyxDQUFDO0lBQ3ZCLENBQUM7OzZHQW5CVSxnQkFBZ0I7aUdBQWhCLGdCQUFnQixpRkFqQmpCOzs7OztDQUtYOzJGQVlZLGdCQUFnQjtrQkFsQjVCLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFOzs7OztDQUtYO29CQUNDLE1BQU0sRUFBRSxDQUFDOzs7Ozs7OztDQVFWLENBQUM7b0JBQ0EsUUFBUSxFQUFFLGlCQUFpQjtpQkFDNUI7bUdBR0MsSUFBSTtzQkFESCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBHdWlkZVNlcnZpY2UgfSBmcm9tICcuL2d1aWRlLnNlcnZpY2UnO1xyXG5cbi8qKiAgKi9cbkBDb21wb25lbnQoe1xuICB0ZW1wbGF0ZTogYFxuICA8cCBmeExheW91dD1cInJvd1wiIGNsYXNzPVwiZm9ybS1oZWxwLXRpcFwiICpuZ0lmPVwic2hvd1RpcFwiPlxuICAgIDxtYXQtaWNvbj5oZWxwX291dGxpbmU8L21hdC1pY29uPiAmbmJzcDs8c3BhbiAoY2xpY2spPVwib3BlbigkZXZlbnQpXCIgW2lubmVySFRNTF09XCInSGVscFRpcCd8dHJhbnNsYXRlOiBfbWVzc2FnZVwiIGNsYXNzPVwibWF0LWJvZHktMVwiPjwvc3Bhbj5cbiAgICA8YnV0dG9uIG1hdC1pY29uLWJ1dHRvbiAoY2xpY2spPVwiZGlzbWlzcygpXCIgW2JpemRvY1Rvb2x0aXBdPVwiJ0Rpc21pc3MnfHRyYW5zbGF0ZVwiPjxtYXQtaWNvbiBpbmxpbmU+Y2xvc2U8L21hdC1pY29uPjwvYnV0dG9uPlxuICA8L3A+XG5gLFxuICBzdHlsZXM6IFtgXG4uZm9ybS1oZWxwLXRpcCB7XHJcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcclxuYm9yZGVyOiAxcHggcmdiKDAgMCAwIC8gMzglKSBzb2xpZDtcclxuICBtYXJnaW46IDEwcHg7XHJcbiAgYm9yZGVyLXJhZGl1czogM3B4IDNweDtcclxuICBwYWRkaW5nOiAwIDhweDtcclxufVxyXG5gXSxcbiAgc2VsZWN0b3I6ICdiaXpkb2MtaGVscC10aXAnXG59KVxuZXhwb3J0IGNsYXNzIEhlbHBUaXBDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBASW5wdXQoKVxuICBuYW1lITogc3RyaW5nO1xuICBfbWVzc2FnZTogc3RyaW5nO1xyXG4gIHNob3dUaXA6IGJvb2xlYW47XHJcbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSBfZ3VpZGU6IEd1aWRlU2VydmljZSxcbiAgKSB7IH1cbiAgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgICB0aGlzLnNob3dUaXAgPSBsb2NhbFN0b3JhZ2UuZ2V0SXRlbSh0aGlzLm5hbWUgKyAnLXRpcCcpICE9PSAnMSc7XG4gICAgY29uc3QgZ3VpZGUgPSB0aGlzLl9ndWlkZS5ndWlkZXMuZmluZChnID0+IGcubmFtZSA9PT0gdGhpcy5uYW1lKTtcbiAgICB0aGlzLl9tZXNzYWdlID0gZ3VpZGUudGl0bGU7XG4gIH1cclxuICBvcGVuKGV2dDogTW91c2VFdmVudCkge1xuICAgIHRoaXMuX2d1aWRlLnN0YXJ0KHRoaXMubmFtZSk7XG4gIH1cbiAgZGlzbWlzcygpIHtcbiAgICBsb2NhbFN0b3JhZ2Uuc2V0SXRlbSh0aGlzLm5hbWUgKyAndGlwJywgJzEnKTtcbiAgICB0aGlzLnNob3dUaXAgPSBmYWxzZTtcbiAgfVxufVxuIl19
@@ -4,6 +4,7 @@ import * as i1 from "./slots/router.service";
4
4
  import * as i2 from "@angular/router";
5
5
  export class RouterImpl {
6
6
  }
7
+ /** desktop */
7
8
  export class PaneRouter extends RouterImpl {
8
9
  constructor(_router) {
9
10
  super();
@@ -18,6 +19,7 @@ PaneRouter.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version:
18
19
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.1", ngImport: i0, type: PaneRouter, decorators: [{
19
20
  type: Injectable
20
21
  }], ctorParameters: function () { return [{ type: i1.PanesRouter }]; } });
22
+ /** mobile */
21
23
  export class NgRouter extends RouterImpl {
22
24
  constructor(_router) {
23
25
  super();
@@ -32,4 +34,4 @@ NgRouter.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "1
32
34
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.1", ngImport: i0, type: NgRouter, decorators: [{
33
35
  type: Injectable
34
36
  }], ctorParameters: function () { return [{ type: i2.Router }]; } });
35
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm91dGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicmFyaWVzL2NvcmUvc3JjL2xpYi9jb3JlL3JvdXRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7O0FBSTNDLE1BQU0sT0FBZ0IsVUFBVTtDQUUvQjtBQUVELE1BQU0sT0FBTyxVQUFXLFNBQVEsVUFBVTtJQUN4QyxZQUNVLE9BQW9CO1FBRTVCLEtBQUssRUFBRSxDQUFDO1FBRkEsWUFBTyxHQUFQLE9BQU8sQ0FBYTtJQUc5QixDQUFDO0lBQ0QsUUFBUSxDQUFDLFFBQWtCLEVBQUUsS0FBTTtRQUNqQyxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxRQUFRLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDekMsQ0FBQzs7dUdBUlUsVUFBVTsyR0FBVixVQUFVOzJGQUFWLFVBQVU7a0JBRHRCLFVBQVU7O0FBWVgsTUFBTSxPQUFPLFFBQVMsU0FBUSxVQUFVO0lBQ3RDLFlBQ1UsT0FBZTtRQUVyQixLQUFLLEVBQUUsQ0FBQztRQUZGLFlBQU8sR0FBUCxPQUFPLENBQVE7SUFHekIsQ0FBQztJQUNELFFBQVEsQ0FBQyxRQUFrQixFQUFFLEtBQU07UUFDakMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsUUFBUSxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQ3pDLENBQUM7O3FHQVJVLFFBQVE7eUdBQVIsUUFBUTsyRkFBUixRQUFRO2tCQURwQixVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7IFJvdXRlciB9IGZyb20gXCJAYW5ndWxhci9yb3V0ZXJcIjtcclxuaW1wb3J0IHsgUGFuZXNSb3V0ZXIgfSBmcm9tIFwiLi9zbG90cy9yb3V0ZXIuc2VydmljZVwiO1xyXG5cclxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIFJvdXRlckltcGwge1xyXG4gIGFic3RyYWN0IG5hdmlnYXRlKGNvbW1hbmRzOiAoc3RyaW5nfG51bWJlcilbXSwgZXh0cmE/KTtcclxufVxyXG5ASW5qZWN0YWJsZSgpXHJcbmV4cG9ydCBjbGFzcyBQYW5lUm91dGVyIGV4dGVuZHMgUm91dGVySW1wbCB7XHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwcml2YXRlIF9yb3V0ZXI6IFBhbmVzUm91dGVyXHJcbiAgKSB7XHJcbiAgICBzdXBlcigpO1xyXG4gIH1cclxuICBuYXZpZ2F0ZShjb21tYW5kczogc3RyaW5nW10sIGV4dHJhPykge1xyXG4gICAgdGhpcy5fcm91dGVyLm5hdmlnYXRlKGNvbW1hbmRzLCBleHRyYSk7XHJcbiAgfVxyXG59XHJcbkBJbmplY3RhYmxlKClcclxuZXhwb3J0IGNsYXNzIE5nUm91dGVyIGV4dGVuZHMgUm91dGVySW1wbCB7XHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwcml2YXRlIF9yb3V0ZXI6IFJvdXRlclxyXG4gICkge1xyXG4gICAgICBzdXBlcigpO1xyXG4gIH1cclxuICBuYXZpZ2F0ZShjb21tYW5kczogc3RyaW5nW10sIGV4dHJhPykge1xyXG4gICAgdGhpcy5fcm91dGVyLm5hdmlnYXRlKGNvbW1hbmRzLCBleHRyYSk7XHJcbiAgfVxyXG59XHJcbiJdfQ==
37
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm91dGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicmFyaWVzL2NvcmUvc3JjL2xpYi9jb3JlL3JvdXRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7O0FBSTNDLE1BQU0sT0FBZ0IsVUFBVTtDQUUvQjtBQUNELGNBQWM7QUFFZCxNQUFNLE9BQU8sVUFBVyxTQUFRLFVBQVU7SUFDeEMsWUFDVSxPQUFvQjtRQUU1QixLQUFLLEVBQUUsQ0FBQztRQUZBLFlBQU8sR0FBUCxPQUFPLENBQWE7SUFHOUIsQ0FBQztJQUNELFFBQVEsQ0FBQyxRQUFrQixFQUFFLEtBQU07UUFDakMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsUUFBUSxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQ3pDLENBQUM7O3VHQVJVLFVBQVU7MkdBQVYsVUFBVTsyRkFBVixVQUFVO2tCQUR0QixVQUFVOztBQVdYLGFBQWE7QUFFYixNQUFNLE9BQU8sUUFBUyxTQUFRLFVBQVU7SUFDdEMsWUFDVSxPQUFlO1FBRXJCLEtBQUssRUFBRSxDQUFDO1FBRkYsWUFBTyxHQUFQLE9BQU8sQ0FBUTtJQUd6QixDQUFDO0lBQ0QsUUFBUSxDQUFDLFFBQWtCLEVBQUUsS0FBTTtRQUNqQyxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxRQUFRLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDekMsQ0FBQzs7cUdBUlUsUUFBUTt5R0FBUixRQUFROzJGQUFSLFFBQVE7a0JBRHBCLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgUm91dGVyIH0gZnJvbSBcIkBhbmd1bGFyL3JvdXRlclwiO1xyXG5pbXBvcnQgeyBQYW5lc1JvdXRlciB9IGZyb20gXCIuL3Nsb3RzL3JvdXRlci5zZXJ2aWNlXCI7XHJcblxyXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgUm91dGVySW1wbCB7XHJcbiAgYWJzdHJhY3QgbmF2aWdhdGUoY29tbWFuZHM6IChzdHJpbmd8bnVtYmVyKVtdLCBleHRyYT8pO1xyXG59XHJcbi8qKiBkZXNrdG9wICovXHJcbkBJbmplY3RhYmxlKClcclxuZXhwb3J0IGNsYXNzIFBhbmVSb3V0ZXIgZXh0ZW5kcyBSb3V0ZXJJbXBsIHtcclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHByaXZhdGUgX3JvdXRlcjogUGFuZXNSb3V0ZXJcclxuICApIHtcclxuICAgIHN1cGVyKCk7XHJcbiAgfVxyXG4gIG5hdmlnYXRlKGNvbW1hbmRzOiBzdHJpbmdbXSwgZXh0cmE/KSB7XHJcbiAgICB0aGlzLl9yb3V0ZXIubmF2aWdhdGUoY29tbWFuZHMsIGV4dHJhKTtcclxuICB9XHJcbn1cclxuLyoqIG1vYmlsZSAqL1xyXG5ASW5qZWN0YWJsZSgpXHJcbmV4cG9ydCBjbGFzcyBOZ1JvdXRlciBleHRlbmRzIFJvdXRlckltcGwge1xyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgcHJpdmF0ZSBfcm91dGVyOiBSb3V0ZXJcclxuICApIHtcclxuICAgICAgc3VwZXIoKTtcclxuICB9XHJcbiAgbmF2aWdhdGUoY29tbWFuZHM6IHN0cmluZ1tdLCBleHRyYT8pIHtcclxuICAgIHRoaXMuX3JvdXRlci5uYXZpZ2F0ZShjb21tYW5kcywgZXh0cmEpO1xyXG4gIH1cclxufVxyXG4iXX0=