@bizdoc/core 2.3.22 → 2.3.24
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.
- package/esm2022/lib/admin/architecture/elements/form.component.mjs +3 -3
- package/esm2022/lib/admin/document-trace/document-trace.component.mjs +3 -3
- package/esm2022/lib/admin/form/workflow/workflow.component.mjs +3 -3
- package/esm2022/lib/admin/patterns/patterns.component.mjs +3 -3
- package/esm2022/lib/admin/permissions/permissions.component.mjs +3 -3
- package/esm2022/lib/admin/positions/positions.component.mjs +3 -3
- package/esm2022/lib/admin/profiler/profiler.component.mjs +3 -3
- package/esm2022/lib/browse/browse.mobile.component.mjs +3 -3
- package/esm2022/lib/browse/browse.pane.component.mjs +3 -3
- package/esm2022/lib/compose/compose.mobile.component.mjs +3 -3
- package/esm2022/lib/compose/compose.pane.component.mjs +3 -3
- package/esm2022/lib/core/translations.mjs +5 -3
- package/esm2022/lib/cube/accum/accum.component.mjs +3 -3
- package/esm2022/lib/cube/chart/chart.component.mjs +3 -3
- package/esm2022/lib/cube/cube.service.mjs +13 -6
- package/esm2022/lib/cube/grid/grid.component.mjs +51 -56
- package/esm2022/lib/cube/parallel/parallel.component.mjs +3 -3
- package/esm2022/lib/cube/pivot/pivot.component.mjs +3 -3
- package/esm2022/lib/cube/spreadsheet/spreadsheet.component.mjs +5 -4
- package/esm2022/lib/dashboard/actions/actions.widget.mjs +3 -3
- package/esm2022/lib/dashboard/cube/compare.widget.mjs +3 -3
- package/esm2022/lib/dashboard/cube/cube-analysis.base.mjs +3 -3
- package/esm2022/lib/dashboard/cube/document-state.widget.mjs +3 -3
- package/esm2022/lib/dashboard/score/activity.widget.mjs +3 -3
- package/esm2022/lib/dashboard/score/compare-groups.widget.mjs +3 -3
- package/esm2022/lib/dashboard/score/peers-performance.widget.mjs +3 -3
- package/esm2022/lib/dashboard/score/personal-score.widget.mjs +7 -4
- package/esm2022/lib/reports/cube/grid-documents.component.mjs +3 -3
- package/esm2022/lib/reports/cube/usage-chart.component.mjs +3 -3
- package/esm2022/lib/reports/report-viewer.component.mjs +3 -6
- package/fesm2022/bizdoc-core.mjs +124 -118
- package/fesm2022/bizdoc-core.mjs.map +1 -1
- package/lib/admin/architecture/elements/form.component.d.ts +1 -1
- package/lib/admin/profiler/profiler.component.d.ts +1 -1
- package/lib/core/translations.d.ts +2 -0
- package/lib/cube/accum/accum.component.d.ts +1 -1
- package/lib/cube/chart/chart.component.d.ts +1 -1
- package/lib/cube/grid/grid.component.d.ts +1 -1
- package/lib/cube/parallel/parallel.component.d.ts +1 -1
- package/lib/dashboard/actions/actions.widget.d.ts +1 -1
- package/lib/dashboard/cube/compare.widget.d.ts +1 -1
- package/lib/dashboard/cube/cube-analysis.base.d.ts +1 -1
- package/lib/dashboard/cube/document-state.widget.d.ts +1 -1
- package/lib/dashboard/score/activity.widget.d.ts +1 -1
- package/lib/dashboard/score/compare-groups.widget.d.ts +1 -1
- package/lib/dashboard/score/peers-performance.widget.d.ts +1 -1
- package/lib/dashboard/score/personal-score.widget.d.ts +1 -1
- package/package.json +11 -11
@@ -96,13 +96,13 @@ let ProfilerComponent = class ProfilerComponent {
|
|
96
96
|
height: 10
|
97
97
|
};
|
98
98
|
this.palettes = this._session.accentPalette;
|
99
|
-
this.theme = this._session.theme.dark ? '
|
99
|
+
this.theme = this._session.theme.dark ? 'Material3Dark' : 'Material3';
|
100
100
|
this.cols = 2;
|
101
101
|
this._destroy = new Subject();
|
102
102
|
this.separatorKeysCodes = [ENTER, COMMA, SEMICOLON];
|
103
103
|
this.cols = 2;
|
104
104
|
_session.themeChange.pipe(takeUntil(this._destroy)).subscribe(t => {
|
105
|
-
this.theme = t.dark ? '
|
105
|
+
this.theme = t.dark ? 'Material3Dark' : 'Material3';
|
106
106
|
this.palettes = _session.accentPalette;
|
107
107
|
});
|
108
108
|
}
|
@@ -283,4 +283,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
|
|
283
283
|
type: HostListener,
|
284
284
|
args: ['window:keydown.f1', ['$event']]
|
285
285
|
}] } });
|
286
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"profiler.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/admin/profiler/profiler.component.ts","../../../../../../libraries/core/src/lib/admin/profiler/profiler.component.html"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAE,SAAS,EAAkC,UAAU,EAAE,YAAY,EAAqB,MAAM,eAAe,CAAC;AAClI,OAAO,EAAe,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAGzD,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAEhE,OAAO,EAAE,OAAO,EAAc,MAAM,MAAM,CAAC;AAC3C,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,SAAS,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACjF,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAChD,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAS/C,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAIhD,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AACtD,OAAO,EAAE,qBAAqB,EAAmB,MAAM,yBAAyB,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAW1E,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;IAqD5B,WAAW;IACX,YAAoB,GAAkB,EAC5B,WAAoE,EACpE,QAAwB,EACxB,OAAkB,EAClB,aAA2B,EAC3B,KAAe,EACf,MAAoB,EACpB,OAAoB,EACpB,GAAsB,EACtB,KAAiC,EACjC,UAA4B,EAC5B,SAAyB,EACzB,GAAgB;QAZN,QAAG,GAAH,GAAG,CAAe;QAC5B,gBAAW,GAAX,WAAW,CAAyD;QACpE,aAAQ,GAAR,QAAQ,CAAgB;QACxB,YAAO,GAAP,OAAO,CAAW;QAClB,kBAAa,GAAb,aAAa,CAAc;QAC3B,UAAK,GAAL,KAAK,CAAU;QACf,WAAM,GAAN,MAAM,CAAc;QACpB,YAAO,GAAP,OAAO,CAAa;QACpB,QAAG,GAAH,GAAG,CAAmB;QACtB,UAAK,GAAL,KAAK,CAA4B;QACjC,eAAU,GAAV,UAAU,CAAkB;QAC5B,cAAS,GAAT,SAAS,CAAgB;QACzB,QAAG,GAAH,GAAG,CAAa;QAjEjB,WAAM,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAIhC,QAAG,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,EAAE,UAAU,CAAC,QAAQ,CAAC,CAAC;QAClD,iBAAY,GAAG;YACtB,SAAS,EAAE,UAAU;YACrB,WAAW,EAAE,QAAQ;YACrB,UAAU,EAAE;gBACV,UAAU,EAAE,WAAW;aACxB;SACW,CAAC;QACN,iBAAY,GAAG;YACtB,UAAU,EAAE;gBACV,IAAI,EAAE,KAAK;aACZ;SACW,CAAC;QACN,iBAAY,GAAsB;YACzC,uBAAuB,EAAE,IAAI;YAC7B,kBAAkB,EAAE,IAAI;YACxB,YAAY,EAAE,EAAE;YAChB,sBAAsB,EAAE,KAAK;YAC7B,eAAe,EAAE,IAAI;SACtB,CAAC;QACO,YAAO,GAAyB;YACvC,MAAM,EAAE,IAAI;YACZ,MAAM,EAAE,IAAI;YACZ,SAAS,EAAE;gBACT,UAAU,EAAE,WAAW;aACxB;SACF,CAAC;QACO,WAAM,GAAsB;YACnC,OAAO,EAAE,KAAK;YACd,SAAS,EAAE;gBACT,UAAU,EAAE,WAAW;aACxB;SACF,CAAC;QACO,WAAM,GAAG,EAAE,KAAK,EAAE,CAAC,EAAiB,CAAC;QACrC,WAAM,GAAuB;YACpC,OAAO,EAAE,IAAI;YACb,KAAK,EAAE,EAAE;YACT,MAAM,EAAE,EAAE;SACX,CAAA;QAGD,aAAQ,GAAa,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC;QACjD,UAAK,GAAgC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,UAAU,CAAC;QAE5F,SAAI,GAAG,CAAC,CAAC;QACQ,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;QACvC,uBAAkB,GAAa,CAAC,KAAK,EAAE,KAAK,EAAE,SAAS,CAAC,CAAC;QAgBhE,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;QACd,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;YAChE,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,UAAU,CAAC;YAClD,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,aAAa,CAAC;QACzC,CAAC,CAAC,CAAC;IACL,CAAC;IACD,QAAQ;QACN,IAAI,CAAC,KAAK,CAAC,iBAAiB,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;YAC3C,MAAM,EAAE,MAAM,EAAE,GAAG,CAAC,CAAC;YACrB,MAAM,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QAC/B,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,WAAW,EAAE,CAAC,CAAC;QAC/F,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,EAClE,YAAY,CAAC,GAAG,CAAC,EACjB,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EACzB,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC/C,CAAC;IAED,KAAK,CAAC,GAA2B;QAC/B,MAAM,KAAK,GAAgB,EAAE,CAAC;QAC9B,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;YACd,KAAK,CAAC,IAAI,CAAC;gBACT,QAAQ,EAAE,sBAAsB;gBAChC,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,iBAAiB,CAAC;aAChD,CAAC,CAAC;YACH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM;gBACpC,KAAK,CAAC,IAAI,CAAC;oBACT,QAAQ,EAAE,sBAAsB;oBAChC,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,cAAc,CAAC;iBAC7C,CAAC,CAAC;YACL,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM;gBACtB,KAAK,CAAC,IAAI,CAAC;oBACT,QAAQ,EAAE,qBAAqB;oBAC/B,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,aAAa,CAAC;iBAC5C,CAAC,CAAC;YACL,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM;gBACxB,KAAK,CAAC,IAAI,CAAC;oBACT,QAAQ,EAAE,uBAAuB;oBACjC,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,eAAe,CAAC;iBAC9C,CAAC,CAAC;YACL,KAAK,CAAC,IAAI,CAAC;gBACT,QAAQ,EAAE,sBAAsB;gBAChC,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,cAAc,CAAC;aAC7C,CAAC,CAAC;QACL,CAAC;;YACI,KAAK,CAAC,IAAI,CAAC;gBACd,QAAQ,EAAE,oBAAoB;gBAC9B,QAAQ,EAAE,OAAO;gBACjB,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,oBAAoB,CAAC;aACnD,CAAC,CAAC;QACH,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;YAChB,IAAI,EAAE,UAAU;YAChB,KAAK;SACN,CAAC,CAAC;QACH,GAAG,IAAI,GAAG,CAAC,cAAc,EAAE,CAAC;IAC9B,CAAC;IACD,MAAM,CAAC,GAAiC;QACtC,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,GAAG,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC;QACxC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,EAAE,EAAE,WAAW,EAAE,EAAE,MAAM,EAAE,EAAE,CAAC,CAAC;IACzD,CAAC;IACD;;;OAGG;IACK,KAAK,CAAC,MAAc;QAC1B,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC;QACtB,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC;YAC1C,IAAI,EAAE,CAAC,CAAC,EAAE;gBACR,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;gBACd,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;gBAC9C,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;gBACzB,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM;oBAC7B,IAAI,CAAC,KAAK,EAAE,YAAY,CAAC,CAAC,CAAC,CAAC;gBAC9B,IAAI,CAAC,KAAK,EAAE,SAAS,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;YACxC,CAAC,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE;SACjC,CAAC,CAAC;IACL,CAAC;IACD,MAAM;IACE,OAAO;QACb,OAAO,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;YAC7C,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;YAClC,OAAO;gBACL,IAAI,EAAE,SAAS;gBACf,IAAI,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC;gBACzB,KAAK,EAAE,MAAM;gBACb,KAAK,EAAE,UAAU;gBACjB,UAAU,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;oBACtB,OAAO;wBACL,EAAE,EAAE,CAAC,CAAC,EAAE;wBACR,IAAI,EAAE,IAAI,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;wBACtB,QAAQ,EAAE,CAAC,CAAC,QAAQ;qBACrB,CAAC;gBACJ,CAAC,CAAC;aACH,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,WAAW,CAAC,IAAY;QAC9B,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,CAAC;QACxE,OAAO,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,IAAI,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC;IACrD,CAAC;IACD,UAAU,CAAC,GAAoB;QAC7B,MAAM,EAAE,EAAE,EAAE,GAAG,GAAG,CAAC,MAAM,CAAC,UAAU,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QACrD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC9B,CAAC;IACD,WAAW,CAAC,IAAc;QACxB,OAAO,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;IACjC,CAAC;IACD,KAAK,CAAC,EAAU;QACd,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,OAAO,EAAE,OAAO,EAAE,gBAAgB,CAAC,EAAE;YAC1D,WAAW,EAAE,EAAE,UAAU,EAAE,EAAE,CAAC,QAAQ,EAAE,EAAE;YAC1C,MAAM,EAAE,UAAU,CAAC,KAAK,GAAG,UAAU,CAAC,QAAQ;SAC/C,CAAC,CAAC;IACL,CAAC;IACD,IAAI;QACF,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAChC,CAAC;IACD,QAAQ,CAAC,QAAuB;QAC9B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QACjG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,WAAW,EAAE;YACjD,SAAS,CAAC,CAAC,CAAC,EAAE,CACZ,CAAC,IAAI,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,QAAQ,CAAC,CACjC,CAAC;IACN,CAAC;IACD,QAAQ;QACN,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,qBAAqB,EAAE;YACvC,iBAAiB,EAAE,IAAI;YACvB,IAAI,EAAE;gBACJ,MAAM,EAAE,IAAI,CAAC,OAAO;gBACpB,WAAW,EAAE,IAAI,CAAC,IAAI,CAAC,WAAW;gBAClC,WAAW,EAAE,IAAI,CAAC,IAAI,CAAC,WAAW;aAChB;SACrB,CAAC,CAAC,WAAW,EAAE;YACd,SAAS,CAAC,CAAC,CAAC,EAAE,CACZ,CAAC,IAAI,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC;YAC5B,WAAW,EAAE,CAAC,CAAC,WAAW;YAC1B,WAAW,EAAE,CAAC,CAAC,WAAW;YAC1B,MAAM,EAAE,IAAI,CAAC,OAAO;SACrB,CAAC,CAAC,SAAS,CAAC;YACX,IAAI,EAAE,GAAG,EAAE;gBACT,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;gBAC5B,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC;YACjC,CAAC,EAAE,KAAK,EAAE,GAAG,EAAE,CACb,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE;SACnB,CAAC,CAAC,CAAC;IACV,CAAC;IACD,MAAM;IACE,SAAS,CAAC,GAAW,EAAE,QAAuB;QACpD,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,EAAE,QAAQ,EAAE,EAAE,GAAG,EAAE,GAAG,QAAQ,EAAE,EAAE,MAAM,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,SAAS,CAAC;YAC3F,IAAI,EAAE,GAAG,EAAE;gBACT,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;gBAC3B,IAAI,QAAQ;oBACV,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;;oBAErC,IAAI,CAAC,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;YAC7B,CAAC,EAAE,KAAK,EAAE,GAAG,EAAE,CACb,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE;SACnB,CAAC,CAAC;IACL,CAAC;IACD,aAAa,CAAC,CAA0B;QACtC,CAAC,CAAC,IAAI,GAAG,GAAG,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAW,EAAE,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC;IACpE,CAAC;IACD,WAAW;QACT,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;8GAxOU,iBAAiB;kGAAjB,iBAAiB,oTAGG,UAAU,sHCtC3C,mwKA+HA;;AD5Fa,iBAAiB;IAF7B,MAAM,CAAC,EAAE,QAAQ,EAAE,sBAAsB,EAAE,CAAC;IAC7C,eAAe;GACF,iBAAiB,CAyO7B;;2FAzOY,iBAAiB;kBAT7B,SAAS;2BAGF;wBACJ,KAAK,EAAE,MAAM;qBACd;sZAMsB,KAAK;sBAA3B,SAAS;uBAAC,UAAU;gBACwB,YAAY;sBAAxD,SAAS;uBAAC,UAAU,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE;gBACnB,SAAS;sBAAhC,SAAS;uBAAC,WAAW;gBAiFtB,KAAK;sBADJ,YAAY;uBAAC,mBAAmB,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import { Component, ViewChild, OnInit, OnDestroy, TemplateRef, ElementRef, HostListener, ChangeDetectorRef } from '@angular/core';\r\nimport { FormBuilder, Validators } from '@angular/forms';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { MatAutocompleteSelectedEvent } from '@angular/material/autocomplete';\r\nimport { COMMA, ENTER, SEMICOLON } from '@angular/cdk/keycodes';\r\nimport { AxisModel, BorderModel, ChartComponent, IPointEventArgs, ITooltipRenderEventArgs, LegendSeriesModel, MarkerOptionsModel, SeriesModel, TooltipSettingsModel, ZoomSettingsModel } from '@syncfusion/ej2-angular-charts';\r\nimport { Subject, Observable } from 'rxjs';\r\nimport { takeUntil, debounceTime, switchMap, filter, map } from 'rxjs/operators';\r\nimport dayjs from 'dayjs';\r\nimport { isObject } from '../../core/functions';\r\nimport { BizDoc } from '../../core/decorators';\r\nimport { GrantSettings, GuideStep, OutOfOfficeSettings, UserInfo } from '../../core/models';\r\nimport { UtilityRef } from '../utility-ref';\r\nimport { PromptService } from '../../core/prompt.service';\r\nimport { AccountService } from '../../core/account.service';\r\nimport { DocumentInfo } from '../../core/info/document-info.service';\r\nimport { SessionService } from '../../core/session.service';\r\nimport { GuideService } from '../../core/guide/guide.service';\r\nimport { TranslateService } from '../../core/translate.service';\r\nimport { FONT_FAMILY } from '../../core/colors';\r\nimport { PanesRouter } from '../../core/slots/router.service';\r\nimport { ChatInfo } from '../../chat/chat-info';\r\nimport { PaneRef } from '../../core/slots/pane-ref';\r\nimport { OpenPolicy } from '../../core/configuration';\r\nimport { ProfileSettingsDialog, OutOfOfficeData } from './outofoffice.component';\r\n\r\n@Component({\r\n  templateUrl: './profiler.component.html',\r\n  styleUrls: ['./profiler.component.scss'],\r\n  host: {\r\n    class: 'pane'\r\n  },\r\n})\r\n@BizDoc({ selector: 'bizdoc-user-profiler' })\r\n/** component*/\r\nexport class ProfilerComponent implements OnInit, OnDestroy {\r\n  readonly search = this._fb.control(null);\r\n  @ViewChild('activity') chart: ChartComponent;\r\n  @ViewChild('activity', { read: ElementRef }) chartElement: ElementRef;\r\n  @ViewChild('assignTpl') assignTpl: TemplateRef<any>;\r\n  readonly who = this._fb.control(null, Validators.required);\r\n  readonly primaryXAxis = {\r\n    valueType: 'DateTime',\r\n    labelFormat: 'MMM dd',\r\n    labelStyle: {\r\n      fontFamily: FONT_FAMILY\r\n    }\r\n  } as AxisModel;\r\n  readonly primaryYAxis = {\r\n    labelStyle: {\r\n      size: '0px'\r\n    },\r\n  } as AxisModel;\r\n  readonly zoomSettings: ZoomSettingsModel = {\r\n    enableMouseWheelZooming: true,\r\n    enablePinchZooming: true,\r\n    toolbarItems: [],\r\n    enableSelectionZooming: false,\r\n    enableScrollbar: true\r\n  };\r\n  readonly tooltip: TooltipSettingsModel = {\r\n    enable: true,\r\n    shared: true,\r\n    textStyle: {\r\n      fontFamily: FONT_FAMILY\r\n    }\r\n  };\r\n  readonly legend: LegendSeriesModel = {\r\n    visible: false,\r\n    textStyle: {\r\n      fontFamily: FONT_FAMILY\r\n    }\r\n  };\r\n  readonly border = { width: 0 } as BorderModel;\r\n  readonly marker: MarkerOptionsModel = {\r\n    visible: true,\r\n    width: 10,\r\n    height: 10\r\n  }\r\n  users$: Observable<UserInfo[]>;\r\n  assignable$: Observable<UserInfo[]>;\r\n  palettes: string[] = this._session.accentPalette;\r\n  theme: 'Material' | 'MaterialDark' = this._session.theme.dark ? 'MaterialDark' : 'Material';\r\n  data: ProfileInfo;\r\n  cols = 2;\r\n  private readonly _destroy = new Subject<void>();\r\n  readonly separatorKeysCodes: number[] = [ENTER, COMMA, SEMICOLON];\r\n  private _userId: string;\r\n  /** ctor */\r\n  constructor(private _sb: PromptService,\r\n    private _utilityRef: UtilityRef<boolean, ProfilerModel, ProfileInfo, string>,\r\n    private _session: SessionService,\r\n    private _dialog: MatDialog,\r\n    private _documentInfo: DocumentInfo,\r\n    private _chat: ChatInfo,\r\n    private _guide: GuideService,\r\n    private _router: PanesRouter,\r\n    private _cd: ChangeDetectorRef,\r\n    private _pane: PaneRef<ProfilerComponent>,\r\n    private _translate: TranslateService,\r\n    private _accounts: AccountService,\r\n    private _fb: FormBuilder) {\r\n    this.cols = 2;\r\n    _session.themeChange.pipe(takeUntil(this._destroy)).subscribe(t => {\r\n      this.theme = t.dark ? 'MaterialDark' : 'Material';\r\n      this.palettes = _session.accentPalette;\r\n    });\r\n  }\r\n  ngOnInit(): void {\r\n    this._pane.queryParamsChange().subscribe(p => {\r\n      const { userId } = p;\r\n      userId && this._open(userId);\r\n    });\r\n    this._pane.resized().pipe(takeUntil(this._destroy)).subscribe(() => this.chart?.chartResize());\r\n    this.users$ = this.search.valueChanges.pipe(takeUntil(this._destroy),\r\n      debounceTime(250),\r\n      filter(v => !isObject(v)),\r\n      switchMap(v => this._accounts.findAll(v)));\r\n  }\r\n  @HostListener('window:keydown.f1', ['$event'])\r\n  guide(evt?: Event | KeyboardEvent) {\r\n    const steps: GuideStep[] = [];\r\n    if (this.data) {\r\n      steps.push({\r\n        selector: '[data-help=settings]',\r\n        content: this._translate.get('OutOfOfficeHelp')\r\n      });\r\n      Object.keys(this.data.activity).length &&\r\n        steps.push({\r\n          selector: '[data-help=activity]',\r\n          content: this._translate.get('ActivityHelp')\r\n        });\r\n      this.data.pending.length &&\r\n        steps.push({\r\n          selector: '[data-help=pending]',\r\n          content: this._translate.get('PendingHelp')\r\n        });\r\n      this.data.positions.length &&\r\n        steps.push({\r\n          selector: '[data-help=positions]',\r\n          content: this._translate.get('PositionsHelp')\r\n        });\r\n      steps.push({\r\n        selector: '[data-help=reassign]',\r\n        content: this._translate.get('ReassignHelp')\r\n      });\r\n    }\r\n    else steps.push({\r\n      selector: '[data-help=search]',\r\n      position: 'Below',\r\n      content: this._translate.get('ProfilerSearchHelp')\r\n    });\r\n    this._guide.start({\r\n      name: 'profiler',\r\n      steps\r\n    });\r\n    evt && evt.preventDefault();\r\n  }\r\n  change(evt: MatAutocompleteSelectedEvent) {\r\n    const { id: userId } = evt.option.value;\r\n    this._router.navigate([], { queryParams: { userId } });\r\n  }\r\n  /**\r\n   * \r\n   * @param userId\r\n   */\r\n  private _open(userId: string) {\r\n    this._userId = userId;\r\n    this._utilityRef.populate(userId).subscribe({\r\n      next: e => {\r\n        this.data = e;\r\n        this.search.reset(null, { emitEvent: false });\r\n        this._cd.detectChanges();\r\n        while (this.chart.series.length)\r\n          this.chart?.removeSeries(0);\r\n        this.chart?.addSeries(this._series());\r\n      }, error: () => this._sb.error()\r\n    });\r\n  }\r\n  /** */\r\n  private _series(): SeriesModel[] {\r\n    return Object.keys(this.data.activity).map(a => {\r\n      const log = this.data.activity[a];\r\n      return {\r\n        type: 'Scatter',\r\n        name: this._actionName(a),\r\n        xName: 'time',\r\n        yName: 'duration',\r\n        dataSource: log.map(l => {\r\n          return {\r\n            id: l.id,\r\n            time: new Date(l.time),\r\n            duration: l.duration\r\n          };\r\n        })\r\n      };\r\n    });\r\n  }\r\n\r\n  private _actionName(name: string): string {\r\n    const action = this._session.profile.actions.find(a => a.name === name);\r\n    return action ? action.past || action.title : name;\r\n  }\r\n  pointClick(evt: IPointEventArgs) {\r\n    const { id } = evt.series.dataSource[evt.pointIndex];\r\n    this._documentInfo.open(id);\r\n  }\r\n  userDisplay(item: UserInfo) {\r\n    return item ? item.name : null;\r\n  }\r\n  trace(id: number) {\r\n    this._router.navigate(['admin', 'tools', 'document-trace'], {\r\n      queryParams: { documentId: id.encodeId() },\r\n      policy: OpenPolicy.Defer | OpenPolicy.Pinnable\r\n    });\r\n  }\r\n  chat() {\r\n    this._chat.open(this._userId);\r\n  }\r\n  reassign(position?: PositionInfo) {\r\n    this.assignable$ = this._accounts.findAll().pipe(map(u => u.filter(u => u.id !== this._userId)));\r\n    this._dialog.open(this.assignTpl, {}).afterClosed().\r\n      subscribe(u =>\r\n        u && this._reassign(u, position)\r\n      );\r\n  }\r\n  settings() {\r\n    this._dialog.open(ProfileSettingsDialog, {\r\n      closeOnNavigation: true,\r\n      data: {\r\n        userId: this._userId,\r\n        grantAccess: this.data.grantAccess,\r\n        outOfOffice: this.data.outOfOffice\r\n      } as OutOfOfficeData\r\n    }).afterClosed().\r\n      subscribe(v =>\r\n        v && this._utilityRef.execute({\r\n          outOfOffice: v.outOfOffice,\r\n          grantAccess: v.grantAccess,\r\n          userId: this._userId\r\n        }).subscribe({\r\n          next: () => {\r\n            Object.assign(this.data, v);\r\n            this._sb.toast('ChangesSaved');\r\n          }, error: () =>\r\n            this._sb.error()\r\n        }));\r\n  }\r\n  /** */\r\n  private _reassign(who: string, position?: PositionInfo) {\r\n    this._utilityRef.execute({ reassign: { who, ...position }, userId: this._userId }).subscribe({\r\n      next: () => {\r\n        this._sb.toast('Assigned');\r\n        if (position)\r\n          this.data.positions.remove(position);\r\n        else\r\n          this.data.positions = [];\r\n      }, error: () =>\r\n        this._sb.error()\r\n    });\r\n  }\r\n  tooltipRender(e: ITooltipRenderEventArgs) {\r\n    e.text = `${dayjs.duration(e.point.y as number, 's').humanize()}`;\r\n  }\r\n  ngOnDestroy(): void {\r\n    this._destroy.next();\r\n    this._destroy.complete();\r\n  }\r\n}\r\n\r\ninterface ProfileInfo {\r\n  outOfOffice: OutOfOfficeSettings;\r\n  grantAccess: GrantSettings;\r\n  positions: PositionInfo[];\r\n  activity: {\r\n    [action: string]: {\r\n      id: number;\r\n      /** seconds */\r\n      duration: number;\r\n      number: string;\r\n      time: Date;\r\n    }[]\r\n  };\r\n  pending: {\r\n    id: number;\r\n    received: Date;\r\n    number: string;\r\n  }[];\r\n  info: UserInfo;\r\n}\r\ninterface PositionInfo {\r\n  type: string;\r\n  key: string;\r\n  value: string;\r\n  role: string;\r\n}\r\ninterface ProfilerModel {\r\n  outOfOffice?: OutOfOfficeSettings;\r\n  grantAccess?: GrantSettings;\r\n  userId: string;\r\n  reassign?: {\r\n    who: string;\r\n    role?: string;\r\n    key?: any;\r\n  }\r\n}\r\n\r\n","<mat-toolbar>\n  <mat-form-field subscriptSizing=\"dynamic\">\n    <input matInput type=\"search\" [matAutocomplete]=\"auto\" [formControl]=\"search\" data-help=\"search\" width=\"20\" />\n    <mat-autocomplete #auto=\"matAutocomplete\" [displayWith]=\"userDisplay\"\n      (optionSelected)=\"change($event)\">\n      @for (u of users$ | async; track u) {\n        <mat-option [value]=\"u\">\n          <span>{{u.name}}</span>\n        </mat-option>\n      }\n    </mat-autocomplete>\n    <mat-icon (click)=\"null\" class=\"mat-icon-rtl-mirror\" matSuffix>search</mat-icon>\n  </mat-form-field>\n  <span class=\"divider\"></span>\n  <button mat-icon-button (click)=\"guide()\" [bizdocTooltip]=\"'Help' | translate\"><mat-icon>help_outline</mat-icon></button>\n</mat-toolbar>\n@if (data) {\n  <div class=\"row wrap\">\n    <!-- info -->\n    <mat-card class=\"flex\">\n      <mat-card-header>\n        <mat-card-title>\n          <span>{{data.info.name}}</span>\n        </mat-card-title>\n      </mat-card-header>\n      <mat-card-content>\n        <br />\n      </mat-card-content>\n      <mat-card-actions>\n        <button mat-icon-button (click)=\"chat()\" [bizdocTooltip]=\"'Chat' | translate\" [disabled]=\"!data\"><mat-icon>chat</mat-icon></button>\n        <span class=\"divider\"></span>\n        <button mat-icon-button (click)=\"settings()\" [bizdocTooltip]=\"'Settings' | translate\" [disabled]=\"!data\" data-help=\"settings\"><mat-icon>settings</mat-icon></button>\n      </mat-card-actions>\n    </mat-card>\n    <mat-card class=\"flex\" data-help=\"activity\">\n      <mat-card-header>\n        <mat-card-title>\n          {{'Activity' | translate}}\n        </mat-card-title>\n      </mat-card-header>\n      <mat-card-content>\n        <ejs-chart #activity [primaryXAxis]=\"primaryXAxis\" [primaryYAxis]=\"primaryYAxis\" [zoomSettings]=\"zoomSettings\" [tooltip]='tooltip' (tooltipRender)=\"tooltipRender($event)\" [palettes]=\"palettes\" background=\"transparent\" [theme]='theme' [border]=\"border\" (pointClick)=\"pointClick($event)\">\n          <e-series-collection>\n          </e-series-collection>\n        </ejs-chart>\n      </mat-card-content>\n    </mat-card>\n    <!-- pending -->\n    <mat-card class=\"flex\" data-help=\"pending\">\n      <mat-card-header>\n        <mat-card-title>\n          {{'Pending' | translate}}\n        </mat-card-title>\n      </mat-card-header>\n      <mat-card-content>\n        @if (data.pending.length) {\n          <table class=\"mat-mdc-table\">\n            <thead>\n              <tr class=\"mat-mdc-row\">\n                <td class=\"mat-mdc-header-cell\"></td>\n                <td class=\"mat-mdc-header-cell\"></td>\n              </tr>\n            </thead>\n            <tbody role=\"rowgroup\">\n              @for (r of data.pending; track r) {\n                <tr class=\"mat-mdc-row\">\n                  <td class=\"mat-mdc-cell\"><a (click)=\"trace(r.id)\">{{r.number}}</a></td>\n                  <td class=\"mat-mdc-cell\">{{ r.received | amDifference : null : 's' | amDuration : 's'}}</td>\n                </tr>\n              }\n            </tbody>\n          </table>\n        } @else {\n          <span class=\"mat-body-2\">{{'None' | translate }}</span>\n        }\n      </mat-card-content>\n    </mat-card>\n    <!-- positions -->\n    <mat-card class=\"flex\" data-help=\"positions\">\n      <mat-card-header>\n        <mat-card-title>\n          {{'Positions' | translate}}\n        </mat-card-title>\n      </mat-card-header>\n      <mat-card-content>\n        @if (data.positions.length) {\n          <table class=\"mat-mdc-table\">\n            @for (p of data.positions; track p) {\n              <tr class=\"mat-mdc-row\">\n                <td class=\"mat-mdc-cell\">{{p.value }}</td>\n                <td class=\"mat-mdc-cell\">{{p.role | role}}</td>\n                <td class=\"mat-mdc-cell\">\n                  <button mat-icon-button (click)=\"reassign(p)\" [bizdocTooltip]=\"'Reassign' | translate\"><mat-icon>swap_horiz</mat-icon></button>\n                </td>\n              </tr>\n            }\n          </table>\n        } @else {\n          <span class=\"mat-body-2\">{{'None' | translate }}</span>\n        }\n      </mat-card-content>\n      <mat-card-actions>\n        <span class=\"divider\"></span>\n        <button mat-icon-button (click)=\"reassign()\" [bizdocTooltip]=\"'ReassignAll' | translate\" [disabled]=\"!data || !data.positions.length\" data-help=\"reassign\"><mat-icon>swap_horiz</mat-icon></button>\n      </mat-card-actions>\n    </mat-card>\n  </div>\n}\n<!-- assign dialog -->\n<ng-template #assignTpl>\n  <h2 mat-dialog-title>{{'Reassign' | translate }}</h2>\n  <mat-dialog-content>\n    <form autocomplete=\"off\" class=\"column\">\n      <mat-form-field>\n        <mat-select placeholder=\"{{'Who' | translate}}\" [formControl]=\"who\" required>\n          @for (u of assignable$ | async; track u) {\n            <mat-option [value]=\"u.id\">{{u.name}}</mat-option>\n          }\n        </mat-select>\n      </mat-form-field>\n    </form>\n  </mat-dialog-content>\n  <mat-dialog-actions>\n    <button mat-button [mat-dialog-close]=\"who.value\" color=\"primary\" [disabled]=\"!who.valid\">{{'OK' | translate}}</button>\n    <button mat-button mat-dialog-close>{{'Cancel' | translate}}</button>\n  </mat-dialog-actions>\n</ng-template>\n"]}
|
286
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"profiler.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/admin/profiler/profiler.component.ts","../../../../../../libraries/core/src/lib/admin/profiler/profiler.component.html"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAE,SAAS,EAAkC,UAAU,EAAE,YAAY,EAAqB,MAAM,eAAe,CAAC;AAClI,OAAO,EAAe,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAGzD,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAEhE,OAAO,EAAE,OAAO,EAAc,MAAM,MAAM,CAAC;AAC3C,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,SAAS,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACjF,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAChD,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAS/C,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAIhD,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AACtD,OAAO,EAAE,qBAAqB,EAAmB,MAAM,yBAAyB,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAW1E,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;IAqD5B,WAAW;IACX,YAAoB,GAAkB,EAC5B,WAAoE,EACpE,QAAwB,EACxB,OAAkB,EAClB,aAA2B,EAC3B,KAAe,EACf,MAAoB,EACpB,OAAoB,EACpB,GAAsB,EACtB,KAAiC,EACjC,UAA4B,EAC5B,SAAyB,EACzB,GAAgB;QAZN,QAAG,GAAH,GAAG,CAAe;QAC5B,gBAAW,GAAX,WAAW,CAAyD;QACpE,aAAQ,GAAR,QAAQ,CAAgB;QACxB,YAAO,GAAP,OAAO,CAAW;QAClB,kBAAa,GAAb,aAAa,CAAc;QAC3B,UAAK,GAAL,KAAK,CAAU;QACf,WAAM,GAAN,MAAM,CAAc;QACpB,YAAO,GAAP,OAAO,CAAa;QACpB,QAAG,GAAH,GAAG,CAAmB;QACtB,UAAK,GAAL,KAAK,CAA4B;QACjC,eAAU,GAAV,UAAU,CAAkB;QAC5B,cAAS,GAAT,SAAS,CAAgB;QACzB,QAAG,GAAH,GAAG,CAAa;QAjEjB,WAAM,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAIhC,QAAG,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,EAAE,UAAU,CAAC,QAAQ,CAAC,CAAC;QAClD,iBAAY,GAAG;YACtB,SAAS,EAAE,UAAU;YACrB,WAAW,EAAE,QAAQ;YACrB,UAAU,EAAE;gBACV,UAAU,EAAE,WAAW;aACxB;SACW,CAAC;QACN,iBAAY,GAAG;YACtB,UAAU,EAAE;gBACV,IAAI,EAAE,KAAK;aACZ;SACW,CAAC;QACN,iBAAY,GAAsB;YACzC,uBAAuB,EAAE,IAAI;YAC7B,kBAAkB,EAAE,IAAI;YACxB,YAAY,EAAE,EAAE;YAChB,sBAAsB,EAAE,KAAK;YAC7B,eAAe,EAAE,IAAI;SACtB,CAAC;QACO,YAAO,GAAyB;YACvC,MAAM,EAAE,IAAI;YACZ,MAAM,EAAE,IAAI;YACZ,SAAS,EAAE;gBACT,UAAU,EAAE,WAAW;aACxB;SACF,CAAC;QACO,WAAM,GAAsB;YACnC,OAAO,EAAE,KAAK;YACd,SAAS,EAAE;gBACT,UAAU,EAAE,WAAW;aACxB;SACF,CAAC;QACO,WAAM,GAAG,EAAE,KAAK,EAAE,CAAC,EAAiB,CAAC;QACrC,WAAM,GAAuB;YACpC,OAAO,EAAE,IAAI;YACb,KAAK,EAAE,EAAE;YACT,MAAM,EAAE,EAAE;SACX,CAAA;QAGD,aAAQ,GAAa,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC;QACjD,UAAK,GAAkC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,WAAW,CAAC;QAEhG,SAAI,GAAG,CAAC,CAAC;QACQ,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;QACvC,uBAAkB,GAAa,CAAC,KAAK,EAAE,KAAK,EAAE,SAAS,CAAC,CAAC;QAgBhE,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;QACd,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;YAChE,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,WAAW,CAAC;YACpD,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,aAAa,CAAC;QACzC,CAAC,CAAC,CAAC;IACL,CAAC;IACD,QAAQ;QACN,IAAI,CAAC,KAAK,CAAC,iBAAiB,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;YAC3C,MAAM,EAAE,MAAM,EAAE,GAAG,CAAC,CAAC;YACrB,MAAM,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QAC/B,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,WAAW,EAAE,CAAC,CAAC;QAC/F,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,EAClE,YAAY,CAAC,GAAG,CAAC,EACjB,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EACzB,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC/C,CAAC;IAED,KAAK,CAAC,GAA2B;QAC/B,MAAM,KAAK,GAAgB,EAAE,CAAC;QAC9B,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;YACd,KAAK,CAAC,IAAI,CAAC;gBACT,QAAQ,EAAE,sBAAsB;gBAChC,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,iBAAiB,CAAC;aAChD,CAAC,CAAC;YACH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM;gBACpC,KAAK,CAAC,IAAI,CAAC;oBACT,QAAQ,EAAE,sBAAsB;oBAChC,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,cAAc,CAAC;iBAC7C,CAAC,CAAC;YACL,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM;gBACtB,KAAK,CAAC,IAAI,CAAC;oBACT,QAAQ,EAAE,qBAAqB;oBAC/B,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,aAAa,CAAC;iBAC5C,CAAC,CAAC;YACL,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM;gBACxB,KAAK,CAAC,IAAI,CAAC;oBACT,QAAQ,EAAE,uBAAuB;oBACjC,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,eAAe,CAAC;iBAC9C,CAAC,CAAC;YACL,KAAK,CAAC,IAAI,CAAC;gBACT,QAAQ,EAAE,sBAAsB;gBAChC,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,cAAc,CAAC;aAC7C,CAAC,CAAC;QACL,CAAC;;YACI,KAAK,CAAC,IAAI,CAAC;gBACd,QAAQ,EAAE,oBAAoB;gBAC9B,QAAQ,EAAE,OAAO;gBACjB,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,oBAAoB,CAAC;aACnD,CAAC,CAAC;QACH,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;YAChB,IAAI,EAAE,UAAU;YAChB,KAAK;SACN,CAAC,CAAC;QACH,GAAG,IAAI,GAAG,CAAC,cAAc,EAAE,CAAC;IAC9B,CAAC;IACD,MAAM,CAAC,GAAiC;QACtC,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,GAAG,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC;QACxC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,EAAE,EAAE,WAAW,EAAE,EAAE,MAAM,EAAE,EAAE,CAAC,CAAC;IACzD,CAAC;IACD;;;OAGG;IACK,KAAK,CAAC,MAAc;QAC1B,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC;QACtB,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC;YAC1C,IAAI,EAAE,CAAC,CAAC,EAAE;gBACR,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;gBACd,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;gBAC9C,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;gBACzB,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM;oBAC7B,IAAI,CAAC,KAAK,EAAE,YAAY,CAAC,CAAC,CAAC,CAAC;gBAC9B,IAAI,CAAC,KAAK,EAAE,SAAS,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;YACxC,CAAC,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE;SACjC,CAAC,CAAC;IACL,CAAC;IACD,MAAM;IACE,OAAO;QACb,OAAO,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;YAC7C,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;YAClC,OAAO;gBACL,IAAI,EAAE,SAAS;gBACf,IAAI,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC;gBACzB,KAAK,EAAE,MAAM;gBACb,KAAK,EAAE,UAAU;gBACjB,UAAU,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;oBACtB,OAAO;wBACL,EAAE,EAAE,CAAC,CAAC,EAAE;wBACR,IAAI,EAAE,IAAI,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;wBACtB,QAAQ,EAAE,CAAC,CAAC,QAAQ;qBACrB,CAAC;gBACJ,CAAC,CAAC;aACH,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,WAAW,CAAC,IAAY;QAC9B,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,CAAC;QACxE,OAAO,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,IAAI,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC;IACrD,CAAC;IACD,UAAU,CAAC,GAAoB;QAC7B,MAAM,EAAE,EAAE,EAAE,GAAG,GAAG,CAAC,MAAM,CAAC,UAAU,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QACrD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC9B,CAAC;IACD,WAAW,CAAC,IAAc;QACxB,OAAO,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;IACjC,CAAC;IACD,KAAK,CAAC,EAAU;QACd,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,OAAO,EAAE,OAAO,EAAE,gBAAgB,CAAC,EAAE;YAC1D,WAAW,EAAE,EAAE,UAAU,EAAE,EAAE,CAAC,QAAQ,EAAE,EAAE;YAC1C,MAAM,EAAE,UAAU,CAAC,KAAK,GAAG,UAAU,CAAC,QAAQ;SAC/C,CAAC,CAAC;IACL,CAAC;IACD,IAAI;QACF,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAChC,CAAC;IACD,QAAQ,CAAC,QAAuB;QAC9B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QACjG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,WAAW,EAAE;YACjD,SAAS,CAAC,CAAC,CAAC,EAAE,CACZ,CAAC,IAAI,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,QAAQ,CAAC,CACjC,CAAC;IACN,CAAC;IACD,QAAQ;QACN,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,qBAAqB,EAAE;YACvC,iBAAiB,EAAE,IAAI;YACvB,IAAI,EAAE;gBACJ,MAAM,EAAE,IAAI,CAAC,OAAO;gBACpB,WAAW,EAAE,IAAI,CAAC,IAAI,CAAC,WAAW;gBAClC,WAAW,EAAE,IAAI,CAAC,IAAI,CAAC,WAAW;aAChB;SACrB,CAAC,CAAC,WAAW,EAAE;YACd,SAAS,CAAC,CAAC,CAAC,EAAE,CACZ,CAAC,IAAI,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC;YAC5B,WAAW,EAAE,CAAC,CAAC,WAAW;YAC1B,WAAW,EAAE,CAAC,CAAC,WAAW;YAC1B,MAAM,EAAE,IAAI,CAAC,OAAO;SACrB,CAAC,CAAC,SAAS,CAAC;YACX,IAAI,EAAE,GAAG,EAAE;gBACT,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;gBAC5B,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC;YACjC,CAAC,EAAE,KAAK,EAAE,GAAG,EAAE,CACb,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE;SACnB,CAAC,CAAC,CAAC;IACV,CAAC;IACD,MAAM;IACE,SAAS,CAAC,GAAW,EAAE,QAAuB;QACpD,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,EAAE,QAAQ,EAAE,EAAE,GAAG,EAAE,GAAG,QAAQ,EAAE,EAAE,MAAM,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,SAAS,CAAC;YAC3F,IAAI,EAAE,GAAG,EAAE;gBACT,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;gBAC3B,IAAI,QAAQ;oBACV,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;;oBAErC,IAAI,CAAC,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;YAC7B,CAAC,EAAE,KAAK,EAAE,GAAG,EAAE,CACb,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE;SACnB,CAAC,CAAC;IACL,CAAC;IACD,aAAa,CAAC,CAA0B;QACtC,CAAC,CAAC,IAAI,GAAG,GAAG,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAW,EAAE,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC;IACpE,CAAC;IACD,WAAW;QACT,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;8GAxOU,iBAAiB;kGAAjB,iBAAiB,oTAGG,UAAU,sHCtC3C,mwKA+HA;;AD5Fa,iBAAiB;IAF7B,MAAM,CAAC,EAAE,QAAQ,EAAE,sBAAsB,EAAE,CAAC;IAC7C,eAAe;GACF,iBAAiB,CAyO7B;;2FAzOY,iBAAiB;kBAT7B,SAAS;2BAGF;wBACJ,KAAK,EAAE,MAAM;qBACd;sZAMsB,KAAK;sBAA3B,SAAS;uBAAC,UAAU;gBACwB,YAAY;sBAAxD,SAAS;uBAAC,UAAU,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE;gBACnB,SAAS;sBAAhC,SAAS;uBAAC,WAAW;gBAiFtB,KAAK;sBADJ,YAAY;uBAAC,mBAAmB,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import { Component, ViewChild, OnInit, OnDestroy, TemplateRef, ElementRef, HostListener, ChangeDetectorRef } from '@angular/core';\r\nimport { FormBuilder, Validators } from '@angular/forms';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { MatAutocompleteSelectedEvent } from '@angular/material/autocomplete';\r\nimport { COMMA, ENTER, SEMICOLON } from '@angular/cdk/keycodes';\r\nimport { AxisModel, BorderModel, ChartComponent, IPointEventArgs, ITooltipRenderEventArgs, LegendSeriesModel, MarkerOptionsModel, SeriesModel, TooltipSettingsModel, ZoomSettingsModel } from '@syncfusion/ej2-angular-charts';\r\nimport { Subject, Observable } from 'rxjs';\r\nimport { takeUntil, debounceTime, switchMap, filter, map } from 'rxjs/operators';\r\nimport dayjs from 'dayjs';\r\nimport { isObject } from '../../core/functions';\r\nimport { BizDoc } from '../../core/decorators';\r\nimport { GrantSettings, GuideStep, OutOfOfficeSettings, UserInfo } from '../../core/models';\r\nimport { UtilityRef } from '../utility-ref';\r\nimport { PromptService } from '../../core/prompt.service';\r\nimport { AccountService } from '../../core/account.service';\r\nimport { DocumentInfo } from '../../core/info/document-info.service';\r\nimport { SessionService } from '../../core/session.service';\r\nimport { GuideService } from '../../core/guide/guide.service';\r\nimport { TranslateService } from '../../core/translate.service';\r\nimport { FONT_FAMILY } from '../../core/colors';\r\nimport { PanesRouter } from '../../core/slots/router.service';\r\nimport { ChatInfo } from '../../chat/chat-info';\r\nimport { PaneRef } from '../../core/slots/pane-ref';\r\nimport { OpenPolicy } from '../../core/configuration';\r\nimport { ProfileSettingsDialog, OutOfOfficeData } from './outofoffice.component';\r\n\r\n@Component({\r\n  templateUrl: './profiler.component.html',\r\n  styleUrls: ['./profiler.component.scss'],\r\n  host: {\r\n    class: 'pane'\r\n  },\r\n})\r\n@BizDoc({ selector: 'bizdoc-user-profiler' })\r\n/** component*/\r\nexport class ProfilerComponent implements OnInit, OnDestroy {\r\n  readonly search = this._fb.control(null);\r\n  @ViewChild('activity') chart: ChartComponent;\r\n  @ViewChild('activity', { read: ElementRef }) chartElement: ElementRef;\r\n  @ViewChild('assignTpl') assignTpl: TemplateRef<any>;\r\n  readonly who = this._fb.control(null, Validators.required);\r\n  readonly primaryXAxis = {\r\n    valueType: 'DateTime',\r\n    labelFormat: 'MMM dd',\r\n    labelStyle: {\r\n      fontFamily: FONT_FAMILY\r\n    }\r\n  } as AxisModel;\r\n  readonly primaryYAxis = {\r\n    labelStyle: {\r\n      size: '0px'\r\n    },\r\n  } as AxisModel;\r\n  readonly zoomSettings: ZoomSettingsModel = {\r\n    enableMouseWheelZooming: true,\r\n    enablePinchZooming: true,\r\n    toolbarItems: [],\r\n    enableSelectionZooming: false,\r\n    enableScrollbar: true\r\n  };\r\n  readonly tooltip: TooltipSettingsModel = {\r\n    enable: true,\r\n    shared: true,\r\n    textStyle: {\r\n      fontFamily: FONT_FAMILY\r\n    }\r\n  };\r\n  readonly legend: LegendSeriesModel = {\r\n    visible: false,\r\n    textStyle: {\r\n      fontFamily: FONT_FAMILY\r\n    }\r\n  };\r\n  readonly border = { width: 0 } as BorderModel;\r\n  readonly marker: MarkerOptionsModel = {\r\n    visible: true,\r\n    width: 10,\r\n    height: 10\r\n  }\r\n  users$: Observable<UserInfo[]>;\r\n  assignable$: Observable<UserInfo[]>;\r\n  palettes: string[] = this._session.accentPalette;\r\n  theme: 'Material3' | 'Material3Dark' = this._session.theme.dark ? 'Material3Dark' : 'Material3';\r\n  data: ProfileInfo;\r\n  cols = 2;\r\n  private readonly _destroy = new Subject<void>();\r\n  readonly separatorKeysCodes: number[] = [ENTER, COMMA, SEMICOLON];\r\n  private _userId: string;\r\n  /** ctor */\r\n  constructor(private _sb: PromptService,\r\n    private _utilityRef: UtilityRef<boolean, ProfilerModel, ProfileInfo, string>,\r\n    private _session: SessionService,\r\n    private _dialog: MatDialog,\r\n    private _documentInfo: DocumentInfo,\r\n    private _chat: ChatInfo,\r\n    private _guide: GuideService,\r\n    private _router: PanesRouter,\r\n    private _cd: ChangeDetectorRef,\r\n    private _pane: PaneRef<ProfilerComponent>,\r\n    private _translate: TranslateService,\r\n    private _accounts: AccountService,\r\n    private _fb: FormBuilder) {\r\n    this.cols = 2;\r\n    _session.themeChange.pipe(takeUntil(this._destroy)).subscribe(t => {\r\n      this.theme = t.dark ? 'Material3Dark' : 'Material3';\r\n      this.palettes = _session.accentPalette;\r\n    });\r\n  }\r\n  ngOnInit(): void {\r\n    this._pane.queryParamsChange().subscribe(p => {\r\n      const { userId } = p;\r\n      userId && this._open(userId);\r\n    });\r\n    this._pane.resized().pipe(takeUntil(this._destroy)).subscribe(() => this.chart?.chartResize());\r\n    this.users$ = this.search.valueChanges.pipe(takeUntil(this._destroy),\r\n      debounceTime(250),\r\n      filter(v => !isObject(v)),\r\n      switchMap(v => this._accounts.findAll(v)));\r\n  }\r\n  @HostListener('window:keydown.f1', ['$event'])\r\n  guide(evt?: Event | KeyboardEvent) {\r\n    const steps: GuideStep[] = [];\r\n    if (this.data) {\r\n      steps.push({\r\n        selector: '[data-help=settings]',\r\n        content: this._translate.get('OutOfOfficeHelp')\r\n      });\r\n      Object.keys(this.data.activity).length &&\r\n        steps.push({\r\n          selector: '[data-help=activity]',\r\n          content: this._translate.get('ActivityHelp')\r\n        });\r\n      this.data.pending.length &&\r\n        steps.push({\r\n          selector: '[data-help=pending]',\r\n          content: this._translate.get('PendingHelp')\r\n        });\r\n      this.data.positions.length &&\r\n        steps.push({\r\n          selector: '[data-help=positions]',\r\n          content: this._translate.get('PositionsHelp')\r\n        });\r\n      steps.push({\r\n        selector: '[data-help=reassign]',\r\n        content: this._translate.get('ReassignHelp')\r\n      });\r\n    }\r\n    else steps.push({\r\n      selector: '[data-help=search]',\r\n      position: 'Below',\r\n      content: this._translate.get('ProfilerSearchHelp')\r\n    });\r\n    this._guide.start({\r\n      name: 'profiler',\r\n      steps\r\n    });\r\n    evt && evt.preventDefault();\r\n  }\r\n  change(evt: MatAutocompleteSelectedEvent) {\r\n    const { id: userId } = evt.option.value;\r\n    this._router.navigate([], { queryParams: { userId } });\r\n  }\r\n  /**\r\n   * \r\n   * @param userId\r\n   */\r\n  private _open(userId: string) {\r\n    this._userId = userId;\r\n    this._utilityRef.populate(userId).subscribe({\r\n      next: e => {\r\n        this.data = e;\r\n        this.search.reset(null, { emitEvent: false });\r\n        this._cd.detectChanges();\r\n        while (this.chart.series.length)\r\n          this.chart?.removeSeries(0);\r\n        this.chart?.addSeries(this._series());\r\n      }, error: () => this._sb.error()\r\n    });\r\n  }\r\n  /** */\r\n  private _series(): SeriesModel[] {\r\n    return Object.keys(this.data.activity).map(a => {\r\n      const log = this.data.activity[a];\r\n      return {\r\n        type: 'Scatter',\r\n        name: this._actionName(a),\r\n        xName: 'time',\r\n        yName: 'duration',\r\n        dataSource: log.map(l => {\r\n          return {\r\n            id: l.id,\r\n            time: new Date(l.time),\r\n            duration: l.duration\r\n          };\r\n        })\r\n      };\r\n    });\r\n  }\r\n\r\n  private _actionName(name: string): string {\r\n    const action = this._session.profile.actions.find(a => a.name === name);\r\n    return action ? action.past || action.title : name;\r\n  }\r\n  pointClick(evt: IPointEventArgs) {\r\n    const { id } = evt.series.dataSource[evt.pointIndex];\r\n    this._documentInfo.open(id);\r\n  }\r\n  userDisplay(item: UserInfo) {\r\n    return item ? item.name : null;\r\n  }\r\n  trace(id: number) {\r\n    this._router.navigate(['admin', 'tools', 'document-trace'], {\r\n      queryParams: { documentId: id.encodeId() },\r\n      policy: OpenPolicy.Defer | OpenPolicy.Pinnable\r\n    });\r\n  }\r\n  chat() {\r\n    this._chat.open(this._userId);\r\n  }\r\n  reassign(position?: PositionInfo) {\r\n    this.assignable$ = this._accounts.findAll().pipe(map(u => u.filter(u => u.id !== this._userId)));\r\n    this._dialog.open(this.assignTpl, {}).afterClosed().\r\n      subscribe(u =>\r\n        u && this._reassign(u, position)\r\n      );\r\n  }\r\n  settings() {\r\n    this._dialog.open(ProfileSettingsDialog, {\r\n      closeOnNavigation: true,\r\n      data: {\r\n        userId: this._userId,\r\n        grantAccess: this.data.grantAccess,\r\n        outOfOffice: this.data.outOfOffice\r\n      } as OutOfOfficeData\r\n    }).afterClosed().\r\n      subscribe(v =>\r\n        v && this._utilityRef.execute({\r\n          outOfOffice: v.outOfOffice,\r\n          grantAccess: v.grantAccess,\r\n          userId: this._userId\r\n        }).subscribe({\r\n          next: () => {\r\n            Object.assign(this.data, v);\r\n            this._sb.toast('ChangesSaved');\r\n          }, error: () =>\r\n            this._sb.error()\r\n        }));\r\n  }\r\n  /** */\r\n  private _reassign(who: string, position?: PositionInfo) {\r\n    this._utilityRef.execute({ reassign: { who, ...position }, userId: this._userId }).subscribe({\r\n      next: () => {\r\n        this._sb.toast('Assigned');\r\n        if (position)\r\n          this.data.positions.remove(position);\r\n        else\r\n          this.data.positions = [];\r\n      }, error: () =>\r\n        this._sb.error()\r\n    });\r\n  }\r\n  tooltipRender(e: ITooltipRenderEventArgs) {\r\n    e.text = `${dayjs.duration(e.point.y as number, 's').humanize()}`;\r\n  }\r\n  ngOnDestroy(): void {\r\n    this._destroy.next();\r\n    this._destroy.complete();\r\n  }\r\n}\r\n\r\ninterface ProfileInfo {\r\n  outOfOffice: OutOfOfficeSettings;\r\n  grantAccess: GrantSettings;\r\n  positions: PositionInfo[];\r\n  activity: {\r\n    [action: string]: {\r\n      id: number;\r\n      /** seconds */\r\n      duration: number;\r\n      number: string;\r\n      time: Date;\r\n    }[]\r\n  };\r\n  pending: {\r\n    id: number;\r\n    received: Date;\r\n    number: string;\r\n  }[];\r\n  info: UserInfo;\r\n}\r\ninterface PositionInfo {\r\n  type: string;\r\n  key: string;\r\n  value: string;\r\n  role: string;\r\n}\r\ninterface ProfilerModel {\r\n  outOfOffice?: OutOfOfficeSettings;\r\n  grantAccess?: GrantSettings;\r\n  userId: string;\r\n  reassign?: {\r\n    who: string;\r\n    role?: string;\r\n    key?: any;\r\n  }\r\n}\r\n\r\n","<mat-toolbar>\n  <mat-form-field subscriptSizing=\"dynamic\">\n    <input matInput type=\"search\" [matAutocomplete]=\"auto\" [formControl]=\"search\" data-help=\"search\" width=\"20\" />\n    <mat-autocomplete #auto=\"matAutocomplete\" [displayWith]=\"userDisplay\"\n      (optionSelected)=\"change($event)\">\n      @for (u of users$ | async; track u) {\n        <mat-option [value]=\"u\">\n          <span>{{u.name}}</span>\n        </mat-option>\n      }\n    </mat-autocomplete>\n    <mat-icon (click)=\"null\" class=\"mat-icon-rtl-mirror\" matSuffix>search</mat-icon>\n  </mat-form-field>\n  <span class=\"divider\"></span>\n  <button mat-icon-button (click)=\"guide()\" [bizdocTooltip]=\"'Help' | translate\"><mat-icon>help_outline</mat-icon></button>\n</mat-toolbar>\n@if (data) {\n  <div class=\"row wrap\">\n    <!-- info -->\n    <mat-card class=\"flex\">\n      <mat-card-header>\n        <mat-card-title>\n          <span>{{data.info.name}}</span>\n        </mat-card-title>\n      </mat-card-header>\n      <mat-card-content>\n        <br />\n      </mat-card-content>\n      <mat-card-actions>\n        <button mat-icon-button (click)=\"chat()\" [bizdocTooltip]=\"'Chat' | translate\" [disabled]=\"!data\"><mat-icon>chat</mat-icon></button>\n        <span class=\"divider\"></span>\n        <button mat-icon-button (click)=\"settings()\" [bizdocTooltip]=\"'Settings' | translate\" [disabled]=\"!data\" data-help=\"settings\"><mat-icon>settings</mat-icon></button>\n      </mat-card-actions>\n    </mat-card>\n    <mat-card class=\"flex\" data-help=\"activity\">\n      <mat-card-header>\n        <mat-card-title>\n          {{'Activity' | translate}}\n        </mat-card-title>\n      </mat-card-header>\n      <mat-card-content>\n        <ejs-chart #activity [primaryXAxis]=\"primaryXAxis\" [primaryYAxis]=\"primaryYAxis\" [zoomSettings]=\"zoomSettings\" [tooltip]='tooltip' (tooltipRender)=\"tooltipRender($event)\" [palettes]=\"palettes\" background=\"transparent\" [theme]='theme' [border]=\"border\" (pointClick)=\"pointClick($event)\">\n          <e-series-collection>\n          </e-series-collection>\n        </ejs-chart>\n      </mat-card-content>\n    </mat-card>\n    <!-- pending -->\n    <mat-card class=\"flex\" data-help=\"pending\">\n      <mat-card-header>\n        <mat-card-title>\n          {{'Pending' | translate}}\n        </mat-card-title>\n      </mat-card-header>\n      <mat-card-content>\n        @if (data.pending.length) {\n          <table class=\"mat-mdc-table\">\n            <thead>\n              <tr class=\"mat-mdc-row\">\n                <td class=\"mat-mdc-header-cell\"></td>\n                <td class=\"mat-mdc-header-cell\"></td>\n              </tr>\n            </thead>\n            <tbody role=\"rowgroup\">\n              @for (r of data.pending; track r) {\n                <tr class=\"mat-mdc-row\">\n                  <td class=\"mat-mdc-cell\"><a (click)=\"trace(r.id)\">{{r.number}}</a></td>\n                  <td class=\"mat-mdc-cell\">{{ r.received | amDifference : null : 's' | amDuration : 's'}}</td>\n                </tr>\n              }\n            </tbody>\n          </table>\n        } @else {\n          <span class=\"mat-body-2\">{{'None' | translate }}</span>\n        }\n      </mat-card-content>\n    </mat-card>\n    <!-- positions -->\n    <mat-card class=\"flex\" data-help=\"positions\">\n      <mat-card-header>\n        <mat-card-title>\n          {{'Positions' | translate}}\n        </mat-card-title>\n      </mat-card-header>\n      <mat-card-content>\n        @if (data.positions.length) {\n          <table class=\"mat-mdc-table\">\n            @for (p of data.positions; track p) {\n              <tr class=\"mat-mdc-row\">\n                <td class=\"mat-mdc-cell\">{{p.value }}</td>\n                <td class=\"mat-mdc-cell\">{{p.role | role}}</td>\n                <td class=\"mat-mdc-cell\">\n                  <button mat-icon-button (click)=\"reassign(p)\" [bizdocTooltip]=\"'Reassign' | translate\"><mat-icon>swap_horiz</mat-icon></button>\n                </td>\n              </tr>\n            }\n          </table>\n        } @else {\n          <span class=\"mat-body-2\">{{'None' | translate }}</span>\n        }\n      </mat-card-content>\n      <mat-card-actions>\n        <span class=\"divider\"></span>\n        <button mat-icon-button (click)=\"reassign()\" [bizdocTooltip]=\"'ReassignAll' | translate\" [disabled]=\"!data || !data.positions.length\" data-help=\"reassign\"><mat-icon>swap_horiz</mat-icon></button>\n      </mat-card-actions>\n    </mat-card>\n  </div>\n}\n<!-- assign dialog -->\n<ng-template #assignTpl>\n  <h2 mat-dialog-title>{{'Reassign' | translate }}</h2>\n  <mat-dialog-content>\n    <form autocomplete=\"off\" class=\"column\">\n      <mat-form-field>\n        <mat-select placeholder=\"{{'Who' | translate}}\" [formControl]=\"who\" required>\n          @for (u of assignable$ | async; track u) {\n            <mat-option [value]=\"u.id\">{{u.name}}</mat-option>\n          }\n        </mat-select>\n      </mat-form-field>\n    </form>\n  </mat-dialog-content>\n  <mat-dialog-actions>\n    <button mat-button [mat-dialog-close]=\"who.value\" color=\"primary\" [disabled]=\"!who.valid\">{{'OK' | translate}}</button>\n    <button mat-button mat-dialog-close>{{'Cancel' | translate}}</button>\n  </mat-dialog-actions>\n</ng-template>\n"]}
|
@@ -84,11 +84,11 @@ export class BrowseMobileComponent {
|
|
84
84
|
this._destroy.complete();
|
85
85
|
}
|
86
86
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: BrowseMobileComponent, deps: [{ token: i1.Router }, { token: i2.WindowTitleService }, { token: i3.SessionService }, { token: i1.ActivatedRoute }, { token: i4.Directionality }, { token: i5.MatDialog }], target: i0.ɵɵFactoryTarget.Component }); }
|
87
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.2", type: BrowseMobileComponent, selector: "ng-component", viewQueries: [{ propertyName: "items", first: true, predicate: BrowseItemsComponent, descendants: true, static: true }, { propertyName: "drawer", first: true, predicate: MatSidenav, descendants: true, static: true }], ngImport: i0, template: "<mat-toolbar class=\"nav-toolbar\">\n <button mat-icon-button (click)=\"items.refresh()\" [bizdocTooltip]=\"'Refresh' | translate\" [attr.aria-label]=\"'Refresh' | translate\"><mat-icon matAnimate=\"rotate\">autorenew</mat-icon></button>\n @if (items.isAllDraft()) {\n <button mat-icon-button (click)=\"items.discardAll()\" [bizdocTooltip]=\"'DiscardSelected' | translate : items.selection.selected.length\" [attr.aria-label]=\"'DiscardSelected' | translate : items.selection.selected.length\"><mat-icon>delete_sweep</mat-icon></button>\n <button mat-button color=\"primary\" class=\"hide-xs\" (click)=\"items.submitAll()\">{{'SubmitSelected' | translate : items.selection.selected.length }}</button>\n <!-- <span class=\"mat-body show-xs\">{{items.selection.selected.length}}</span>-->\n <button mat-icon-button color=\"primary\" (click)=\"items.submitAll()\" [bizdocTooltip]=\"'Submit' | translate\" [attr.aria-label]=\"'Submit' | translate\" class=\"show-xs\"><mat-icon class=\"mat-icon-rtl-mirror\">send</mat-icon></button>\n }\n @if (items.sharedActions.length === 1) {\n <button mat-button color=\"primary\" (click)=\"sendAll(items.sharedActions[0].name)\" [bizdocTooltip]=\"items.sharedActions[0].title\">@if (items.sharedActions[0].icon) {\n <mat-icon>{{items.sharedActions[0].icon}}</mat-icon>\n }{{'SendSelected' | translate : items.selection.selected.length}}</button>\n }\n @if (items.sharedActions.length > 1) {\n <button mat-button color=\"primary\" [matMenuTriggerFor]=\"action\" [bizdocTooltip]=\"'Send' | translate\" [attr.aria-label]=\"'Send' | translate\">\n {{'SendSelected'| translate : items.selection.selected.length }}\n </button>\n }\n <mat-menu #action>\n @for (a of items.sharedActions | sort : 'group'; track a; let i = $index) {\n @if (i > 0 && items.sharedActions[i-1].group !== a.group) {\n <mat-divider>\n </mat-divider>\n }\n <button mat-menu-item (click)=\"sendAll(a.name)\" [attr.aria-label]=\"a.title\">\n {{ a.title }}\n </button>\n }\n </mat-menu>\n <span class=\"divider\"></span>\n <button mat-icon-button class=\"hide-xs\" (click)=\"items.paginator.previousPage()\" [bizdocTooltip]=\"'PrevPage' | translate\" [attr.aria-label]=\"'PrevPage' | translate\" [disabled]=\"!items.paginator.hasPreviousPage()\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_left</mat-icon></button>\n <button mat-icon-button class=\"hide-xs\" (click)=\"items.paginator.nextPage()\" [bizdocTooltip]=\"'NextPage' | translate\" [attr.aria-label]=\"'NextPage' | translate\" [disabled]=\"!items.paginator.hasNextPage()\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_right</mat-icon></button>\n <button mat-icon-button (click)=\"drawer.toggle()\" [bizdocTooltip]=\"'Filter' | translate\" [attr.aria-label]=\"'Filter' | translate\"><mat-icon>filter_list</mat-icon></button>\n</mat-toolbar>\n<mat-sidenav-container class=\"page-container\" autosize>\n <mat-sidenav #drawer mode=\"over\" position=\"end\" [opened]=\"false\">\n @switch (mode) {\n @default {\n <bizdoc-browse-filter class=\"nav-filter\" [values]=filters (valuesChange)=\"filterChange($event)\" [folderId]=\"folderId\"></bizdoc-browse-filter>\n }\n }\n </mat-sidenav>\n <mat-sidenav-content>\n <bizdoc-browse-items [filters]=\"filters\" [folderId]=\"folderId\" [filterType]=\"filterType\" (open)=\"open($event)\" (view)=view($event) #items></bizdoc-browse-items>\n </mat-sidenav-content>\n</mat-sidenav-container>\n", styles: [".nav-filter{padding:8px;display:flex}\n"], dependencies: [{ kind: "component", type: i6.MatDivider, selector: "mat-divider", inputs: ["vertical", "inset"] }, { kind: "component", type: i7.MatSidenav, selector: "mat-sidenav", inputs: ["fixedInViewport", "fixedTopGap", "fixedBottomGap"], exportAs: ["matSidenav"] }, { kind: "component", type: i7.MatSidenavContainer, selector: "mat-sidenav-container", exportAs: ["matSidenavContainer"] }, { kind: "component", type: i7.MatSidenavContent, selector: "mat-sidenav-content" }, { kind: "component", type: i8.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { kind: "component", type: i9.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i9.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "component", type: i10.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i11.MatMenu, selector: "mat-menu", inputs: ["backdropClass", "aria-label", "aria-labelledby", "aria-describedby", "xPosition", "yPosition", "overlapTrigger", "hasBackdrop", "class", "classList"], outputs: ["closed", "close"], exportAs: ["matMenu"] }, { kind: "component", type: i11.MatMenuItem, selector: "[mat-menu-item]", inputs: ["role", "disabled", "disableRipple"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i11.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", inputs: ["mat-menu-trigger-for", "matMenuTriggerFor", "matMenuTriggerData", "matMenuTriggerRestoreFocus"], outputs: ["menuOpened", "onMenuOpen", "menuClosed", "onMenuClose"], exportAs: ["matMenuTrigger"] }, { kind: "component", type: i12.BrowseFilterComponent, selector: "bizdoc-browse-filter", inputs: ["values", "folderId", "exclude"], outputs: ["valuesChange"] }, { kind: "component", type: i13.BrowseItemsComponent, selector: "bizdoc-browse-items", inputs: ["folderId", "filterType", "filters"], outputs: ["open", "view"] }, { kind: "directive", type: i14.MatIconAnimate, selector: "[matAnimate]" }, { kind: "directive", type: i15.TooltipDirective, selector: "[bizdocTooltip]", inputs: ["bizdocTooltip", "bizdocTooltipTemplate", "bizdocTooltipContext", "bizdocTooltipPosition", "bizdocTooltipDuration", "bizdocTooltipDisabled"] }, { kind: "pipe", type: i16.ArraySortPipe, name: "sort" }, { kind: "pipe", type: i17.TranslatePipe, name: "translate" }] }); }
|
87
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.2", type: BrowseMobileComponent, selector: "ng-component", viewQueries: [{ propertyName: "items", first: true, predicate: BrowseItemsComponent, descendants: true, static: true }, { propertyName: "drawer", first: true, predicate: MatSidenav, descendants: true, static: true }], ngImport: i0, template: "<mat-toolbar class=\"nav-toolbar\">\n <button mat-icon-button (click)=\"items.refresh()\" [bizdocTooltip]=\"'Refresh' | translate\" [attr.aria-label]=\"'Refresh' | translate\"><mat-icon matAnimate=\"rotate\">autorenew</mat-icon></button>\n @if (items.isAllDraft()) {\n <button mat-icon-button (click)=\"items.discardAll()\" [bizdocTooltip]=\"'DiscardSelected' | translate : items.selection.selected.length\" [attr.aria-label]=\"'DiscardSelected' | translate : items.selection.selected.length\"><mat-icon>delete_sweep</mat-icon></button>\n <button mat-button color=\"primary\" class=\"hide-xs\" (click)=\"items.submitAll()\">{{'SubmitSelected' | translate : items.selection.selected.length }}</button>\n <!-- <span class=\"mat-body show-xs\">{{items.selection.selected.length}}</span>-->\n <button mat-icon-button color=\"primary\" (click)=\"items.submitAll()\" [bizdocTooltip]=\"'Submit' | translate\" [attr.aria-label]=\"'Submit' | translate\" class=\"show-xs\"><mat-icon class=\"mat-icon-rtl-mirror\">send</mat-icon></button>\n }\n @if (items.sharedActions.length === 1) {\n <button mat-button color=\"primary\" (click)=\"sendAll(items.sharedActions[0].name)\" [bizdocTooltip]=\"items.sharedActions[0].title\">@if (items.sharedActions[0].icon) {\n <mat-icon>{{items.sharedActions[0].icon}}</mat-icon>\n }{{'SendSelected' | translate : items.selection.selected.length}}</button>\n }\n @else if (items.sharedActions.length > 1) {\n <button mat-button color=\"primary\" [matMenuTriggerFor]=\"action\" [bizdocTooltip]=\"'Send' | translate\" [attr.aria-label]=\"'Send' | translate\">\n {{'SendSelected'| translate : items.selection.selected.length }}\n </button>\n }\n <mat-menu #action>\n @for (a of items.sharedActions | sort : 'group'; track a; let i = $index) {\n @if (i > 0 && items.sharedActions[i-1].group !== a.group) {\n <mat-divider>\n </mat-divider>\n }\n <button mat-menu-item (click)=\"sendAll(a.name)\" [attr.aria-label]=\"a.title\">\n {{ a.title }}\n </button>\n }\n </mat-menu>\n <span class=\"divider\"></span>\n <button mat-icon-button class=\"hide-xs\" (click)=\"items.paginator.previousPage()\" [bizdocTooltip]=\"'PrevPage' | translate\" [attr.aria-label]=\"'PrevPage' | translate\" [disabled]=\"!items.paginator.hasPreviousPage()\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_left</mat-icon></button>\n <button mat-icon-button class=\"hide-xs\" (click)=\"items.paginator.nextPage()\" [bizdocTooltip]=\"'NextPage' | translate\" [attr.aria-label]=\"'NextPage' | translate\" [disabled]=\"!items.paginator.hasNextPage()\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_right</mat-icon></button>\n <button mat-icon-button (click)=\"drawer.toggle()\" [bizdocTooltip]=\"'Filter' | translate\" [attr.aria-label]=\"'Filter' | translate\"><mat-icon>filter_list</mat-icon></button>\n</mat-toolbar>\n<mat-sidenav-container class=\"page-container\" autosize>\n <mat-sidenav #drawer mode=\"over\" position=\"end\" [opened]=\"false\">\n @switch (mode) {\n @default {\n <bizdoc-browse-filter class=\"nav-filter\" [values]=filters (valuesChange)=\"filterChange($event)\" [folderId]=\"folderId\"></bizdoc-browse-filter>\n }\n }\n </mat-sidenav>\n <mat-sidenav-content>\n <bizdoc-browse-items [filters]=\"filters\" [folderId]=\"folderId\" [filterType]=\"filterType\" (open)=\"open($event)\" (view)=view($event) #items></bizdoc-browse-items>\n </mat-sidenav-content>\n</mat-sidenav-container>\n", styles: [".nav-filter{padding:8px;display:flex}\n"], dependencies: [{ kind: "component", type: i6.MatDivider, selector: "mat-divider", inputs: ["vertical", "inset"] }, { kind: "component", type: i7.MatSidenav, selector: "mat-sidenav", inputs: ["fixedInViewport", "fixedTopGap", "fixedBottomGap"], exportAs: ["matSidenav"] }, { kind: "component", type: i7.MatSidenavContainer, selector: "mat-sidenav-container", exportAs: ["matSidenavContainer"] }, { kind: "component", type: i7.MatSidenavContent, selector: "mat-sidenav-content" }, { kind: "component", type: i8.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { kind: "component", type: i9.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i9.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "component", type: i10.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i11.MatMenu, selector: "mat-menu", inputs: ["backdropClass", "aria-label", "aria-labelledby", "aria-describedby", "xPosition", "yPosition", "overlapTrigger", "hasBackdrop", "class", "classList"], outputs: ["closed", "close"], exportAs: ["matMenu"] }, { kind: "component", type: i11.MatMenuItem, selector: "[mat-menu-item]", inputs: ["role", "disabled", "disableRipple"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i11.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", inputs: ["mat-menu-trigger-for", "matMenuTriggerFor", "matMenuTriggerData", "matMenuTriggerRestoreFocus"], outputs: ["menuOpened", "onMenuOpen", "menuClosed", "onMenuClose"], exportAs: ["matMenuTrigger"] }, { kind: "component", type: i12.BrowseFilterComponent, selector: "bizdoc-browse-filter", inputs: ["values", "folderId", "exclude"], outputs: ["valuesChange"] }, { kind: "component", type: i13.BrowseItemsComponent, selector: "bizdoc-browse-items", inputs: ["folderId", "filterType", "filters"], outputs: ["open", "view"] }, { kind: "directive", type: i14.MatIconAnimate, selector: "[matAnimate]" }, { kind: "directive", type: i15.TooltipDirective, selector: "[bizdocTooltip]", inputs: ["bizdocTooltip", "bizdocTooltipTemplate", "bizdocTooltipContext", "bizdocTooltipPosition", "bizdocTooltipDuration", "bizdocTooltipDisabled"] }, { kind: "pipe", type: i16.ArraySortPipe, name: "sort" }, { kind: "pipe", type: i17.TranslatePipe, name: "translate" }] }); }
|
88
88
|
}
|
89
89
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: BrowseMobileComponent, decorators: [{
|
90
90
|
type: Component,
|
91
|
-
args: [{ template: "<mat-toolbar class=\"nav-toolbar\">\n <button mat-icon-button (click)=\"items.refresh()\" [bizdocTooltip]=\"'Refresh' | translate\" [attr.aria-label]=\"'Refresh' | translate\"><mat-icon matAnimate=\"rotate\">autorenew</mat-icon></button>\n @if (items.isAllDraft()) {\n <button mat-icon-button (click)=\"items.discardAll()\" [bizdocTooltip]=\"'DiscardSelected' | translate : items.selection.selected.length\" [attr.aria-label]=\"'DiscardSelected' | translate : items.selection.selected.length\"><mat-icon>delete_sweep</mat-icon></button>\n <button mat-button color=\"primary\" class=\"hide-xs\" (click)=\"items.submitAll()\">{{'SubmitSelected' | translate : items.selection.selected.length }}</button>\n <!-- <span class=\"mat-body show-xs\">{{items.selection.selected.length}}</span>-->\n <button mat-icon-button color=\"primary\" (click)=\"items.submitAll()\" [bizdocTooltip]=\"'Submit' | translate\" [attr.aria-label]=\"'Submit' | translate\" class=\"show-xs\"><mat-icon class=\"mat-icon-rtl-mirror\">send</mat-icon></button>\n }\n @if (items.sharedActions.length === 1) {\n <button mat-button color=\"primary\" (click)=\"sendAll(items.sharedActions[0].name)\" [bizdocTooltip]=\"items.sharedActions[0].title\">@if (items.sharedActions[0].icon) {\n <mat-icon>{{items.sharedActions[0].icon}}</mat-icon>\n }{{'SendSelected' | translate : items.selection.selected.length}}</button>\n }\n @if (items.sharedActions.length > 1) {\n <button mat-button color=\"primary\" [matMenuTriggerFor]=\"action\" [bizdocTooltip]=\"'Send' | translate\" [attr.aria-label]=\"'Send' | translate\">\n {{'SendSelected'| translate : items.selection.selected.length }}\n </button>\n }\n <mat-menu #action>\n @for (a of items.sharedActions | sort : 'group'; track a; let i = $index) {\n @if (i > 0 && items.sharedActions[i-1].group !== a.group) {\n <mat-divider>\n </mat-divider>\n }\n <button mat-menu-item (click)=\"sendAll(a.name)\" [attr.aria-label]=\"a.title\">\n {{ a.title }}\n </button>\n }\n </mat-menu>\n <span class=\"divider\"></span>\n <button mat-icon-button class=\"hide-xs\" (click)=\"items.paginator.previousPage()\" [bizdocTooltip]=\"'PrevPage' | translate\" [attr.aria-label]=\"'PrevPage' | translate\" [disabled]=\"!items.paginator.hasPreviousPage()\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_left</mat-icon></button>\n <button mat-icon-button class=\"hide-xs\" (click)=\"items.paginator.nextPage()\" [bizdocTooltip]=\"'NextPage' | translate\" [attr.aria-label]=\"'NextPage' | translate\" [disabled]=\"!items.paginator.hasNextPage()\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_right</mat-icon></button>\n <button mat-icon-button (click)=\"drawer.toggle()\" [bizdocTooltip]=\"'Filter' | translate\" [attr.aria-label]=\"'Filter' | translate\"><mat-icon>filter_list</mat-icon></button>\n</mat-toolbar>\n<mat-sidenav-container class=\"page-container\" autosize>\n <mat-sidenav #drawer mode=\"over\" position=\"end\" [opened]=\"false\">\n @switch (mode) {\n @default {\n <bizdoc-browse-filter class=\"nav-filter\" [values]=filters (valuesChange)=\"filterChange($event)\" [folderId]=\"folderId\"></bizdoc-browse-filter>\n }\n }\n </mat-sidenav>\n <mat-sidenav-content>\n <bizdoc-browse-items [filters]=\"filters\" [folderId]=\"folderId\" [filterType]=\"filterType\" (open)=\"open($event)\" (view)=view($event) #items></bizdoc-browse-items>\n </mat-sidenav-content>\n</mat-sidenav-container>\n", styles: [".nav-filter{padding:8px;display:flex}\n"] }]
|
91
|
+
args: [{ template: "<mat-toolbar class=\"nav-toolbar\">\n <button mat-icon-button (click)=\"items.refresh()\" [bizdocTooltip]=\"'Refresh' | translate\" [attr.aria-label]=\"'Refresh' | translate\"><mat-icon matAnimate=\"rotate\">autorenew</mat-icon></button>\n @if (items.isAllDraft()) {\n <button mat-icon-button (click)=\"items.discardAll()\" [bizdocTooltip]=\"'DiscardSelected' | translate : items.selection.selected.length\" [attr.aria-label]=\"'DiscardSelected' | translate : items.selection.selected.length\"><mat-icon>delete_sweep</mat-icon></button>\n <button mat-button color=\"primary\" class=\"hide-xs\" (click)=\"items.submitAll()\">{{'SubmitSelected' | translate : items.selection.selected.length }}</button>\n <!-- <span class=\"mat-body show-xs\">{{items.selection.selected.length}}</span>-->\n <button mat-icon-button color=\"primary\" (click)=\"items.submitAll()\" [bizdocTooltip]=\"'Submit' | translate\" [attr.aria-label]=\"'Submit' | translate\" class=\"show-xs\"><mat-icon class=\"mat-icon-rtl-mirror\">send</mat-icon></button>\n }\n @if (items.sharedActions.length === 1) {\n <button mat-button color=\"primary\" (click)=\"sendAll(items.sharedActions[0].name)\" [bizdocTooltip]=\"items.sharedActions[0].title\">@if (items.sharedActions[0].icon) {\n <mat-icon>{{items.sharedActions[0].icon}}</mat-icon>\n }{{'SendSelected' | translate : items.selection.selected.length}}</button>\n }\n @else if (items.sharedActions.length > 1) {\n <button mat-button color=\"primary\" [matMenuTriggerFor]=\"action\" [bizdocTooltip]=\"'Send' | translate\" [attr.aria-label]=\"'Send' | translate\">\n {{'SendSelected'| translate : items.selection.selected.length }}\n </button>\n }\n <mat-menu #action>\n @for (a of items.sharedActions | sort : 'group'; track a; let i = $index) {\n @if (i > 0 && items.sharedActions[i-1].group !== a.group) {\n <mat-divider>\n </mat-divider>\n }\n <button mat-menu-item (click)=\"sendAll(a.name)\" [attr.aria-label]=\"a.title\">\n {{ a.title }}\n </button>\n }\n </mat-menu>\n <span class=\"divider\"></span>\n <button mat-icon-button class=\"hide-xs\" (click)=\"items.paginator.previousPage()\" [bizdocTooltip]=\"'PrevPage' | translate\" [attr.aria-label]=\"'PrevPage' | translate\" [disabled]=\"!items.paginator.hasPreviousPage()\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_left</mat-icon></button>\n <button mat-icon-button class=\"hide-xs\" (click)=\"items.paginator.nextPage()\" [bizdocTooltip]=\"'NextPage' | translate\" [attr.aria-label]=\"'NextPage' | translate\" [disabled]=\"!items.paginator.hasNextPage()\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_right</mat-icon></button>\n <button mat-icon-button (click)=\"drawer.toggle()\" [bizdocTooltip]=\"'Filter' | translate\" [attr.aria-label]=\"'Filter' | translate\"><mat-icon>filter_list</mat-icon></button>\n</mat-toolbar>\n<mat-sidenav-container class=\"page-container\" autosize>\n <mat-sidenav #drawer mode=\"over\" position=\"end\" [opened]=\"false\">\n @switch (mode) {\n @default {\n <bizdoc-browse-filter class=\"nav-filter\" [values]=filters (valuesChange)=\"filterChange($event)\" [folderId]=\"folderId\"></bizdoc-browse-filter>\n }\n }\n </mat-sidenav>\n <mat-sidenav-content>\n <bizdoc-browse-items [filters]=\"filters\" [folderId]=\"folderId\" [filterType]=\"filterType\" (open)=\"open($event)\" (view)=view($event) #items></bizdoc-browse-items>\n </mat-sidenav-content>\n</mat-sidenav-container>\n", styles: [".nav-filter{padding:8px;display:flex}\n"] }]
|
92
92
|
}], ctorParameters: () => [{ type: i1.Router }, { type: i2.WindowTitleService }, { type: i3.SessionService }, { type: i1.ActivatedRoute }, { type: i4.Directionality }, { type: i5.MatDialog }], propDecorators: { items: [{
|
93
93
|
type: ViewChild,
|
94
94
|
args: [BrowseItemsComponent, { static: true }]
|
@@ -96,4 +96,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
|
|
96
96
|
type: ViewChild,
|
97
97
|
args: [MatSidenav, { static: true }]
|
98
98
|
}] } });
|
99
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"browse.mobile.component.js","sourceRoot":"","sources":["../../../../../libraries/core/src/lib/browse/browse.mobile.component.ts","../../../../../libraries/core/src/lib/browse/browse.mobile.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, OnDestroy, ViewChild } from '@angular/core';\r\nimport { ActivatedRoute, Router } from '@angular/router';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { MatSidenav } from '@angular/material/sidenav';\r\nimport { Directionality } from '@angular/cdk/bidi';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { Folder, RecipientModel } from '../core/models';\r\nimport { WindowTitleService } from '../core/window-title.service';\r\nimport { ActionDialog, ActionDialogData } from '../compose/action/action.dialog';\r\nimport { BrowseFilterArgs } from './filter/filter.component';\r\nimport { BrowseItemsComponent } from './browse-items.component';\r\nimport { FilterType } from '../core/mailbox.service';\r\nimport { SessionService } from '../core/session.service';\r\n\r\n@Component({\r\n  templateUrl: './browse.mobile.component.html',\r\n  styleUrl: 'browse.mobile.component.scss'\r\n})\r\n/** browse component*/\r\nexport class BrowseMobileComponent implements OnInit, OnDestroy {\r\n  mode = 'filter';\r\n  pageSize: number;\r\n  @ViewChild(BrowseItemsComponent, { static: true }) items: BrowseItemsComponent;\r\n  @ViewChild(MatSidenav, { static: true }) drawer: MatSidenav;\r\n   folderId: string;\r\n  filterType: FilterType;\r\n  filters: BrowseFilterArgs;\r\n  private readonly _destroy = new Subject<void>();\r\n  /** browse ctor */\r\n  constructor(\r\n    private _router: Router,\r\n    private _title: WindowTitleService,\r\n    private _session: SessionService,\r\n    private _route: ActivatedRoute,\r\n    private _directionality: Directionality,\r\n    private _dialog: MatDialog) {\r\n  }\r\n  ngOnInit(): void {\r\n    this._route.params.pipe(takeUntil(this._destroy)).subscribe(p => {\r\n      this.folderId = p['id'];\r\n      this._title.set(this.folderId ? this.folder.title : null);\r\n    });\r\n    this._route.queryParams.pipe(takeUntil(this._destroy)).subscribe(p => {\r\n      this.filterType = p['type'];\r\n      this.filters = p;\r\n      Object.keys(p).length && this.drawer.open();\r\n    });\r\n  }\r\n  get folder(): Folder { return this._session.profile.folders.find(f => f.name === this.folderId); }\r\n  filterChange(filters: BrowseFilterArgs) {\r\n    this._router.navigate([], {\r\n      queryParams: filters\r\n    });\r\n  }\r\n  open(item: RecipientModel<any>) {\r\n    this._router.navigate(['mailbox/i', item.id.encodeId()],\r\n      {\r\n        state: {\r\n          item: { ...item }\r\n        }\r\n      });\r\n  }\r\n  view(item: RecipientModel<any>) {\r\n    this._router.navigate(['mailbox/i', item.id.encodeId(), 'views'],\r\n      {\r\n        state: {\r\n          item: { ...item }\r\n        }\r\n      })\r\n  }\r\n\r\n  sendAll(action: string) {\r\n    const { selected } = this.items.selection;\r\n    const data: ActionDialogData = {\r\n      action,\r\n      items: selected as RecipientModel[]\r\n    };\r\n    this._dialog.open(ActionDialog, {\r\n      data,\r\n      direction: this._directionality.value,\r\n      restoreFocus: false\r\n    }).afterClosed().subscribe(args =>\r\n      args &&\r\n      this.items.sendAll(action, args));\r\n  }\r\n  ngOnDestroy(): void {\r\n    this._destroy.next();\r\n    this._destroy.complete();\r\n  }\r\n}\r\n","<mat-toolbar class=\"nav-toolbar\">\n  <button mat-icon-button (click)=\"items.refresh()\" [bizdocTooltip]=\"'Refresh' | translate\" [attr.aria-label]=\"'Refresh' | translate\"><mat-icon matAnimate=\"rotate\">autorenew</mat-icon></button>\n  @if (items.isAllDraft()) {\n    <button mat-icon-button (click)=\"items.discardAll()\" [bizdocTooltip]=\"'DiscardSelected' | translate : items.selection.selected.length\" [attr.aria-label]=\"'DiscardSelected' | translate : items.selection.selected.length\"><mat-icon>delete_sweep</mat-icon></button>\n    <button mat-button color=\"primary\" class=\"hide-xs\" (click)=\"items.submitAll()\">{{'SubmitSelected' | translate : items.selection.selected.length }}</button>\n  <!--  <span class=\"mat-body show-xs\">{{items.selection.selected.length}}</span>-->\n    <button mat-icon-button color=\"primary\" (click)=\"items.submitAll()\" [bizdocTooltip]=\"'Submit' | translate\" [attr.aria-label]=\"'Submit' | translate\" class=\"show-xs\"><mat-icon class=\"mat-icon-rtl-mirror\">send</mat-icon></button>\n  }\n  @if (items.sharedActions.length === 1) {\n    <button mat-button color=\"primary\" (click)=\"sendAll(items.sharedActions[0].name)\" [bizdocTooltip]=\"items.sharedActions[0].title\">@if (items.sharedActions[0].icon) {\n      <mat-icon>{{items.sharedActions[0].icon}}</mat-icon>\n    }{{'SendSelected' | translate : items.selection.selected.length}}</button>\n  }\n  @if (items.sharedActions.length > 1) {\n    <button mat-button color=\"primary\" [matMenuTriggerFor]=\"action\" [bizdocTooltip]=\"'Send' | translate\" [attr.aria-label]=\"'Send' | translate\">\n      {{'SendSelected'| translate : items.selection.selected.length }}\n    </button>\n  }\n  <mat-menu #action>\n    @for (a of items.sharedActions | sort : 'group'; track a; let i = $index) {\n      @if (i > 0 && items.sharedActions[i-1].group !== a.group) {\n        <mat-divider>\n        </mat-divider>\n      }\n      <button mat-menu-item (click)=\"sendAll(a.name)\" [attr.aria-label]=\"a.title\">\n        {{ a.title }}\n      </button>\n    }\n  </mat-menu>\n  <span class=\"divider\"></span>\n  <button mat-icon-button class=\"hide-xs\" (click)=\"items.paginator.previousPage()\" [bizdocTooltip]=\"'PrevPage' | translate\" [attr.aria-label]=\"'PrevPage' | translate\" [disabled]=\"!items.paginator.hasPreviousPage()\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_left</mat-icon></button>\n  <button mat-icon-button class=\"hide-xs\" (click)=\"items.paginator.nextPage()\" [bizdocTooltip]=\"'NextPage' | translate\" [attr.aria-label]=\"'NextPage' | translate\" [disabled]=\"!items.paginator.hasNextPage()\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_right</mat-icon></button>\n  <button mat-icon-button (click)=\"drawer.toggle()\" [bizdocTooltip]=\"'Filter' | translate\" [attr.aria-label]=\"'Filter' | translate\"><mat-icon>filter_list</mat-icon></button>\n</mat-toolbar>\n<mat-sidenav-container class=\"page-container\" autosize>\n  <mat-sidenav #drawer mode=\"over\" position=\"end\" [opened]=\"false\">\n    @switch (mode) {\n      @default {\n        <bizdoc-browse-filter class=\"nav-filter\" [values]=filters (valuesChange)=\"filterChange($event)\" [folderId]=\"folderId\"></bizdoc-browse-filter>\n      }\n    }\n  </mat-sidenav>\n  <mat-sidenav-content>\n    <bizdoc-browse-items [filters]=\"filters\" [folderId]=\"folderId\" [filterType]=\"filterType\" (open)=\"open($event)\" (view)=view($event) #items></bizdoc-browse-items>\n  </mat-sidenav-content>\n</mat-sidenav-container>\n"]}
|
99
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"browse.mobile.component.js","sourceRoot":"","sources":["../../../../../libraries/core/src/lib/browse/browse.mobile.component.ts","../../../../../libraries/core/src/lib/browse/browse.mobile.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, OnDestroy, ViewChild } from '@angular/core';\r\nimport { ActivatedRoute, Router } from '@angular/router';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { MatSidenav } from '@angular/material/sidenav';\r\nimport { Directionality } from '@angular/cdk/bidi';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { Folder, RecipientModel } from '../core/models';\r\nimport { WindowTitleService } from '../core/window-title.service';\r\nimport { ActionDialog, ActionDialogData } from '../compose/action/action.dialog';\r\nimport { BrowseFilterArgs } from './filter/filter.component';\r\nimport { BrowseItemsComponent } from './browse-items.component';\r\nimport { FilterType } from '../core/mailbox.service';\r\nimport { SessionService } from '../core/session.service';\r\n\r\n@Component({\r\n  templateUrl: './browse.mobile.component.html',\r\n  styleUrl: 'browse.mobile.component.scss'\r\n})\r\n/** browse component*/\r\nexport class BrowseMobileComponent implements OnInit, OnDestroy {\r\n  mode = 'filter';\r\n  pageSize: number;\r\n  @ViewChild(BrowseItemsComponent, { static: true }) items: BrowseItemsComponent;\r\n  @ViewChild(MatSidenav, { static: true }) drawer: MatSidenav;\r\n   folderId: string;\r\n  filterType: FilterType;\r\n  filters: BrowseFilterArgs;\r\n  private readonly _destroy = new Subject<void>();\r\n  /** browse ctor */\r\n  constructor(\r\n    private _router: Router,\r\n    private _title: WindowTitleService,\r\n    private _session: SessionService,\r\n    private _route: ActivatedRoute,\r\n    private _directionality: Directionality,\r\n    private _dialog: MatDialog) {\r\n  }\r\n  ngOnInit(): void {\r\n    this._route.params.pipe(takeUntil(this._destroy)).subscribe(p => {\r\n      this.folderId = p['id'];\r\n      this._title.set(this.folderId ? this.folder.title : null);\r\n    });\r\n    this._route.queryParams.pipe(takeUntil(this._destroy)).subscribe(p => {\r\n      this.filterType = p['type'];\r\n      this.filters = p;\r\n      Object.keys(p).length && this.drawer.open();\r\n    });\r\n  }\r\n  get folder(): Folder { return this._session.profile.folders.find(f => f.name === this.folderId); }\r\n  filterChange(filters: BrowseFilterArgs) {\r\n    this._router.navigate([], {\r\n      queryParams: filters\r\n    });\r\n  }\r\n  open(item: RecipientModel<any>) {\r\n    this._router.navigate(['mailbox/i', item.id.encodeId()],\r\n      {\r\n        state: {\r\n          item: { ...item }\r\n        }\r\n      });\r\n  }\r\n  view(item: RecipientModel<any>) {\r\n    this._router.navigate(['mailbox/i', item.id.encodeId(), 'views'],\r\n      {\r\n        state: {\r\n          item: { ...item }\r\n        }\r\n      })\r\n  }\r\n\r\n  sendAll(action: string) {\r\n    const { selected } = this.items.selection;\r\n    const data: ActionDialogData = {\r\n      action,\r\n      items: selected as RecipientModel[]\r\n    };\r\n    this._dialog.open(ActionDialog, {\r\n      data,\r\n      direction: this._directionality.value,\r\n      restoreFocus: false\r\n    }).afterClosed().subscribe(args =>\r\n      args &&\r\n      this.items.sendAll(action, args));\r\n  }\r\n  ngOnDestroy(): void {\r\n    this._destroy.next();\r\n    this._destroy.complete();\r\n  }\r\n}\r\n","<mat-toolbar class=\"nav-toolbar\">\n  <button mat-icon-button (click)=\"items.refresh()\" [bizdocTooltip]=\"'Refresh' | translate\" [attr.aria-label]=\"'Refresh' | translate\"><mat-icon matAnimate=\"rotate\">autorenew</mat-icon></button>\n  @if (items.isAllDraft()) {\n    <button mat-icon-button (click)=\"items.discardAll()\" [bizdocTooltip]=\"'DiscardSelected' | translate : items.selection.selected.length\" [attr.aria-label]=\"'DiscardSelected' | translate : items.selection.selected.length\"><mat-icon>delete_sweep</mat-icon></button>\n    <button mat-button color=\"primary\" class=\"hide-xs\" (click)=\"items.submitAll()\">{{'SubmitSelected' | translate : items.selection.selected.length }}</button>\n  <!--  <span class=\"mat-body show-xs\">{{items.selection.selected.length}}</span>-->\n    <button mat-icon-button color=\"primary\" (click)=\"items.submitAll()\" [bizdocTooltip]=\"'Submit' | translate\" [attr.aria-label]=\"'Submit' | translate\" class=\"show-xs\"><mat-icon class=\"mat-icon-rtl-mirror\">send</mat-icon></button>\n  }\n  @if (items.sharedActions.length === 1) {\n    <button mat-button color=\"primary\" (click)=\"sendAll(items.sharedActions[0].name)\" [bizdocTooltip]=\"items.sharedActions[0].title\">@if (items.sharedActions[0].icon) {\n      <mat-icon>{{items.sharedActions[0].icon}}</mat-icon>\n    }{{'SendSelected' | translate : items.selection.selected.length}}</button>\n  }\n  @else if (items.sharedActions.length > 1) {\n    <button mat-button color=\"primary\" [matMenuTriggerFor]=\"action\" [bizdocTooltip]=\"'Send' | translate\" [attr.aria-label]=\"'Send' | translate\">\n      {{'SendSelected'| translate : items.selection.selected.length }}\n    </button>\n  }\n  <mat-menu #action>\n    @for (a of items.sharedActions | sort : 'group'; track a; let i = $index) {\n      @if (i > 0 && items.sharedActions[i-1].group !== a.group) {\n        <mat-divider>\n        </mat-divider>\n      }\n      <button mat-menu-item (click)=\"sendAll(a.name)\" [attr.aria-label]=\"a.title\">\n        {{ a.title }}\n      </button>\n    }\n  </mat-menu>\n  <span class=\"divider\"></span>\n  <button mat-icon-button class=\"hide-xs\" (click)=\"items.paginator.previousPage()\" [bizdocTooltip]=\"'PrevPage' | translate\" [attr.aria-label]=\"'PrevPage' | translate\" [disabled]=\"!items.paginator.hasPreviousPage()\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_left</mat-icon></button>\n  <button mat-icon-button class=\"hide-xs\" (click)=\"items.paginator.nextPage()\" [bizdocTooltip]=\"'NextPage' | translate\" [attr.aria-label]=\"'NextPage' | translate\" [disabled]=\"!items.paginator.hasNextPage()\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_right</mat-icon></button>\n  <button mat-icon-button (click)=\"drawer.toggle()\" [bizdocTooltip]=\"'Filter' | translate\" [attr.aria-label]=\"'Filter' | translate\"><mat-icon>filter_list</mat-icon></button>\n</mat-toolbar>\n<mat-sidenav-container class=\"page-container\" autosize>\n  <mat-sidenav #drawer mode=\"over\" position=\"end\" [opened]=\"false\">\n    @switch (mode) {\n      @default {\n        <bizdoc-browse-filter class=\"nav-filter\" [values]=filters (valuesChange)=\"filterChange($event)\" [folderId]=\"folderId\"></bizdoc-browse-filter>\n      }\n    }\n  </mat-sidenav>\n  <mat-sidenav-content>\n    <bizdoc-browse-items [filters]=\"filters\" [folderId]=\"folderId\" [filterType]=\"filterType\" (open)=\"open($event)\" (view)=view($event) #items></bizdoc-browse-items>\n  </mat-sidenav-content>\n</mat-sidenav-container>\n"]}
|
@@ -126,13 +126,13 @@ export class BrowsePaneComponent {
|
|
126
126
|
this._destroy.complete();
|
127
127
|
}
|
128
128
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: BrowsePaneComponent, deps: [{ token: i1.PaneRef }, { token: i2.SessionService }, { token: i3.Popup }, { token: i4.PanesRouter }, { token: i5.Directionality }, { token: i6.TranslateService }, { token: i7.MatDialog }], target: i0.ɵɵFactoryTarget.Component }); }
|
129
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.2", type: BrowsePaneComponent, selector: "bizdoc-browse.pane", host: { listeners: { "document:keydown": "handleKeydown($event)" }, classAttribute: "pane" }, viewQueries: [{ propertyName: "items", first: true, predicate: BrowseItemsComponent, descendants: true, static: true }, { propertyName: "search", first: true, predicate: ["searchInput"], descendants: true, read: ElementRef }], ngImport: i0, template: "<mat-toolbar class=\"nav-toolbar\"
|
129
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.2", type: BrowsePaneComponent, selector: "bizdoc-browse.pane", host: { listeners: { "document:keydown": "handleKeydown($event)" }, classAttribute: "pane" }, viewQueries: [{ propertyName: "items", first: true, predicate: BrowseItemsComponent, descendants: true, static: true }, { propertyName: "search", first: true, predicate: ["searchInput"], descendants: true, read: ElementRef }], ngImport: i0, template: "<mat-toolbar class=\"nav-toolbar\">\n @if (!items.selection.isEmpty()) {\n <!--<button mat-icon-button (click)=\"items.refresh()\" [bizdocTooltip]=\"'Refresh' | translate\" [attr.aria-label]=\"'Refresh' | translate\"><mat-icon matAnimate=\"rotate\">autorenew</mat-icon></button>-->\n @if (items.isAllDraft()) {\n <button mat-icon-button (click)=\"items.discardAll()\" [bizdocTooltip]=\"'DiscardSelected' | translate : items.selection.selected.length\" [attr.aria-label]=\"'DiscardSelected' | translate : items.selection.selected.length\"><mat-icon>delete_sweep</mat-icon></button>\n <button mat-button color=\"primary\" (click)=\"items.submitAll()\">{{'SubmitSelected' | translate : items.selection.selected.length }}</button>\n }\n @if (items.sharedActions.length === 1) {\n <button mat-button color=\"primary\" (click)=\"sendAll(items.sharedActions[0].name)\" [bizdocTooltip]=\"items.sharedActions[0].title\">\n @if (items.sharedActions[0].icon) {\n <mat-icon>{{items.sharedActions[0].icon}}</mat-icon>\n }{{'SendSelected' | translate : items.selection.selected.length}}\n </button>\n }\n @else if (items.sharedActions.length > 1) {\n <button mat-button color=\"primary\" [matMenuTriggerFor]=\"action\" [bizdocTooltip]=\"'Send' | translate\" [attr.aria-label]=\"'Send' | translate\">\n {{'SendSelected'| translate : items.selection.selected.length }}\n </button>\n <mat-menu #action>\n @for (a of items.sharedActions | sort : 'group'; track a; let i = $index) {\n @if (i>0 && items.sharedActions[i-1].group !== a.group) {\n <mat-divider>\n </mat-divider>\n }\n <button mat-menu-item (click)=\"sendAll(a.name)\" [attr.aria-label]=\"a.title\">\n {{ a.title }}\n </button>\n }\n </mat-menu>\n }\n <!--<button mat-icon-button (click)=\"items.paginator.previousPage()\" [bizdocTooltip]=\"'PrevPage' | translate\" [attr.aria-label]=\"'PrevPage' | translate\" [disabled]=\"!items.paginator.hasPreviousPage()\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_left</mat-icon></button>\n <button mat-icon-button (click)=\"items.paginator.nextPage()\" [bizdocTooltip]=\"'NextPage' | translate\" [attr.aria-label]=\"'NextPage' | translate\" [disabled]=\"!items.paginator.hasNextPage()\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_right</mat-icon></button>-->\n } @else {\n <!--<button mat-icon-button (click)=\"openSearch()\"\n [bizdocTooltip]=\"'Search'|translate\" class=\"tool\">\n <mat-icon>search</mat-icon>\n </button>\n [@search]=\"searching\"\n (@search.done)=\"searching && focus()\"-->\n <input matInput\n [formControl]=\"contains\" autocomplete=\"off\" placeholder=\"{{'Search' | translate}}\"\n class=\"mat-body search-box\"\n #searchInput\n (keydown.escape)=\"clearSearch($event)\">\n @if (contains.value) {\n <mat-icon (click)=\"clearSearch()\">close</mat-icon>\n }\n <span class=\"divider\"></span>\n <!--<button mat-icon-button (click)=\"items.paginator.previousPage()\" [bizdocTooltip]=\"'PrevPage' | translate\" [attr.aria-label]=\"'PrevPage' | translate\" [disabled]=\"!items.paginator.hasPreviousPage()\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_left</mat-icon></button>\n <button mat-icon-button (click)=\"items.paginator.nextPage()\" [bizdocTooltip]=\"'NextPage' | translate\" [attr.aria-label]=\"'NextPage' | translate\" [disabled]=\"!items.paginator.hasNextPage()\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_right</mat-icon></button>-->\n <button mat-icon-button (click)=\"openFilter($event)\" [bizdocTooltip]=\"'Filter' | translate\" [attr.aria-label]=\"'Filter' | translate\"><mat-icon>filter_list</mat-icon></button>\n }\n</mat-toolbar>\n<bizdoc-browse-items [filters]=\"filters\" [folderId]=\"folderId\" [filterType]=\"filterType\"\n (open)=\"open($event)\" (view)=\"view($event) \" #items></bizdoc-browse-items>\n", styles: [":host{min-width:540px;display:contents!important}\n"], dependencies: [{ kind: "directive", type: i8.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i8.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i9.MatDivider, selector: "mat-divider", inputs: ["vertical", "inset"] }, { kind: "component", type: i10.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { kind: "component", type: i11.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i11.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "directive", type: i12.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"] }, { kind: "component", type: i13.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i14.MatMenu, selector: "mat-menu", inputs: ["backdropClass", "aria-label", "aria-labelledby", "aria-describedby", "xPosition", "yPosition", "overlapTrigger", "hasBackdrop", "class", "classList"], outputs: ["closed", "close"], exportAs: ["matMenu"] }, { kind: "component", type: i14.MatMenuItem, selector: "[mat-menu-item]", inputs: ["role", "disabled", "disableRipple"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i14.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", inputs: ["mat-menu-trigger-for", "matMenuTriggerFor", "matMenuTriggerData", "matMenuTriggerRestoreFocus"], outputs: ["menuOpened", "onMenuOpen", "menuClosed", "onMenuClose"], exportAs: ["matMenuTrigger"] }, { kind: "component", type: i15.BrowseItemsComponent, selector: "bizdoc-browse-items", inputs: ["folderId", "filterType", "filters"], outputs: ["open", "view"] }, { kind: "directive", type: i16.TooltipDirective, selector: "[bizdocTooltip]", inputs: ["bizdocTooltip", "bizdocTooltipTemplate", "bizdocTooltipContext", "bizdocTooltipPosition", "bizdocTooltipDuration", "bizdocTooltipDisabled"] }, { kind: "pipe", type: i17.ArraySortPipe, name: "sort" }, { kind: "pipe", type: i18.TranslatePipe, name: "translate" }], animations: [searchAnimation] }); }
|
130
130
|
}
|
131
131
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: BrowsePaneComponent, decorators: [{
|
132
132
|
type: Component,
|
133
133
|
args: [{ selector: 'bizdoc-browse.pane', animations: [searchAnimation], host: {
|
134
134
|
class: 'pane'
|
135
|
-
}, template: "<mat-toolbar class=\"nav-toolbar\"
|
135
|
+
}, template: "<mat-toolbar class=\"nav-toolbar\">\n @if (!items.selection.isEmpty()) {\n <!--<button mat-icon-button (click)=\"items.refresh()\" [bizdocTooltip]=\"'Refresh' | translate\" [attr.aria-label]=\"'Refresh' | translate\"><mat-icon matAnimate=\"rotate\">autorenew</mat-icon></button>-->\n @if (items.isAllDraft()) {\n <button mat-icon-button (click)=\"items.discardAll()\" [bizdocTooltip]=\"'DiscardSelected' | translate : items.selection.selected.length\" [attr.aria-label]=\"'DiscardSelected' | translate : items.selection.selected.length\"><mat-icon>delete_sweep</mat-icon></button>\n <button mat-button color=\"primary\" (click)=\"items.submitAll()\">{{'SubmitSelected' | translate : items.selection.selected.length }}</button>\n }\n @if (items.sharedActions.length === 1) {\n <button mat-button color=\"primary\" (click)=\"sendAll(items.sharedActions[0].name)\" [bizdocTooltip]=\"items.sharedActions[0].title\">\n @if (items.sharedActions[0].icon) {\n <mat-icon>{{items.sharedActions[0].icon}}</mat-icon>\n }{{'SendSelected' | translate : items.selection.selected.length}}\n </button>\n }\n @else if (items.sharedActions.length > 1) {\n <button mat-button color=\"primary\" [matMenuTriggerFor]=\"action\" [bizdocTooltip]=\"'Send' | translate\" [attr.aria-label]=\"'Send' | translate\">\n {{'SendSelected'| translate : items.selection.selected.length }}\n </button>\n <mat-menu #action>\n @for (a of items.sharedActions | sort : 'group'; track a; let i = $index) {\n @if (i>0 && items.sharedActions[i-1].group !== a.group) {\n <mat-divider>\n </mat-divider>\n }\n <button mat-menu-item (click)=\"sendAll(a.name)\" [attr.aria-label]=\"a.title\">\n {{ a.title }}\n </button>\n }\n </mat-menu>\n }\n <!--<button mat-icon-button (click)=\"items.paginator.previousPage()\" [bizdocTooltip]=\"'PrevPage' | translate\" [attr.aria-label]=\"'PrevPage' | translate\" [disabled]=\"!items.paginator.hasPreviousPage()\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_left</mat-icon></button>\n <button mat-icon-button (click)=\"items.paginator.nextPage()\" [bizdocTooltip]=\"'NextPage' | translate\" [attr.aria-label]=\"'NextPage' | translate\" [disabled]=\"!items.paginator.hasNextPage()\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_right</mat-icon></button>-->\n } @else {\n <!--<button mat-icon-button (click)=\"openSearch()\"\n [bizdocTooltip]=\"'Search'|translate\" class=\"tool\">\n <mat-icon>search</mat-icon>\n </button>\n [@search]=\"searching\"\n (@search.done)=\"searching && focus()\"-->\n <input matInput\n [formControl]=\"contains\" autocomplete=\"off\" placeholder=\"{{'Search' | translate}}\"\n class=\"mat-body search-box\"\n #searchInput\n (keydown.escape)=\"clearSearch($event)\">\n @if (contains.value) {\n <mat-icon (click)=\"clearSearch()\">close</mat-icon>\n }\n <span class=\"divider\"></span>\n <!--<button mat-icon-button (click)=\"items.paginator.previousPage()\" [bizdocTooltip]=\"'PrevPage' | translate\" [attr.aria-label]=\"'PrevPage' | translate\" [disabled]=\"!items.paginator.hasPreviousPage()\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_left</mat-icon></button>\n <button mat-icon-button (click)=\"items.paginator.nextPage()\" [bizdocTooltip]=\"'NextPage' | translate\" [attr.aria-label]=\"'NextPage' | translate\" [disabled]=\"!items.paginator.hasNextPage()\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_right</mat-icon></button>-->\n <button mat-icon-button (click)=\"openFilter($event)\" [bizdocTooltip]=\"'Filter' | translate\" [attr.aria-label]=\"'Filter' | translate\"><mat-icon>filter_list</mat-icon></button>\n }\n</mat-toolbar>\n<bizdoc-browse-items [filters]=\"filters\" [folderId]=\"folderId\" [filterType]=\"filterType\"\n (open)=\"open($event)\" (view)=\"view($event) \" #items></bizdoc-browse-items>\n", styles: [":host{min-width:540px;display:contents!important}\n"] }]
|
136
136
|
}], ctorParameters: () => [{ type: i1.PaneRef }, { type: i2.SessionService }, { type: i3.Popup }, { type: i4.PanesRouter }, { type: i5.Directionality }, { type: i6.TranslateService }, { type: i7.MatDialog }], propDecorators: { items: [{
|
137
137
|
type: ViewChild,
|
138
138
|
args: [BrowseItemsComponent, { static: true }]
|
@@ -143,4 +143,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
|
|
143
143
|
type: HostListener,
|
144
144
|
args: ['document:keydown', ['$event']]
|
145
145
|
}] } });
|
146
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"browse.pane.component.js","sourceRoot":"","sources":["../../../../../libraries/core/src/lib/browse/browse.pane.component.ts","../../../../../libraries/core/src/lib/browse/browse.pane.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,YAAY,EAAU,SAAS,EAAE,MAAM,eAAe,CAAC;AACvF,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAG7C,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,YAAY,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAIjE,OAAO,EAAE,YAAY,EAAoB,MAAM,iCAAiC,CAAC;AACjF,OAAO,EAAoB,qBAAqB,EAAE,MAAM,2BAA2B,CAAC;AACpF,OAAO,EAAE,eAAe,EAAsB,eAAe,EAAE,eAAe,EAAW,MAAM,wBAAwB,CAAC;AACxH,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAEhE,OAAO,EAAE,oBAAoB,EAAE,MAAM,mCAAmC,CAAC;AAEzE,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;;;;;;;;;;;;;;;;;;;;AAYrD,sBAAsB;AACtB,MAAM,OAAO,mBAAmB;IAU9B,kBAAkB;IAClB,YACU,KAAmC,EACnC,QAAwB,EACxB,MAAa,EACb,OAAoB,EACpB,eAA+B,EAC/B,UAA4B,EAC5B,OAAkB;QANlB,UAAK,GAAL,KAAK,CAA8B;QACnC,aAAQ,GAAR,QAAQ,CAAgB;QACxB,WAAM,GAAN,MAAM,CAAO;QACb,YAAO,GAAP,OAAO,CAAa;QACpB,oBAAe,GAAf,eAAe,CAAgB;QAC/B,eAAU,GAAV,UAAU,CAAkB;QAC5B,YAAO,GAAP,OAAO,CAAW;QAZ5B,cAAS,GAAG,KAAK,CAAC;QAET,aAAQ,GAAG,IAAI,WAAW,EAAE,CAAC;QACrB,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;IAUhD,CAAC;IACD,QAAQ;QACN,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;YACtC,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC;YACxB,IAAI,IAAI,CAAC,QAAQ;gBAAE,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;QAC1D,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,KAAK,CAAC,iBAAiB,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;YAC3C,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC;YAC5B,IAAI,IAAI,CAAC,UAAU,KAAK,SAAS;gBAC/B,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;iBAElD,IAAI,CAAC,CAAC,KAAK,CAAC;gBACV,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;YACnD,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC;QACnB,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,EAC/C,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,YAAY,eAAe,IAAI,CAAC,YAAY,eAAe,IAAI,CAAC,YAAY,eAAe,CAAC;eACrG,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,KAAK,oBAAoB,CAAC,CAAC;YACxD,SAAS,CAAC,CAAC,CAA2C,EAAE,EAAE,CACxD,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CACvC,CAAC;QACJ,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,GAAG,EAAE,GAAG,IAAI,CAAC,OAAO,EAAE,QAAQ,EAAE,CAAC,EAAE,CAAC,CAAC;IAC/I,CAAC;IACD,IAAI,MAAM,KAAa,OAAO,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;IAElG,UAAU,CAAC,GAAU;QACnB,0EAA0E;QAC1E,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,qBAAqB,EAAE,GAAG,CAAC,MAAqB,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;YACrF,MAAM,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;YACrB,CAAC,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;YAC3B,CAAC,CAAC,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC;YACxB,CAAC,CAAC,OAAO,GAAG,CAAC,UAAU,CAAC,CAAC;YACzB,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC,CAAC;QACjF,CAAC,CAAC,CAAC;IACP,CAAC;IACD;;;KAGC;IAED,aAAa,CAAC,KAAoB;QAChC,IAAI,KAAK,CAAC,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,KAAK,GAAG,IAAI,KAAK,CAAC,GAAG,KAAK,GAAG,CAAC,EAAE,CAAC;YAC9D,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;YAClC,KAAK,CAAC,cAAc,EAAE,CAAC;QACzB,CAAC;IACH,CAAC;IACD,UAAU;QACR,IAAI,CAAC,SAAS,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC;QACjC,IAAI,CAAC,SAAS;YACZ,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IACtC,CAAC;IACD,WAAW,CAAC,GAAW;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QAC7B,IAAI,GAAG,EAAE,CAAC;YACR,GAAG,CAAC,eAAe,EAAE,CAAC;YACtB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACzB,CAAC;IACH,CAAC;IACD,IAAI,CAAC,IAAyB;QAC5B,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,WAAW,EAAE,IAAI,CAAC,EAAE,CAAC,QAAQ,EAAE,CAAC,EACrD;YACE,KAAK,EAAE;gBACL,IAAI,EAAE,EAAE,GAAG,IAAI,EAAE;aAClB;SACF,CAAC,CAAC;IACP,CAAC;IACD,IAAI,CAAC,IAAyB;QAC5B,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,WAAW,EAAE,IAAI,CAAC,EAAE,CAAC,QAAQ,EAAE,EAAE,OAAO,CAAC,EAC9D;YACE,KAAK,EAAE;gBACL,IAAI,EAAE,EAAE,GAAG,IAAI,EAAE;aAClB;SACF,CAAC,CAAA;IACN,CAAC;IACD,OAAO,CAAC,MAAc;QACpB,MAAM,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC;QAC1C,MAAM,IAAI,GAAqB;YAC7B,MAAM;YACN,KAAK,EAAE,QAA4B;SACpC,CAAC;QACF,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,YAAY,EAAE;YAC9B,IAAI;YACJ,SAAS,EAAE,IAAI,CAAC,eAAe,CAAC,KAAK;YACrC,YAAY,EAAE,KAAK;SACpB,CAAC,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAChC,IAAI;YACJ,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,CAAC;IACtC,CAAC;IACD,WAAW;QACT,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;8GA9GU,mBAAmB;kGAAnB,mBAAmB,+LACnB,oBAAoB,iIACG,UAAU,6BC/B9C,y/KA8EA,k1FDvDc,CAAC,eAAe,CAAC;;2FAMlB,mBAAmB;kBAV/B,SAAS;+BACE,oBAAoB,cAGlB,CAAC,eAAe,CAAC,QACvB;wBACJ,KAAK,EAAE,MAAM;qBACd;2OAIkD,KAAK;sBAAvD,SAAS;uBAAC,oBAAoB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBACD,MAAM;sBAArD,SAAS;uBAAC,aAAa,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE;gBAyD9C,aAAa;sBADZ,YAAY;uBAAC,kBAAkB,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import { Component, ElementRef, HostListener, OnInit, ViewChild } from '@angular/core';\r\nimport { FormControl } from '@angular/forms';\r\nimport { Directionality } from '@angular/cdk/bidi';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { Subject } from 'rxjs';\r\nimport { debounceTime, filter, takeUntil } from 'rxjs/operators';\r\nimport { Folder, RecipientModel } from '../core/models';\r\nimport { PanesRouter } from '../core/slots/router.service';\r\nimport { FilterType } from '../core/mailbox.service';\r\nimport { ActionDialog, ActionDialogData } from '../compose/action/action.dialog';\r\nimport { BrowseFilterArgs, BrowseFilterComponent } from './filter/filter.component';\r\nimport { NavigationFocus, NavigationPaneBase, NavigationStart, ParamNavigation, PaneRef } from '../core/slots/pane-ref';\r\nimport { BrowseItemsComponent } from './browse-items.component';\r\nimport { Popup } from '../core/popup/popup.service';\r\nimport { ComposePaneComponent } from '../compose/compose.pane.component';\r\nimport { SessionService } from '../core/session.service';\r\nimport { searchAnimation } from '../core/animations';\r\nimport { TranslateService } from '../core/translate.service';\r\n\r\n@Component({\r\n  selector: 'bizdoc-browse.pane',\r\n  templateUrl: './browse.pane.component.html',\r\n  styleUrls: ['./browse.pane.component.scss'],\r\n  animations: [searchAnimation],\r\n  host: {\r\n    class: 'pane'\r\n  }\r\n})\r\n/** browse component*/\r\nexport class BrowsePaneComponent implements OnInit {\r\n  @ViewChild(BrowseItemsComponent, { static: true }) items: BrowseItemsComponent;\r\n  @ViewChild('searchInput', { read: ElementRef }) search: ElementRef;\r\n  folderId: string;\r\n  filterType: FilterType;\r\n  filters: BrowseFilterArgs;\r\n  searching = false;\r\n  pageSize: number;\r\n  readonly contains = new FormControl();\r\n  private readonly _destroy = new Subject<void>();\r\n  /** browse ctor */\r\n  constructor(\r\n    private _pane: PaneRef<BrowsePaneComponent>,\r\n    private _session: SessionService,\r\n    private _popup: Popup,\r\n    private _router: PanesRouter,\r\n    private _directionality: Directionality,\r\n    private _translate: TranslateService,\r\n    private _dialog: MatDialog) {\r\n  }\r\n  ngOnInit(): void {\r\n    this._pane.paramsChange().subscribe(p => {\r\n      this.folderId = p['id'];\r\n      if (this.folderId) this._pane.title = this.folder.title;\r\n    });\r\n    this._pane.queryParamsChange().subscribe(p => {\r\n      this.filterType = p['type'];\r\n      if (this.filterType === 'flagged')\r\n        this._pane.title = this._translate.get('Flagged');\r\n      else\r\n        if (p['tag'])\r\n          this._pane.title = this._translate.get('Tags');\r\n      this.filters = p;\r\n    });\r\n    this._router.events.pipe(takeUntil(this._destroy),\r\n      filter(e => (e instanceof ParamNavigation || e instanceof NavigationStart || e instanceof NavigationFocus)\r\n        && e.pane._portal.component === ComposePaneComponent)).\r\n      subscribe((e: NavigationPaneBase<ComposePaneComponent>) =>\r\n        this.items.select(e.pane.data.item.id)\r\n      );\r\n    this.contains.valueChanges.pipe(takeUntil(this._destroy), debounceTime(200)).subscribe(v => this.filters = { ...this.filters, contains: v });\r\n  }\r\n  get folder(): Folder { return this._session.profile.folders.find(f => f.name === this.folderId); }\r\n\r\n  openFilter(evt: Event) {\r\n    //this.filterElement.nativeElement.scrollIntoView({ behavior: 'smooth' });\r\n    this._popup.open(BrowseFilterComponent, evt.target as HTMLElement, { position: 'end' }).\r\n      opened().subscribe(e => {\r\n        e.folderId = this.folderId;\r\n        e.values = this.filters;\r\n        e.exclude = ['contains'];\r\n        e.valuesChange.pipe(takeUntil(this._destroy)).subscribe(v => this.filters = v);\r\n      });\r\n  }\r\n  /**\r\n * Ctrl-f\r\n * @param event\r\n */\r\n  @HostListener('document:keydown', ['$event'])\r\n  handleKeydown(event: KeyboardEvent) {\r\n    if (event.ctrlKey && (event.key === 'f' || event.key === 'F')) {\r\n      this.search.nativeElement.focus();\r\n      event.preventDefault();\r\n    }\r\n  }\r\n  openSearch() {\r\n    this.searching = !this.searching;\r\n    this.searching &&\r\n      this.search.nativeElement.focus();\r\n  }\r\n  clearSearch(evt?: Event) {\r\n    this.contains.setValue(null);\r\n    if (evt) {\r\n      evt.stopPropagation();\r\n      this.searching = false;\r\n    }\r\n  }\r\n  open(item: RecipientModel<any>) {\r\n    this._router.navigate(['mailbox/i', item.id.encodeId()],\r\n      {\r\n        state: {\r\n          item: { ...item }\r\n        },\r\n      });\r\n  }\r\n  view(item: RecipientModel<any>) {\r\n    this._router.navigate(['mailbox/i', item.id.encodeId(), 'views'],\r\n      {\r\n        state: {\r\n          item: { ...item }\r\n        }\r\n      })\r\n  }\r\n  sendAll(action: string) {\r\n    const { selected } = this.items.selection;\r\n    const data: ActionDialogData = {\r\n      action,\r\n      items: selected as RecipientModel[]\r\n    };\r\n    this._dialog.open(ActionDialog, {\r\n      data,\r\n      direction: this._directionality.value,\r\n      restoreFocus: false\r\n    }).afterClosed().subscribe(args =>\r\n      args &&\r\n      this.items.sendAll(action, args));\r\n  }\r\n  ngOnDestroy(): void {\r\n    this._destroy.next();\r\n    this._destroy.complete();\r\n  }\r\n}\r\n","<mat-toolbar class=\"nav-toolbar\" >\n  @if (!items.selection.isEmpty()) {\n    <!--<button mat-icon-button (click)=\"items.refresh()\" [bizdocTooltip]=\"'Refresh' | translate\" [attr.aria-label]=\"'Refresh' | translate\"><mat-icon matAnimate=\"rotate\">autorenew</mat-icon></button>-->\n    @if (items.isAllDraft()) {\n      <button mat-icon-button (click)=\"items.discardAll()\" [bizdocTooltip]=\"'DiscardSelected' | translate : items.selection.selected.length\" [attr.aria-label]=\"'DiscardSelected' | translate : items.selection.selected.length\"><mat-icon>delete_sweep</mat-icon></button>\n    }\n    @if (items.isAllDraft()) {\n      <button mat-button color=\"primary\" class=\"hide-xs\" (click)=\"items.submitAll()\">{{'SubmitSelected' | translate : items.selection.selected.length }}</button>\n    }\n    @if (items.isAllDraft()) {\n      <button mat-icon-button color=\"primary\" class=\"show-xs\" (click)=\"items.submitAll()\" [bizdocTooltip]=\"'Submit' | translate\" [attr.aria-label]=\"'Submit' | translate\"><mat-icon>send</mat-icon></button>\n    }\n    @if (items.sharedActions.length === 1) {\n      <button mat-button color=\"primary\" (click)=\"sendAll(items.sharedActions[0].name)\" [bizdocTooltip]=\"items.sharedActions[0].title\">@if (items.sharedActions[0].icon) {\n        <mat-icon>{{items.sharedActions[0].icon}}</mat-icon>\n      }{{'SendSelected' | translate : items.selection.selected.length}}</button>\n    }\n    @if (items.sharedActions.length > 1) {\n      <button mat-button color=\"primary\" [matMenuTriggerFor]=\"action\" [bizdocTooltip]=\"'Send' | translate\" [attr.aria-label]=\"'Send' | translate\">\n        {{'SendSelected'| translate : items.selection.selected.length }}\n      </button>\n    }\n    <mat-menu #action>\n      @for (a of items.sharedActions | sort : 'group'; track a; let i = $index) {\n        @if (i>0 && items.sharedActions[i-1].group !== a.group) {\n          <mat-divider>\n          </mat-divider>\n        }\n        <button mat-menu-item (click)=\"sendAll(a.name)\" [attr.aria-label]=\"a.title\">\n          {{ a.title }}\n        </button>\n      }\n    </mat-menu>\n    <!--<button mat-icon-button (click)=\"items.paginator.previousPage()\" [bizdocTooltip]=\"'PrevPage' | translate\" [attr.aria-label]=\"'PrevPage' | translate\" [disabled]=\"!items.paginator.hasPreviousPage()\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_left</mat-icon></button>\n    <button mat-icon-button (click)=\"items.paginator.nextPage()\" [bizdocTooltip]=\"'NextPage' | translate\" [attr.aria-label]=\"'NextPage' | translate\" [disabled]=\"!items.paginator.hasNextPage()\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_right</mat-icon></button>-->\n  } @else {\n    <!--<button mat-icon-button (click)=\"openSearch()\"\n    [bizdocTooltip]=\"'Search'|translate\" class=\"tool\">\n    <mat-icon>search</mat-icon>\n  </button>\n  [@search]=\"searching\"\n  (@search.done)=\"searching && focus()\"-->\n  <input matInput\n    [formControl]=\"contains\" autocomplete=\"off\" placeholder=\"{{'Search' | translate}}\"\n    class=\"mat-body search-box\"\n    #searchInput\n    (keydown.escape)=\"clearSearch($event)\">\n    @if (contains.value) {\n      <mat-icon (click)=\"clearSearch()\">close</mat-icon>\n    }\n    <span class=\"divider\"></span>\n    <!--<button mat-icon-button (click)=\"items.paginator.previousPage()\" [bizdocTooltip]=\"'PrevPage' | translate\" [attr.aria-label]=\"'PrevPage' | translate\" [disabled]=\"!items.paginator.hasPreviousPage()\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_left</mat-icon></button>\n    <button mat-icon-button (click)=\"items.paginator.nextPage()\" [bizdocTooltip]=\"'NextPage' | translate\" [attr.aria-label]=\"'NextPage' | translate\" [disabled]=\"!items.paginator.hasNextPage()\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_right</mat-icon></button>-->\n    <button mat-icon-button (click)=\"openFilter($event)\" [bizdocTooltip]=\"'Filter' | translate\" [attr.aria-label]=\"'Filter' | translate\"><mat-icon>filter_list</mat-icon></button>\n  }\n</mat-toolbar>\n<bizdoc-browse-items [filters]=\"filters\" [folderId]=\"folderId\" [filterType]=\"filterType\"\n(open)=\"open($event)\" (view)=\"view($event) \" #items></bizdoc-browse-items>\n<ng-template #search>\n  <!--<button mat-icon-button (click)=\"openSearch()\"\n  [bizdocTooltip]=\"'Search'|translate\" class=\"tool\">\n  <mat-icon>search</mat-icon>\n</button>\n[@search]=\"searching\"\n(@search.done)=\"searching && focus()\"-->\n<input matInput\n  [formControl]=\"contains\" autocomplete=\"off\" placeholder=\"{{'Search' | translate}}\"\n  class=\"mat-body search-box\"\n  #searchInput\n  (keydown.escape)=\"clearSearch($event)\">\n  @if (contains.value) {\n    <mat-icon (click)=\"clearSearch()\">close</mat-icon>\n  }\n  <span class=\"divider\"></span>\n  <!--<button mat-icon-button (click)=\"items.paginator.previousPage()\" [bizdocTooltip]=\"'PrevPage' | translate\" [attr.aria-label]=\"'PrevPage' | translate\" [disabled]=\"!items.paginator.hasPreviousPage()\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_left</mat-icon></button>\n  <button mat-icon-button (click)=\"items.paginator.nextPage()\" [bizdocTooltip]=\"'NextPage' | translate\" [attr.aria-label]=\"'NextPage' | translate\" [disabled]=\"!items.paginator.hasNextPage()\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_right</mat-icon></button>-->\n  <button mat-icon-button (click)=\"openFilter($event)\" [bizdocTooltip]=\"'Filter' | translate\" [attr.aria-label]=\"'Filter' | translate\"><mat-icon>filter_list</mat-icon></button>\n</ng-template>\n"]}
|
146
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"browse.pane.component.js","sourceRoot":"","sources":["../../../../../libraries/core/src/lib/browse/browse.pane.component.ts","../../../../../libraries/core/src/lib/browse/browse.pane.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, HostListener, OnInit, ViewChild } from '@angular/core';\r\nimport { FormControl } from '@angular/forms';\r\nimport { Directionality } from '@angular/cdk/bidi';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { Subject } from 'rxjs';\r\nimport { debounceTime, filter, takeUntil } from 'rxjs/operators';\r\nimport { Folder, RecipientModel } from '../core/models';\r\nimport { PanesRouter } from '../core/slots/router.service';\r\nimport { FilterType } from '../core/mailbox.service';\r\nimport { ActionDialog, ActionDialogData } from '../compose/action/action.dialog';\r\nimport { BrowseFilterArgs, BrowseFilterComponent } from './filter/filter.component';\r\nimport { NavigationFocus, NavigationPaneBase, NavigationStart, ParamNavigation, PaneRef } from '../core/slots/pane-ref';\r\nimport { BrowseItemsComponent } from './browse-items.component';\r\nimport { Popup } from '../core/popup/popup.service';\r\nimport { ComposePaneComponent } from '../compose/compose.pane.component';\r\nimport { SessionService } from '../core/session.service';\r\nimport { searchAnimation } from '../core/animations';\r\nimport { TranslateService } from '../core/translate.service';\r\n\r\n@Component({\r\n  selector: 'bizdoc-browse.pane',\r\n  templateUrl: './browse.pane.component.html',\r\n  styleUrls: ['./browse.pane.component.scss'],\r\n  animations: [searchAnimation],\r\n  host: {\r\n    class: 'pane'\r\n  }\r\n})\r\n/** browse component*/\r\nexport class BrowsePaneComponent implements OnInit {\r\n  @ViewChild(BrowseItemsComponent, { static: true }) items: BrowseItemsComponent;\r\n  @ViewChild('searchInput', { read: ElementRef }) search: ElementRef;\r\n  folderId: string;\r\n  filterType: FilterType;\r\n  filters: BrowseFilterArgs;\r\n  searching = false;\r\n  pageSize: number;\r\n  readonly contains = new FormControl();\r\n  private readonly _destroy = new Subject<void>();\r\n  /** browse ctor */\r\n  constructor(\r\n    private _pane: PaneRef<BrowsePaneComponent>,\r\n    private _session: SessionService,\r\n    private _popup: Popup,\r\n    private _router: PanesRouter,\r\n    private _directionality: Directionality,\r\n    private _translate: TranslateService,\r\n    private _dialog: MatDialog) {\r\n  }\r\n  ngOnInit(): void {\r\n    this._pane.paramsChange().subscribe(p => {\r\n      this.folderId = p['id'];\r\n      if (this.folderId) this._pane.title = this.folder.title;\r\n    });\r\n    this._pane.queryParamsChange().subscribe(p => {\r\n      this.filterType = p['type'];\r\n      if (this.filterType === 'flagged')\r\n        this._pane.title = this._translate.get('Flagged');\r\n      else\r\n        if (p['tag'])\r\n          this._pane.title = this._translate.get('Tags');\r\n      this.filters = p;\r\n    });\r\n    this._router.events.pipe(takeUntil(this._destroy),\r\n      filter(e => (e instanceof ParamNavigation || e instanceof NavigationStart || e instanceof NavigationFocus)\r\n        && e.pane._portal.component === ComposePaneComponent)).\r\n      subscribe((e: NavigationPaneBase<ComposePaneComponent>) =>\r\n        this.items.select(e.pane.data.item.id)\r\n      );\r\n    this.contains.valueChanges.pipe(takeUntil(this._destroy), debounceTime(200)).subscribe(v => this.filters = { ...this.filters, contains: v });\r\n  }\r\n  get folder(): Folder { return this._session.profile.folders.find(f => f.name === this.folderId); }\r\n\r\n  openFilter(evt: Event) {\r\n    //this.filterElement.nativeElement.scrollIntoView({ behavior: 'smooth' });\r\n    this._popup.open(BrowseFilterComponent, evt.target as HTMLElement, { position: 'end' }).\r\n      opened().subscribe(e => {\r\n        e.folderId = this.folderId;\r\n        e.values = this.filters;\r\n        e.exclude = ['contains'];\r\n        e.valuesChange.pipe(takeUntil(this._destroy)).subscribe(v => this.filters = v);\r\n      });\r\n  }\r\n  /**\r\n * Ctrl-f\r\n * @param event\r\n */\r\n  @HostListener('document:keydown', ['$event'])\r\n  handleKeydown(event: KeyboardEvent) {\r\n    if (event.ctrlKey && (event.key === 'f' || event.key === 'F')) {\r\n      this.search.nativeElement.focus();\r\n      event.preventDefault();\r\n    }\r\n  }\r\n  openSearch() {\r\n    this.searching = !this.searching;\r\n    this.searching &&\r\n      this.search.nativeElement.focus();\r\n  }\r\n  clearSearch(evt?: Event) {\r\n    this.contains.setValue(null);\r\n    if (evt) {\r\n      evt.stopPropagation();\r\n      this.searching = false;\r\n    }\r\n  }\r\n  open(item: RecipientModel<any>) {\r\n    this._router.navigate(['mailbox/i', item.id.encodeId()],\r\n      {\r\n        state: {\r\n          item: { ...item }\r\n        },\r\n      });\r\n  }\r\n  view(item: RecipientModel<any>) {\r\n    this._router.navigate(['mailbox/i', item.id.encodeId(), 'views'],\r\n      {\r\n        state: {\r\n          item: { ...item }\r\n        }\r\n      })\r\n  }\r\n  sendAll(action: string) {\r\n    const { selected } = this.items.selection;\r\n    const data: ActionDialogData = {\r\n      action,\r\n      items: selected as RecipientModel[]\r\n    };\r\n    this._dialog.open(ActionDialog, {\r\n      data,\r\n      direction: this._directionality.value,\r\n      restoreFocus: false\r\n    }).afterClosed().subscribe(args =>\r\n      args &&\r\n      this.items.sendAll(action, args));\r\n  }\r\n  ngOnDestroy(): void {\r\n    this._destroy.next();\r\n    this._destroy.complete();\r\n  }\r\n}\r\n","<mat-toolbar class=\"nav-toolbar\">\n  @if (!items.selection.isEmpty()) {\n  <!--<button mat-icon-button (click)=\"items.refresh()\" [bizdocTooltip]=\"'Refresh' | translate\" [attr.aria-label]=\"'Refresh' | translate\"><mat-icon matAnimate=\"rotate\">autorenew</mat-icon></button>-->\n  @if (items.isAllDraft()) {\n  <button mat-icon-button (click)=\"items.discardAll()\" [bizdocTooltip]=\"'DiscardSelected' | translate : items.selection.selected.length\" [attr.aria-label]=\"'DiscardSelected' | translate : items.selection.selected.length\"><mat-icon>delete_sweep</mat-icon></button>\n  <button mat-button color=\"primary\" (click)=\"items.submitAll()\">{{'SubmitSelected' | translate : items.selection.selected.length }}</button>\n  }\n  @if (items.sharedActions.length === 1) {\n  <button mat-button color=\"primary\" (click)=\"sendAll(items.sharedActions[0].name)\" [bizdocTooltip]=\"items.sharedActions[0].title\">\n    @if (items.sharedActions[0].icon) {\n    <mat-icon>{{items.sharedActions[0].icon}}</mat-icon>\n    }{{'SendSelected' | translate : items.selection.selected.length}}\n  </button>\n  }\n  @else if (items.sharedActions.length > 1) {\n  <button mat-button color=\"primary\" [matMenuTriggerFor]=\"action\" [bizdocTooltip]=\"'Send' | translate\" [attr.aria-label]=\"'Send' | translate\">\n    {{'SendSelected'| translate : items.selection.selected.length }}\n  </button>\n  <mat-menu #action>\n    @for (a of items.sharedActions | sort : 'group'; track a; let i = $index) {\n    @if (i>0 && items.sharedActions[i-1].group !== a.group) {\n    <mat-divider>\n    </mat-divider>\n    }\n    <button mat-menu-item (click)=\"sendAll(a.name)\" [attr.aria-label]=\"a.title\">\n      {{ a.title }}\n    </button>\n    }\n  </mat-menu>\n  }\n  <!--<button mat-icon-button (click)=\"items.paginator.previousPage()\" [bizdocTooltip]=\"'PrevPage' | translate\" [attr.aria-label]=\"'PrevPage' | translate\" [disabled]=\"!items.paginator.hasPreviousPage()\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_left</mat-icon></button>\n  <button mat-icon-button (click)=\"items.paginator.nextPage()\" [bizdocTooltip]=\"'NextPage' | translate\" [attr.aria-label]=\"'NextPage' | translate\" [disabled]=\"!items.paginator.hasNextPage()\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_right</mat-icon></button>-->\n  } @else {\n  <!--<button mat-icon-button (click)=\"openSearch()\"\n    [bizdocTooltip]=\"'Search'|translate\" class=\"tool\">\n    <mat-icon>search</mat-icon>\n  </button>\n  [@search]=\"searching\"\n  (@search.done)=\"searching && focus()\"-->\n  <input matInput\n         [formControl]=\"contains\" autocomplete=\"off\" placeholder=\"{{'Search' | translate}}\"\n         class=\"mat-body search-box\"\n         #searchInput\n         (keydown.escape)=\"clearSearch($event)\">\n  @if (contains.value) {\n  <mat-icon (click)=\"clearSearch()\">close</mat-icon>\n  }\n  <span class=\"divider\"></span>\n  <!--<button mat-icon-button (click)=\"items.paginator.previousPage()\" [bizdocTooltip]=\"'PrevPage' | translate\" [attr.aria-label]=\"'PrevPage' | translate\" [disabled]=\"!items.paginator.hasPreviousPage()\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_left</mat-icon></button>\n  <button mat-icon-button (click)=\"items.paginator.nextPage()\" [bizdocTooltip]=\"'NextPage' | translate\" [attr.aria-label]=\"'NextPage' | translate\" [disabled]=\"!items.paginator.hasNextPage()\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_right</mat-icon></button>-->\n  <button mat-icon-button (click)=\"openFilter($event)\" [bizdocTooltip]=\"'Filter' | translate\" [attr.aria-label]=\"'Filter' | translate\"><mat-icon>filter_list</mat-icon></button>\n  }\n</mat-toolbar>\n<bizdoc-browse-items [filters]=\"filters\" [folderId]=\"folderId\" [filterType]=\"filterType\"\n                     (open)=\"open($event)\" (view)=\"view($event) \" #items></bizdoc-browse-items>\n"]}
|