@theseam/ui-common 0.2.6 → 0.2.10
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/breadcrumbs/breadcrumb.d.ts +3 -1
- package/breadcrumbs/breadcrumbs/breadcrumbs.component.d.ts +2 -2
- package/breadcrumbs/breadcrumbs-resolver.d.ts +3 -1
- package/breadcrumbs/breadcrumbs.service.d.ts +15 -6
- package/breadcrumbs/theseam-ui-common-breadcrumbs.metadata.json +1 -1
- package/bundles/theseam-ui-common-breadcrumbs.umd.js +487 -16
- package/bundles/theseam-ui-common-breadcrumbs.umd.js.map +1 -1
- package/bundles/theseam-ui-common-data-exporter.umd.js.map +1 -1
- package/bundles/theseam-ui-common-datatable.umd.js +54 -4
- package/bundles/theseam-ui-common-datatable.umd.js.map +1 -1
- package/bundles/theseam-ui-common-framework.umd.js +2 -2
- package/bundles/theseam-ui-common-framework.umd.js.map +1 -1
- package/bundles/theseam-ui-common-shared.umd.js +20 -6
- package/bundles/theseam-ui-common-shared.umd.js.map +1 -1
- package/bundles/theseam-ui-common-unsaved-changes-dialog.umd.js +1 -0
- package/bundles/theseam-ui-common-unsaved-changes-dialog.umd.js.map +1 -1
- package/bundles/theseam-ui-common-utils.umd.js +82 -1
- package/bundles/theseam-ui-common-utils.umd.js.map +1 -1
- package/bundles/theseam-ui-common-validators.umd.js +54 -4
- package/bundles/theseam-ui-common-validators.umd.js.map +1 -1
- package/data-exporter/data-exporter.d.ts +4 -0
- package/data-exporter/theseam-ui-common-data-exporter.metadata.json +1 -1
- package/datatable/datatable/datatable.component.d.ts +2 -0
- package/datatable/datatable-footer/datatable-footer-tpl.directive.d.ts +5 -0
- package/datatable/datatable-footer/datatable-footer.directive.d.ts +6 -0
- package/datatable/public-api.d.ts +2 -0
- package/datatable/theseam-ui-common-datatable.metadata.json +1 -1
- package/esm2015/breadcrumbs/breadcrumb.js +1 -1
- package/esm2015/breadcrumbs/breadcrumbs/breadcrumbs.component.js +1 -1
- package/esm2015/breadcrumbs/breadcrumbs-resolver.js +1 -1
- package/esm2015/breadcrumbs/breadcrumbs.service.js +133 -15
- package/esm2015/data-exporter/data-exporter.js +1 -1
- package/esm2015/datatable/datatable/datatable.component.js +5 -3
- package/esm2015/datatable/datatable-export-button/datatable-export-button.component.js +8 -3
- package/esm2015/datatable/datatable-footer/datatable-footer-tpl.directive.js +15 -0
- package/esm2015/datatable/datatable-footer/datatable-footer.directive.js +18 -0
- package/esm2015/datatable/datatable.module.js +7 -1
- package/esm2015/datatable/public-api.js +3 -1
- package/esm2015/framework/side-nav/side-nav-item/side-nav-item.component.js +3 -3
- package/esm2015/shared/directives/ng-select-extra.directive.js +16 -3
- package/esm2015/shared/pipes/mask-chars.pipe.js +2 -2
- package/esm2015/unsaved-changes-dialog/unsaved-changes-can-deactivate.js +3 -2
- package/esm2015/utils/create-padding.js +17 -0
- package/esm2015/utils/form/is-empty-input-value.js +6 -0
- package/esm2015/utils/fractional-digits-count.js +19 -0
- package/esm2015/utils/is-numeric.js +4 -0
- package/esm2015/utils/pad-end.js +9 -0
- package/esm2015/utils/pad-start.js +9 -0
- package/esm2015/utils/public-api.js +7 -1
- package/esm2015/utils/router/index.js +3 -1
- package/esm2015/utils/router/is-empty-url-route.js +4 -0
- package/esm2015/utils/router/leaf-child-route.js +1 -1
- package/esm2015/utils/router/operators/activated-routes-with-data-property.js +3 -8
- package/esm2015/utils/router/will-have-data-prop.js +10 -0
- package/esm2015/validators/decimal.validator.js +25 -0
- package/esm2015/validators/integer.validator.js +25 -0
- package/esm2015/validators/public-api.js +3 -1
- package/fesm2015/theseam-ui-common-breadcrumbs.js +132 -14
- package/fesm2015/theseam-ui-common-breadcrumbs.js.map +1 -1
- package/fesm2015/theseam-ui-common-data-exporter.js.map +1 -1
- package/fesm2015/theseam-ui-common-datatable.js +45 -5
- package/fesm2015/theseam-ui-common-datatable.js.map +1 -1
- package/fesm2015/theseam-ui-common-framework.js +2 -2
- package/fesm2015/theseam-ui-common-framework.js.map +1 -1
- package/fesm2015/theseam-ui-common-shared.js +15 -2
- package/fesm2015/theseam-ui-common-shared.js.map +1 -1
- package/fesm2015/theseam-ui-common-unsaved-changes-dialog.js +1 -0
- package/fesm2015/theseam-ui-common-unsaved-changes-dialog.js.map +1 -1
- package/fesm2015/theseam-ui-common-utils.js +71 -2
- package/fesm2015/theseam-ui-common-utils.js.map +1 -1
- package/fesm2015/theseam-ui-common-validators.js +49 -1
- package/fesm2015/theseam-ui-common-validators.js.map +1 -1
- package/framework/side-nav/side-nav-item/side-nav-item.component.scss +36 -9
- package/framework/theseam-ui-common-framework.metadata.json +1 -1
- package/package.json +1 -1
- package/shared/directives/ng-select-extra.directive.d.ts +1 -0
- package/shared/theseam-ui-common-shared.metadata.json +1 -1
- package/styles/common/_table.scss +0 -5
- package/styles/vendor/ngx-datatable/_ngx-datatable.scss +475 -87
- package/styles/vendor/ngx-datatable/_themes/bootstrap/_variables.scss +173 -0
- package/styles/vendor/ngx-datatable/_themes/dark/_variables.scss +166 -0
- package/styles/vendor/ngx-datatable/_themes/material/_variables.scss +165 -0
- package/styles/vendor/ngx-datatable/_variables.scss +3 -0
- package/unsaved-changes-dialog/theseam-ui-common-unsaved-changes-dialog.metadata.json +1 -1
- package/utils/create-padding.d.ts +1 -0
- package/utils/form/is-empty-input-value.d.ts +1 -0
- package/utils/fractional-digits-count.d.ts +8 -0
- package/utils/is-numeric.d.ts +1 -0
- package/utils/pad-end.d.ts +1 -0
- package/utils/pad-start.d.ts +1 -0
- package/utils/public-api.d.ts +6 -0
- package/utils/router/index.d.ts +2 -0
- package/utils/router/is-empty-url-route.d.ts +2 -0
- package/utils/router/will-have-data-prop.d.ts +2 -0
- package/utils/theseam-ui-common-utils.metadata.json +1 -1
- package/validators/decimal.validator.d.ts +9 -0
- package/validators/integer.validator.d.ts +9 -0
- package/validators/public-api.d.ts +2 -0
- package/validators/theseam-ui-common-validators.metadata.json +1 -1
|
@@ -31,7 +31,12 @@ export class DatatableExportButtonComponent {
|
|
|
31
31
|
this._toastr.error(msg, 'Data Export');
|
|
32
32
|
}
|
|
33
33
|
const export$ = this._datatable.rows$
|
|
34
|
-
.pipe(take(1), map(rows =>
|
|
34
|
+
.pipe(take(1), map(rows => {
|
|
35
|
+
if (exporter.skipDataMapping) {
|
|
36
|
+
return rows;
|
|
37
|
+
}
|
|
38
|
+
return this._mapExportData(this._datatable.columns || [], rows);
|
|
39
|
+
}), concatMap(data => exporter.export(data)), catchError(err => {
|
|
35
40
|
console.error(err);
|
|
36
41
|
return of(false);
|
|
37
42
|
}), tap(success => {
|
|
@@ -39,7 +44,7 @@ export class DatatableExportButtonComponent {
|
|
|
39
44
|
this._toastr.success(`${exporter.label} export complete.`, 'Data Export');
|
|
40
45
|
}
|
|
41
46
|
else {
|
|
42
|
-
this._toastr.
|
|
47
|
+
this._toastr.error(`${exporter.label} export failed.`, 'Data Export');
|
|
43
48
|
}
|
|
44
49
|
}));
|
|
45
50
|
this._loading.while(export$).subscribe();
|
|
@@ -90,4 +95,4 @@ DatatableExportButtonComponent.ctorParameters = () => [
|
|
|
90
95
|
DatatableExportButtonComponent.propDecorators = {
|
|
91
96
|
exporters: [{ type: Input }]
|
|
92
97
|
};
|
|
93
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
98
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datatable-export-button.component.js","sourceRoot":"","sources":["../../../../../projects/ui-common/datatable/datatable-export-button/datatable-export-button.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Inject, Input, isDevMode, OnInit, Optional } from '@angular/core'\nimport { of } from 'rxjs'\nimport { catchError, concatMap, map, take, tap } from 'rxjs/operators'\n\nimport { faFileDownload } from '@fortawesome/free-solid-svg-icons'\nimport { ToastrService } from 'ngx-toastr'\n\nimport { IDataExporter } from '@theseam/ui-common/data-exporter'\nimport { DynamicValueHelperService, THESEAM_DYNAMIC_DATA } from '@theseam/ui-common/dynamic'\nimport { TheSeamLoadingOverlayService } from '@theseam/ui-common/loading'\nimport { hasProperty } from '@theseam/ui-common/utils'\n\nimport { DatatableComponent, THESEAM_DATATABLE } from '../datatable/datatable.component'\nimport { TheSeamDatatableColumn } from '../models/table-column'\n\nexport interface IDatatableExportButtonData {\n  exporters: IDataExporter[]\n}\n\n@Component({\n  selector: 'seam-datatable-export-button',\n  templateUrl: './datatable-export-button.component.html',\n  styleUrls: ['./datatable-export-button.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DatatableExportButtonComponent implements OnInit {\n\n  icon = faFileDownload\n\n  @Input() exporters: IDataExporter[] | undefined | null\n\n  get disabled() {\n    return !(this.exporters && this.exporters.length > 0)\n  }\n\n  constructor(\n    @Inject(THESEAM_DATATABLE) private readonly _datatable: DatatableComponent,\n    private readonly _toastr: ToastrService,\n    private readonly _loading: TheSeamLoadingOverlayService,\n    private readonly _valueHelper: DynamicValueHelperService,\n    @Optional() @Inject(THESEAM_DYNAMIC_DATA) private readonly _data?: IDatatableExportButtonData\n  ) {\n    if (this._data && this._data.exporters) {\n      this.exporters = this._data.exporters\n    }\n  }\n\n  ngOnInit() { }\n\n  _onExporterClicked(exporter: IDataExporter) {\n    if (!exporter.export) {\n      const msg = isDevMode()\n        ? `Exporter '${exporter.name}' is missing an export method.`\n        : `${exporter.label} export is not available.`\n      this._toastr.error(msg, 'Data Export')\n    }\n\n    const export$ = this._datatable.rows$\n      .pipe(\n        take(1),\n        map(rows => {\n          if (exporter.skipDataMapping) {\n            return rows\n          }\n          return this._mapExportData(this._datatable.columns || [], rows)\n        }),\n        concatMap(data => exporter.export(data)),\n        catchError(err => {\n          console.error(err)\n          return of(false)\n        }),\n        tap(success => {\n          if (success) {\n            this._toastr.success(`${exporter.label} export complete.`, 'Data Export')\n          } else {\n            this._toastr.error(`${exporter.label} export failed.`, 'Data Export')\n          }\n        })\n      )\n\n    this._loading.while(export$).subscribe()\n  }\n\n  private _mapExportData(columns: TheSeamDatatableColumn[], rows: any[]) {\n    const data: any[] = []\n\n    for (const row of rows) {\n      const newRow: any = {}\n\n      for (const col of columns) {\n        if (!col.exportIgnore) {\n          const colName = col.exportHeader || col.name || col.prop\n          if (colName) {\n            newRow[colName] = this._rowValue(col, row)\n          }\n        }\n      }\n\n      data.push(newRow)\n    }\n\n    return data\n  }\n\n  private _rowValue(column: TheSeamDatatableColumn, row: any) {\n    if (hasProperty(column as any, 'exportValue')) {\n      const context = { value: column.prop ? row[column.prop] : undefined, row }\n      return this._valueHelper.evalSync((column as any).exportValue, context)\n    }\n\n    const colProp = column.prop\n    if (colProp) {\n      return row[colProp]\n    }\n    return undefined\n  }\n\n}\n"]}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { Directive, TemplateRef } from '@angular/core';
|
|
2
|
+
export class DatatableFooterTplDirective {
|
|
3
|
+
constructor(template) {
|
|
4
|
+
this.template = template;
|
|
5
|
+
}
|
|
6
|
+
}
|
|
7
|
+
DatatableFooterTplDirective.decorators = [
|
|
8
|
+
{ type: Directive, args: [{
|
|
9
|
+
selector: '[seamDatatableFooterTpl]'
|
|
10
|
+
},] }
|
|
11
|
+
];
|
|
12
|
+
DatatableFooterTplDirective.ctorParameters = () => [
|
|
13
|
+
{ type: TemplateRef }
|
|
14
|
+
];
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YXRhYmxlLWZvb3Rlci10cGwuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWktY29tbW9uL2RhdGF0YWJsZS9kYXRhdGFibGUtZm9vdGVyL2RhdGF0YWJsZS1mb290ZXItdHBsLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUt0RCxNQUFNLE9BQU8sMkJBQTJCO0lBRXRDLFlBQW1CLFFBQTBCO1FBQTFCLGFBQVEsR0FBUixRQUFRLENBQWtCO0lBQUksQ0FBQzs7O1lBTG5ELFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsMEJBQTBCO2FBQ3JDOzs7WUFKbUIsV0FBVyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgVGVtcGxhdGVSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJ1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbc2VhbURhdGF0YWJsZUZvb3RlclRwbF0nXG59KVxuZXhwb3J0IGNsYXNzIERhdGF0YWJsZUZvb3RlclRwbERpcmVjdGl2ZSB7XG5cbiAgY29uc3RydWN0b3IocHVibGljIHRlbXBsYXRlOiBUZW1wbGF0ZVJlZjxhbnk+KSB7IH1cblxufVxuIl19
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { ContentChild, Directive, Input, TemplateRef } from '@angular/core';
|
|
2
|
+
import { DatatableFooterTplDirective } from './datatable-footer-tpl.directive';
|
|
3
|
+
export class TheSeamDatatableFooterDirective {
|
|
4
|
+
get template() {
|
|
5
|
+
return this._templateInput || this._templateQuery;
|
|
6
|
+
}
|
|
7
|
+
}
|
|
8
|
+
TheSeamDatatableFooterDirective.decorators = [
|
|
9
|
+
{ type: Directive, args: [{
|
|
10
|
+
// tslint:disable-next-line: directive-selector
|
|
11
|
+
selector: 'seam-datatable-footer'
|
|
12
|
+
},] }
|
|
13
|
+
];
|
|
14
|
+
TheSeamDatatableFooterDirective.propDecorators = {
|
|
15
|
+
_templateInput: [{ type: Input, args: ['template',] }],
|
|
16
|
+
_templateQuery: [{ type: ContentChild, args: [DatatableFooterTplDirective, { read: TemplateRef, static: true },] }]
|
|
17
|
+
};
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YXRhYmxlLWZvb3Rlci5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS1jb21tb24vZGF0YXRhYmxlL2RhdGF0YWJsZS1mb290ZXIvZGF0YXRhYmxlLWZvb3Rlci5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLFdBQVcsRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUUzRSxPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQTtBQU05RSxNQUFNLE9BQU8sK0JBQStCO0lBUzFDLElBQUksUUFBUTtRQUNWLE9BQU8sSUFBSSxDQUFDLGNBQWMsSUFBSSxJQUFJLENBQUMsY0FBYyxDQUFBO0lBQ25ELENBQUM7OztZQWZGLFNBQVMsU0FBQztnQkFDVCwrQ0FBK0M7Z0JBQy9DLFFBQVEsRUFBRSx1QkFBdUI7YUFDbEM7Ozs2QkFJRSxLQUFLLFNBQUMsVUFBVTs2QkFHaEIsWUFBWSxTQUFDLDJCQUEyQixFQUFFLEVBQUUsSUFBSSxFQUFFLFdBQVcsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29udGVudENoaWxkLCBEaXJlY3RpdmUsIElucHV0LCBUZW1wbGF0ZVJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5cbmltcG9ydCB7IERhdGF0YWJsZUZvb3RlclRwbERpcmVjdGl2ZSB9IGZyb20gJy4vZGF0YXRhYmxlLWZvb3Rlci10cGwuZGlyZWN0aXZlJ1xuXG5ARGlyZWN0aXZlKHtcbiAgLy8gdHNsaW50OmRpc2FibGUtbmV4dC1saW5lOiBkaXJlY3RpdmUtc2VsZWN0b3JcbiAgc2VsZWN0b3I6ICdzZWFtLWRhdGF0YWJsZS1mb290ZXInXG59KVxuZXhwb3J0IGNsYXNzIFRoZVNlYW1EYXRhdGFibGVGb290ZXJEaXJlY3RpdmUge1xuXG4gIC8vIHRzbGludDpkaXNhYmxlLW5leHQtbGluZTogbm8taW5wdXQtcmVuYW1lXG4gIEBJbnB1dCgndGVtcGxhdGUnKVxuICBfdGVtcGxhdGVJbnB1dDogVGVtcGxhdGVSZWY8YW55PiB8IHVuZGVmaW5lZCB8IG51bGxcblxuICBAQ29udGVudENoaWxkKERhdGF0YWJsZUZvb3RlclRwbERpcmVjdGl2ZSwgeyByZWFkOiBUZW1wbGF0ZVJlZiwgc3RhdGljOiB0cnVlIH0pXG4gIF90ZW1wbGF0ZVF1ZXJ5OiBUZW1wbGF0ZVJlZjxhbnk+IHwgdW5kZWZpbmVkIHwgbnVsbFxuXG4gIGdldCB0ZW1wbGF0ZSgpOiBUZW1wbGF0ZVJlZjxhbnk+IHwgdW5kZWZpbmVkIHwgbnVsbCB7XG4gICAgcmV0dXJuIHRoaXMuX3RlbXBsYXRlSW5wdXQgfHwgdGhpcy5fdGVtcGxhdGVRdWVyeVxuICB9XG5cbn1cbiJdfQ==
|
|
@@ -24,6 +24,8 @@ import { DatatableColumnPreferencesButtonComponent } from './datatable-column-pr
|
|
|
24
24
|
import { DatatableColumnPreferencesComponent } from './datatable-column-preferences/datatable-column-preferences.component';
|
|
25
25
|
import { DatatableColumnComponent } from './datatable-column/datatable-column.component';
|
|
26
26
|
import { DatatableExportButtonComponent } from './datatable-export-button/datatable-export-button.component';
|
|
27
|
+
import { DatatableFooterTplDirective } from './datatable-footer/datatable-footer-tpl.directive';
|
|
28
|
+
import { TheSeamDatatableFooterDirective } from './datatable-footer/datatable-footer.directive';
|
|
27
29
|
import { DatatableMenuBarColumnCenterComponent } from './datatable-menu-bar-column-center/datatable-menu-bar-column-center.component';
|
|
28
30
|
import { DatatableMenuBarColumnLeftComponent } from './datatable-menu-bar-column-left/datatable-menu-bar-column-left.component';
|
|
29
31
|
import { DatatableMenuBarColumnRightComponent } from './datatable-menu-bar-column-right/datatable-menu-bar-column-right.component';
|
|
@@ -56,6 +58,8 @@ TheSeamDatatableModule.decorators = [
|
|
|
56
58
|
DatatableExportButtonComponent,
|
|
57
59
|
TheSeamDatatableRowDetailDirective,
|
|
58
60
|
DatatableRowDetailTplDirective,
|
|
61
|
+
TheSeamDatatableFooterDirective,
|
|
62
|
+
DatatableFooterTplDirective,
|
|
59
63
|
DatatableColumnPreferencesComponent,
|
|
60
64
|
DatatableColumnPreferencesButtonComponent,
|
|
61
65
|
DatatableActionMenuItemDirective,
|
|
@@ -98,6 +102,8 @@ TheSeamDatatableModule.decorators = [
|
|
|
98
102
|
DatatableExportButtonComponent,
|
|
99
103
|
TheSeamDatatableRowDetailDirective,
|
|
100
104
|
DatatableRowDetailTplDirective,
|
|
105
|
+
TheSeamDatatableFooterDirective,
|
|
106
|
+
DatatableFooterTplDirective,
|
|
101
107
|
DatatableColumnPreferencesComponent,
|
|
102
108
|
DatatableColumnPreferencesButtonComponent,
|
|
103
109
|
DatatableActionMenuItemDirective,
|
|
@@ -117,4 +123,4 @@ TheSeamDatatableModule.decorators = [
|
|
|
117
123
|
]
|
|
118
124
|
},] }
|
|
119
125
|
];
|
|
120
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datatable.module.js","sourceRoot":"","sources":["../../../../projects/ui-common/datatable/datatable.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { A11yModule } from '@angular/cdk/a11y'\nimport { OverlayModule } from '@angular/cdk/overlay'\nimport { PortalModule } from '@angular/cdk/portal'\nimport { CommonModule } from '@angular/common'\nimport { NgModule } from '@angular/core'\nimport { ReactiveFormsModule } from '@angular/forms'\nimport { RouterModule } from '@angular/router'\n\nimport { FontAwesomeModule } from '@fortawesome/angular-fontawesome'\nimport { NgxDatatableModule, ScrollbarHelper } from '@marklb/ngx-datatable'\nimport { ToastrModule } from 'ngx-toastr'\n\nimport { TheSeamButtonsModule } from '@theseam/ui-common/buttons'\nimport { TheSeamCheckboxModule } from '@theseam/ui-common/checkbox'\nimport { TheSeamConfirmDialogModule } from '@theseam/ui-common/confirm-dialog'\nimport { TheSeamFormFieldModule } from '@theseam/ui-common/form-field'\nimport { TheSeamIconModule } from '@theseam/ui-common/icon'\nimport { TheSeamLoadingModule } from '@theseam/ui-common/loading'\nimport { TheSeamMenuModule } from '@theseam/ui-common/menu'\nimport { TheSeamPopoverModule } from '@theseam/ui-common/popover'\nimport { TheSeamSharedModule } from '@theseam/ui-common/shared'\nimport { TheSeamTableCellTypeModule } from '@theseam/ui-common/table-cell-type'\n\nimport { DatatableActionMenuItemComponent } from './datatable-action-menu-item/datatable-action-menu-item.component'\nimport { DatatableActionMenuComponent } from './datatable-action-menu/datatable-action-menu.component'\nimport { DatatableColumnPreferencesButtonComponent } from './datatable-column-preferences-button/datatable-column-preferences-button.component' // tslint:disable-line: max-line-length\nimport { DatatableColumnPreferencesComponent } from './datatable-column-preferences/datatable-column-preferences.component'\nimport { DatatableColumnComponent } from './datatable-column/datatable-column.component'\nimport { DatatableExportButtonComponent } from './datatable-export-button/datatable-export-button.component'\nimport { DatatableMenuBarColumnCenterComponent } from './datatable-menu-bar-column-center/datatable-menu-bar-column-center.component'\nimport { DatatableMenuBarColumnLeftComponent } from './datatable-menu-bar-column-left/datatable-menu-bar-column-left.component'\nimport { DatatableMenuBarColumnRightComponent } from './datatable-menu-bar-column-right/datatable-menu-bar-column-right.component'\nimport { DatatableMenuBarRowComponent } from './datatable-menu-bar-row/datatable-menu-bar-row.component'\nimport { DatatableMenuBarTextComponent } from './datatable-menu-bar-text/datatable-menu-bar-text.component'\nimport { DatatableMenuBarComponent } from './datatable-menu-bar/datatable-menu-bar.component'\nimport { DatatableRowDetailTplDirective } from './datatable-row-detail/datatable-row-detail-tpl.directive'\nimport { TheSeamDatatableRowDetailDirective } from './datatable-row-detail/datatable-row-detail.directive'\nimport { DatatableComponent } from './datatable/datatable.component'\nimport { DatatableActionMenuItemDirective } from './directives/datatable-action-menu-item.directive'\nimport { DatatableActionMenuToggleDirective } from './directives/datatable-action-menu-toggle.directive'\nimport { DatatableCellTplDirective } from './directives/datatable-cell-tpl.directive'\nimport { DatatableFilterDirective } from './directives/datatable-filter.directive'\nimport { DatatableRowActionItemDirective } from './directives/datatable-row-action-item.directive'\nimport { TheSeamDatatableScrollbarHelperService } from './services/datatable-scrollbar-helper.service'\n\n@NgModule({\n  declarations: [\n    DatatableComponent,\n    DatatableCellTplDirective,\n    DatatableColumnComponent,\n    DatatableActionMenuComponent,\n    DatatableActionMenuToggleDirective,\n    DatatableActionMenuItemComponent,\n    DatatableMenuBarComponent,\n    DatatableFilterDirective,\n    DatatableRowActionItemDirective,\n    DatatableExportButtonComponent,\n    TheSeamDatatableRowDetailDirective,\n    DatatableRowDetailTplDirective,\n    DatatableColumnPreferencesComponent,\n    DatatableColumnPreferencesButtonComponent,\n    DatatableActionMenuItemDirective,\n    DatatableMenuBarRowComponent,\n    DatatableMenuBarColumnLeftComponent,\n    DatatableMenuBarColumnCenterComponent,\n    DatatableMenuBarColumnRightComponent,\n    DatatableMenuBarTextComponent,\n  ],\n  imports: [\n    CommonModule,\n    NgxDatatableModule,\n    FontAwesomeModule,\n    OverlayModule,\n    A11yModule,\n    TheSeamSharedModule,\n    RouterModule,\n    TheSeamMenuModule,\n    TheSeamButtonsModule,\n    TheSeamIconModule,\n    ToastrModule,\n    TheSeamLoadingModule,\n    PortalModule,\n    TheSeamConfirmDialogModule,\n    TheSeamPopoverModule,\n    TheSeamCheckboxModule,\n    TheSeamFormFieldModule,\n    ReactiveFormsModule,\n    TheSeamTableCellTypeModule\n  ],\n  exports: [\n    DatatableComponent,\n    DatatableCellTplDirective,\n    DatatableColumnComponent,\n    DatatableActionMenuComponent,\n    DatatableActionMenuItemComponent,\n    DatatableMenuBarComponent,\n    DatatableFilterDirective,\n    DatatableRowActionItemDirective,\n    DatatableExportButtonComponent,\n    TheSeamDatatableRowDetailDirective,\n    DatatableRowDetailTplDirective,\n    DatatableColumnPreferencesComponent,\n    DatatableColumnPreferencesButtonComponent,\n    DatatableActionMenuItemDirective,\n    DatatableMenuBarRowComponent,\n    DatatableMenuBarColumnLeftComponent,\n    DatatableMenuBarColumnCenterComponent,\n    DatatableMenuBarColumnRightComponent,\n    DatatableMenuBarTextComponent\n  ],\n  providers: [\n    { provide: ScrollbarHelper, useClass: TheSeamDatatableScrollbarHelperService }\n  ],\n  entryComponents: [\n    DatatableColumnPreferencesComponent,\n    DatatableExportButtonComponent,\n    DatatableMenuBarTextComponent\n  ]\n})\nexport class TheSeamDatatableModule { }\n"]}
|
|
126
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datatable.module.js","sourceRoot":"","sources":["../../../../projects/ui-common/datatable/datatable.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { A11yModule } from '@angular/cdk/a11y'\nimport { OverlayModule } from '@angular/cdk/overlay'\nimport { PortalModule } from '@angular/cdk/portal'\nimport { CommonModule } from '@angular/common'\nimport { NgModule } from '@angular/core'\nimport { ReactiveFormsModule } from '@angular/forms'\nimport { RouterModule } from '@angular/router'\n\nimport { FontAwesomeModule } from '@fortawesome/angular-fontawesome'\nimport { NgxDatatableModule, ScrollbarHelper } from '@marklb/ngx-datatable'\nimport { ToastrModule } from 'ngx-toastr'\n\nimport { TheSeamButtonsModule } from '@theseam/ui-common/buttons'\nimport { TheSeamCheckboxModule } from '@theseam/ui-common/checkbox'\nimport { TheSeamConfirmDialogModule } from '@theseam/ui-common/confirm-dialog'\nimport { TheSeamFormFieldModule } from '@theseam/ui-common/form-field'\nimport { TheSeamIconModule } from '@theseam/ui-common/icon'\nimport { TheSeamLoadingModule } from '@theseam/ui-common/loading'\nimport { TheSeamMenuModule } from '@theseam/ui-common/menu'\nimport { TheSeamPopoverModule } from '@theseam/ui-common/popover'\nimport { TheSeamSharedModule } from '@theseam/ui-common/shared'\nimport { TheSeamTableCellTypeModule } from '@theseam/ui-common/table-cell-type'\n\nimport { DatatableActionMenuItemComponent } from './datatable-action-menu-item/datatable-action-menu-item.component'\nimport { DatatableActionMenuComponent } from './datatable-action-menu/datatable-action-menu.component'\nimport { DatatableColumnPreferencesButtonComponent } from './datatable-column-preferences-button/datatable-column-preferences-button.component' // tslint:disable-line: max-line-length\nimport { DatatableColumnPreferencesComponent } from './datatable-column-preferences/datatable-column-preferences.component'\nimport { DatatableColumnComponent } from './datatable-column/datatable-column.component'\nimport { DatatableExportButtonComponent } from './datatable-export-button/datatable-export-button.component'\nimport { DatatableFooterTplDirective } from './datatable-footer/datatable-footer-tpl.directive'\nimport { TheSeamDatatableFooterDirective } from './datatable-footer/datatable-footer.directive'\nimport { DatatableMenuBarColumnCenterComponent } from './datatable-menu-bar-column-center/datatable-menu-bar-column-center.component'\nimport { DatatableMenuBarColumnLeftComponent } from './datatable-menu-bar-column-left/datatable-menu-bar-column-left.component'\nimport { DatatableMenuBarColumnRightComponent } from './datatable-menu-bar-column-right/datatable-menu-bar-column-right.component'\nimport { DatatableMenuBarRowComponent } from './datatable-menu-bar-row/datatable-menu-bar-row.component'\nimport { DatatableMenuBarTextComponent } from './datatable-menu-bar-text/datatable-menu-bar-text.component'\nimport { DatatableMenuBarComponent } from './datatable-menu-bar/datatable-menu-bar.component'\nimport { DatatableRowDetailTplDirective } from './datatable-row-detail/datatable-row-detail-tpl.directive'\nimport { TheSeamDatatableRowDetailDirective } from './datatable-row-detail/datatable-row-detail.directive'\nimport { DatatableComponent } from './datatable/datatable.component'\nimport { DatatableActionMenuItemDirective } from './directives/datatable-action-menu-item.directive'\nimport { DatatableActionMenuToggleDirective } from './directives/datatable-action-menu-toggle.directive'\nimport { DatatableCellTplDirective } from './directives/datatable-cell-tpl.directive'\nimport { DatatableFilterDirective } from './directives/datatable-filter.directive'\nimport { DatatableRowActionItemDirective } from './directives/datatable-row-action-item.directive'\nimport { TheSeamDatatableScrollbarHelperService } from './services/datatable-scrollbar-helper.service'\n\n@NgModule({\n  declarations: [\n    DatatableComponent,\n    DatatableCellTplDirective,\n    DatatableColumnComponent,\n    DatatableActionMenuComponent,\n    DatatableActionMenuToggleDirective,\n    DatatableActionMenuItemComponent,\n    DatatableMenuBarComponent,\n    DatatableFilterDirective,\n    DatatableRowActionItemDirective,\n    DatatableExportButtonComponent,\n    TheSeamDatatableRowDetailDirective,\n    DatatableRowDetailTplDirective,\n    TheSeamDatatableFooterDirective,\n    DatatableFooterTplDirective,\n    DatatableColumnPreferencesComponent,\n    DatatableColumnPreferencesButtonComponent,\n    DatatableActionMenuItemDirective,\n    DatatableMenuBarRowComponent,\n    DatatableMenuBarColumnLeftComponent,\n    DatatableMenuBarColumnCenterComponent,\n    DatatableMenuBarColumnRightComponent,\n    DatatableMenuBarTextComponent,\n  ],\n  imports: [\n    CommonModule,\n    NgxDatatableModule,\n    FontAwesomeModule,\n    OverlayModule,\n    A11yModule,\n    TheSeamSharedModule,\n    RouterModule,\n    TheSeamMenuModule,\n    TheSeamButtonsModule,\n    TheSeamIconModule,\n    ToastrModule,\n    TheSeamLoadingModule,\n    PortalModule,\n    TheSeamConfirmDialogModule,\n    TheSeamPopoverModule,\n    TheSeamCheckboxModule,\n    TheSeamFormFieldModule,\n    ReactiveFormsModule,\n    TheSeamTableCellTypeModule\n  ],\n  exports: [\n    DatatableComponent,\n    DatatableCellTplDirective,\n    DatatableColumnComponent,\n    DatatableActionMenuComponent,\n    DatatableActionMenuItemComponent,\n    DatatableMenuBarComponent,\n    DatatableFilterDirective,\n    DatatableRowActionItemDirective,\n    DatatableExportButtonComponent,\n    TheSeamDatatableRowDetailDirective,\n    DatatableRowDetailTplDirective,\n    TheSeamDatatableFooterDirective,\n    DatatableFooterTplDirective,\n    DatatableColumnPreferencesComponent,\n    DatatableColumnPreferencesButtonComponent,\n    DatatableActionMenuItemDirective,\n    DatatableMenuBarRowComponent,\n    DatatableMenuBarColumnLeftComponent,\n    DatatableMenuBarColumnCenterComponent,\n    DatatableMenuBarColumnRightComponent,\n    DatatableMenuBarTextComponent\n  ],\n  providers: [\n    { provide: ScrollbarHelper, useClass: TheSeamDatatableScrollbarHelperService }\n  ],\n  entryComponents: [\n    DatatableColumnPreferencesComponent,\n    DatatableExportButtonComponent,\n    DatatableMenuBarTextComponent\n  ]\n})\nexport class TheSeamDatatableModule { }\n"]}
|
|
@@ -5,6 +5,8 @@ export * from './datatable-column/datatable-column.component';
|
|
|
5
5
|
export * from './datatable-column-preferences/datatable-column-preferences.component';
|
|
6
6
|
export * from './datatable-column-preferences-button/datatable-column-preferences-button.component';
|
|
7
7
|
export * from './datatable-export-button/datatable-export-button.component';
|
|
8
|
+
export * from './datatable-footer/datatable-footer-tpl.directive';
|
|
9
|
+
export * from './datatable-footer/datatable-footer.directive';
|
|
8
10
|
export * from './datatable-menu-bar/datatable-menu-bar.component';
|
|
9
11
|
export * from './datatable-menu-bar-column-center/datatable-menu-bar-column-center.component';
|
|
10
12
|
export * from './datatable-menu-bar-column-left/datatable-menu-bar-column-left.component';
|
|
@@ -36,4 +38,4 @@ export * from './tokens/datatable-preferences-accessor';
|
|
|
36
38
|
export * from './tokens/menubar-item-data';
|
|
37
39
|
export * from './utils/with-stored-column-info';
|
|
38
40
|
export * from './datatable.module';
|
|
39
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
41
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi9kYXRhdGFibGUvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGlDQUFpQyxDQUFBO0FBQy9DLGNBQWMseURBQXlELENBQUE7QUFDdkUsY0FBYyxtRUFBbUUsQ0FBQTtBQUNqRixjQUFjLCtDQUErQyxDQUFBO0FBQzdELGNBQWMsdUVBQXVFLENBQUE7QUFDckYsY0FBYyxxRkFBcUYsQ0FBQTtBQUNuRyxjQUFjLDZEQUE2RCxDQUFBO0FBQzNFLGNBQWMsbURBQW1ELENBQUE7QUFDakUsY0FBYywrQ0FBK0MsQ0FBQTtBQUM3RCxjQUFjLG1EQUFtRCxDQUFBO0FBQ2pFLGNBQWMsK0VBQStFLENBQUE7QUFDN0YsY0FBYywyRUFBMkUsQ0FBQTtBQUN6RixjQUFjLDZFQUE2RSxDQUFBO0FBQzNGLGNBQWMsMkRBQTJELENBQUE7QUFDekUsY0FBYyw2REFBNkQsQ0FBQTtBQUMzRSxjQUFjLDJEQUEyRCxDQUFBO0FBQ3pFLGNBQWMsdURBQXVELENBQUE7QUFFckUsY0FBYyxtREFBbUQsQ0FBQTtBQUNqRSxjQUFjLHFEQUFxRCxDQUFBO0FBQ25FLGNBQWMsMkNBQTJDLENBQUE7QUFDekQsY0FBYyx5Q0FBeUMsQ0FBQTtBQUN2RCxjQUFjLGtEQUFrRCxDQUFBO0FBRWhFLGNBQWMsNkJBQTZCLENBQUE7QUFDM0MsY0FBYyxnQ0FBZ0MsQ0FBQTtBQUM5QyxjQUFjLG9DQUFvQyxDQUFBO0FBQ2xELGNBQWMsNEJBQTRCLENBQUE7QUFDMUMsY0FBYyxvQkFBb0IsQ0FBQTtBQUNsQyxjQUFjLCtCQUErQixDQUFBO0FBQzdDLGNBQWMsc0JBQXNCLENBQUE7QUFDcEMsY0FBYyx1QkFBdUIsQ0FBQTtBQUNyQyxjQUFjLHFCQUFxQixDQUFBO0FBQ25DLGNBQWMsb0JBQW9CLENBQUE7QUFDbEMsY0FBYyx1QkFBdUIsQ0FBQTtBQUVyQyxjQUFjLDZDQUE2QyxDQUFBO0FBQzNELGNBQWMsMENBQTBDLENBQUE7QUFDeEQsY0FBYywrQ0FBK0MsQ0FBQTtBQUU3RCxjQUFjLHlDQUF5QyxDQUFBO0FBQ3ZELGNBQWMsNEJBQTRCLENBQUE7QUFFMUMsY0FBYyxpQ0FBaUMsQ0FBQTtBQUUvQyxjQUFjLG9CQUFvQixDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9kYXRhdGFibGUvZGF0YXRhYmxlLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vZGF0YXRhYmxlLWFjdGlvbi1tZW51L2RhdGF0YWJsZS1hY3Rpb24tbWVudS5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2RhdGF0YWJsZS1hY3Rpb24tbWVudS1pdGVtL2RhdGF0YWJsZS1hY3Rpb24tbWVudS1pdGVtLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vZGF0YXRhYmxlLWNvbHVtbi9kYXRhdGFibGUtY29sdW1uLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vZGF0YXRhYmxlLWNvbHVtbi1wcmVmZXJlbmNlcy9kYXRhdGFibGUtY29sdW1uLXByZWZlcmVuY2VzLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vZGF0YXRhYmxlLWNvbHVtbi1wcmVmZXJlbmNlcy1idXR0b24vZGF0YXRhYmxlLWNvbHVtbi1wcmVmZXJlbmNlcy1idXR0b24uY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9kYXRhdGFibGUtZXhwb3J0LWJ1dHRvbi9kYXRhdGFibGUtZXhwb3J0LWJ1dHRvbi5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2RhdGF0YWJsZS1mb290ZXIvZGF0YXRhYmxlLWZvb3Rlci10cGwuZGlyZWN0aXZlJ1xuZXhwb3J0ICogZnJvbSAnLi9kYXRhdGFibGUtZm9vdGVyL2RhdGF0YWJsZS1mb290ZXIuZGlyZWN0aXZlJ1xuZXhwb3J0ICogZnJvbSAnLi9kYXRhdGFibGUtbWVudS1iYXIvZGF0YXRhYmxlLW1lbnUtYmFyLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vZGF0YXRhYmxlLW1lbnUtYmFyLWNvbHVtbi1jZW50ZXIvZGF0YXRhYmxlLW1lbnUtYmFyLWNvbHVtbi1jZW50ZXIuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9kYXRhdGFibGUtbWVudS1iYXItY29sdW1uLWxlZnQvZGF0YXRhYmxlLW1lbnUtYmFyLWNvbHVtbi1sZWZ0LmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vZGF0YXRhYmxlLW1lbnUtYmFyLWNvbHVtbi1yaWdodC9kYXRhdGFibGUtbWVudS1iYXItY29sdW1uLXJpZ2h0LmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vZGF0YXRhYmxlLW1lbnUtYmFyLXJvdy9kYXRhdGFibGUtbWVudS1iYXItcm93LmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vZGF0YXRhYmxlLW1lbnUtYmFyLXRleHQvZGF0YXRhYmxlLW1lbnUtYmFyLXRleHQuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9kYXRhdGFibGUtcm93LWRldGFpbC9kYXRhdGFibGUtcm93LWRldGFpbC10cGwuZGlyZWN0aXZlJ1xuZXhwb3J0ICogZnJvbSAnLi9kYXRhdGFibGUtcm93LWRldGFpbC9kYXRhdGFibGUtcm93LWRldGFpbC5kaXJlY3RpdmUnXG5cbmV4cG9ydCAqIGZyb20gJy4vZGlyZWN0aXZlcy9kYXRhdGFibGUtYWN0aW9uLW1lbnUtaXRlbS5kaXJlY3RpdmUnXG5leHBvcnQgKiBmcm9tICcuL2RpcmVjdGl2ZXMvZGF0YXRhYmxlLWFjdGlvbi1tZW51LXRvZ2dsZS5kaXJlY3RpdmUnXG5leHBvcnQgKiBmcm9tICcuL2RpcmVjdGl2ZXMvZGF0YXRhYmxlLWNlbGwtdHBsLmRpcmVjdGl2ZSdcbmV4cG9ydCAqIGZyb20gJy4vZGlyZWN0aXZlcy9kYXRhdGFibGUtZmlsdGVyLmRpcmVjdGl2ZSdcbmV4cG9ydCAqIGZyb20gJy4vZGlyZWN0aXZlcy9kYXRhdGFibGUtcm93LWFjdGlvbi1pdGVtLmRpcmVjdGl2ZSdcblxuZXhwb3J0ICogZnJvbSAnLi9tb2RlbHMvZGF0YXRhYmxlLWFjY2Vzc29yJ1xuZXhwb3J0ICogZnJvbSAnLi9tb2RlbHMvZGF0YXRhYmxlLWRhdGEtc291cmNlJ1xuZXhwb3J0ICogZnJvbSAnLi9tb2RlbHMvZGF0YXRhYmxlLWdxbC1kYXRhLXNvdXJjZSdcbmV4cG9ydCAqIGZyb20gJy4vbW9kZWxzL21lbnViYXItaXRlbS1kYXRhJ1xuZXhwb3J0ICogZnJvbSAnLi9tb2RlbHMvcGFnZS1pbmZvJ1xuZXhwb3J0ICogZnJvbSAnLi9tb2RlbHMvcHJlZmVyZW5jZXMtYWNjZXNzb3InXG5leHBvcnQgKiBmcm9tICcuL21vZGVscy9wcmVmZXJlbmNlcydcbmV4cG9ydCAqIGZyb20gJy4vbW9kZWxzL3RhYmxlLWNvbHVtbidcbmV4cG9ydCAqIGZyb20gJy4vbW9kZWxzL3NvcnQtZXZlbnQnXG5leHBvcnQgKiBmcm9tICcuL21vZGVscy9zb3J0LWl0ZW0nXG5leHBvcnQgKiBmcm9tICcuL21vZGVscy90YWJsZS1jb2x1bW4nXG5cbmV4cG9ydCAqIGZyb20gJy4vc2VydmljZXMvZGF0YXRhYmxlLWNvbHVtbi1jaGFuZ2VzLnNlcnZpY2UnXG5leHBvcnQgKiBmcm9tICcuL3NlcnZpY2VzL2RhdGF0YWJsZS1wcmVmZXJlbmNlcy5zZXJ2aWNlJ1xuZXhwb3J0ICogZnJvbSAnLi9zZXJ2aWNlcy9kYXRhdGFibGUtc2Nyb2xsYmFyLWhlbHBlci5zZXJ2aWNlJ1xuXG5leHBvcnQgKiBmcm9tICcuL3Rva2Vucy9kYXRhdGFibGUtcHJlZmVyZW5jZXMtYWNjZXNzb3InXG5leHBvcnQgKiBmcm9tICcuL3Rva2Vucy9tZW51YmFyLWl0ZW0tZGF0YSdcblxuZXhwb3J0ICogZnJvbSAnLi91dGlscy93aXRoLXN0b3JlZC1jb2x1bW4taW5mbydcblxuZXhwb3J0ICogZnJvbSAnLi9kYXRhdGFibGUubW9kdWxlJ1xuIl19
|
|
@@ -80,7 +80,7 @@ export class SideNavItemComponent {
|
|
|
80
80
|
SideNavItemComponent.decorators = [
|
|
81
81
|
{ type: Component, args: [{
|
|
82
82
|
selector: 'seam-side-nav-item',
|
|
83
|
-
template: "<div class=\"d-flex flex-row\">\n <ng-container *ngIf=\"itemType === 'basic'\">\n <ng-template [ngTemplateOutlet]=\"itemTypeBasic\"></ng-template>\n </ng-container>\n <ng-container *ngIf=\"itemType === 'link'\">\n <ng-template [ngTemplateOutlet]=\"itemTypeLink\"></ng-template>\n </ng-container>\n <ng-container *ngIf=\"itemType === 'divider'\">\n <ng-template [ngTemplateOutlet]=\"itemTypeDivider\"></ng-template>\n </ng-container>\n <ng-container *ngIf=\"itemType === 'title'\">\n <ng-template [ngTemplateOutlet]=\"itemTypeTitle\"></ng-template>\n </ng-container>\n</div>\n\n<ng-container *ngIf=\"hasChildren\">\n <div class=\"side-nav--group side-nav--group--level-{{ hierLevel + 1 }}\"\n [@childGroupAnim]=\"childGroupAnimState$ | async\">\n <seam-side-nav-item *ngFor=\"let child of children\"\n [hierLevel]=\"compact ? 0 : (hierLevel + 1)\"\n [compact]=\"compact\"\n [itemType]=\"$any(child).itemType\"\n [icon]=\"$any(child).icon\"\n [label]=\"$any(child).label\"\n [link]=\"$any(child).link\"\n [badgeText]=\"$any(child).badge?.text\"\n [badgeTheme]=\"$any(child).badge?.theme || 'danger'\"\n [badgeSrContent]=\"$any(child).badge?.srContent\"\n [queryParams]=\"$any(child).queryParams\"\n routerLinkActive=\"active\"\n [routerLinkActiveOptions]=\"{ exact: true }\"\n [children]=\"$any(child)?.children\"\n [active]=\"$any(child).__state.active\"\n [expanded]=\"$any(child).__state.expanded\">\n </seam-side-nav-item>\n </div>\n</ng-container>\n\n<ng-template #itemTypeBasic>\n <button class=\"side-nav-item btn side-nav-btn p-0 d-flex flex-row rounded-0 text-decoration-none text-nowrap w-100\"\n cdkMonitorElementFocus\n (click)=\"toggleChildren()\"\n [attr.aria-expanded]=\"expanded\">\n <div class=\"nav-link d-flex flex-row w-100\" [class.
|
|
83
|
+
template: "<div class=\"d-flex flex-row\">\n <ng-container *ngIf=\"itemType === 'basic'\">\n <ng-template [ngTemplateOutlet]=\"itemTypeBasic\"></ng-template>\n </ng-container>\n <ng-container *ngIf=\"itemType === 'link'\">\n <ng-template [ngTemplateOutlet]=\"itemTypeLink\"></ng-template>\n </ng-container>\n <ng-container *ngIf=\"itemType === 'divider'\">\n <ng-template [ngTemplateOutlet]=\"itemTypeDivider\"></ng-template>\n </ng-container>\n <ng-container *ngIf=\"itemType === 'title'\">\n <ng-template [ngTemplateOutlet]=\"itemTypeTitle\"></ng-template>\n </ng-container>\n</div>\n\n<ng-container *ngIf=\"hasChildren\">\n <div class=\"side-nav--group side-nav--group--level-{{ hierLevel + 1 }}\"\n [@childGroupAnim]=\"childGroupAnimState$ | async\">\n <seam-side-nav-item *ngFor=\"let child of children\"\n [hierLevel]=\"compact ? 0 : (hierLevel + 1)\"\n [compact]=\"compact\"\n [itemType]=\"$any(child).itemType\"\n [icon]=\"$any(child).icon\"\n [label]=\"$any(child).label\"\n [link]=\"$any(child).link\"\n [badgeText]=\"$any(child).badge?.text\"\n [badgeTheme]=\"$any(child).badge?.theme || 'danger'\"\n [badgeSrContent]=\"$any(child).badge?.srContent\"\n [badgeTooltip]=\"$any(child)?.badge?.tooltip\"\n [queryParams]=\"$any(child).queryParams\"\n routerLinkActive=\"active\"\n [routerLinkActiveOptions]=\"{ exact: true }\"\n [children]=\"$any(child)?.children\"\n [active]=\"$any(child).__state.active\"\n [expanded]=\"$any(child).__state.expanded\">\n </seam-side-nav-item>\n </div>\n</ng-container>\n\n<ng-template #itemTypeBasic>\n <button class=\"side-nav-item btn side-nav-btn p-0 d-flex flex-row rounded-0 text-decoration-none text-nowrap w-100\"\n cdkMonitorElementFocus\n (click)=\"toggleChildren()\"\n [attr.aria-expanded]=\"expanded\">\n <div class=\"nav-link d-flex flex-row w-100\" [class.nav-link__compact]=\"compact\">\n <div [style.padding-left.px]=\"hierLevel * indentSize\"></div>\n <div class=\"side-nav-item--icon\">\n <seam-icon *ngIf=\"icon\" [icon]=\"icon\"></seam-icon>\n <ng-container *ngIf=\"compact\">\n <ng-template [ngTemplateOutlet]=\"itemBadge\"></ng-template>\n </ng-container>\n </div>\n <span *ngIf=\"!compact\" side-nav-item-label style=\"margin-left: 11px;\">\n {{ label }}\n </span>\n <span *ngIf=\"compact\" class=\"sr-only\" side-nav-item-label>{{ label }}</span>\n <ng-container *ngIf=\"!compact\">\n <ng-template [ngTemplateOutlet]=\"itemBadge\"></ng-template>\n </ng-container>\n </div>\n\n <div *ngIf=\"hasChildren && !compact\"\n class=\"btn side-nav-btn side-nav-item--toggle-btn-container rounded-0\">\n <seam-icon\n class=\"side-nav-item--toggle-btn\"\n [class.side-nav-item--toggle-btn-expanded]=\"expanded\"\n [icon]=\"faAngleLeft\"\n type>\n </seam-icon>\n </div>\n </button>\n</ng-template>\n\n<ng-template #itemTypeLink>\n <a *ngIf=\"link; else noLink\" class=\"side-nav-item nav-link d-flex flex-row text-nowrap w-100 align-items-center\"\n [class.nav-link__compact]=\"compact\"\n [routerLink]=\"link\"\n [queryParams]=\"queryParams\"\n routerLinkActive=\"active\"\n [routerLinkActiveOptions]=\"{ exact: true }\"\n (click)=\"_linkClicked()\">\n <div [style.padding-left.px]=\"hierLevel * indentSize\"></div>\n <div class=\"side-nav-item--icon\">\n <seam-icon *ngIf=\"icon\" [icon]=\"icon\"></seam-icon>\n <ng-container *ngIf=\"compact\">\n <ng-template [ngTemplateOutlet]=\"itemBadge\"></ng-template>\n </ng-container>\n </div>\n <span *ngIf=\"!compact\" style=\"margin-left: 11px;\" side-nav-item-label>\n {{ label }}\n </span>\n <span *ngIf=\"compact\" class=\"sr-only\" side-nav-item-label>{{ label }}</span>\n <ng-container *ngIf=\"!compact\">\n <ng-template [ngTemplateOutlet]=\"itemBadge\"></ng-template>\n </ng-container>\n </a>\n\n <ng-template #noLink>\n <a class=\"side-nav-item nav-link d-flex flex-row text-nowrap w-100 align-items-center\" [class.nav-link__compact]=\"compact\">\n <div [style.padding-left.px]=\"hierLevel * indentSize\"></div>\n <div class=\"side-nav-item--icon\">\n <seam-icon *ngIf=\"icon\" [icon]=\"icon\"></seam-icon>\n </div>\n <span *ngIf=\"!compact\" style=\"margin-left: 11px;\" side-nav-item-label>\n {{ label }}\n </span>\n <span *ngIf=\"compact\" class=\"sr-only\" side-nav-item-label>{{ label }}</span>\n </a>\n </ng-template>\n\n <button *ngIf=\"hasChildren && !compact\"\n type=\"button\"\n class=\"btn side-nav-btn side-nav-item--toggle-btn-container rounded-0\"\n (click)=\"toggleChildren()\"\n [attr.aria-expanded]=\"expanded\"\n cdkMonitorElementFocus>\n <seam-icon\n class=\"side-nav-item--toggle-btn\"\n [class.side-nav-item--toggle-btn-expanded]=\"expanded\"\n [icon]=\"faAngleLeft\"\n type>\n </seam-icon>\n <span class=\"sr-only\">Group Toggle</span>\n </button>\n</ng-template>\n\n<ng-template #itemTypeDivider>\n <div class=\"px-2 w-100\">\n <hr class=\"side-nav-item--divider\" />\n </div>\n</ng-template>\n\n<ng-template #itemTypeTitle>\n <ng-container *ngIf=\"!compact\">\n <span class=\"side-nav-item--title pt-1\" side-nav-item-label>{{ label }}</span>\n </ng-container>\n</ng-template>\n\n<ng-template #itemBadge>\n <ng-container *ngIf=\"badgeText\">\n <div class=\"badge-spacer flex-grow-1\" *ngIf=\"!compact\"></div>\n <div class=\"side-nav-item--badge\"\n [class.side-nav-item--badge-no-icon]=\"!icon\"\n [ngbTooltip]=\"$any(badgeTooltip)?.tooltip\"\n [tooltipClass]=\"$any(badgeTooltip)?.class\"\n [placement]=\"$any(badgeTooltip)?.placement\"\n [container]=\"$any(badgeTooltip)?.container\"\n [disableTooltip]=\"!badgeTooltip || !!$any(badgeTooltip)?.disabled\">\n <span class=\"badge badge-pill badge-{{ badgeTheme }}\">\n <ng-container *ngIf=\"!compact || !icon\">\n {{ badgeText }}\n </ng-container>\n <span *ngIf=\"badgeSrContent\">{{ badgeSrContent }}</span>\n </span>\n </div>\n </ng-container>\n</ng-template>\n",
|
|
84
84
|
exportAs: 'seamSideNavItem',
|
|
85
85
|
animations: [
|
|
86
86
|
trigger('childGroupAnim', [
|
|
@@ -113,7 +113,7 @@ SideNavItemComponent.decorators = [
|
|
|
113
113
|
],
|
|
114
114
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
115
115
|
encapsulation: ViewEncapsulation.None,
|
|
116
|
-
styles: ["seam-side-nav-item{display:block;transition:background-color .25s ease-in-out}seam-side-nav-item.seam-side-nav-item--active,seam-side-nav-item.seam-side-nav-item--active .active,seam-side-nav-item.seam-side-nav-item--active:active{background-color:#2a6395}seam-side-nav-item.seam-side-nav-item--active .side-nav-item:hover{background-color:#2f71a9}seam-side-nav-item.seam-side-nav-item--active .nav-link{color:#fff}seam-side-nav-item:not(.side-nav-item--icon) .side-nav-item--badge{
|
|
116
|
+
styles: ["seam-side-nav-item{display:block;transition:background-color .25s ease-in-out}seam-side-nav-item.seam-side-nav-item--active,seam-side-nav-item.seam-side-nav-item--active .active,seam-side-nav-item.seam-side-nav-item--active .side-nav-item.active:hover,seam-side-nav-item.seam-side-nav-item--active:active{background-color:#2a6395}seam-side-nav-item.seam-side-nav-item--active .side-nav-item:hover{background-color:#2f71a9}seam-side-nav-item.seam-side-nav-item--active .nav-link{color:#fff}seam-side-nav-item .badge{vertical-align:middle}seam-side-nav-item:not(.side-nav-item--icon) .side-nav-item--badge{pointer-events:all;margin-left:5px;margin-right:3px}seam-side-nav-item .side-nav-item--icon{position:relative;width:24px;max-width:24px;min-width:24px;height:24px;max-height:24px;min-height:24px;text-align:center}seam-side-nav-item .side-nav-item--icon .side-nav-item--badge{top:-4px;right:-4px;position:absolute}seam-side-nav-item .side-nav-item--icon .side-nav-item--badge .badge:empty{display:block;width:8px;height:8px;padding:0}seam-side-nav-item .side-nav-item--icon .side-nav-item--badge.side-nav-item--badge-no-icon{top:0;right:0}seam-side-nav-item .side-nav-item{min-height:45px;transition:background-color .25s ease-in-out}seam-side-nav-item .side-nav-item:hover{background-color:#2f71a9}seam-side-nav-item .side-nav-item.active{pointer-events:none;cursor:default}seam-side-nav-item a.side-nav-item:not([href]):not([tabindex]){color:#ccc}seam-side-nav-item a.side-nav-item:not([href]):not([tabindex]):hover{background-color:transparent}seam-side-nav-item .nav-link{color:#fff;padding-right:2px}seam-side-nav-item .nav-link__compact{padding-right:0;padding-left:12px}seam-side-nav-item .nav-link:last-child{padding-right:8px}seam-side-nav-item .side-nav-btn{font-weight:400;color:#fff;text-decoration:none}seam-side-nav-item .side-nav-btn:hover{color:#2f71a9;text-decoration:underline}seam-side-nav-item .side-nav-btn.focus,seam-side-nav-item .side-nav-btn:focus{text-decoration:underline;box-shadow:none}seam-side-nav-item .side-nav-btn.disabled,seam-side-nav-item .side-nav-btn:disabled{color:#ccc;pointer-events:none}seam-side-nav-item .cdk-keyboard-focused{outline:1px dotted;outline:5px auto -webkit-focus-ring-color}seam-side-nav-item .side-nav-item--toggle-btn-container{transition:background-color .25s ease-in-out;padding:.5rem 1rem}seam-side-nav-item button.side-nav-item--toggle-btn-container:hover{background-color:#2f71a9}seam-side-nav-item .side-nav-item--toggle-btn{color:#fff}seam-side-nav-item .side-nav-item--toggle-btn .svg-inline--fa{transition:transform .1s ease-in-out}seam-side-nav-item .side-nav-item--toggle-btn.side-nav-item--toggle-btn-expanded .svg-inline--fa{transform:rotate(-90deg)}seam-side-nav-item .side-nav--group{will-change:height;overflow:hidden}seam-side-nav-item .side-nav--group--level-1{background-color:#3276b1}seam-side-nav-item .side-nav--group--level-2{background-color:#2e6ea5}seam-side-nav-item .side-nav--group--level-3{background-color:#2b6699}seam-side-nav-item .side-nav--group--level-4{background-color:#285e8d}seam-side-nav-item .side-nav--group--level-5{background-color:#245681}seam-side-nav-item .side-nav--group--level-6{background-color:#214e75}seam-side-nav-item .side-nav--group--level-7{background-color:#1e4669}seam-side-nav-item .side-nav--group--level-8{background-color:#1a3e5d}seam-side-nav-item .side-nav--group--level-9{background-color:#173651}seam-side-nav-item .side-nav-item--divider{display:block;border-top:1px solid #2a6395;width:100%}seam-side-nav-item .side-nav-item--title{color:#fff;font-size:24px;padding-left:10px}seam-side-nav-item .sr-only{top:0;left:0}"]
|
|
117
117
|
},] }
|
|
118
118
|
];
|
|
119
119
|
SideNavItemComponent.ctorParameters = () => [
|
|
@@ -148,4 +148,4 @@ __decorate([
|
|
|
148
148
|
__decorate([
|
|
149
149
|
InputNumber(10)
|
|
150
150
|
], SideNavItemComponent.prototype, "indentSize", void 0);
|
|
151
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"side-nav-item.component.js","sourceRoot":"","sources":["../../../../../../projects/ui-common/framework/side-nav/side-nav-item/side-nav-item.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  animate,\n  query,\n  state,\n  style,\n  transition,\n  trigger,\n} from '@angular/animations'\nimport { BooleanInput, coerceBooleanProperty, NumberInput } from '@angular/cdk/coercion'\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  Host,\n  HostBinding,\n  Input,\n  OnDestroy,\n  Optional,\n  SkipSelf,\n  ViewEncapsulation\n} from '@angular/core'\nimport { BehaviorSubject, Observable, Subject } from 'rxjs'\nimport { map } from 'rxjs/operators'\n\nimport { faAngleLeft } from '@fortawesome/free-solid-svg-icons'\n\nimport { InputBoolean, InputNumber } from '@theseam/ui-common/core'\nimport type { SeamIcon } from '@theseam/ui-common/icon'\nimport type { ThemeTypes } from '@theseam/ui-common/models'\n\nimport { SideNavComponent } from '../side-nav.component'\nimport { ISideNavItem } from '../side-nav.models'\n\nexport interface SideNavItemBadgeTooltip {\n  tooltip?: string\n  class?: string\n  placement?: string\n  container?: string\n  disabled?: boolean\n}\n\nconst EXPANDED_STATE = 'expanded'\nconst COLLAPSED_STATE = 'collapsed'\n\nconst FULL_STATE = 'full'\nconst COMPACT_STATE = 'compact'\n\n@Component({\n  selector: 'seam-side-nav-item',\n  templateUrl: './side-nav-item.component.html',\n  styleUrls: ['./side-nav-item.component.scss'],\n  exportAs: 'seamSideNavItem',\n  animations: [\n    trigger('childGroupAnim', [\n      state(EXPANDED_STATE, style({ height: '*' })),\n      state(COLLAPSED_STATE, style({ height: 0, 'overflow-y': 'hidden', visibility: 'hidden' })),\n      transition(`${EXPANDED_STATE} <=> ${COLLAPSED_STATE}`, animate('0.2s ease-in-out')),\n    ]),\n\n\n    trigger('compactAnim', [\n      // transition('* <=> *', [\n      //   query(':enter', [\n      //     style({ opacity: '0' }),\n      //     animate('5.2s ease-in-out', style({ opacity: '1' }))\n      //   ], { optional: true }),\n      //   query(':leave', [\n      //     style({ opacity: '1' }),\n      //     animate('5.2s ease-in-out', style({ opacity: '0' }))\n      //   ], { optional: true })\n      // ])\n\n      // state(FULL_STATE, style({ opacity: '1' })),\n      // state(COMPACT_STATE, style({ opacity: '0' })),\n      // transition(`${FULL_STATE} <=> ${COMPACT_STATE}`, animate('5.2s ease-in-out')),\n      // transition(`${FULL_STATE} <=> ${COMPACT_STATE}`, [\n      // transition('* <=> *', [\n      //   query(':leave', [\n      //     style({ opacity: '1' }),\n      //     animate('5.2s ease-in-out', style({ opacity: '0' }))\n      //   ], { optional: true })\n      // ]),\n\n\n    ])\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None\n})\nexport class SideNavItemComponent implements OnDestroy {\n  static ngAcceptInputType_hierLevel: NumberInput\n  static ngAcceptInputType_indentSize: NumberInput\n  static ngAcceptInputType_expanded: BooleanInput\n  static ngAcceptInputType_compact: BooleanInput\n  static ngAcceptInputType_active: BooleanInput\n\n  private readonly _ngUnsubscribe = new Subject()\n\n  readonly faAngleLeft = faAngleLeft\n\n  @Input() itemType: 'divider' | 'basic' | 'link' | 'button' | 'title' | undefined | null\n\n  @Input() icon: SeamIcon | undefined | null\n\n  @Input() label: string | undefined | null\n\n  @Input() @InputBoolean() active: boolean = false\n\n  @Input()\n  set link(value: string | undefined | null) { this._link.next(value) }\n  get link() { return this._link.value }\n  private readonly _link = new BehaviorSubject<string | undefined | null>(undefined)\n  public readonly link$ = this._link.asObservable()\n\n  @Input() queryParams: { [k: string]: any } | undefined | null\n\n  @Input() children: ISideNavItem[] | undefined | null\n\n  @Input() @InputNumber(0) hierLevel: number = 0\n\n  @Input() @InputNumber(10) indentSize: number = 10\n\n  @Input()\n  set expanded(value: boolean) { this._expanded.next(coerceBooleanProperty(value)) }\n  get expanded() { return this._expanded.value }\n  private readonly _expanded = new BehaviorSubject<boolean>(false)\n  public readonly expanded$ = this._expanded.asObservable()\n\n  @Input()\n  set compact(value: boolean) { this._compact.next(coerceBooleanProperty(value)) }\n  get compact() { return this._compact.value }\n  private readonly _compact = new BehaviorSubject<boolean>(false)\n  public readonly compact$ = this._compact.asObservable()\n\n  @Input() badgeText: string | undefined | null\n  @Input() badgeTheme: ThemeTypes | undefined | null = 'danger'\n\n  /**\n   * Content to provide to assistive technology, such as screen readers.\n   */\n  @Input() badgeSrContent: string | undefined | null\n\n  @Input()\n  get badgeTooltip() { return this._badgeTooltip }\n  set badgeTooltip(value: string | SideNavItemBadgeTooltip | undefined | null) {\n    if (value !== null && value !== undefined) {\n      if (typeof value === 'string') {\n        this._badgeTooltip = {\n          tooltip: value,\n          placement: 'auto',\n          disabled: false\n        }\n      } else {\n        this._badgeTooltip = {\n          ...value,\n          placement: value.placement || 'auto',\n          disabled: typeof value?.disabled === 'boolean'\n            ? value.disabled\n            : typeof value.tooltip === 'string' ? false : true\n        }\n      }\n    } else {\n      this._badgeTooltip = undefined\n    }\n  }\n  private _badgeTooltip: SideNavItemBadgeTooltip | undefined | null\n\n  @HostBinding('class.seam-side-nav-item--active') get _isActiveCssClass() { return this.active }\n\n  @HostBinding('attr.data-hier-level') get _attrDataHierLevel() { return this.hierLevel }\n\n  public readonly childGroupAnimState$: Observable<string>\n  public readonly compactAnimState$: Observable<string>\n\n  constructor(\n    private readonly _sideNav: SideNavComponent,\n    @Optional() @SkipSelf() @Host() private readonly _parent?: SideNavItemComponent\n  ) {\n    this.childGroupAnimState$ = this.expanded$\n      .pipe(map(expanded => expanded ? EXPANDED_STATE : COLLAPSED_STATE))\n\n    this.compactAnimState$ = this.compact$\n      .pipe(map(compact => compact ? COMPACT_STATE : FULL_STATE))\n  }\n\n  ngOnDestroy() {\n    this._ngUnsubscribe.next()\n    this._ngUnsubscribe.complete()\n  }\n\n  get hasChildren() {\n    return Array.isArray(this.children) && this.children.length > 0\n  }\n\n  public toggleChildren(): void {\n    this.expanded = !this.expanded\n  }\n\n  _linkClicked() {\n    // Close nav when link is clicked while in overlay state\n    if (this._sideNav.overlay) {\n      this._sideNav.collapse()\n    }\n  }\n\n}\n"]}
|
|
151
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"side-nav-item.component.js","sourceRoot":"","sources":["../../../../../../projects/ui-common/framework/side-nav/side-nav-item/side-nav-item.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  animate,\n  query,\n  state,\n  style,\n  transition,\n  trigger,\n} from '@angular/animations'\nimport { BooleanInput, coerceBooleanProperty, NumberInput } from '@angular/cdk/coercion'\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  Host,\n  HostBinding,\n  Input,\n  OnDestroy,\n  Optional,\n  SkipSelf,\n  ViewEncapsulation\n} from '@angular/core'\nimport { BehaviorSubject, Observable, Subject } from 'rxjs'\nimport { map } from 'rxjs/operators'\n\nimport { faAngleLeft } from '@fortawesome/free-solid-svg-icons'\n\nimport { InputBoolean, InputNumber } from '@theseam/ui-common/core'\nimport type { SeamIcon } from '@theseam/ui-common/icon'\nimport type { ThemeTypes } from '@theseam/ui-common/models'\n\nimport { SideNavComponent } from '../side-nav.component'\nimport { ISideNavItem } from '../side-nav.models'\n\nexport interface SideNavItemBadgeTooltip {\n  tooltip?: string\n  class?: string\n  placement?: string\n  container?: string\n  disabled?: boolean\n}\n\nconst EXPANDED_STATE = 'expanded'\nconst COLLAPSED_STATE = 'collapsed'\n\nconst FULL_STATE = 'full'\nconst COMPACT_STATE = 'compact'\n\n@Component({\n  selector: 'seam-side-nav-item',\n  templateUrl: './side-nav-item.component.html',\n  styleUrls: ['./side-nav-item.component.scss'],\n  exportAs: 'seamSideNavItem',\n  animations: [\n    trigger('childGroupAnim', [\n      state(EXPANDED_STATE, style({ height: '*' })),\n      state(COLLAPSED_STATE, style({ height: 0, 'overflow-y': 'hidden', visibility: 'hidden' })),\n      transition(`${EXPANDED_STATE} <=> ${COLLAPSED_STATE}`, animate('0.2s ease-in-out')),\n    ]),\n\n\n    trigger('compactAnim', [\n      // transition('* <=> *', [\n      //   query(':enter', [\n      //     style({ opacity: '0' }),\n      //     animate('5.2s ease-in-out', style({ opacity: '1' }))\n      //   ], { optional: true }),\n      //   query(':leave', [\n      //     style({ opacity: '1' }),\n      //     animate('5.2s ease-in-out', style({ opacity: '0' }))\n      //   ], { optional: true })\n      // ])\n\n      // state(FULL_STATE, style({ opacity: '1' })),\n      // state(COMPACT_STATE, style({ opacity: '0' })),\n      // transition(`${FULL_STATE} <=> ${COMPACT_STATE}`, animate('5.2s ease-in-out')),\n      // transition(`${FULL_STATE} <=> ${COMPACT_STATE}`, [\n      // transition('* <=> *', [\n      //   query(':leave', [\n      //     style({ opacity: '1' }),\n      //     animate('5.2s ease-in-out', style({ opacity: '0' }))\n      //   ], { optional: true })\n      // ]),\n\n\n    ])\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None\n})\nexport class SideNavItemComponent implements OnDestroy {\n  static ngAcceptInputType_hierLevel: NumberInput\n  static ngAcceptInputType_indentSize: NumberInput\n  static ngAcceptInputType_expanded: BooleanInput\n  static ngAcceptInputType_compact: BooleanInput\n  static ngAcceptInputType_active: BooleanInput\n\n  private readonly _ngUnsubscribe = new Subject()\n\n  readonly faAngleLeft = faAngleLeft\n\n  @Input() itemType: 'divider' | 'basic' | 'link' | 'button' | 'title' | undefined | null\n\n  @Input() icon: SeamIcon | undefined | null\n\n  @Input() label: string | undefined | null\n\n  @Input() @InputBoolean() active: boolean = false\n\n  @Input()\n  set link(value: string | undefined | null) { this._link.next(value) }\n  get link() { return this._link.value }\n  private readonly _link = new BehaviorSubject<string | undefined | null>(undefined)\n  public readonly link$ = this._link.asObservable()\n\n  @Input() queryParams: { [k: string]: any } | undefined | null\n\n  @Input() children: ISideNavItem[] | undefined | null\n\n  @Input() @InputNumber(0) hierLevel: number = 0\n\n  @Input() @InputNumber(10) indentSize: number = 10\n\n  @Input()\n  set expanded(value: boolean) { this._expanded.next(coerceBooleanProperty(value)) }\n  get expanded() { return this._expanded.value }\n  private readonly _expanded = new BehaviorSubject<boolean>(false)\n  public readonly expanded$ = this._expanded.asObservable()\n\n  @Input()\n  set compact(value: boolean) { this._compact.next(coerceBooleanProperty(value)) }\n  get compact() { return this._compact.value }\n  private readonly _compact = new BehaviorSubject<boolean>(false)\n  public readonly compact$ = this._compact.asObservable()\n\n  @Input() badgeText: string | undefined | null\n  @Input() badgeTheme: ThemeTypes | undefined | null = 'danger'\n\n  /**\n   * Content to provide to assistive technology, such as screen readers.\n   */\n  @Input() badgeSrContent: string | undefined | null\n\n  @Input()\n  get badgeTooltip() { return this._badgeTooltip }\n  set badgeTooltip(value: string | SideNavItemBadgeTooltip | undefined | null) {\n    if (value !== null && value !== undefined) {\n      if (typeof value === 'string') {\n        this._badgeTooltip = {\n          tooltip: value,\n          placement: 'auto',\n          disabled: false\n        }\n      } else {\n        this._badgeTooltip = {\n          ...value,\n          placement: value.placement || 'auto',\n          disabled: typeof value?.disabled === 'boolean'\n            ? value.disabled\n            : typeof value.tooltip === 'string' ? false : true\n        }\n      }\n    } else {\n      this._badgeTooltip = undefined\n    }\n  }\n  private _badgeTooltip: SideNavItemBadgeTooltip | undefined | null\n\n  @HostBinding('class.seam-side-nav-item--active') get _isActiveCssClass() { return this.active }\n\n  @HostBinding('attr.data-hier-level') get _attrDataHierLevel() { return this.hierLevel }\n\n  public readonly childGroupAnimState$: Observable<string>\n  public readonly compactAnimState$: Observable<string>\n\n  constructor(\n    private readonly _sideNav: SideNavComponent,\n    @Optional() @SkipSelf() @Host() private readonly _parent?: SideNavItemComponent\n  ) {\n    this.childGroupAnimState$ = this.expanded$\n      .pipe(map(expanded => expanded ? EXPANDED_STATE : COLLAPSED_STATE))\n\n    this.compactAnimState$ = this.compact$\n      .pipe(map(compact => compact ? COMPACT_STATE : FULL_STATE))\n  }\n\n  ngOnDestroy() {\n    this._ngUnsubscribe.next()\n    this._ngUnsubscribe.complete()\n  }\n\n  get hasChildren() {\n    return Array.isArray(this.children) && this.children.length > 0\n  }\n\n  public toggleChildren(): void {\n    this.expanded = !this.expanded\n  }\n\n  _linkClicked() {\n    // Close nav when link is clicked while in overlay state\n    if (this._sideNav.overlay) {\n      this._sideNav.collapse()\n    }\n  }\n\n}\n"]}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { Directive, ElementRef, EventEmitter, HostBinding, HostListener, NgZone, Optional, Self } from '@angular/core';
|
|
2
2
|
import { NgControl } from '@angular/forms';
|
|
3
|
-
import { NgSelectComponent } from '@ng-select/ng-select';
|
|
4
|
-
import { ResizeSensor } from 'css-element-queries';
|
|
5
3
|
import { Subject } from 'rxjs';
|
|
6
4
|
import { filter, takeUntil } from 'rxjs/operators';
|
|
5
|
+
import { NgSelectComponent } from '@ng-select/ng-select';
|
|
6
|
+
import { ResizeSensor } from 'css-element-queries';
|
|
7
7
|
export class NgSelectExtraDirective {
|
|
8
8
|
constructor(elementRef, _ngZone, ngSelect, ngControl) {
|
|
9
9
|
this.elementRef = elementRef;
|
|
@@ -15,6 +15,17 @@ export class NgSelectExtraDirective {
|
|
|
15
15
|
this._checkMarked = false;
|
|
16
16
|
this._keyPressWorkaroundSub = null;
|
|
17
17
|
this._resizedEvent = new EventEmitter();
|
|
18
|
+
this._onScroll = (event) => {
|
|
19
|
+
if (this.ngSelect && this.ngSelect.isOpen) {
|
|
20
|
+
const isScrollingInScrollHost = event.target.className.indexOf('ng-dropdown-panel-items') !== -1;
|
|
21
|
+
const isInSensor = event.target.className.indexOf('resize-sensor-shrink') !== -1 ||
|
|
22
|
+
event.target.className.indexOf('os-resize-observer-host') !== -1;
|
|
23
|
+
if (isScrollingInScrollHost || isInSensor) {
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
this.ngSelect.close();
|
|
27
|
+
}
|
|
28
|
+
};
|
|
18
29
|
}
|
|
19
30
|
/**
|
|
20
31
|
* Set the tab index to `-1` to allow the root element of the ng-select
|
|
@@ -50,6 +61,7 @@ export class NgSelectExtraDirective {
|
|
|
50
61
|
.subscribe(v => this._enableKeyPressWorkaround());
|
|
51
62
|
this.ngSelect.blurEvent
|
|
52
63
|
.subscribe(v => this._disableKeyPressWorkaround());
|
|
64
|
+
window.addEventListener('scroll', this._onScroll, true);
|
|
53
65
|
// When the input is allowed to change its height the position doesn't update itself.
|
|
54
66
|
// this._resizedEvent.pipe(
|
|
55
67
|
// auditTime(30)
|
|
@@ -69,6 +81,7 @@ export class NgSelectExtraDirective {
|
|
|
69
81
|
ngOnDestroy() {
|
|
70
82
|
var _a;
|
|
71
83
|
(_a = this._resizeSensor) === null || _a === void 0 ? void 0 : _a.detach();
|
|
84
|
+
window.removeEventListener('scroll', this._onScroll, true);
|
|
72
85
|
this._ngUnsubscribe.next();
|
|
73
86
|
this._ngUnsubscribe.complete();
|
|
74
87
|
}
|
|
@@ -161,4 +174,4 @@ NgSelectExtraDirective.propDecorators = {
|
|
|
161
174
|
_isInvalid: [{ type: HostBinding, args: ['class.is-invalid',] }],
|
|
162
175
|
_isEmptyStringValue: [{ type: HostBinding, args: ['class.ng-empty-string-value',] }]
|
|
163
176
|
};
|
|
164
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ng-select-extra.directive.js","sourceRoot":"","sources":["../../../../../projects/ui-common/shared/directives/ng-select-extra.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewChecked, Directive, ElementRef, EventEmitter, HostBinding,\n  HostListener, NgZone, OnDestroy, OnInit, Optional, Self } from '@angular/core'\nimport { NgControl } from '@angular/forms'\nimport { NgOption, NgSelectComponent } from '@ng-select/ng-select'\nimport { ResizeSensor } from 'css-element-queries'\nimport { Subject, Subscription } from 'rxjs'\nimport { auditTime, filter, takeUntil } from 'rxjs/operators'\nimport { IElementResizedEvent } from './elem-resized.directive'\n\n@Directive({\n  // tslint:disable-next-line:directive-selector\n  selector: 'ng-select'\n})\nexport class NgSelectExtraDirective implements OnInit, AfterViewChecked, OnDestroy {\n\n  private readonly _ngUnsubscribe = new Subject()\n\n  private _markedItem: NgOption | null = null\n  private _checkMarked = false\n  private _keyPressWorkaroundSub: Subscription | null = null\n\n  private _resizedEvent = new EventEmitter<IElementResizedEvent>()\n  private _resizeSensor?: ResizeSensor\n\n  /**\n   * Set the tab index to `-1` to allow the root element of the ng-select\n   * component to receive `focus` event from javascript, but not get focused by\n   * keyboard navigation.\n   */\n  @HostBinding('attr.tabIndex')\n  get _tabIndex() { return this.ngSelect.disabled ? undefined : -1 }\n\n  /**\n   * Listening for focus event on root of component to allow javascript\n   * `focus()` function to trigger the components focus.\n   */\n  @HostListener('focus', ['$event']) onFocus($event: FocusEvent) {\n    const target = $event.target as HTMLElement\n    if (target === this.elementRef.nativeElement && !this.ngSelect.disabled) {\n      this.ngSelect.focus()\n    }\n\n    // ng-select has an input `labelForId` that sets the autocomplete attribute\n    // in ngOnInit. I am not positive that it is wrong by doing that, but this\n    // hack makes it set the attributes again on focus, because that gives the\n    // result I was expecting, since we don't manually set the `labelForId`\n    // input.\n    const _ngSelect = this.ngSelect as any\n    _ngSelect._setInputAttributes()\n  }\n\n  @HostBinding('class.is-invalid') get _isInvalid() {\n    return this.ngControl ? this.ngControl.invalid && (this.ngControl.dirty || this.ngControl.touched) : false\n  }\n\n  @HostBinding('class.ng-empty-string-value') get _isEmptyStringValue() {\n    return this.ngControl ? this.ngControl.value === '' ? true : false : false\n  }\n\n  constructor(\n    private readonly elementRef: ElementRef,\n    private readonly _ngZone: NgZone,\n    private readonly ngSelect: NgSelectComponent,\n    @Optional() @Self() public readonly ngControl: NgControl\n  ) { }\n\n  ngOnInit() {\n    this.ngSelect.focusEvent\n      .subscribe(v => this._enableKeyPressWorkaround())\n\n    this.ngSelect.blurEvent\n      .subscribe(v => this._disableKeyPressWorkaround())\n\n    // When the input is allowed to change its height the position doesn't update itself.\n    // this._resizedEvent.pipe(\n    //   auditTime(30)\n    // ).subscribe(event => {\n    //   if (this.elementRef && this.elementRef.nativeElement) {\n    //     if (this.elementRef.nativeElement.classList.contains('ng-select-value-grow-h')) {\n    //       if (this.ngSelect.isOpen && this.ngSelect.dropdownPanel) {\n    //         this.ngSelect.dropdownPanel.updateDropdownPosition()\n    //       }\n    //     } else {\n    //       this.elementRef.nativeElement.classList.remove('ng-select-value-grow-h')\n    //     }\n    //   }\n    // })\n\n    // this._patch_ngSelect_open()\n  }\n\n  ngOnDestroy() {\n    this._resizeSensor?.detach()\n\n    this._ngUnsubscribe.next()\n    this._ngUnsubscribe.complete()\n  }\n\n  ngAfterViewChecked() {\n    if (this.ngSelect.dropdownPanel) {\n      if (this._checkMarked) {\n        if (this.ngSelect.dropdownPanel && this._markedItem !== null) {\n          if (this._markedItem.index !== this.ngSelect.dropdownPanel.markedItem.index) {\n            this.ngSelect.dropdownPanel.scrollTo(this.ngSelect.dropdownPanel.markedItem)\n          }\n        }\n      }\n    }\n    this._checkMarked = false\n\n    this._resizeSensor = new ResizeSensor(this.elementRef.nativeElement, (event) => {\n      this._resizedEvent.emit({ element: this.elementRef.nativeElement, size: event })\n    })\n  }\n\n  /**\n   * Temp fix for: https://github.com/ng-select/ng-select/issues/1122\n   */\n  // private _patch_ngSelect_open() {\n  //   const original = this.ngSelect.open\n  //   const _self = this\n  //   this.ngSelect.open = function() {\n  //     original.apply(this, arguments)\n  //     _self._patch_ngSelectDropdownPanel_updateDropdownPosition()\n  //   }\n  // }\n\n  /** Should ONLY be called by `_patch_ngSelect_open`. */\n  // private _patch_ngSelectDropdownPanel_updateDropdownPosition() {\n  //   if (!this.ngSelect.dropdownPanel) { return }\n  //   const drop: any = this.ngSelect.dropdownPanel\n  //   // Only needed once, to update the position before the timeout in\n  //   // `updateDropdownPosition()`. So, using this variable to check if I already called\n  //   // `_updateAppendedDropdownPosition()`.\n  //   if (!drop.__libPatched) {\n  //     drop.__libPatched = 'patched'\n  //     const original = drop.updateDropdownPosition\n  //     const _self = this\n  //     drop.updateDropdownPosition = function() {\n  //       original.apply(this, arguments)\n  //       if (!!_self.ngSelect.appendTo) {\n  //         drop._updateAppendedDropdownPosition()\n  //       }\n  //     }\n  //   }\n  // }\n\n  private _enableKeyPressWorkaround() {\n    if (this._keyPressWorkaroundSub) { return }\n    const _ngSelect = <any>this.ngSelect\n\n    this._keyPressWorkaroundSub = _ngSelect._keyPress$\n      .pipe(takeUntil(this._ngUnsubscribe))\n      .pipe(filter(() => !this.ngSelect.searchable))\n      .subscribe(() => {\n        this._ngZone.runOutsideAngular(() => {\n          window.requestAnimationFrame(() => {\n            if (this.ngSelect.dropdownPanel) {\n              this._markedItem = this.ngSelect.dropdownPanel.markedItem\n            }\n            this._checkMarked = true\n          })\n        })\n      })\n  }\n\n  private _disableKeyPressWorkaround() {\n    if (this._keyPressWorkaroundSub) {\n      this._keyPressWorkaroundSub.unsubscribe()\n      this._keyPressWorkaroundSub = null\n    }\n  }\n\n}\n"]}
|
|
177
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ng-select-extra.directive.js","sourceRoot":"","sources":["../../../../../projects/ui-common/shared/directives/ng-select-extra.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewChecked, Directive, ElementRef, EventEmitter, HostBinding,\n  HostListener, NgZone, OnDestroy, OnInit, Optional, Self } from '@angular/core'\nimport { NgControl } from '@angular/forms'\nimport { Subject, Subscription } from 'rxjs'\nimport { filter, takeUntil } from 'rxjs/operators'\n\nimport { NgOption, NgSelectComponent } from '@ng-select/ng-select'\nimport { ResizeSensor } from 'css-element-queries'\n\nimport { IElementResizedEvent } from './elem-resized.directive'\n\n@Directive({\n  // tslint:disable-next-line:directive-selector\n  selector: 'ng-select'\n})\nexport class NgSelectExtraDirective implements OnInit, AfterViewChecked, OnDestroy {\n\n  private readonly _ngUnsubscribe = new Subject()\n\n  private _markedItem: NgOption | null = null\n  private _checkMarked = false\n  private _keyPressWorkaroundSub: Subscription | null = null\n\n  private _resizedEvent = new EventEmitter<IElementResizedEvent>()\n  private _resizeSensor?: ResizeSensor\n\n  /**\n   * Set the tab index to `-1` to allow the root element of the ng-select\n   * component to receive `focus` event from javascript, but not get focused by\n   * keyboard navigation.\n   */\n  @HostBinding('attr.tabIndex')\n  get _tabIndex() { return this.ngSelect.disabled ? undefined : -1 }\n\n  /**\n   * Listening for focus event on root of component to allow javascript\n   * `focus()` function to trigger the components focus.\n   */\n  @HostListener('focus', ['$event']) onFocus($event: FocusEvent) {\n    const target = $event.target as HTMLElement\n    if (target === this.elementRef.nativeElement && !this.ngSelect.disabled) {\n      this.ngSelect.focus()\n    }\n\n    // ng-select has an input `labelForId` that sets the autocomplete attribute\n    // in ngOnInit. I am not positive that it is wrong by doing that, but this\n    // hack makes it set the attributes again on focus, because that gives the\n    // result I was expecting, since we don't manually set the `labelForId`\n    // input.\n    const _ngSelect = this.ngSelect as any\n    _ngSelect._setInputAttributes()\n  }\n\n  @HostBinding('class.is-invalid') get _isInvalid() {\n    return this.ngControl ? this.ngControl.invalid && (this.ngControl.dirty || this.ngControl.touched) : false\n  }\n\n  @HostBinding('class.ng-empty-string-value') get _isEmptyStringValue() {\n    return this.ngControl ? this.ngControl.value === '' ? true : false : false\n  }\n\n  constructor(\n    private readonly elementRef: ElementRef,\n    private readonly _ngZone: NgZone,\n    private readonly ngSelect: NgSelectComponent,\n    @Optional() @Self() public readonly ngControl: NgControl\n  ) { }\n\n  ngOnInit() {\n    this.ngSelect.focusEvent\n      .subscribe(v => this._enableKeyPressWorkaround())\n\n    this.ngSelect.blurEvent\n      .subscribe(v => this._disableKeyPressWorkaround())\n\n    window.addEventListener('scroll', this._onScroll, true)\n\n    // When the input is allowed to change its height the position doesn't update itself.\n    // this._resizedEvent.pipe(\n    //   auditTime(30)\n    // ).subscribe(event => {\n    //   if (this.elementRef && this.elementRef.nativeElement) {\n    //     if (this.elementRef.nativeElement.classList.contains('ng-select-value-grow-h')) {\n    //       if (this.ngSelect.isOpen && this.ngSelect.dropdownPanel) {\n    //         this.ngSelect.dropdownPanel.updateDropdownPosition()\n    //       }\n    //     } else {\n    //       this.elementRef.nativeElement.classList.remove('ng-select-value-grow-h')\n    //     }\n    //   }\n    // })\n\n    // this._patch_ngSelect_open()\n  }\n\n  ngOnDestroy() {\n    this._resizeSensor?.detach()\n\n    window.removeEventListener('scroll', this._onScroll, true)\n\n    this._ngUnsubscribe.next()\n    this._ngUnsubscribe.complete()\n  }\n\n  ngAfterViewChecked() {\n    if (this.ngSelect.dropdownPanel) {\n      if (this._checkMarked) {\n        if (this.ngSelect.dropdownPanel && this._markedItem !== null) {\n          if (this._markedItem.index !== this.ngSelect.dropdownPanel.markedItem.index) {\n            this.ngSelect.dropdownPanel.scrollTo(this.ngSelect.dropdownPanel.markedItem)\n          }\n        }\n      }\n    }\n    this._checkMarked = false\n\n    this._resizeSensor = new ResizeSensor(this.elementRef.nativeElement, (event) => {\n      this._resizedEvent.emit({ element: this.elementRef.nativeElement, size: event })\n    })\n  }\n\n  private _onScroll = (event: any) => {\n    if (this.ngSelect && this.ngSelect.isOpen) {\n      const isScrollingInScrollHost = (event.target.className as string).indexOf('ng-dropdown-panel-items') !== -1\n      const isInSensor = (event.target.className as string).indexOf('resize-sensor-shrink') !== -1 ||\n        (event.target.className as string).indexOf('os-resize-observer-host') !== -1\n      if (isScrollingInScrollHost || isInSensor) { return }\n      this.ngSelect.close()\n    }\n}\n\n  /**\n   * Temp fix for: https://github.com/ng-select/ng-select/issues/1122\n   */\n  // private _patch_ngSelect_open() {\n  //   const original = this.ngSelect.open\n  //   const _self = this\n  //   this.ngSelect.open = function() {\n  //     original.apply(this, arguments)\n  //     _self._patch_ngSelectDropdownPanel_updateDropdownPosition()\n  //   }\n  // }\n\n  /** Should ONLY be called by `_patch_ngSelect_open`. */\n  // private _patch_ngSelectDropdownPanel_updateDropdownPosition() {\n  //   if (!this.ngSelect.dropdownPanel) { return }\n  //   const drop: any = this.ngSelect.dropdownPanel\n  //   // Only needed once, to update the position before the timeout in\n  //   // `updateDropdownPosition()`. So, using this variable to check if I already called\n  //   // `_updateAppendedDropdownPosition()`.\n  //   if (!drop.__libPatched) {\n  //     drop.__libPatched = 'patched'\n  //     const original = drop.updateDropdownPosition\n  //     const _self = this\n  //     drop.updateDropdownPosition = function() {\n  //       original.apply(this, arguments)\n  //       if (!!_self.ngSelect.appendTo) {\n  //         drop._updateAppendedDropdownPosition()\n  //       }\n  //     }\n  //   }\n  // }\n\n  private _enableKeyPressWorkaround() {\n    if (this._keyPressWorkaroundSub) { return }\n    const _ngSelect = <any>this.ngSelect\n\n    this._keyPressWorkaroundSub = _ngSelect._keyPress$\n      .pipe(takeUntil(this._ngUnsubscribe))\n      .pipe(filter(() => !this.ngSelect.searchable))\n      .subscribe(() => {\n        this._ngZone.runOutsideAngular(() => {\n          window.requestAnimationFrame(() => {\n            if (this.ngSelect.dropdownPanel) {\n              this._markedItem = this.ngSelect.dropdownPanel.markedItem\n            }\n            this._checkMarked = true\n          })\n        })\n      })\n  }\n\n  private _disableKeyPressWorkaround() {\n    if (this._keyPressWorkaroundSub) {\n      this._keyPressWorkaroundSub.unsubscribe()\n      this._keyPressWorkaroundSub = null\n    }\n  }\n\n}\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Pipe } from '@angular/core';
|
|
2
|
-
import { padEnd, padStart } from '
|
|
2
|
+
import { padEnd, padStart } from '@theseam/ui-common/utils';
|
|
3
3
|
export class MaskCharsPipe {
|
|
4
4
|
transform(value, replacementChar = '*', ignoreCount = 0, ignoreFrom = 'right') {
|
|
5
5
|
if (ignoreFrom === 'right') {
|
|
@@ -18,4 +18,4 @@ MaskCharsPipe.decorators = [
|
|
|
18
18
|
name: 'maskChars'
|
|
19
19
|
},] }
|
|
20
20
|
];
|
|
21
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFzay1jaGFycy5waXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWktY29tbW9uL3NoYXJlZC9waXBlcy9tYXNrLWNoYXJzLnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBaUIsTUFBTSxlQUFlLENBQUE7QUFFbkQsT0FBTyxFQUFFLE1BQU0sRUFBRSxRQUFRLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQTtBQUszRCxNQUFNLE9BQU8sYUFBYTtJQUV4QixTQUFTLENBQUMsS0FBYSxFQUFFLGtCQUEwQixHQUFHLEVBQUUsY0FBc0IsQ0FBQyxFQUFFLGFBQStCLE9BQU87UUFDckgsSUFBSSxVQUFVLEtBQUssT0FBTyxFQUFFO1lBQzFCLE1BQU0sQ0FBQyxHQUFHLEtBQUssSUFBSSxFQUFFLENBQUE7WUFDckIsT0FBTyxRQUFRLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsTUFBTSxHQUFHLFdBQVcsRUFBRSxDQUFDLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxDQUFDLE1BQU0sRUFBRSxlQUFlLENBQUMsQ0FBQTtTQUMxRjthQUFNLElBQUksVUFBVSxLQUFLLE1BQU0sRUFBRTtZQUNoQyxNQUFNLENBQUMsR0FBRyxLQUFLLElBQUksRUFBRSxDQUFBO1lBQ3JCLE9BQU8sTUFBTSxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxFQUFFLFdBQVcsQ0FBQyxFQUFFLENBQUMsQ0FBQyxNQUFNLEVBQUUsZUFBZSxDQUFDLENBQUE7U0FDdEU7UUFFRCxPQUFPLEtBQUssQ0FBQTtJQUNkLENBQUM7OztZQWZGLElBQUksU0FBQztnQkFDSixJQUFJLEVBQUUsV0FBVzthQUNsQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJ1xuXG5pbXBvcnQgeyBwYWRFbmQsIHBhZFN0YXJ0IH0gZnJvbSAnQHRoZXNlYW0vdWktY29tbW9uL3V0aWxzJ1xuXG5AUGlwZSh7XG4gIG5hbWU6ICdtYXNrQ2hhcnMnXG59KVxuZXhwb3J0IGNsYXNzIE1hc2tDaGFyc1BpcGUgaW1wbGVtZW50cyBQaXBlVHJhbnNmb3JtIHtcblxuICB0cmFuc2Zvcm0odmFsdWU6IHN0cmluZywgcmVwbGFjZW1lbnRDaGFyOiBzdHJpbmcgPSAnKicsIGlnbm9yZUNvdW50OiBudW1iZXIgPSAwLCBpZ25vcmVGcm9tOiAnbGVmdCcgfCAncmlnaHQnID0gJ3JpZ2h0Jyk6IHN0cmluZyB7XG4gICAgaWYgKGlnbm9yZUZyb20gPT09ICdyaWdodCcpIHtcbiAgICAgIGNvbnN0IHMgPSB2YWx1ZSB8fCAnJ1xuICAgICAgcmV0dXJuIHBhZFN0YXJ0KHMuc3Vic3RyaW5nKHMubGVuZ3RoIC0gaWdub3JlQ291bnQsIHMubGVuZ3RoKSwgcy5sZW5ndGgsIHJlcGxhY2VtZW50Q2hhcilcbiAgICB9IGVsc2UgaWYgKGlnbm9yZUZyb20gPT09ICdsZWZ0Jykge1xuICAgICAgY29uc3QgcyA9IHZhbHVlIHx8ICcnXG4gICAgICByZXR1cm4gcGFkRW5kKHMuc3Vic3RyaW5nKDAsIGlnbm9yZUNvdW50KSwgcy5sZW5ndGgsIHJlcGxhY2VtZW50Q2hhcilcbiAgICB9XG5cbiAgICByZXR1cm4gdmFsdWVcbiAgfVxuXG59XG4iXX0=
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
import { HostListener, isDevMode
|
|
1
|
+
import { Directive, HostListener, isDevMode } from '@angular/core';
|
|
2
|
+
// tslint:disable-next-line: directive-class-suffix
|
|
2
3
|
export class UnsavedChangesCanDeactivate {
|
|
3
4
|
__unloadNotification($event) {
|
|
4
5
|
if (isDevMode()) {
|
|
@@ -23,4 +24,4 @@ UnsavedChangesCanDeactivate.decorators = [
|
|
|
23
24
|
UnsavedChangesCanDeactivate.propDecorators = {
|
|
24
25
|
__unloadNotification: [{ type: HostListener, args: ['window:beforeunload', ['$event'],] }]
|
|
25
26
|
};
|
|
26
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidW5zYXZlZC1jaGFuZ2VzLWNhbi1kZWFjdGl2YXRlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvdWktY29tbW9uL3Vuc2F2ZWQtY2hhbmdlcy1kaWFsb2cvdW5zYXZlZC1jaGFuZ2VzLWNhbi1kZWFjdGl2YXRlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUdsRSxtREFBbUQ7QUFDbkQsTUFBTSxPQUFnQiwyQkFBMkI7SUFLN0Msb0JBQW9CLENBQUMsTUFBVztRQUM5QixJQUFJLFNBQVMsRUFBRSxFQUFFO1lBQ2YsSUFBSSxDQUFDLElBQUksQ0FBQywyQkFBMkIsRUFBRTtnQkFDckMsT0FBTyxDQUFDLElBQUksQ0FBQyx5R0FBeUcsQ0FBQyxDQUFBO2FBQ3hIO1lBRUQsTUFBTSxDQUFDLEdBQUcsTUFBYSxDQUFBO1lBQ3ZCLHlDQUF5QztZQUN6QyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsd0JBQXdCLEVBQUU7Z0JBQ25DLE9BQU8sSUFBSSxDQUFBO2FBQ1o7U0FDRjtRQUVELElBQUksQ0FBQyxJQUFJLENBQUMsMkJBQTJCLEVBQUUsRUFBRTtZQUN2Qyw0QkFBNEI7WUFDNUIsTUFBTSxDQUFDLFdBQVcsR0FBRyxvRUFBb0UsQ0FBQTtTQUMxRjtJQUNILENBQUM7OztZQXhCSixTQUFTOzs7bUNBTUwsWUFBWSxTQUFDLHFCQUFxQixFQUFFLENBQUMsUUFBUSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBIb3N0TGlzdGVuZXIsIGlzRGV2TW9kZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5cbkBEaXJlY3RpdmUoKVxuLy8gdHNsaW50OmRpc2FibGUtbmV4dC1saW5lOiBkaXJlY3RpdmUtY2xhc3Mtc3VmZml4XG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgVW5zYXZlZENoYW5nZXNDYW5EZWFjdGl2YXRlIHtcblxuICBhYnN0cmFjdCB1bnNhdmVkQ2hhbmdlc0NhbkRlYWN0aXZhdGUoKTogYm9vbGVhblxuXG4gICAgQEhvc3RMaXN0ZW5lcignd2luZG93OmJlZm9yZXVubG9hZCcsIFsnJGV2ZW50J10pXG4gICAgX191bmxvYWROb3RpZmljYXRpb24oJGV2ZW50OiBhbnkpIHtcbiAgICAgIGlmIChpc0Rldk1vZGUoKSkge1xuICAgICAgICBpZiAoIXRoaXMudW5zYXZlZENoYW5nZXNDYW5EZWFjdGl2YXRlKSB7XG4gICAgICAgICAgY29uc29sZS53YXJuKCdSb3V0ZSBDb21wb25lbnQgd2l0aCBbVW5zYXZlZENoYW5nZXNEaWFsb2dHdWFyZF0gZ3VhcmQgbXVzdCBleHRlbmQgW1Vuc2F2ZWRDaGFuZ2VzQ2FuRGVhY3RpdmF0ZV0gY2xhc3MuJylcbiAgICAgICAgfVxuXG4gICAgICAgIGNvbnN0IHcgPSB3aW5kb3cgYXMgYW55XG4gICAgICAgIC8vIEF2b2lkIHJlZGlyZWN0IHByZXZlbnRpb24gaW4gU3Rvcnlib29rXG4gICAgICAgIGlmICh3ICYmIHcuX19TVE9SWUJPT0tfQ0xJRU5UX0FQSV9fKSB7XG4gICAgICAgICAgcmV0dXJuIHRydWVcbiAgICAgICAgfVxuICAgICAgfVxuXG4gICAgICBpZiAoIXRoaXMudW5zYXZlZENoYW5nZXNDYW5EZWFjdGl2YXRlKCkpIHtcbiAgICAgICAgLy8gJGV2ZW50LnJldHVyblZhbHVlID0gdHJ1ZVxuICAgICAgICAkZXZlbnQucmV0dXJuVmFsdWUgPSAnWW91IGhhdmUgdW5zYXZlZCBjaGFuZ2VzISBJZiB5b3UgbGVhdmUsIHlvdXIgY2hhbmdlcyB3aWxsIGJlIGxvc3QuJ1xuICAgICAgfVxuICAgIH1cblxufVxuIl19
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export function createPadding(len, chars) {
|
|
2
|
+
// if (chars.length <= len) {
|
|
3
|
+
// return chars
|
|
4
|
+
// }
|
|
5
|
+
if (chars.length === 0) {
|
|
6
|
+
throw Error(`Padding characters must be at least 1 char length.`);
|
|
7
|
+
}
|
|
8
|
+
let str = chars;
|
|
9
|
+
while (str.length < len) {
|
|
10
|
+
str += chars;
|
|
11
|
+
}
|
|
12
|
+
if (str.length > len) {
|
|
13
|
+
str = str.slice(0, len);
|
|
14
|
+
}
|
|
15
|
+
return str;
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlLXBhZGRpbmcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy91aS1jb21tb24vdXRpbHMvY3JlYXRlLXBhZGRpbmcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsTUFBTSxVQUFVLGFBQWEsQ0FBQyxHQUFXLEVBQUUsS0FBYTtJQUN0RCw2QkFBNkI7SUFDN0IsaUJBQWlCO0lBQ2pCLElBQUk7SUFFSixJQUFJLEtBQUssQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFO1FBQ3RCLE1BQU0sS0FBSyxDQUFDLG9EQUFvRCxDQUFDLENBQUE7S0FDbEU7SUFFRCxJQUFJLEdBQUcsR0FBRyxLQUFLLENBQUE7SUFDZixPQUFPLEdBQUcsQ0FBQyxNQUFNLEdBQUcsR0FBRyxFQUFFO1FBQ3ZCLEdBQUcsSUFBSSxLQUFLLENBQUE7S0FDYjtJQUVELElBQUksR0FBRyxDQUFDLE1BQU0sR0FBRyxHQUFHLEVBQUU7UUFDcEIsR0FBRyxHQUFHLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFBO0tBQ3hCO0lBRUQsT0FBTyxHQUFHLENBQUE7QUFDWixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlUGFkZGluZyhsZW46IG51bWJlciwgY2hhcnM6IHN0cmluZyk6IHN0cmluZyB7XG4gIC8vIGlmIChjaGFycy5sZW5ndGggPD0gbGVuKSB7XG4gIC8vICAgcmV0dXJuIGNoYXJzXG4gIC8vIH1cblxuICBpZiAoY2hhcnMubGVuZ3RoID09PSAwKSB7XG4gICAgdGhyb3cgRXJyb3IoYFBhZGRpbmcgY2hhcmFjdGVycyBtdXN0IGJlIGF0IGxlYXN0IDEgY2hhciBsZW5ndGguYClcbiAgfVxuXG4gIGxldCBzdHIgPSBjaGFyc1xuICB3aGlsZSAoc3RyLmxlbmd0aCA8IGxlbikge1xuICAgIHN0ciArPSBjaGFyc1xuICB9XG5cbiAgaWYgKHN0ci5sZW5ndGggPiBsZW4pIHtcbiAgICBzdHIgPSBzdHIuc2xpY2UoMCwgbGVuKVxuICB9XG5cbiAgcmV0dXJuIHN0clxufVxuIl19
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
// Source: https://github.com/angular/angular/blob/master/packages/forms/src/validators.ts#L16
|
|
2
|
+
export function isEmptyInputValue(value) {
|
|
3
|
+
// we don't check for string here so it also works with arrays
|
|
4
|
+
return value == null || value.length === 0;
|
|
5
|
+
}
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXMtZW1wdHktaW5wdXQtdmFsdWUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS1jb21tb24vdXRpbHMvZm9ybS9pcy1lbXB0eS1pbnB1dC12YWx1ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSw4RkFBOEY7QUFDOUYsTUFBTSxVQUFVLGlCQUFpQixDQUFDLEtBQVU7SUFDMUMsOERBQThEO0lBQzlELE9BQU8sS0FBSyxJQUFJLElBQUksSUFBSSxLQUFLLENBQUMsTUFBTSxLQUFLLENBQUMsQ0FBQTtBQUM1QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gU291cmNlOiBodHRwczovL2dpdGh1Yi5jb20vYW5ndWxhci9hbmd1bGFyL2Jsb2IvbWFzdGVyL3BhY2thZ2VzL2Zvcm1zL3NyYy92YWxpZGF0b3JzLnRzI0wxNlxuZXhwb3J0IGZ1bmN0aW9uIGlzRW1wdHlJbnB1dFZhbHVlKHZhbHVlOiBhbnkpOiBib29sZWFuIHtcbiAgLy8gd2UgZG9uJ3QgY2hlY2sgZm9yIHN0cmluZyBoZXJlIHNvIGl0IGFsc28gd29ya3Mgd2l0aCBhcnJheXNcbiAgcmV0dXJuIHZhbHVlID09IG51bGwgfHwgdmFsdWUubGVuZ3RoID09PSAwXG59XG4iXX0=
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { isNumeric } from './is-numeric';
|
|
2
|
+
/**
|
|
3
|
+
* Returns the number of fractional digits.
|
|
4
|
+
*
|
|
5
|
+
* NOTE: This is intended for input validation, so trailing 0's will be included
|
|
6
|
+
* in the total. Also, localization is not considered, so '.' is assumed to be
|
|
7
|
+
* the fractional separator.
|
|
8
|
+
*/
|
|
9
|
+
export function fractionalDigitsCount(value) {
|
|
10
|
+
if (!isNumeric(value)) {
|
|
11
|
+
return null;
|
|
12
|
+
}
|
|
13
|
+
const a = value.split('.');
|
|
14
|
+
if (a.length !== 2) {
|
|
15
|
+
return null;
|
|
16
|
+
}
|
|
17
|
+
return a[1].length;
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnJhY3Rpb25hbC1kaWdpdHMtY291bnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy91aS1jb21tb24vdXRpbHMvZnJhY3Rpb25hbC1kaWdpdHMtY291bnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGNBQWMsQ0FBQTtBQUV4Qzs7Ozs7O0dBTUc7QUFDSCxNQUFNLFVBQVUscUJBQXFCLENBQUMsS0FBYTtJQUNqRCxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxFQUFFO1FBQ3JCLE9BQU8sSUFBSSxDQUFBO0tBQ1o7SUFFRCxNQUFNLENBQUMsR0FBRyxLQUFLLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFBO0lBQzFCLElBQUksQ0FBQyxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7UUFDbEIsT0FBTyxJQUFJLENBQUE7S0FDWjtJQUVELE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQTtBQUNwQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgaXNOdW1lcmljIH0gZnJvbSAnLi9pcy1udW1lcmljJ1xuXG4vKipcbiAqIFJldHVybnMgdGhlIG51bWJlciBvZiBmcmFjdGlvbmFsIGRpZ2l0cy5cbiAqXG4gKiBOT1RFOiBUaGlzIGlzIGludGVuZGVkIGZvciBpbnB1dCB2YWxpZGF0aW9uLCBzbyB0cmFpbGluZyAwJ3Mgd2lsbCBiZSBpbmNsdWRlZFxuICogaW4gdGhlIHRvdGFsLiBBbHNvLCBsb2NhbGl6YXRpb24gaXMgbm90IGNvbnNpZGVyZWQsIHNvICcuJyBpcyBhc3N1bWVkIHRvIGJlXG4gKiB0aGUgZnJhY3Rpb25hbCBzZXBhcmF0b3IuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBmcmFjdGlvbmFsRGlnaXRzQ291bnQodmFsdWU6IHN0cmluZyk6IG51bWJlciB8IG51bGwge1xuICBpZiAoIWlzTnVtZXJpYyh2YWx1ZSkpIHtcbiAgICByZXR1cm4gbnVsbFxuICB9XG5cbiAgY29uc3QgYSA9IHZhbHVlLnNwbGl0KCcuJylcbiAgaWYgKGEubGVuZ3RoICE9PSAyKSB7XG4gICAgcmV0dXJuIG51bGxcbiAgfVxuXG4gIHJldHVybiBhWzFdLmxlbmd0aFxufVxuIl19
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export function isNumeric(value) {
|
|
2
|
+
return !isNaN(Number(value) - parseFloat(value));
|
|
3
|
+
}
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXMtbnVtZXJpYy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi91dGlscy9pcy1udW1lcmljLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sVUFBVSxTQUFTLENBQUMsS0FBVTtJQUNsQyxPQUFPLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsR0FBRyxVQUFVLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQTtBQUNsRCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGZ1bmN0aW9uIGlzTnVtZXJpYyh2YWx1ZTogYW55KTogYm9vbGVhbiB7XG4gIHJldHVybiAhaXNOYU4oTnVtYmVyKHZhbHVlKSAtIHBhcnNlRmxvYXQodmFsdWUpKVxufVxuIl19
|