@theseam/ui-common 0.4.4 → 0.4.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (59) hide show
  1. package/datatable/models/preferences-accessor.d.ts +3 -15
  2. package/datatable/models/preferences.d.ts +2 -1
  3. package/datatable/services/datatable-preferences.service.d.ts +11 -14
  4. package/datatable/tokens/datatable-preferences-accessor.d.ts +2 -2
  5. package/esm2020/datatable/datatable/datatable.component.mjs +3 -3
  6. package/esm2020/datatable/models/preferences-accessor.mjs +1 -1
  7. package/esm2020/datatable/models/preferences.mjs +1 -1
  8. package/esm2020/datatable/services/datatable-preferences.service.mjs +34 -106
  9. package/esm2020/datatable/tokens/datatable-preferences-accessor.mjs +1 -1
  10. package/esm2020/framework/dashboard/dashboard-widgets/dashboard-widgets.service.mjs +9 -3
  11. package/esm2020/services/preferences/preferences-accessor.mjs +2 -0
  12. package/esm2020/services/preferences/preferences-manager.service.mjs +69 -0
  13. package/esm2020/services/preferences/preferences-record.mjs +74 -0
  14. package/esm2020/services/preferences/preferences.models.mjs +2 -0
  15. package/esm2020/services/public-api.mjs +5 -1
  16. package/esm2020/story-helpers/public-api.mjs +2 -1
  17. package/esm2020/story-helpers/story-preferences-accessor.service.mjs +34 -0
  18. package/esm2020/widget/preferences/widget-preferences.models.mjs +5 -0
  19. package/esm2020/widget/preferences/widget-preferences.service.mjs +78 -0
  20. package/esm2020/widget/preferences/widget-preferences.token.mjs +3 -0
  21. package/esm2020/widget/public-api.mjs +2 -1
  22. package/esm2020/widget/widget/widget.component.mjs +81 -30
  23. package/esm2020/widget/widget-token.mjs +3 -1
  24. package/esm2020/widget/widget.models.mjs +2 -0
  25. package/fesm2015/theseam-ui-common-datatable.mjs +45 -116
  26. package/fesm2015/theseam-ui-common-datatable.mjs.map +1 -1
  27. package/fesm2015/theseam-ui-common-framework.mjs +9 -3
  28. package/fesm2015/theseam-ui-common-framework.mjs.map +1 -1
  29. package/fesm2015/theseam-ui-common-services.mjs +144 -8
  30. package/fesm2015/theseam-ui-common-services.mjs.map +1 -1
  31. package/fesm2015/theseam-ui-common-story-helpers.mjs +32 -1
  32. package/fesm2015/theseam-ui-common-story-helpers.mjs.map +1 -1
  33. package/fesm2015/theseam-ui-common-widget.mjs +166 -35
  34. package/fesm2015/theseam-ui-common-widget.mjs.map +1 -1
  35. package/fesm2020/theseam-ui-common-datatable.mjs +45 -116
  36. package/fesm2020/theseam-ui-common-datatable.mjs.map +1 -1
  37. package/fesm2020/theseam-ui-common-framework.mjs +8 -3
  38. package/fesm2020/theseam-ui-common-framework.mjs.map +1 -1
  39. package/fesm2020/theseam-ui-common-services.mjs +144 -8
  40. package/fesm2020/theseam-ui-common-services.mjs.map +1 -1
  41. package/fesm2020/theseam-ui-common-story-helpers.mjs +32 -1
  42. package/fesm2020/theseam-ui-common-story-helpers.mjs.map +1 -1
  43. package/fesm2020/theseam-ui-common-widget.mjs +162 -35
  44. package/fesm2020/theseam-ui-common-widget.mjs.map +1 -1
  45. package/package.json +1 -1
  46. package/services/preferences/preferences-accessor.d.ts +15 -0
  47. package/services/preferences/preferences-manager.service.d.ts +15 -0
  48. package/services/preferences/preferences-record.d.ts +28 -0
  49. package/services/preferences/preferences.models.d.ts +3 -0
  50. package/services/public-api.d.ts +4 -0
  51. package/story-helpers/public-api.d.ts +1 -0
  52. package/story-helpers/story-preferences-accessor.service.d.ts +19 -0
  53. package/widget/preferences/widget-preferences.models.d.ts +8 -0
  54. package/widget/preferences/widget-preferences.service.d.ts +21 -0
  55. package/widget/preferences/widget-preferences.token.d.ts +3 -0
  56. package/widget/public-api.d.ts +1 -0
  57. package/widget/widget/widget.component.d.ts +12 -2
  58. package/widget/widget-token.d.ts +3 -0
  59. package/widget/widget.models.d.ts +7 -0
@@ -0,0 +1,34 @@
1
+ import { Injectable } from '@angular/core';
2
+ import { of } from 'rxjs';
3
+ import * as i0 from "@angular/core";
4
+ const ACCESSOR_PREFIX = 'story-pref';
5
+ export class StoryPreferencesAccessorService {
6
+ /**
7
+ * Gets a preference.
8
+ */
9
+ get(name) {
10
+ // console.log('get', name)
11
+ return of(localStorage.getItem(`${ACCESSOR_PREFIX}-${name}`) || '{}');
12
+ }
13
+ /**
14
+ * Update a preference.
15
+ */
16
+ update(name, value) {
17
+ // console.log('update', name)
18
+ localStorage.setItem(`${ACCESSOR_PREFIX}-${name}`, value);
19
+ return this.get(name);
20
+ }
21
+ /**
22
+ * Delete a preference.
23
+ */
24
+ delete(name) {
25
+ localStorage.removeItem(`${ACCESSOR_PREFIX}-${name}`);
26
+ return of(true);
27
+ }
28
+ }
29
+ StoryPreferencesAccessorService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: StoryPreferencesAccessorService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
30
+ StoryPreferencesAccessorService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: StoryPreferencesAccessorService });
31
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: StoryPreferencesAccessorService, decorators: [{
32
+ type: Injectable
33
+ }] });
34
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RvcnktcHJlZmVyZW5jZXMtYWNjZXNzb3Iuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi9zdG9yeS1oZWxwZXJzL3N0b3J5LXByZWZlcmVuY2VzLWFjY2Vzc29yLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUUxQyxPQUFPLEVBQWMsRUFBRSxFQUFFLE1BQU0sTUFBTSxDQUFBOztBQUVyQyxNQUFNLGVBQWUsR0FBRyxZQUFZLENBQUE7QUFHcEMsTUFBTSxPQUFPLCtCQUErQjtJQUUxQzs7T0FFRztJQUNJLEdBQUcsQ0FBQyxJQUFZO1FBQ3JCLDJCQUEyQjtRQUMzQixPQUFPLEVBQUUsQ0FBQyxZQUFZLENBQUMsT0FBTyxDQUFDLEdBQUcsZUFBZSxJQUFJLElBQUksRUFBRSxDQUFDLElBQUksSUFBSSxDQUFDLENBQUE7SUFDdkUsQ0FBQztJQUVEOztPQUVHO0lBQ0ksTUFBTSxDQUFDLElBQVksRUFBRSxLQUFhO1FBQ3ZDLDhCQUE4QjtRQUM5QixZQUFZLENBQUMsT0FBTyxDQUFDLEdBQUcsZUFBZSxJQUFJLElBQUksRUFBRSxFQUFFLEtBQUssQ0FBQyxDQUFBO1FBQ3pELE9BQU8sSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQTtJQUN2QixDQUFDO0lBRUQ7O09BRUc7SUFDSSxNQUFNLENBQUMsSUFBWTtRQUN4QixZQUFZLENBQUMsVUFBVSxDQUFDLEdBQUcsZUFBZSxJQUFJLElBQUksRUFBRSxDQUFDLENBQUE7UUFDckQsT0FBTyxFQUFFLENBQUMsSUFBSSxDQUFDLENBQUE7SUFDakIsQ0FBQzs7NEhBekJVLCtCQUErQjtnSUFBL0IsK0JBQStCOzJGQUEvQiwrQkFBK0I7a0JBRDNDLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcclxuaW1wb3J0IHsgVGhlU2VhbVByZWZlcmVuY2VzQWNjZXNzb3IgfSBmcm9tICdAdGhlc2VhbS91aS1jb21tb24vc2VydmljZXMnXHJcbmltcG9ydCB7IE9ic2VydmFibGUsIG9mIH0gZnJvbSAncnhqcydcclxuXHJcbmNvbnN0IEFDQ0VTU09SX1BSRUZJWCA9ICdzdG9yeS1wcmVmJ1xyXG5cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgU3RvcnlQcmVmZXJlbmNlc0FjY2Vzc29yU2VydmljZSBpbXBsZW1lbnRzIFRoZVNlYW1QcmVmZXJlbmNlc0FjY2Vzc29yIHtcclxuXHJcbiAgLyoqXHJcbiAgICogR2V0cyBhIHByZWZlcmVuY2UuXHJcbiAgICovXHJcbiAgcHVibGljIGdldChuYW1lOiBzdHJpbmcpOiBPYnNlcnZhYmxlPHN0cmluZz4ge1xyXG4gICAgLy8gY29uc29sZS5sb2coJ2dldCcsIG5hbWUpXHJcbiAgICByZXR1cm4gb2YobG9jYWxTdG9yYWdlLmdldEl0ZW0oYCR7QUNDRVNTT1JfUFJFRklYfS0ke25hbWV9YCkgfHwgJ3t9JylcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIFVwZGF0ZSBhIHByZWZlcmVuY2UuXHJcbiAgICovXHJcbiAgcHVibGljIHVwZGF0ZShuYW1lOiBzdHJpbmcsIHZhbHVlOiBzdHJpbmcpOiBPYnNlcnZhYmxlPHN0cmluZz4ge1xyXG4gICAgLy8gY29uc29sZS5sb2coJ3VwZGF0ZScsIG5hbWUpXHJcbiAgICBsb2NhbFN0b3JhZ2Uuc2V0SXRlbShgJHtBQ0NFU1NPUl9QUkVGSVh9LSR7bmFtZX1gLCB2YWx1ZSlcclxuICAgIHJldHVybiB0aGlzLmdldChuYW1lKVxyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogRGVsZXRlIGEgcHJlZmVyZW5jZS5cclxuICAgKi9cclxuICBwdWJsaWMgZGVsZXRlKG5hbWU6IHN0cmluZyk6IE9ic2VydmFibGU8Ym9vbGVhbj4ge1xyXG4gICAgbG9jYWxTdG9yYWdlLnJlbW92ZUl0ZW0oYCR7QUNDRVNTT1JfUFJFRklYfS0ke25hbWV9YClcclxuICAgIHJldHVybiBvZih0cnVlKVxyXG4gIH1cclxuXHJcbn1cclxuIl19
@@ -0,0 +1,5 @@
1
+ export const CURRENT_WIDGET_PREFERENCES_VERSION = 1;
2
+ export const EMPTY_WIDGET_PREFERENCES = {
3
+ version: 1,
4
+ };
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2lkZ2V0LXByZWZlcmVuY2VzLm1vZGVscy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi93aWRnZXQvcHJlZmVyZW5jZXMvd2lkZ2V0LXByZWZlcmVuY2VzLm1vZGVscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFTQSxNQUFNLENBQUMsTUFBTSxrQ0FBa0MsR0FBRyxDQUFDLENBQUE7QUFFbkQsTUFBTSxDQUFDLE1BQU0sd0JBQXdCLEdBQTZCO0lBQ2hFLE9BQU8sRUFBRSxDQUFDO0NBQ1gsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRoZVNlYW1QcmVmZXJlbmNlc0Jhc2UgfSBmcm9tICdAdGhlc2VhbS91aS1jb21tb24vc2VydmljZXMnXHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIFRoZVNlYW1XaWRnZXRQcmVmZXJlbmNlc192MSBleHRlbmRzIFRoZVNlYW1QcmVmZXJlbmNlc0Jhc2Uge1xyXG4gIHZlcnNpb246IDFcclxuICBjb2xsYXBzZWQ/OiBib29sZWFuXHJcbn1cclxuXHJcbmV4cG9ydCB0eXBlIFRoZVNlYW1XaWRnZXRQcmVmZXJlbmNlcyA9IFRoZVNlYW1XaWRnZXRQcmVmZXJlbmNlc192MVxyXG5cclxuZXhwb3J0IGNvbnN0IENVUlJFTlRfV0lER0VUX1BSRUZFUkVOQ0VTX1ZFUlNJT04gPSAxXHJcblxyXG5leHBvcnQgY29uc3QgRU1QVFlfV0lER0VUX1BSRUZFUkVOQ0VTOiBUaGVTZWFtV2lkZ2V0UHJlZmVyZW5jZXMgPSB7XHJcbiAgdmVyc2lvbjogMSxcclxufVxyXG4iXX0=
@@ -0,0 +1,78 @@
1
+ import { Inject, Injectable, Optional } from '@angular/core';
2
+ import { of } from 'rxjs';
3
+ import { map, take, tap } from 'rxjs/operators';
4
+ import { THESEAM_WIDGET_PREFERENCES_ACCESSOR } from './widget-preferences.token';
5
+ import { CURRENT_WIDGET_PREFERENCES_VERSION, EMPTY_WIDGET_PREFERENCES } from './widget-preferences.models';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "@theseam/ui-common/services";
8
+ // TODO: Rethink this. I originally implemented this to be shared widget's then
9
+ // changed it to be per widget, for the accessor injection.
10
+ // @Injectable({ providedIn: 'root' })
11
+ export class WidgetPreferencesService {
12
+ constructor(_preferencesManager, _prefsAccessor) {
13
+ this._preferencesManager = _preferencesManager;
14
+ this._prefsAccessor = _prefsAccessor;
15
+ this._pendingPatches = {};
16
+ }
17
+ isPatchPending(preferenceKey) {
18
+ return this._pendingPatches[preferenceKey] && this._pendingPatches[preferenceKey].length > 0;
19
+ }
20
+ isPending(preferenceKey) {
21
+ return this._preferencesManager.isPending(preferenceKey);
22
+ }
23
+ isLoaded(preferenceKey) {
24
+ return this._preferencesManager.isLoaded(preferenceKey);
25
+ }
26
+ preferences(preferenceKey) {
27
+ if (!this._prefsAccessor) {
28
+ return of(JSON.parse(JSON.stringify(EMPTY_WIDGET_PREFERENCES)));
29
+ }
30
+ return this._preferencesManager.preferences(preferenceKey, this._prefsAccessor, EMPTY_WIDGET_PREFERENCES).pipe(map(prefs => {
31
+ if (this._isValidPreferences(prefs)) {
32
+ return prefs;
33
+ }
34
+ throw Error(`Preferences for key '${preferenceKey}' is not a valid widget preferences.`);
35
+ }));
36
+ }
37
+ refresh(preferenceKey) {
38
+ this._preferencesManager.refresh(preferenceKey);
39
+ }
40
+ patchPreferences(preferenceKey, preferences) {
41
+ if (!this._prefsAccessor) {
42
+ return;
43
+ }
44
+ if (!this._pendingPatches[preferenceKey]) {
45
+ this._pendingPatches[preferenceKey] = [];
46
+ }
47
+ if (this._pendingPatches[preferenceKey].length > 0) {
48
+ this._pendingPatches[preferenceKey].push(preferences);
49
+ return;
50
+ }
51
+ this._pendingPatches[preferenceKey].push(preferences);
52
+ this.preferences(preferenceKey).pipe(take(1), map(prefs => {
53
+ const pendingPatches = this._pendingPatches[preferenceKey];
54
+ this._pendingPatches[preferenceKey] = [];
55
+ const newPrefs = pendingPatches.reduce((acc, patch) => {
56
+ return { ...acc, ...patch };
57
+ }, prefs); // Typescript isn't recognizing that 'version' is included in the initial value.
58
+ if (!this._isValidPreferences(newPrefs)) {
59
+ throw Error(`Attempted to patch preferences for key '${preferenceKey}' with invalid preferences.`);
60
+ }
61
+ this._preferencesManager.update(preferenceKey, newPrefs);
62
+ }), tap(() => this.refresh(preferenceKey))).subscribe();
63
+ }
64
+ _isValidPreferences(prefs) {
65
+ return prefs.version === CURRENT_WIDGET_PREFERENCES_VERSION;
66
+ }
67
+ }
68
+ WidgetPreferencesService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: WidgetPreferencesService, deps: [{ token: i1.TheSeamPreferencesManagerService }, { token: THESEAM_WIDGET_PREFERENCES_ACCESSOR, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
69
+ WidgetPreferencesService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: WidgetPreferencesService });
70
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: WidgetPreferencesService, decorators: [{
71
+ type: Injectable
72
+ }], ctorParameters: function () { return [{ type: i1.TheSeamPreferencesManagerService }, { type: undefined, decorators: [{
73
+ type: Optional
74
+ }, {
75
+ type: Inject,
76
+ args: [THESEAM_WIDGET_PREFERENCES_ACCESSOR]
77
+ }] }]; } });
78
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-preferences.service.js","sourceRoot":"","sources":["../../../../../projects/ui-common/widget/preferences/widget-preferences.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAA;AAC5D,OAAO,EAAc,EAAE,EAAE,MAAM,MAAM,CAAA;AACrC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAA;AAG/C,OAAO,EAAE,mCAAmC,EAAE,MAAM,4BAA4B,CAAA;AAChF,OAAO,EAAE,kCAAkC,EAAE,wBAAwB,EAA4B,MAAM,6BAA6B,CAAA;;;AAIpI,+EAA+E;AAC/E,2DAA2D;AAE3D,sCAAsC;AAEtC,MAAM,OAAO,wBAAwB;IAInC,YACmB,mBAAqD,EACL,cAA2C;QAD3F,wBAAmB,GAAnB,mBAAmB,CAAkC;QACL,mBAAc,GAAd,cAAc,CAA6B;QAJtG,oBAAe,GAAkE,EAAG,CAAA;IAKxF,CAAC;IAEE,cAAc,CAAC,aAAqB;QACzC,OAAO,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,IAAI,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,MAAM,GAAG,CAAC,CAAA;IAC9F,CAAC;IAEM,SAAS,CAAC,aAAqB;QACpC,OAAO,IAAI,CAAC,mBAAmB,CAAC,SAAS,CAAC,aAAa,CAAC,CAAA;IAC1D,CAAC;IAEM,QAAQ,CAAC,aAAqB;QACnC,OAAO,IAAI,CAAC,mBAAmB,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAA;IACzD,CAAC;IAEM,WAAW,CAAC,aAAqB;QACtC,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE;YACxB,OAAO,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,wBAAwB,CAAC,CAAC,CAAC,CAAA;SAChE;QAED,OAAO,IAAI,CAAC,mBAAmB,CAAC,WAAW,CAAC,aAAa,EAAE,IAAI,CAAC,cAAc,EAAE,wBAAwB,CAAC,CAAC,IAAI,CAC5G,GAAG,CAAC,KAAK,CAAC,EAAE;YACV,IAAI,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,EAAE;gBACnC,OAAO,KAAK,CAAA;aACb;YAED,MAAM,KAAK,CAAC,wBAAwB,aAAa,sCAAsC,CAAC,CAAA;QAC1F,CAAC,CAAC,CACH,CAAA;IACH,CAAC;IAEM,OAAO,CAAC,aAAqB;QAClC,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC,aAAa,CAAC,CAAA;IACjD,CAAC;IAEM,gBAAgB,CAAC,aAAqB,EAAE,WAA0C;QACvF,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE;YACxB,OAAM;SACP;QAED,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,EAAE;YACxC,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,GAAG,EAAE,CAAA;SACzC;QAED,IAAI,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE;YAClD,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAA;YACrD,OAAM;SACP;QAED,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAA;QAErD,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC,IAAI,CAClC,IAAI,CAAC,CAAC,CAAC,EACP,GAAG,CAAC,KAAK,CAAC,EAAE;YACV,MAAM,cAAc,GAAG,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,CAAA;YAC1D,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,GAAG,EAAE,CAAA;YACxC,MAAM,QAAQ,GAA6B,cAAc,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE;gBAC9E,OAAO,EAAE,GAAG,GAAG,EAAE,GAAG,KAAK,EAAE,CAAA;YAC7B,CAAC,EAAE,KAAK,CAA6B,CAAA,CAAC,gFAAgF;YAEtH,IAAI,CAAC,IAAI,CAAC,mBAAmB,CAAC,QAAQ,CAAC,EAAE;gBACvC,MAAM,KAAK,CAAC,2CAA2C,aAAa,6BAA6B,CAAC,CAAA;aACnG;YAED,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAA;QAC1D,CAAC,CAAC,EACF,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,CACvC,CAAC,SAAS,EAAE,CAAA;IACf,CAAC;IAEO,mBAAmB,CAAC,KAA6B;QACvD,OAAO,KAAK,CAAC,OAAO,KAAK,kCAAkC,CAAA;IAC7D,CAAC;;qHA9EU,wBAAwB,kEAMb,mCAAmC;yHAN9C,wBAAwB;2FAAxB,wBAAwB;kBADpC,UAAU;;0BAON,QAAQ;;0BAAI,MAAM;2BAAC,mCAAmC","sourcesContent":["import { Inject, Injectable, Optional } from '@angular/core'\r\nimport { Observable, of } from 'rxjs'\r\nimport { map, take, tap } from 'rxjs/operators'\r\n\r\nimport { TheSeamPreferencesAccessor, TheSeamPreferencesBase, TheSeamPreferencesManagerService } from '@theseam/ui-common/services'\r\nimport { THESEAM_WIDGET_PREFERENCES_ACCESSOR } from './widget-preferences.token'\r\nimport { CURRENT_WIDGET_PREFERENCES_VERSION, EMPTY_WIDGET_PREFERENCES, TheSeamWidgetPreferences } from './widget-preferences.models'\r\n\r\ntype TheSeamWidgetPreferencesPatch = Omit<TheSeamWidgetPreferences, 'version'>\r\n\r\n// TODO: Rethink this. I originally implemented this to be shared widget's then\r\n// changed it to be per widget, for the accessor injection.\r\n\r\n// @Injectable({ providedIn: 'root' })\r\n@Injectable()\r\nexport class WidgetPreferencesService {\r\n\r\n  private _pendingPatches: { [preferencesKey: string]: TheSeamWidgetPreferencesPatch[] } = { }\r\n\r\n  constructor(\r\n    private readonly _preferencesManager: TheSeamPreferencesManagerService,\r\n    @Optional() @Inject(THESEAM_WIDGET_PREFERENCES_ACCESSOR) private _prefsAccessor?: TheSeamPreferencesAccessor\r\n  ) { }\r\n\r\n  public isPatchPending(preferenceKey: string): boolean {\r\n    return this._pendingPatches[preferenceKey] && this._pendingPatches[preferenceKey].length > 0\r\n  }\r\n\r\n  public isPending(preferenceKey: string): boolean {\r\n    return this._preferencesManager.isPending(preferenceKey)\r\n  }\r\n\r\n  public isLoaded(preferenceKey: string): boolean {\r\n    return this._preferencesManager.isLoaded(preferenceKey)\r\n  }\r\n\r\n  public preferences(preferenceKey: string): Observable<TheSeamWidgetPreferences> {\r\n    if (!this._prefsAccessor) {\r\n      return of(JSON.parse(JSON.stringify(EMPTY_WIDGET_PREFERENCES)))\r\n    }\r\n\r\n    return this._preferencesManager.preferences(preferenceKey, this._prefsAccessor, EMPTY_WIDGET_PREFERENCES).pipe(\r\n      map(prefs => {\r\n        if (this._isValidPreferences(prefs)) {\r\n          return prefs\r\n        }\r\n\r\n        throw Error(`Preferences for key '${preferenceKey}' is not a valid widget preferences.`)\r\n      })\r\n    )\r\n  }\r\n\r\n  public refresh(preferenceKey: string): void {\r\n    this._preferencesManager.refresh(preferenceKey)\r\n  }\r\n\r\n  public patchPreferences(preferenceKey: string, preferences: TheSeamWidgetPreferencesPatch): void {\r\n    if (!this._prefsAccessor) {\r\n      return\r\n    }\r\n\r\n    if (!this._pendingPatches[preferenceKey]) {\r\n      this._pendingPatches[preferenceKey] = []\r\n    }\r\n\r\n    if (this._pendingPatches[preferenceKey].length > 0) {\r\n      this._pendingPatches[preferenceKey].push(preferences)\r\n      return\r\n    }\r\n\r\n    this._pendingPatches[preferenceKey].push(preferences)\r\n\r\n    this.preferences(preferenceKey).pipe(\r\n      take(1),\r\n      map(prefs => {\r\n        const pendingPatches = this._pendingPatches[preferenceKey]\r\n        this._pendingPatches[preferenceKey] = []\r\n        const newPrefs: TheSeamWidgetPreferences = pendingPatches.reduce((acc, patch) => {\r\n          return { ...acc, ...patch }\r\n        }, prefs) as TheSeamWidgetPreferences // Typescript isn't recognizing that 'version' is included in the initial value.\r\n\r\n        if (!this._isValidPreferences(newPrefs)) {\r\n          throw Error(`Attempted to patch preferences for key '${preferenceKey}' with invalid preferences.`)\r\n        }\r\n\r\n        this._preferencesManager.update(preferenceKey, newPrefs)\r\n      }),\r\n      tap(() => this.refresh(preferenceKey)),\r\n    ).subscribe()\r\n  }\r\n\r\n  private _isValidPreferences(prefs: TheSeamPreferencesBase): prefs is TheSeamWidgetPreferences {\r\n    return prefs.version === CURRENT_WIDGET_PREFERENCES_VERSION\r\n  }\r\n\r\n}\r\n"]}
@@ -0,0 +1,3 @@
1
+ import { InjectionToken } from '@angular/core';
2
+ export const THESEAM_WIDGET_PREFERENCES_ACCESSOR = new InjectionToken('TheSeamWidgetPreferencesAccessor');
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2lkZ2V0LXByZWZlcmVuY2VzLnRva2VuLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWktY29tbW9uL3dpZGdldC9wcmVmZXJlbmNlcy93aWRnZXQtcHJlZmVyZW5jZXMudG9rZW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUk5QyxNQUFNLENBQUMsTUFBTSxtQ0FBbUMsR0FBRyxJQUFJLGNBQWMsQ0FDbkUsa0NBQWtDLENBQ25DLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3Rpb25Ub2tlbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXHJcblxyXG5pbXBvcnQgeyBUaGVTZWFtUHJlZmVyZW5jZXNBY2Nlc3NvciB9IGZyb20gJ0B0aGVzZWFtL3VpLWNvbW1vbi9zZXJ2aWNlcydcclxuXHJcbmV4cG9ydCBjb25zdCBUSEVTRUFNX1dJREdFVF9QUkVGRVJFTkNFU19BQ0NFU1NPUiA9IG5ldyBJbmplY3Rpb25Ub2tlbjxUaGVTZWFtUHJlZmVyZW5jZXNBY2Nlc3Nvcj4oXHJcbiAgJ1RoZVNlYW1XaWRnZXRQcmVmZXJlbmNlc0FjY2Vzc29yJ1xyXG4pXHJcbiJdfQ==
@@ -35,4 +35,5 @@ export * from './widget-registry.models';
35
35
  export * from './widget-registry.service';
36
36
  export * from './widget-token';
37
37
  export * from './widget.module';
38
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi93aWRnZXQvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDJDQUEyQyxDQUFBO0FBQ3pELGNBQWMsd0NBQXdDLENBQUE7QUFDdEQsY0FBYyx5Q0FBeUMsQ0FBQTtBQUV2RCxjQUFjLCtFQUErRSxDQUFBO0FBQzdGLGNBQWMsNEVBQTRFLENBQUE7QUFFMUYsY0FBYyxtRkFBbUYsQ0FBQTtBQUNqRyxjQUFjLGdGQUFnRixDQUFBO0FBRTlGLGNBQWMsNkVBQTZFLENBQUE7QUFDM0YsY0FBYywwRUFBMEUsQ0FBQTtBQUV4RixjQUFjLDZFQUE2RSxDQUFBO0FBQzNGLGNBQWMsMEVBQTBFLENBQUE7QUFFeEYsY0FBYyw2RUFBNkUsQ0FBQTtBQUMzRixjQUFjLDBFQUEwRSxDQUFBO0FBRXhGLGNBQWMsNkVBQTZFLENBQUE7QUFDM0YsY0FBYywwRUFBMEUsQ0FBQTtBQUV4RixjQUFjLCtFQUErRSxDQUFBO0FBQzdGLGNBQWMsNEVBQTRFLENBQUE7QUFFMUYsY0FBYyxnSEFBZ0gsQ0FBQTtBQUM5SCxjQUFjLHVHQUF1RyxDQUFBO0FBQ3JILGNBQWMsMkVBQTJFLENBQUE7QUFDekYsY0FBYyx3RUFBd0UsQ0FBQTtBQUV0RixjQUFjLGlFQUFpRSxDQUFBO0FBQy9FLGNBQWMsOERBQThELENBQUE7QUFFNUUsY0FBYyx5RkFBeUYsQ0FBQTtBQUN2RyxjQUFjLG1HQUFtRyxDQUFBO0FBQ2pILGNBQWMsdUZBQXVGLENBQUE7QUFFckcsY0FBYyw4RUFBOEUsQ0FBQTtBQUM1RixjQUFjLCtEQUErRCxDQUFBO0FBQzdFLGNBQWMsNERBQTRELENBQUE7QUFFMUUsY0FBYyx5RUFBeUUsQ0FBQTtBQUN2RixjQUFjLHNFQUFzRSxDQUFBO0FBRXBGLGNBQWMsMkJBQTJCLENBQUE7QUFFekMsY0FBYyx5Q0FBeUMsQ0FBQTtBQUV2RCxjQUFjLDBCQUEwQixDQUFBO0FBQ3hDLGNBQWMsMkJBQTJCLENBQUE7QUFDekMsY0FBYyxnQkFBZ0IsQ0FBQTtBQUM5QixjQUFjLGlCQUFpQixDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9kaXJlY3RpdmVzL3dpZGdldC1kcmFnLWhhbmRsZS5kaXJlY3RpdmUnXG5leHBvcnQgKiBmcm9tICcuL2RpcmVjdGl2ZXMvd2lkZ2V0LWljb24tdHBsLmRpcmVjdGl2ZSdcbmV4cG9ydCAqIGZyb20gJy4vZGlyZWN0aXZlcy93aWRnZXQtdGl0bGUtdHBsLmRpcmVjdGl2ZSdcblxuZXhwb3J0ICogZnJvbSAnLi93aWRnZXQtY29udGVudC1jb21wb25lbnRzL3dpZGdldC1idXR0b24tZ3JvdXAvd2lkZ2V0LWJ1dHRvbi1ncm91cC5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL3dpZGdldC1jb250ZW50LWNvbXBvbmVudHMvd2lkZ2V0LWJ1dHRvbi1ncm91cC93aWRnZXQtYnV0dG9uLWdyb3VwLm1vZHVsZSdcblxuZXhwb3J0ICogZnJvbSAnLi93aWRnZXQtY29udGVudC1jb21wb25lbnRzL3dpZGdldC1jb250ZW50LWhlYWRlci93aWRnZXQtY29udGVudC1oZWFkZXIuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi93aWRnZXQtY29udGVudC1jb21wb25lbnRzL3dpZGdldC1jb250ZW50LWhlYWRlci93aWRnZXQtY29udGVudC1oZWFkZXIubW9kdWxlJ1xuXG5leHBvcnQgKiBmcm9tICcuL3dpZGdldC1jb250ZW50LWNvbXBvbmVudHMvd2lkZ2V0LWRlc2NyaXB0aW9uL3dpZGdldC1kZXNjcmlwdGlvbi5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL3dpZGdldC1jb250ZW50LWNvbXBvbmVudHMvd2lkZ2V0LWRlc2NyaXB0aW9uL3dpZGdldC1kZXNjcmlwdGlvbi5tb2R1bGUnXG5cbmV4cG9ydCAqIGZyb20gJy4vd2lkZ2V0LWNvbnRlbnQtY29tcG9uZW50cy93aWRnZXQtZW1wdHktbGFiZWwvd2lkZ2V0LWVtcHR5LWxhYmVsLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vd2lkZ2V0LWNvbnRlbnQtY29tcG9uZW50cy93aWRnZXQtZW1wdHktbGFiZWwvd2lkZ2V0LWVtcHR5LWxhYmVsLm1vZHVsZSdcblxuZXhwb3J0ICogZnJvbSAnLi93aWRnZXQtY29udGVudC1jb21wb25lbnRzL3dpZGdldC1mb290ZXItbGluay93aWRnZXQtZm9vdGVyLWxpbmsuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi93aWRnZXQtY29udGVudC1jb21wb25lbnRzL3dpZGdldC1mb290ZXItbGluay93aWRnZXQtZm9vdGVyLWxpbmsubW9kdWxlJ1xuXG5leHBvcnQgKiBmcm9tICcuL3dpZGdldC1jb250ZW50LWNvbXBvbmVudHMvd2lkZ2V0LWZvb3Rlci10ZXh0L3dpZGdldC1mb290ZXItdGV4dC5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL3dpZGdldC1jb250ZW50LWNvbXBvbmVudHMvd2lkZ2V0LWZvb3Rlci10ZXh0L3dpZGdldC1mb290ZXItdGV4dC5tb2R1bGUnXG5cbmV4cG9ydCAqIGZyb20gJy4vd2lkZ2V0LWNvbnRlbnQtY29tcG9uZW50cy93aWRnZXQtaGVhZGVyLWJhZGdlL3dpZGdldC1oZWFkZXItYmFkZ2UuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi93aWRnZXQtY29udGVudC1jb21wb25lbnRzL3dpZGdldC1oZWFkZXItYmFkZ2Uvd2lkZ2V0LWhlYWRlci1iYWRnZS5tb2R1bGUnXG5cbmV4cG9ydCAqIGZyb20gJy4vd2lkZ2V0LWNvbnRlbnQtY29tcG9uZW50cy93aWRnZXQtbGlzdC1ncm91cC93aWRnZXQtbGlzdC1ncm91cC1pdGVtL3dpZGdldC1saXN0LWdyb3VwLWl0ZW0taWNvbi10cGwuZGlyZWN0aXZlJ1xuZXhwb3J0ICogZnJvbSAnLi93aWRnZXQtY29udGVudC1jb21wb25lbnRzL3dpZGdldC1saXN0LWdyb3VwL3dpZGdldC1saXN0LWdyb3VwLWl0ZW0vd2lkZ2V0LWxpc3QtZ3JvdXAtaXRlbS5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL3dpZGdldC1jb250ZW50LWNvbXBvbmVudHMvd2lkZ2V0LWxpc3QtZ3JvdXAvd2lkZ2V0LWxpc3QtZ3JvdXAuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi93aWRnZXQtY29udGVudC1jb21wb25lbnRzL3dpZGdldC1saXN0LWdyb3VwL3dpZGdldC1saXN0LWdyb3VwLm1vZHVsZSdcblxuZXhwb3J0ICogZnJvbSAnLi93aWRnZXQtY29udGVudC1jb21wb25lbnRzL3dpZGdldC10YWJsZS93aWRnZXQtdGFibGUuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi93aWRnZXQtY29udGVudC1jb21wb25lbnRzL3dpZGdldC10YWJsZS93aWRnZXQtdGFibGUubW9kdWxlJ1xuXG5leHBvcnQgKiBmcm9tICcuL3dpZGdldC1jb250ZW50LWNvbXBvbmVudHMvd2lkZ2V0LXRpbGUvd2lkZ2V0LXRpbGUtZm9vdGVyL3dpZGdldC10aWxlLWZvb3Rlci5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL3dpZGdldC1jb250ZW50LWNvbXBvbmVudHMvd2lkZ2V0LXRpbGUvd2lkZ2V0LXRpbGUtZm9vdGVyLWl0ZW0vd2lkZ2V0LXRpbGUtZm9vdGVyLWl0ZW0uY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi93aWRnZXQtY29udGVudC1jb21wb25lbnRzL3dpZGdldC10aWxlL3dpZGdldC10aWxlLWdyb3VwL3dpZGdldC10aWxlLWdyb3VwLmNvbXBvbmVudCdcblxuZXhwb3J0ICogZnJvbSAnLi93aWRnZXQtY29udGVudC1jb21wb25lbnRzL3dpZGdldC10aWxlL3dpZGdldC10aWxlLXNlY29uZGFyeS1pY29uLmRpcmVjdGl2ZSdcbmV4cG9ydCAqIGZyb20gJy4vd2lkZ2V0LWNvbnRlbnQtY29tcG9uZW50cy93aWRnZXQtdGlsZS93aWRnZXQtdGlsZS5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL3dpZGdldC1jb250ZW50LWNvbXBvbmVudHMvd2lkZ2V0LXRpbGUvd2lkZ2V0LXRpbGUubW9kdWxlJ1xuXG5leHBvcnQgKiBmcm9tICcuL3dpZGdldC1jb250ZW50LWNvbXBvbmVudHMvd2lkZ2V0LXRpbGUtbGlzdC93aWRnZXQtdGlsZS1saXN0LmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vd2lkZ2V0LWNvbnRlbnQtY29tcG9uZW50cy93aWRnZXQtdGlsZS1saXN0L3dpZGdldC10aWxlLWxpc3QubW9kdWxlJ1xuXG5leHBvcnQgKiBmcm9tICcuL3dpZGdldC93aWRnZXQuY29tcG9uZW50J1xuXG5leHBvcnQgKiBmcm9tICcuL3dpZGdldC1mb290ZXIvd2lkZ2V0LWZvb3Rlci5jb21wb25lbnQnXG5cbmV4cG9ydCAqIGZyb20gJy4vd2lkZ2V0LXJlZ2lzdHJ5Lm1vZGVscydcbmV4cG9ydCAqIGZyb20gJy4vd2lkZ2V0LXJlZ2lzdHJ5LnNlcnZpY2UnXG5leHBvcnQgKiBmcm9tICcuL3dpZGdldC10b2tlbidcbmV4cG9ydCAqIGZyb20gJy4vd2lkZ2V0Lm1vZHVsZSdcbiJdfQ==
38
+ export * from './widget.models';
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi93aWRnZXQvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDJDQUEyQyxDQUFBO0FBQ3pELGNBQWMsd0NBQXdDLENBQUE7QUFDdEQsY0FBYyx5Q0FBeUMsQ0FBQTtBQUV2RCxjQUFjLCtFQUErRSxDQUFBO0FBQzdGLGNBQWMsNEVBQTRFLENBQUE7QUFFMUYsY0FBYyxtRkFBbUYsQ0FBQTtBQUNqRyxjQUFjLGdGQUFnRixDQUFBO0FBRTlGLGNBQWMsNkVBQTZFLENBQUE7QUFDM0YsY0FBYywwRUFBMEUsQ0FBQTtBQUV4RixjQUFjLDZFQUE2RSxDQUFBO0FBQzNGLGNBQWMsMEVBQTBFLENBQUE7QUFFeEYsY0FBYyw2RUFBNkUsQ0FBQTtBQUMzRixjQUFjLDBFQUEwRSxDQUFBO0FBRXhGLGNBQWMsNkVBQTZFLENBQUE7QUFDM0YsY0FBYywwRUFBMEUsQ0FBQTtBQUV4RixjQUFjLCtFQUErRSxDQUFBO0FBQzdGLGNBQWMsNEVBQTRFLENBQUE7QUFFMUYsY0FBYyxnSEFBZ0gsQ0FBQTtBQUM5SCxjQUFjLHVHQUF1RyxDQUFBO0FBQ3JILGNBQWMsMkVBQTJFLENBQUE7QUFDekYsY0FBYyx3RUFBd0UsQ0FBQTtBQUV0RixjQUFjLGlFQUFpRSxDQUFBO0FBQy9FLGNBQWMsOERBQThELENBQUE7QUFFNUUsY0FBYyx5RkFBeUYsQ0FBQTtBQUN2RyxjQUFjLG1HQUFtRyxDQUFBO0FBQ2pILGNBQWMsdUZBQXVGLENBQUE7QUFFckcsY0FBYyw4RUFBOEUsQ0FBQTtBQUM1RixjQUFjLCtEQUErRCxDQUFBO0FBQzdFLGNBQWMsNERBQTRELENBQUE7QUFFMUUsY0FBYyx5RUFBeUUsQ0FBQTtBQUN2RixjQUFjLHNFQUFzRSxDQUFBO0FBRXBGLGNBQWMsMkJBQTJCLENBQUE7QUFFekMsY0FBYyx5Q0FBeUMsQ0FBQTtBQUV2RCxjQUFjLDBCQUEwQixDQUFBO0FBQ3hDLGNBQWMsMkJBQTJCLENBQUE7QUFDekMsY0FBYyxnQkFBZ0IsQ0FBQTtBQUM5QixjQUFjLGlCQUFpQixDQUFBO0FBQy9CLGNBQWMsaUJBQWlCLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2RpcmVjdGl2ZXMvd2lkZ2V0LWRyYWctaGFuZGxlLmRpcmVjdGl2ZSdcbmV4cG9ydCAqIGZyb20gJy4vZGlyZWN0aXZlcy93aWRnZXQtaWNvbi10cGwuZGlyZWN0aXZlJ1xuZXhwb3J0ICogZnJvbSAnLi9kaXJlY3RpdmVzL3dpZGdldC10aXRsZS10cGwuZGlyZWN0aXZlJ1xuXG5leHBvcnQgKiBmcm9tICcuL3dpZGdldC1jb250ZW50LWNvbXBvbmVudHMvd2lkZ2V0LWJ1dHRvbi1ncm91cC93aWRnZXQtYnV0dG9uLWdyb3VwLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vd2lkZ2V0LWNvbnRlbnQtY29tcG9uZW50cy93aWRnZXQtYnV0dG9uLWdyb3VwL3dpZGdldC1idXR0b24tZ3JvdXAubW9kdWxlJ1xuXG5leHBvcnQgKiBmcm9tICcuL3dpZGdldC1jb250ZW50LWNvbXBvbmVudHMvd2lkZ2V0LWNvbnRlbnQtaGVhZGVyL3dpZGdldC1jb250ZW50LWhlYWRlci5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL3dpZGdldC1jb250ZW50LWNvbXBvbmVudHMvd2lkZ2V0LWNvbnRlbnQtaGVhZGVyL3dpZGdldC1jb250ZW50LWhlYWRlci5tb2R1bGUnXG5cbmV4cG9ydCAqIGZyb20gJy4vd2lkZ2V0LWNvbnRlbnQtY29tcG9uZW50cy93aWRnZXQtZGVzY3JpcHRpb24vd2lkZ2V0LWRlc2NyaXB0aW9uLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vd2lkZ2V0LWNvbnRlbnQtY29tcG9uZW50cy93aWRnZXQtZGVzY3JpcHRpb24vd2lkZ2V0LWRlc2NyaXB0aW9uLm1vZHVsZSdcblxuZXhwb3J0ICogZnJvbSAnLi93aWRnZXQtY29udGVudC1jb21wb25lbnRzL3dpZGdldC1lbXB0eS1sYWJlbC93aWRnZXQtZW1wdHktbGFiZWwuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi93aWRnZXQtY29udGVudC1jb21wb25lbnRzL3dpZGdldC1lbXB0eS1sYWJlbC93aWRnZXQtZW1wdHktbGFiZWwubW9kdWxlJ1xuXG5leHBvcnQgKiBmcm9tICcuL3dpZGdldC1jb250ZW50LWNvbXBvbmVudHMvd2lkZ2V0LWZvb3Rlci1saW5rL3dpZGdldC1mb290ZXItbGluay5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL3dpZGdldC1jb250ZW50LWNvbXBvbmVudHMvd2lkZ2V0LWZvb3Rlci1saW5rL3dpZGdldC1mb290ZXItbGluay5tb2R1bGUnXG5cbmV4cG9ydCAqIGZyb20gJy4vd2lkZ2V0LWNvbnRlbnQtY29tcG9uZW50cy93aWRnZXQtZm9vdGVyLXRleHQvd2lkZ2V0LWZvb3Rlci10ZXh0LmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vd2lkZ2V0LWNvbnRlbnQtY29tcG9uZW50cy93aWRnZXQtZm9vdGVyLXRleHQvd2lkZ2V0LWZvb3Rlci10ZXh0Lm1vZHVsZSdcblxuZXhwb3J0ICogZnJvbSAnLi93aWRnZXQtY29udGVudC1jb21wb25lbnRzL3dpZGdldC1oZWFkZXItYmFkZ2Uvd2lkZ2V0LWhlYWRlci1iYWRnZS5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL3dpZGdldC1jb250ZW50LWNvbXBvbmVudHMvd2lkZ2V0LWhlYWRlci1iYWRnZS93aWRnZXQtaGVhZGVyLWJhZGdlLm1vZHVsZSdcblxuZXhwb3J0ICogZnJvbSAnLi93aWRnZXQtY29udGVudC1jb21wb25lbnRzL3dpZGdldC1saXN0LWdyb3VwL3dpZGdldC1saXN0LWdyb3VwLWl0ZW0vd2lkZ2V0LWxpc3QtZ3JvdXAtaXRlbS1pY29uLXRwbC5kaXJlY3RpdmUnXG5leHBvcnQgKiBmcm9tICcuL3dpZGdldC1jb250ZW50LWNvbXBvbmVudHMvd2lkZ2V0LWxpc3QtZ3JvdXAvd2lkZ2V0LWxpc3QtZ3JvdXAtaXRlbS93aWRnZXQtbGlzdC1ncm91cC1pdGVtLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vd2lkZ2V0LWNvbnRlbnQtY29tcG9uZW50cy93aWRnZXQtbGlzdC1ncm91cC93aWRnZXQtbGlzdC1ncm91cC5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL3dpZGdldC1jb250ZW50LWNvbXBvbmVudHMvd2lkZ2V0LWxpc3QtZ3JvdXAvd2lkZ2V0LWxpc3QtZ3JvdXAubW9kdWxlJ1xuXG5leHBvcnQgKiBmcm9tICcuL3dpZGdldC1jb250ZW50LWNvbXBvbmVudHMvd2lkZ2V0LXRhYmxlL3dpZGdldC10YWJsZS5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL3dpZGdldC1jb250ZW50LWNvbXBvbmVudHMvd2lkZ2V0LXRhYmxlL3dpZGdldC10YWJsZS5tb2R1bGUnXG5cbmV4cG9ydCAqIGZyb20gJy4vd2lkZ2V0LWNvbnRlbnQtY29tcG9uZW50cy93aWRnZXQtdGlsZS93aWRnZXQtdGlsZS1mb290ZXIvd2lkZ2V0LXRpbGUtZm9vdGVyLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vd2lkZ2V0LWNvbnRlbnQtY29tcG9uZW50cy93aWRnZXQtdGlsZS93aWRnZXQtdGlsZS1mb290ZXItaXRlbS93aWRnZXQtdGlsZS1mb290ZXItaXRlbS5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL3dpZGdldC1jb250ZW50LWNvbXBvbmVudHMvd2lkZ2V0LXRpbGUvd2lkZ2V0LXRpbGUtZ3JvdXAvd2lkZ2V0LXRpbGUtZ3JvdXAuY29tcG9uZW50J1xuXG5leHBvcnQgKiBmcm9tICcuL3dpZGdldC1jb250ZW50LWNvbXBvbmVudHMvd2lkZ2V0LXRpbGUvd2lkZ2V0LXRpbGUtc2Vjb25kYXJ5LWljb24uZGlyZWN0aXZlJ1xuZXhwb3J0ICogZnJvbSAnLi93aWRnZXQtY29udGVudC1jb21wb25lbnRzL3dpZGdldC10aWxlL3dpZGdldC10aWxlLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vd2lkZ2V0LWNvbnRlbnQtY29tcG9uZW50cy93aWRnZXQtdGlsZS93aWRnZXQtdGlsZS5tb2R1bGUnXG5cbmV4cG9ydCAqIGZyb20gJy4vd2lkZ2V0LWNvbnRlbnQtY29tcG9uZW50cy93aWRnZXQtdGlsZS1saXN0L3dpZGdldC10aWxlLWxpc3QuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi93aWRnZXQtY29udGVudC1jb21wb25lbnRzL3dpZGdldC10aWxlLWxpc3Qvd2lkZ2V0LXRpbGUtbGlzdC5tb2R1bGUnXG5cbmV4cG9ydCAqIGZyb20gJy4vd2lkZ2V0L3dpZGdldC5jb21wb25lbnQnXG5cbmV4cG9ydCAqIGZyb20gJy4vd2lkZ2V0LWZvb3Rlci93aWRnZXQtZm9vdGVyLmNvbXBvbmVudCdcblxuZXhwb3J0ICogZnJvbSAnLi93aWRnZXQtcmVnaXN0cnkubW9kZWxzJ1xuZXhwb3J0ICogZnJvbSAnLi93aWRnZXQtcmVnaXN0cnkuc2VydmljZSdcbmV4cG9ydCAqIGZyb20gJy4vd2lkZ2V0LXRva2VuJ1xuZXhwb3J0ICogZnJvbSAnLi93aWRnZXQubW9kdWxlJ1xuZXhwb3J0ICogZnJvbSAnLi93aWRnZXQubW9kZWxzJ1xuIl19
@@ -1,17 +1,22 @@
1
1
  import { __decorate } from "tslib";
2
2
  import { animate, state, style, transition, trigger } from '@angular/animations';
3
- import { Component, ContentChild, Input, isDevMode, ViewEncapsulation } from '@angular/core';
3
+ import { Component, ContentChild, Inject, Input, isDevMode, Optional, ViewEncapsulation } from '@angular/core';
4
+ import { Subject, takeUntil, tap } from 'rxjs';
4
5
  import { faAngleDown, faCog } from '@fortawesome/free-solid-svg-icons';
5
6
  import { InputBoolean } from '@theseam/ui-common/core';
7
+ import { hasProperty } from '@theseam/ui-common/utils';
6
8
  import { WidgetIconTplDirective } from '../directives/widget-icon-tpl.directive';
7
9
  import { WidgetTitleTplDirective } from '../directives/widget-title-tpl.directive';
10
+ import { WidgetPreferencesService } from '../preferences/widget-preferences.service';
11
+ import { THESEAM_WIDGET_DATA, THESEAM_WIDGET_DEFAULTS } from '../widget-token';
8
12
  import * as i0 from "@angular/core";
9
- import * as i1 from "@angular/common";
10
- import * as i2 from "@fortawesome/angular-fontawesome";
11
- import * as i3 from "@theseam/ui-common/icon";
12
- import * as i4 from "@theseam/ui-common/loading";
13
- import * as i5 from "@theseam/ui-common/buttons";
14
- import * as i6 from "../directives/widget-drag-handle.directive";
13
+ import * as i1 from "../preferences/widget-preferences.service";
14
+ import * as i2 from "@angular/common";
15
+ import * as i3 from "@fortawesome/angular-fontawesome";
16
+ import * as i4 from "@theseam/ui-common/icon";
17
+ import * as i5 from "@theseam/ui-common/loading";
18
+ import * as i6 from "@theseam/ui-common/buttons";
19
+ import * as i7 from "../directives/widget-drag-handle.directive";
15
20
  const EXPANDED_STATE = 'expanded';
16
21
  const COLLAPSED_STATE = 'collapsed';
17
22
  const EXPAND_TRANSITION = `${EXPANDED_STATE} <=> ${COLLAPSED_STATE}`;
@@ -53,9 +58,32 @@ const collapseAnimation = trigger('collapseAnim', [
53
58
  * used then the situation should be considered for becoming a widget component.
54
59
  */
55
60
  export class WidgetComponent {
56
- constructor() {
61
+ /**
62
+ * Icon displayed in the top header.
63
+ *
64
+ * If a more advanced icon is needed you can use `seamWidgetIconTpl` template
65
+ * directive, but a `SeamIcon` input is recommended, because allowing custom
66
+ * icons that do not follow the tested types can lead to inconsitency quickly
67
+ * as different developers keep making tweaks.
68
+ */
69
+ get icon() { return this._iconUrl || this._iconObj; }
70
+ set icon(value) {
71
+ if (typeof value === 'string') {
72
+ this._iconUrl = value;
73
+ this._iconObj = undefined;
74
+ }
75
+ else {
76
+ this._iconUrl = undefined;
77
+ this._iconObj = value;
78
+ }
79
+ }
80
+ constructor(_widgetPreferences, _defaults, _data) {
81
+ this._widgetPreferences = _widgetPreferences;
82
+ this._defaults = _defaults;
83
+ this._data = _data;
57
84
  this.configIcon = faCog;
58
85
  this.collapseIcon = faAngleDown;
86
+ this._ngUnsubscribe = new Subject();
59
87
  /**
60
88
  * Toggles the collapsed state of a widget.
61
89
  */
@@ -75,26 +103,27 @@ export class WidgetComponent {
75
103
  * header to toggle the collapsed state.
76
104
  */
77
105
  this.canCollapse = false;
78
- }
79
- /**
80
- * Icon displayed in the top header.
81
- *
82
- * If a more advanced icon is needed you can use `seamWidgetIconTpl` template
83
- * directive, but a `SeamIcon` input is recommended, because allowing custom
84
- * icons that do not follow the tested types can lead to inconsitency quickly
85
- * as different developers keep making tweaks.
86
- */
87
- get icon() { return this._iconUrl || this._iconObj; }
88
- set icon(value) {
89
- if (typeof value === 'string') {
90
- this._iconUrl = value;
91
- this._iconObj = undefined;
106
+ if (this._defaults) {
107
+ if (hasProperty(this._defaults, 'canCollapse')) {
108
+ this.canCollapse = this._defaults.canCollapse;
109
+ }
110
+ if (hasProperty(this._defaults, 'collapsed')) {
111
+ this.collapsed = this._defaults.collapsed;
112
+ }
92
113
  }
93
- else {
94
- this._iconUrl = undefined;
95
- this._iconObj = value;
114
+ if (this._data && this._data.widgetId) {
115
+ this._preferencesKey = `widget:${this._data.widgetId}`;
116
+ this._widgetPreferences.preferences(this._preferencesKey).pipe(tap(prefs => {
117
+ if (hasProperty(prefs, 'collapsed')) {
118
+ this.collapsed = prefs.collapsed;
119
+ }
120
+ }), takeUntil(this._ngUnsubscribe)).subscribe();
96
121
  }
97
122
  }
123
+ ngOnDestroy() {
124
+ this._ngUnsubscribe.next();
125
+ this._ngUnsubscribe.complete();
126
+ }
98
127
  /**
99
128
  * Toggles a widget's collapsed state.
100
129
  */
@@ -106,11 +135,21 @@ export class WidgetComponent {
106
135
  return;
107
136
  }
108
137
  this.collapsed = !this.collapsed;
138
+ // Only update the preference, if collapse method is called, because it is
139
+ // assumed that the user is collapsing the widget. If the collapsed state is
140
+ // changed by other means, such using the widget's `collapsed` input, then
141
+ // the preference should not be updated, because that is assumed to be an
142
+ // app controlled change that should not be persisted.
143
+ if (this._preferencesKey) {
144
+ this._widgetPreferences.patchPreferences(this._preferencesKey, { collapsed: this.collapsed });
145
+ }
109
146
  }
110
147
  get collapseState() { return this.collapsed ? COLLAPSED_STATE : EXPANDED_STATE; }
111
148
  }
112
- WidgetComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: WidgetComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
113
- WidgetComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: WidgetComponent, selector: "seam-widget", inputs: { collapsed: "collapsed", hasHeader: "hasHeader", titleText: "titleText", icon: "icon", iconClass: "iconClass", loading: "loading", hasConfig: "hasConfig", canCollapse: "canCollapse" }, queries: [{ propertyName: "iconTpl", first: true, predicate: WidgetIconTplDirective, descendants: true, static: true }, { propertyName: "titleTpl", first: true, predicate: WidgetTitleTplDirective, descendants: true, static: true }], ngImport: i0, template: "<div class=\"seam-widget border rounded overflow-hidden\">\n <div class=\"widget-header\" seamWidgetDragHandle *ngIf=\"hasHeader\">\n <div class=\"widget-header-content p-2 text-nowrap\">\n <span class=\"mr-1 widget-header-icon\">\n <ng-container *ngIf=\"iconTpl; else noIconTpl\">\n <ng-template\n [ngTemplateOutlet]=\"iconTpl.template\"\n [ngTemplateOutletContext]=\"{ $implicit: icon, icon: icon, title: titleText }\">\n </ng-template>\n </ng-container>\n <ng-template #noIconTpl>\n <fa-icon *ngIf=\"_iconObj\"\n class=\"widget-header-icon--fa {{ iconClass }}\"\n [icon]=\"_iconObj\"></fa-icon>\n <img *ngIf=\"_iconUrl\"\n class=\"widget-header-icon--img {{ iconClass }}\"\n [src]=\"_iconUrl\" [alt]=\"titleText\">\n </ng-template>\n </span>\n <span class=\"widget-header-title text-truncate\">\n <ng-container *ngIf=\"titleTpl; else noTitleTpl\">\n <ng-template\n [ngTemplateOutlet]=\"titleTpl.template\"\n [ngTemplateOutletContext]=\"{ $implicit: titleText, icon: icon, title: titleText }\">\n </ng-template>\n </ng-container>\n <ng-template #noTitleTpl>{{ titleText }}</ng-template>\n </span>\n </div>\n <div class=\"widget-header-btns-container\" *ngIf=\"hasConfig || canCollapse\">\n <!-- <div *ngIf=\"hasConfig\">\n <button seamIconBtn [icon]=\"configIcon\"\n class=\"widget-header-btn-config\"\n [iconType]=\"null\">\n <span class=\"sr-only\">Widget configuration menu</span>\n </button>\n <button seamButton class=\"widget-header-btn-config p-0\">\n <seam-icon class=\"d-block\" [icon]=\"configIcon\" iconClass=\"text-secondary\"></seam-icon>\n <span class=\"sr-only\">Widget configuration menu</span>\n </button>\n </div> -->\n\n <div *ngIf=\"canCollapse\" class=\"px-0\">\n\n <button seamButton class=\"widget-header-btn-collapse p-0 mr-1 h-100\" (click)=\"collapse()\" [class.widget-header-btn-collapse--active]=\"collapsed\">\n <seam-icon class=\"d-block\"\n [icon]=\"collapseIcon\"\n iconClass=\"text-secondary\">\n </seam-icon>\n <span class=\"sr-only\">Widget collapse</span>\n </button>\n <!-- iconType=\"borderless-styled-square\" -->\n <!-- style=\"margin-left: -10px; margin-right: -5px;\" -->\n\n <!-- <button seamIconBtn class=\"widget-header-btn-collapse\" (click)=\"collapse()\" [class.widget-header-btn-collapse--active]=\"collapsed\"\n btnTheme=\"secondary\"\n [icon]=\"collapseIcon\"\n iconType=\"borderless-styled-square\"\n size=\"xs\"\n btnSize=\"sm\"\n >\n <seam-icon class=\"d-block\"\n [icon]=\"collapseIcon\"\n iconClass=\"text-secondary\"\n style=\"margin-left: -10px; margin-right: -5px;\"\n iconType=\"borderless-styled-square\"></seam-icon>\n <span class=\"sr-only\">Widget collapse</span>\n </button> -->\n </div>\n </div>\n </div>\n <div class=\"position-relative overflow-hidden\" [style.height.px]=\"loading ? 150 : undefined\" [@collapseAnim]=\"collapseState\">\n <ng-container *ngIf=\"!collapsed\">\n <div class=\"p-2\" *ngIf=\"!loading else loadingTpl\" @keepContentAnim>\n <ng-content></ng-content>\n </div>\n <ng-content select=\"seam-widget-footer\"></ng-content>\n <ng-template #loadingTpl>\n <div class=\"position-absolute\" @loadingAnim style=\"top:0;right:0;bottom:0;left:0\">\n <seam-loading [theme]=\"'primary'\"></seam-loading>\n </div>\n </ng-template>\n </ng-container>\n </div>\n</div>\n", styles: ["seam-widget{display:block;font-size:15px}seam-widget .seam-widget{background:#FFFFFF;box-shadow:none}seam-widget .widget-header{display:flex;flex-direction:row;border-bottom:1px solid #dee2e6;background:#F4F4F4;font-size:17px}seam-widget .widget-header .widget-header-content{flex:1 1 100%}seam-widget .widget-header .widget-header-btns-container{display:flex;flex-direction:row}seam-widget .widget-header .widget-header-btns-container>div{display:flex;flex-direction:column;justify-content:center;padding:4px}seam-widget .widget-header .widget-header-btns-container .widget-header-btn-config .seam-icon--fa{display:flex;flex-direction:row;justify-content:center;text-align:center;height:25px;width:30px}seam-widget .widget-header .widget-header-btns-container .widget-header-btn-config .seam-icon--fa .svg-inline--fa{max-width:100%;height:100%;width:100%}seam-widget .widget-header .widget-header-btns-container .widget-header-btn-collapse .seam-icon--fa{display:flex;flex-direction:row;justify-content:center;text-align:center;height:25px;width:30px}seam-widget .widget-header .widget-header-btns-container .widget-header-btn-collapse .seam-icon--fa .svg-inline--fa{max-width:100%;height:100%;width:100%}seam-widget .widget-header .widget-header-btns-container .widget-header-btn-collapse .svg-inline--fa{transform:rotate(0);transition:.3s ease-in-out transform}seam-widget .widget-header .widget-header-btns-container .widget-header-btn-collapse.widget-header-btn-collapse--active .svg-inline--fa{transform:rotate(90deg)}seam-widget .widget-header .widget-header-title{font-size:17px}seam-widget .widget-header-icon{display:inline-block;vertical-align:top;max-height:20px;max-width:20px;height:20px;width:20px;color:currentColor}seam-widget .widget-header-icon .widget-header-icon--fa{display:flex;flex-direction:row;justify-content:center;text-align:center;max-height:20px;max-width:20px;height:20px;width:20px}seam-widget .widget-header-icon .widget-header-icon--fa .svg-inline--fa{max-width:100%;height:100%;width:100%}seam-widget .widget-header-icon .widget-header-icon--img{height:100%;max-height:20px;max-width:20px}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.FaIconComponent, selector: "fa-icon", inputs: ["classes", "icon", "title", "spin", "pulse", "mask", "styles", "flip", "size", "pull", "border", "inverse", "symbol", "rotate", "fixedWidth", "transform", "a11yRole"] }, { kind: "component", type: i3.IconComponent, selector: "seam-icon", inputs: ["grayscaleOnDisable", "disabled", "iconClass", "icon", "size", "showDefaultOnError", "defaultIcon", "iconType"] }, { kind: "component", type: i4.LoadingComponent, selector: "seam-loading", inputs: ["theme"] }, { kind: "component", type: i5.ButtonComponent, selector: "button[seamButton]", inputs: ["disabled", "theme", "size", "type"], exportAs: ["seamButton"] }, { kind: "directive", type: i6.WidgetDragHandleDirective, selector: "[seamWidgetDragHandle]", inputs: ["cdkDragHandleDisabled"] }], animations: [
149
+ WidgetComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: WidgetComponent, deps: [{ token: i1.WidgetPreferencesService }, { token: THESEAM_WIDGET_DEFAULTS, optional: true }, { token: THESEAM_WIDGET_DATA, optional: true }], target: i0.ɵɵFactoryTarget.Component });
150
+ WidgetComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: WidgetComponent, selector: "seam-widget", inputs: { collapsed: "collapsed", hasHeader: "hasHeader", titleText: "titleText", icon: "icon", iconClass: "iconClass", loading: "loading", hasConfig: "hasConfig", canCollapse: "canCollapse" }, providers: [
151
+ WidgetPreferencesService,
152
+ ], queries: [{ propertyName: "iconTpl", first: true, predicate: WidgetIconTplDirective, descendants: true, static: true }, { propertyName: "titleTpl", first: true, predicate: WidgetTitleTplDirective, descendants: true, static: true }], ngImport: i0, template: "<div class=\"seam-widget border rounded overflow-hidden\">\n <div class=\"widget-header\" seamWidgetDragHandle *ngIf=\"hasHeader\">\n <div class=\"widget-header-content p-2 text-nowrap\">\n <span class=\"mr-1 widget-header-icon\">\n <ng-container *ngIf=\"iconTpl; else noIconTpl\">\n <ng-template\n [ngTemplateOutlet]=\"iconTpl.template\"\n [ngTemplateOutletContext]=\"{ $implicit: icon, icon: icon, title: titleText }\">\n </ng-template>\n </ng-container>\n <ng-template #noIconTpl>\n <fa-icon *ngIf=\"_iconObj\"\n class=\"widget-header-icon--fa {{ iconClass }}\"\n [icon]=\"_iconObj\"></fa-icon>\n <img *ngIf=\"_iconUrl\"\n class=\"widget-header-icon--img {{ iconClass }}\"\n [src]=\"_iconUrl\" [alt]=\"titleText\">\n </ng-template>\n </span>\n <span class=\"widget-header-title text-truncate\">\n <ng-container *ngIf=\"titleTpl; else noTitleTpl\">\n <ng-template\n [ngTemplateOutlet]=\"titleTpl.template\"\n [ngTemplateOutletContext]=\"{ $implicit: titleText, icon: icon, title: titleText }\">\n </ng-template>\n </ng-container>\n <ng-template #noTitleTpl>{{ titleText }}</ng-template>\n </span>\n </div>\n <div class=\"widget-header-btns-container\" *ngIf=\"hasConfig || canCollapse\">\n <!-- <div *ngIf=\"hasConfig\">\n <button seamIconBtn [icon]=\"configIcon\"\n class=\"widget-header-btn-config\"\n [iconType]=\"null\">\n <span class=\"sr-only\">Widget configuration menu</span>\n </button>\n <button seamButton class=\"widget-header-btn-config p-0\">\n <seam-icon class=\"d-block\" [icon]=\"configIcon\" iconClass=\"text-secondary\"></seam-icon>\n <span class=\"sr-only\">Widget configuration menu</span>\n </button>\n </div> -->\n\n <div *ngIf=\"canCollapse\" class=\"px-0\">\n\n <button seamButton class=\"widget-header-btn-collapse p-0 mr-1 h-100\" (click)=\"collapse()\" [class.widget-header-btn-collapse--active]=\"collapsed\">\n <seam-icon class=\"d-block\"\n [icon]=\"collapseIcon\"\n iconClass=\"text-secondary\">\n </seam-icon>\n <span class=\"sr-only\">Widget collapse</span>\n </button>\n <!-- iconType=\"borderless-styled-square\" -->\n <!-- style=\"margin-left: -10px; margin-right: -5px;\" -->\n\n <!-- <button seamIconBtn class=\"widget-header-btn-collapse\" (click)=\"collapse()\" [class.widget-header-btn-collapse--active]=\"collapsed\"\n btnTheme=\"secondary\"\n [icon]=\"collapseIcon\"\n iconType=\"borderless-styled-square\"\n size=\"xs\"\n btnSize=\"sm\"\n >\n <seam-icon class=\"d-block\"\n [icon]=\"collapseIcon\"\n iconClass=\"text-secondary\"\n style=\"margin-left: -10px; margin-right: -5px;\"\n iconType=\"borderless-styled-square\"></seam-icon>\n <span class=\"sr-only\">Widget collapse</span>\n </button> -->\n </div>\n </div>\n </div>\n <div class=\"position-relative overflow-hidden\" [style.height.px]=\"loading ? 150 : undefined\" [@collapseAnim]=\"collapseState\">\n <ng-container *ngIf=\"!collapsed\">\n <div class=\"p-2\" *ngIf=\"!loading else loadingTpl\" @keepContentAnim>\n <ng-content></ng-content>\n </div>\n <ng-content select=\"seam-widget-footer\"></ng-content>\n <ng-template #loadingTpl>\n <div class=\"position-absolute\" @loadingAnim style=\"top:0;right:0;bottom:0;left:0\">\n <seam-loading [theme]=\"'primary'\"></seam-loading>\n </div>\n </ng-template>\n </ng-container>\n </div>\n</div>\n", styles: ["seam-widget{display:block;font-size:15px}seam-widget .seam-widget{background:#FFFFFF;box-shadow:none}seam-widget .widget-header{display:flex;flex-direction:row;border-bottom:1px solid #dee2e6;background:#F4F4F4;font-size:17px}seam-widget .widget-header .widget-header-content{flex:1 1 100%}seam-widget .widget-header .widget-header-btns-container{display:flex;flex-direction:row}seam-widget .widget-header .widget-header-btns-container>div{display:flex;flex-direction:column;justify-content:center;padding:4px}seam-widget .widget-header .widget-header-btns-container .widget-header-btn-config .seam-icon--fa{display:flex;flex-direction:row;justify-content:center;text-align:center;height:25px;width:30px}seam-widget .widget-header .widget-header-btns-container .widget-header-btn-config .seam-icon--fa .svg-inline--fa{max-width:100%;height:100%;width:100%}seam-widget .widget-header .widget-header-btns-container .widget-header-btn-collapse .seam-icon--fa{display:flex;flex-direction:row;justify-content:center;text-align:center;height:25px;width:30px}seam-widget .widget-header .widget-header-btns-container .widget-header-btn-collapse .seam-icon--fa .svg-inline--fa{max-width:100%;height:100%;width:100%}seam-widget .widget-header .widget-header-btns-container .widget-header-btn-collapse .svg-inline--fa{transform:rotate(0);transition:.3s ease-in-out transform}seam-widget .widget-header .widget-header-btns-container .widget-header-btn-collapse.widget-header-btn-collapse--active .svg-inline--fa{transform:rotate(90deg)}seam-widget .widget-header .widget-header-title{font-size:17px}seam-widget .widget-header-icon{display:inline-block;vertical-align:top;max-height:20px;max-width:20px;height:20px;width:20px;color:currentColor}seam-widget .widget-header-icon .widget-header-icon--fa{display:flex;flex-direction:row;justify-content:center;text-align:center;max-height:20px;max-width:20px;height:20px;width:20px}seam-widget .widget-header-icon .widget-header-icon--fa .svg-inline--fa{max-width:100%;height:100%;width:100%}seam-widget .widget-header-icon .widget-header-icon--img{height:100%;max-height:20px;max-width:20px}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i3.FaIconComponent, selector: "fa-icon", inputs: ["classes", "icon", "title", "spin", "pulse", "mask", "styles", "flip", "size", "pull", "border", "inverse", "symbol", "rotate", "fixedWidth", "transform", "a11yRole"] }, { kind: "component", type: i4.IconComponent, selector: "seam-icon", inputs: ["grayscaleOnDisable", "disabled", "iconClass", "icon", "size", "showDefaultOnError", "defaultIcon", "iconType"] }, { kind: "component", type: i5.LoadingComponent, selector: "seam-loading", inputs: ["theme"] }, { kind: "component", type: i6.ButtonComponent, selector: "button[seamButton]", inputs: ["disabled", "theme", "size", "type"], exportAs: ["seamButton"] }, { kind: "directive", type: i7.WidgetDragHandleDirective, selector: "[seamWidgetDragHandle]", inputs: ["cdkDragHandleDisabled"] }], animations: [
114
153
  loadingAnimation,
115
154
  collapseAnimation,
116
155
  keepContentAnimation,
@@ -132,12 +171,24 @@ __decorate([
132
171
  ], WidgetComponent.prototype, "canCollapse", void 0);
133
172
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: WidgetComponent, decorators: [{
134
173
  type: Component,
135
- args: [{ selector: 'seam-widget', encapsulation: ViewEncapsulation.None, animations: [
174
+ args: [{ selector: 'seam-widget', providers: [
175
+ WidgetPreferencesService,
176
+ ], encapsulation: ViewEncapsulation.None, animations: [
136
177
  loadingAnimation,
137
178
  collapseAnimation,
138
179
  keepContentAnimation,
139
180
  ], template: "<div class=\"seam-widget border rounded overflow-hidden\">\n <div class=\"widget-header\" seamWidgetDragHandle *ngIf=\"hasHeader\">\n <div class=\"widget-header-content p-2 text-nowrap\">\n <span class=\"mr-1 widget-header-icon\">\n <ng-container *ngIf=\"iconTpl; else noIconTpl\">\n <ng-template\n [ngTemplateOutlet]=\"iconTpl.template\"\n [ngTemplateOutletContext]=\"{ $implicit: icon, icon: icon, title: titleText }\">\n </ng-template>\n </ng-container>\n <ng-template #noIconTpl>\n <fa-icon *ngIf=\"_iconObj\"\n class=\"widget-header-icon--fa {{ iconClass }}\"\n [icon]=\"_iconObj\"></fa-icon>\n <img *ngIf=\"_iconUrl\"\n class=\"widget-header-icon--img {{ iconClass }}\"\n [src]=\"_iconUrl\" [alt]=\"titleText\">\n </ng-template>\n </span>\n <span class=\"widget-header-title text-truncate\">\n <ng-container *ngIf=\"titleTpl; else noTitleTpl\">\n <ng-template\n [ngTemplateOutlet]=\"titleTpl.template\"\n [ngTemplateOutletContext]=\"{ $implicit: titleText, icon: icon, title: titleText }\">\n </ng-template>\n </ng-container>\n <ng-template #noTitleTpl>{{ titleText }}</ng-template>\n </span>\n </div>\n <div class=\"widget-header-btns-container\" *ngIf=\"hasConfig || canCollapse\">\n <!-- <div *ngIf=\"hasConfig\">\n <button seamIconBtn [icon]=\"configIcon\"\n class=\"widget-header-btn-config\"\n [iconType]=\"null\">\n <span class=\"sr-only\">Widget configuration menu</span>\n </button>\n <button seamButton class=\"widget-header-btn-config p-0\">\n <seam-icon class=\"d-block\" [icon]=\"configIcon\" iconClass=\"text-secondary\"></seam-icon>\n <span class=\"sr-only\">Widget configuration menu</span>\n </button>\n </div> -->\n\n <div *ngIf=\"canCollapse\" class=\"px-0\">\n\n <button seamButton class=\"widget-header-btn-collapse p-0 mr-1 h-100\" (click)=\"collapse()\" [class.widget-header-btn-collapse--active]=\"collapsed\">\n <seam-icon class=\"d-block\"\n [icon]=\"collapseIcon\"\n iconClass=\"text-secondary\">\n </seam-icon>\n <span class=\"sr-only\">Widget collapse</span>\n </button>\n <!-- iconType=\"borderless-styled-square\" -->\n <!-- style=\"margin-left: -10px; margin-right: -5px;\" -->\n\n <!-- <button seamIconBtn class=\"widget-header-btn-collapse\" (click)=\"collapse()\" [class.widget-header-btn-collapse--active]=\"collapsed\"\n btnTheme=\"secondary\"\n [icon]=\"collapseIcon\"\n iconType=\"borderless-styled-square\"\n size=\"xs\"\n btnSize=\"sm\"\n >\n <seam-icon class=\"d-block\"\n [icon]=\"collapseIcon\"\n iconClass=\"text-secondary\"\n style=\"margin-left: -10px; margin-right: -5px;\"\n iconType=\"borderless-styled-square\"></seam-icon>\n <span class=\"sr-only\">Widget collapse</span>\n </button> -->\n </div>\n </div>\n </div>\n <div class=\"position-relative overflow-hidden\" [style.height.px]=\"loading ? 150 : undefined\" [@collapseAnim]=\"collapseState\">\n <ng-container *ngIf=\"!collapsed\">\n <div class=\"p-2\" *ngIf=\"!loading else loadingTpl\" @keepContentAnim>\n <ng-content></ng-content>\n </div>\n <ng-content select=\"seam-widget-footer\"></ng-content>\n <ng-template #loadingTpl>\n <div class=\"position-absolute\" @loadingAnim style=\"top:0;right:0;bottom:0;left:0\">\n <seam-loading [theme]=\"'primary'\"></seam-loading>\n </div>\n </ng-template>\n </ng-container>\n </div>\n</div>\n", styles: ["seam-widget{display:block;font-size:15px}seam-widget .seam-widget{background:#FFFFFF;box-shadow:none}seam-widget .widget-header{display:flex;flex-direction:row;border-bottom:1px solid #dee2e6;background:#F4F4F4;font-size:17px}seam-widget .widget-header .widget-header-content{flex:1 1 100%}seam-widget .widget-header .widget-header-btns-container{display:flex;flex-direction:row}seam-widget .widget-header .widget-header-btns-container>div{display:flex;flex-direction:column;justify-content:center;padding:4px}seam-widget .widget-header .widget-header-btns-container .widget-header-btn-config .seam-icon--fa{display:flex;flex-direction:row;justify-content:center;text-align:center;height:25px;width:30px}seam-widget .widget-header .widget-header-btns-container .widget-header-btn-config .seam-icon--fa .svg-inline--fa{max-width:100%;height:100%;width:100%}seam-widget .widget-header .widget-header-btns-container .widget-header-btn-collapse .seam-icon--fa{display:flex;flex-direction:row;justify-content:center;text-align:center;height:25px;width:30px}seam-widget .widget-header .widget-header-btns-container .widget-header-btn-collapse .seam-icon--fa .svg-inline--fa{max-width:100%;height:100%;width:100%}seam-widget .widget-header .widget-header-btns-container .widget-header-btn-collapse .svg-inline--fa{transform:rotate(0);transition:.3s ease-in-out transform}seam-widget .widget-header .widget-header-btns-container .widget-header-btn-collapse.widget-header-btn-collapse--active .svg-inline--fa{transform:rotate(90deg)}seam-widget .widget-header .widget-header-title{font-size:17px}seam-widget .widget-header-icon{display:inline-block;vertical-align:top;max-height:20px;max-width:20px;height:20px;width:20px;color:currentColor}seam-widget .widget-header-icon .widget-header-icon--fa{display:flex;flex-direction:row;justify-content:center;text-align:center;max-height:20px;max-width:20px;height:20px;width:20px}seam-widget .widget-header-icon .widget-header-icon--fa .svg-inline--fa{max-width:100%;height:100%;width:100%}seam-widget .widget-header-icon .widget-header-icon--img{height:100%;max-height:20px;max-width:20px}\n"] }]
140
- }], propDecorators: { collapsed: [{
181
+ }], ctorParameters: function () { return [{ type: i1.WidgetPreferencesService }, { type: undefined, decorators: [{
182
+ type: Optional
183
+ }, {
184
+ type: Inject,
185
+ args: [THESEAM_WIDGET_DEFAULTS]
186
+ }] }, { type: undefined, decorators: [{
187
+ type: Optional
188
+ }, {
189
+ type: Inject,
190
+ args: [THESEAM_WIDGET_DATA]
191
+ }] }]; }, propDecorators: { collapsed: [{
141
192
  type: Input
142
193
  }], hasHeader: [{
143
194
  type: Input
@@ -160,4 +211,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
160
211
  type: ContentChild,
161
212
  args: [WidgetTitleTplDirective, { static: true }]
162
213
  }] } });
163
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget.component.js","sourceRoot":"","sources":["../../../../../projects/ui-common/widget/widget/widget.component.ts","../../../../../projects/ui-common/widget/widget/widget.component.html"],"names":[],"mappings":"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","sourcesContent":["import { animate, state, style, transition, trigger } from '@angular/animations'\nimport { BooleanInput } from '@angular/cdk/coercion'\nimport { Component, ContentChild, Input, isDevMode, ViewEncapsulation } from '@angular/core'\n\nimport { IconProp } from '@fortawesome/fontawesome-svg-core'\nimport { faAngleDown, faCog } from '@fortawesome/free-solid-svg-icons'\nimport { InputBoolean } from '@theseam/ui-common/core'\nimport { SeamIcon } from '@theseam/ui-common/icon'\n\nimport { WidgetIconTplDirective } from '../directives/widget-icon-tpl.directive'\nimport { WidgetTitleTplDirective } from '../directives/widget-title-tpl.directive'\n\nconst EXPANDED_STATE = 'expanded'\nconst COLLAPSED_STATE = 'collapsed'\n\nconst EXPAND_TRANSITION = `${EXPANDED_STATE} <=> ${COLLAPSED_STATE}`\n\nconst loadingAnimation = trigger('loadingAnim', [\n  transition(':enter', [\n    style({ opacity: 0 }),\n    animate('250ms ease-in-out', style({ opacity: 1 })),\n  ]),\n  transition(':leave', [\n    style({ opacity: 1 }),\n    animate('250ms ease-in-out', style({ opacity: 0 })),\n  ]),\n])\n\n/**\n * I was having an issue getting the content to not be removed from the DOM,\n * before the animation was complete. This animation is a hack to keep the\n * content in the DOM until the animation is complete.\n */\nconst keepContentAnimation = trigger('keepContentAnim', [\n  transition(':leave', [\n    style({ opacity: 1 }),\n    animate('0ms', style({ opacity: 0 })),\n  ]),\n])\n\nconst collapseAnimation = trigger('collapseAnim', [\n  state(EXPANDED_STATE, style({ height: '*' })),\n  state(COLLAPSED_STATE, style({ height: '0' })),\n  transition(EXPAND_TRANSITION, animate('0.3s ease-in-out')),\n])\n\n/**\n * Widget\n *\n * Widgets are designed with the intention of being on a dashboard. Other uses\n * may be supported as the need arises.\n *\n * The only HTML/CSS use should be a widget content component, unless there is a\n * case requiring more advanced design. This is so that we can manage a common\n * style for our widgets. If a case requiring non widget content components is\n * used then the situation should be considered for becoming a widget component.\n */\n@Component({\n  selector: 'seam-widget',\n  templateUrl: './widget.component.html',\n  styleUrls: ['./widget.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  animations: [\n    loadingAnimation,\n    collapseAnimation,\n    keepContentAnimation,\n  ],\n})\nexport class WidgetComponent {\n\n  static ngAcceptInputType_hasHeader: BooleanInput\n  static ngAcceptInputType_loading: BooleanInput\n  static ngAcceptInputType_hasConfig: BooleanInput\n  static ngAcceptInputType_canCollapse: BooleanInput\n\n  readonly configIcon = faCog\n  readonly collapseIcon = faAngleDown\n\n  /**\n   * Toggles the collapsed state of a widget.\n   */\n  @Input() @InputBoolean() collapsed = false\n\n  /**\n   * Toggles the top header bar of a widget. This should be true for most\n   * widgets.\n   */\n  @Input() @InputBoolean() hasHeader = true\n\n  /**\n   * Title displayed in the top header.\n   *\n   * If a more advanced title is needed you can use `seamWidgetTitleTpl`\n   * template directive, but text is recommended, because allowing custom styles\n   * can lead to inconsitency quickly as different developers keep making\n   * tweaks.\n   */\n  @Input() titleText: string | undefined | null\n\n  /**\n   * Icon displayed in the top header.\n   *\n   * If a more advanced icon is needed you can use `seamWidgetIconTpl` template\n   * directive, but a `SeamIcon` input is recommended, because allowing custom\n   * icons that do not follow the tested types can lead to inconsitency quickly\n   * as different developers keep making tweaks.\n   */\n  @Input()\n  get icon(): SeamIcon | undefined { return this._iconUrl || this._iconObj }\n  set icon(value: SeamIcon | undefined) {\n    if (typeof value === 'string') {\n      this._iconUrl = value\n      this._iconObj = undefined\n    } else {\n      this._iconUrl = undefined\n      this._iconObj = value\n    }\n  }\n\n  _iconUrl: string | undefined\n  _iconObj: IconProp | undefined\n\n  /** Add a css class to the header icon. */\n  @Input() iconClass: string | undefined | null\n\n  /** Shows widget loading instead of content. */\n  @Input() @InputBoolean() loading = false\n\n  /** @ignore */\n  // NOTE: Config is still being worked on.\n  @Input() @InputBoolean() hasConfig = false\n\n  /**\n   * Toggles the ability to collapse a widget. An icon will be displayed in the\n   * header to toggle the collapsed state.\n   */\n  @Input() @InputBoolean() canCollapse = false\n\n  @ContentChild(WidgetIconTplDirective, { static: true }) iconTpl?: WidgetIconTplDirective\n  @ContentChild(WidgetTitleTplDirective, { static: true }) titleTpl?: WidgetTitleTplDirective\n\n  /**\n   * Toggles a widget's collapsed state.\n   */\n  public collapse() {\n    if (!this.canCollapse) {\n      if (isDevMode()) {\n        console.warn('WidgetComponent: collapse() called when canCollapse is false.')\n      }\n      return\n    }\n\n    this.collapsed = !this.collapsed\n  }\n\n  get collapseState(): string { return this.collapsed ? COLLAPSED_STATE : EXPANDED_STATE }\n\n}\n","<div class=\"seam-widget border rounded overflow-hidden\">\n  <div class=\"widget-header\" seamWidgetDragHandle *ngIf=\"hasHeader\">\n    <div class=\"widget-header-content p-2 text-nowrap\">\n      <span class=\"mr-1 widget-header-icon\">\n        <ng-container *ngIf=\"iconTpl; else noIconTpl\">\n          <ng-template\n            [ngTemplateOutlet]=\"iconTpl.template\"\n            [ngTemplateOutletContext]=\"{ $implicit: icon, icon: icon, title: titleText }\">\n          </ng-template>\n        </ng-container>\n        <ng-template #noIconTpl>\n          <fa-icon *ngIf=\"_iconObj\"\n            class=\"widget-header-icon--fa {{ iconClass }}\"\n            [icon]=\"_iconObj\"></fa-icon>\n          <img *ngIf=\"_iconUrl\"\n            class=\"widget-header-icon--img {{ iconClass }}\"\n            [src]=\"_iconUrl\" [alt]=\"titleText\">\n        </ng-template>\n      </span>\n      <span class=\"widget-header-title text-truncate\">\n        <ng-container *ngIf=\"titleTpl; else noTitleTpl\">\n          <ng-template\n            [ngTemplateOutlet]=\"titleTpl.template\"\n            [ngTemplateOutletContext]=\"{ $implicit: titleText, icon: icon, title: titleText }\">\n          </ng-template>\n        </ng-container>\n        <ng-template #noTitleTpl>{{ titleText }}</ng-template>\n      </span>\n    </div>\n    <div class=\"widget-header-btns-container\" *ngIf=\"hasConfig || canCollapse\">\n      <!-- <div *ngIf=\"hasConfig\">\n        <button seamIconBtn [icon]=\"configIcon\"\n          class=\"widget-header-btn-config\"\n          [iconType]=\"null\">\n          <span class=\"sr-only\">Widget configuration menu</span>\n        </button>\n        <button seamButton class=\"widget-header-btn-config p-0\">\n          <seam-icon class=\"d-block\" [icon]=\"configIcon\" iconClass=\"text-secondary\"></seam-icon>\n          <span class=\"sr-only\">Widget configuration menu</span>\n        </button>\n      </div> -->\n\n      <div *ngIf=\"canCollapse\" class=\"px-0\">\n\n        <button seamButton class=\"widget-header-btn-collapse p-0 mr-1 h-100\" (click)=\"collapse()\" [class.widget-header-btn-collapse--active]=\"collapsed\">\n          <seam-icon class=\"d-block\"\n            [icon]=\"collapseIcon\"\n            iconClass=\"text-secondary\">\n          </seam-icon>\n          <span class=\"sr-only\">Widget collapse</span>\n        </button>\n        <!-- iconType=\"borderless-styled-square\" -->\n        <!-- style=\"margin-left: -10px; margin-right: -5px;\" -->\n\n        <!-- <button seamIconBtn class=\"widget-header-btn-collapse\" (click)=\"collapse()\" [class.widget-header-btn-collapse--active]=\"collapsed\"\n          btnTheme=\"secondary\"\n          [icon]=\"collapseIcon\"\n          iconType=\"borderless-styled-square\"\n          size=\"xs\"\n          btnSize=\"sm\"\n          >\n          <seam-icon class=\"d-block\"\n            [icon]=\"collapseIcon\"\n            iconClass=\"text-secondary\"\n            style=\"margin-left: -10px; margin-right: -5px;\"\n            iconType=\"borderless-styled-square\"></seam-icon>\n          <span class=\"sr-only\">Widget collapse</span>\n        </button> -->\n      </div>\n    </div>\n  </div>\n  <div class=\"position-relative overflow-hidden\" [style.height.px]=\"loading ? 150 : undefined\" [@collapseAnim]=\"collapseState\">\n    <ng-container *ngIf=\"!collapsed\">\n      <div class=\"p-2\" *ngIf=\"!loading else loadingTpl\" @keepContentAnim>\n        <ng-content></ng-content>\n      </div>\n      <ng-content select=\"seam-widget-footer\"></ng-content>\n      <ng-template #loadingTpl>\n        <div class=\"position-absolute\" @loadingAnim style=\"top:0;right:0;bottom:0;left:0\">\n          <seam-loading [theme]=\"'primary'\"></seam-loading>\n        </div>\n      </ng-template>\n    </ng-container>\n  </div>\n</div>\n"]}
214
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget.component.js","sourceRoot":"","sources":["../../../../../projects/ui-common/widget/widget/widget.component.ts","../../../../../projects/ui-common/widget/widget/widget.component.html"],"names":[],"mappings":"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","sourcesContent":["import { animate, state, style, transition, trigger } from '@angular/animations'\nimport { BooleanInput } from '@angular/cdk/coercion'\nimport { Component, ContentChild, Inject, Input, isDevMode, OnDestroy, Optional, ViewEncapsulation } from '@angular/core'\nimport { Subject, takeUntil, tap } from 'rxjs'\n\nimport { IconProp } from '@fortawesome/fontawesome-svg-core'\nimport { faAngleDown, faCog } from '@fortawesome/free-solid-svg-icons'\nimport { InputBoolean } from '@theseam/ui-common/core'\nimport { SeamIcon } from '@theseam/ui-common/icon'\nimport { hasProperty } from '@theseam/ui-common/utils'\n\nimport { WidgetIconTplDirective } from '../directives/widget-icon-tpl.directive'\nimport { WidgetTitleTplDirective } from '../directives/widget-title-tpl.directive'\nimport { WidgetPreferencesService } from '../preferences/widget-preferences.service'\nimport { THESEAM_WIDGET_DATA, THESEAM_WIDGET_DEFAULTS } from '../widget-token'\nimport { TheSeamWidgetData, TheSeamWidgetDefaults } from '../widget.models'\n\nconst EXPANDED_STATE = 'expanded'\nconst COLLAPSED_STATE = 'collapsed'\n\nconst EXPAND_TRANSITION = `${EXPANDED_STATE} <=> ${COLLAPSED_STATE}`\n\nconst loadingAnimation = trigger('loadingAnim', [\n  transition(':enter', [\n    style({ opacity: 0 }),\n    animate('250ms ease-in-out', style({ opacity: 1 })),\n  ]),\n  transition(':leave', [\n    style({ opacity: 1 }),\n    animate('250ms ease-in-out', style({ opacity: 0 })),\n  ]),\n])\n\n/**\n * I was having an issue getting the content to not be removed from the DOM,\n * before the animation was complete. This animation is a hack to keep the\n * content in the DOM until the animation is complete.\n */\nconst keepContentAnimation = trigger('keepContentAnim', [\n  transition(':leave', [\n    style({ opacity: 1 }),\n    animate('0ms', style({ opacity: 0 })),\n  ]),\n])\n\nconst collapseAnimation = trigger('collapseAnim', [\n  state(EXPANDED_STATE, style({ height: '*' })),\n  state(COLLAPSED_STATE, style({ height: '0' })),\n  transition(EXPAND_TRANSITION, animate('0.3s ease-in-out')),\n])\n\n/**\n * Widget\n *\n * Widgets are designed with the intention of being on a dashboard. Other uses\n * may be supported as the need arises.\n *\n * The only HTML/CSS use should be a widget content component, unless there is a\n * case requiring more advanced design. This is so that we can manage a common\n * style for our widgets. If a case requiring non widget content components is\n * used then the situation should be considered for becoming a widget component.\n */\n@Component({\n  selector: 'seam-widget',\n  templateUrl: './widget.component.html',\n  styleUrls: ['./widget.component.scss'],\n  providers: [\n    WidgetPreferencesService,\n  ],\n  encapsulation: ViewEncapsulation.None,\n  animations: [\n    loadingAnimation,\n    collapseAnimation,\n    keepContentAnimation,\n  ],\n})\nexport class WidgetComponent implements OnDestroy {\n\n  static ngAcceptInputType_hasHeader: BooleanInput\n  static ngAcceptInputType_loading: BooleanInput\n  static ngAcceptInputType_hasConfig: BooleanInput\n  static ngAcceptInputType_canCollapse: BooleanInput\n\n  readonly configIcon = faCog\n  readonly collapseIcon = faAngleDown\n\n  private readonly _ngUnsubscribe = new Subject<void>()\n\n  private _preferencesKey?: string\n\n  /**\n   * Toggles the collapsed state of a widget.\n   */\n  @Input() @InputBoolean() collapsed = false\n\n  /**\n   * Toggles the top header bar of a widget. This should be true for most\n   * widgets.\n   */\n  @Input() @InputBoolean() hasHeader = true\n\n  /**\n   * Title displayed in the top header.\n   *\n   * If a more advanced title is needed you can use `seamWidgetTitleTpl`\n   * template directive, but text is recommended, because allowing custom styles\n   * can lead to inconsitency quickly as different developers keep making\n   * tweaks.\n   */\n  @Input() titleText: string | undefined | null\n\n  /**\n   * Icon displayed in the top header.\n   *\n   * If a more advanced icon is needed you can use `seamWidgetIconTpl` template\n   * directive, but a `SeamIcon` input is recommended, because allowing custom\n   * icons that do not follow the tested types can lead to inconsitency quickly\n   * as different developers keep making tweaks.\n   */\n  @Input()\n  get icon(): SeamIcon | undefined { return this._iconUrl || this._iconObj }\n  set icon(value: SeamIcon | undefined) {\n    if (typeof value === 'string') {\n      this._iconUrl = value\n      this._iconObj = undefined\n    } else {\n      this._iconUrl = undefined\n      this._iconObj = value\n    }\n  }\n\n  _iconUrl: string | undefined\n  _iconObj: IconProp | undefined\n\n  /** Add a css class to the header icon. */\n  @Input() iconClass: string | undefined | null\n\n  /** Shows widget loading instead of content. */\n  @Input() @InputBoolean() loading = false\n\n  /** @ignore */\n  // NOTE: Config is still being worked on.\n  @Input() @InputBoolean() hasConfig = false\n\n  /**\n   * Toggles the ability to collapse a widget. An icon will be displayed in the\n   * header to toggle the collapsed state.\n   */\n  @Input() @InputBoolean() canCollapse = false\n\n  @ContentChild(WidgetIconTplDirective, { static: true }) iconTpl?: WidgetIconTplDirective\n  @ContentChild(WidgetTitleTplDirective, { static: true }) titleTpl?: WidgetTitleTplDirective\n\n  constructor(\n    private readonly _widgetPreferences: WidgetPreferencesService,\n    @Optional() @Inject(THESEAM_WIDGET_DEFAULTS) private readonly _defaults?: TheSeamWidgetDefaults,\n    @Optional() @Inject(THESEAM_WIDGET_DATA) private readonly _data?: TheSeamWidgetData,\n  ) {\n    if (this._defaults) {\n      if (hasProperty(this._defaults, 'canCollapse')) {\n        this.canCollapse = this._defaults.canCollapse\n      }\n      if (hasProperty(this._defaults, 'collapsed')) {\n        this.collapsed = this._defaults.collapsed\n      }\n    }\n\n    if (this._data && this._data.widgetId) {\n      this._preferencesKey = `widget:${this._data.widgetId}`\n      this._widgetPreferences.preferences(this._preferencesKey).pipe(\n        tap(prefs => {\n          if (hasProperty(prefs, 'collapsed')) {\n            this.collapsed = prefs.collapsed\n          }\n        }),\n        takeUntil(this._ngUnsubscribe)\n      ).subscribe()\n    }\n  }\n\n  ngOnDestroy() {\n    this._ngUnsubscribe.next()\n    this._ngUnsubscribe.complete()\n  }\n\n  /**\n   * Toggles a widget's collapsed state.\n   */\n  public collapse() {\n    if (!this.canCollapse) {\n      if (isDevMode()) {\n        console.warn('WidgetComponent: collapse() called when canCollapse is false.')\n      }\n      return\n    }\n\n    this.collapsed = !this.collapsed\n\n    // Only update the preference, if collapse method is called, because it is\n    // assumed that the user is collapsing the widget. If the collapsed state is\n    // changed by other means, such using the widget's `collapsed` input, then\n    // the preference should not be updated, because that is assumed to be an\n    // app controlled change that should not be persisted.\n    if (this._preferencesKey) {\n      this._widgetPreferences.patchPreferences(this._preferencesKey, { collapsed: this.collapsed })\n    }\n  }\n\n  get collapseState(): string { return this.collapsed ? COLLAPSED_STATE : EXPANDED_STATE }\n\n}\n","<div class=\"seam-widget border rounded overflow-hidden\">\n  <div class=\"widget-header\" seamWidgetDragHandle *ngIf=\"hasHeader\">\n    <div class=\"widget-header-content p-2 text-nowrap\">\n      <span class=\"mr-1 widget-header-icon\">\n        <ng-container *ngIf=\"iconTpl; else noIconTpl\">\n          <ng-template\n            [ngTemplateOutlet]=\"iconTpl.template\"\n            [ngTemplateOutletContext]=\"{ $implicit: icon, icon: icon, title: titleText }\">\n          </ng-template>\n        </ng-container>\n        <ng-template #noIconTpl>\n          <fa-icon *ngIf=\"_iconObj\"\n            class=\"widget-header-icon--fa {{ iconClass }}\"\n            [icon]=\"_iconObj\"></fa-icon>\n          <img *ngIf=\"_iconUrl\"\n            class=\"widget-header-icon--img {{ iconClass }}\"\n            [src]=\"_iconUrl\" [alt]=\"titleText\">\n        </ng-template>\n      </span>\n      <span class=\"widget-header-title text-truncate\">\n        <ng-container *ngIf=\"titleTpl; else noTitleTpl\">\n          <ng-template\n            [ngTemplateOutlet]=\"titleTpl.template\"\n            [ngTemplateOutletContext]=\"{ $implicit: titleText, icon: icon, title: titleText }\">\n          </ng-template>\n        </ng-container>\n        <ng-template #noTitleTpl>{{ titleText }}</ng-template>\n      </span>\n    </div>\n    <div class=\"widget-header-btns-container\" *ngIf=\"hasConfig || canCollapse\">\n      <!-- <div *ngIf=\"hasConfig\">\n        <button seamIconBtn [icon]=\"configIcon\"\n          class=\"widget-header-btn-config\"\n          [iconType]=\"null\">\n          <span class=\"sr-only\">Widget configuration menu</span>\n        </button>\n        <button seamButton class=\"widget-header-btn-config p-0\">\n          <seam-icon class=\"d-block\" [icon]=\"configIcon\" iconClass=\"text-secondary\"></seam-icon>\n          <span class=\"sr-only\">Widget configuration menu</span>\n        </button>\n      </div> -->\n\n      <div *ngIf=\"canCollapse\" class=\"px-0\">\n\n        <button seamButton class=\"widget-header-btn-collapse p-0 mr-1 h-100\" (click)=\"collapse()\" [class.widget-header-btn-collapse--active]=\"collapsed\">\n          <seam-icon class=\"d-block\"\n            [icon]=\"collapseIcon\"\n            iconClass=\"text-secondary\">\n          </seam-icon>\n          <span class=\"sr-only\">Widget collapse</span>\n        </button>\n        <!-- iconType=\"borderless-styled-square\" -->\n        <!-- style=\"margin-left: -10px; margin-right: -5px;\" -->\n\n        <!-- <button seamIconBtn class=\"widget-header-btn-collapse\" (click)=\"collapse()\" [class.widget-header-btn-collapse--active]=\"collapsed\"\n          btnTheme=\"secondary\"\n          [icon]=\"collapseIcon\"\n          iconType=\"borderless-styled-square\"\n          size=\"xs\"\n          btnSize=\"sm\"\n          >\n          <seam-icon class=\"d-block\"\n            [icon]=\"collapseIcon\"\n            iconClass=\"text-secondary\"\n            style=\"margin-left: -10px; margin-right: -5px;\"\n            iconType=\"borderless-styled-square\"></seam-icon>\n          <span class=\"sr-only\">Widget collapse</span>\n        </button> -->\n      </div>\n    </div>\n  </div>\n  <div class=\"position-relative overflow-hidden\" [style.height.px]=\"loading ? 150 : undefined\" [@collapseAnim]=\"collapseState\">\n    <ng-container *ngIf=\"!collapsed\">\n      <div class=\"p-2\" *ngIf=\"!loading else loadingTpl\" @keepContentAnim>\n        <ng-content></ng-content>\n      </div>\n      <ng-content select=\"seam-widget-footer\"></ng-content>\n      <ng-template #loadingTpl>\n        <div class=\"position-absolute\" @loadingAnim style=\"top:0;right:0;bottom:0;left:0\">\n          <seam-loading [theme]=\"'primary'\"></seam-loading>\n        </div>\n      </ng-template>\n    </ng-container>\n  </div>\n</div>\n"]}
@@ -1,3 +1,5 @@
1
1
  import { InjectionToken } from '@angular/core';
2
2
  export const THESEAM_WIDGETS = new InjectionToken('TheSeamWidgets');
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2lkZ2V0LXRva2VuLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvdWktY29tbW9uL3dpZGdldC93aWRnZXQtdG9rZW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUk5QyxNQUFNLENBQUMsTUFBTSxlQUFlLEdBQUcsSUFBSSxjQUFjLENBQXdCLGdCQUFnQixDQUFDLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3Rpb25Ub2tlbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5cbmltcG9ydCB7IElXaWRnZXRSZWdpc3RyeVJlY29yZCB9IGZyb20gJy4vd2lkZ2V0LXJlZ2lzdHJ5Lm1vZGVscydcblxuZXhwb3J0IGNvbnN0IFRIRVNFQU1fV0lER0VUUyA9IG5ldyBJbmplY3Rpb25Ub2tlbjxJV2lkZ2V0UmVnaXN0cnlSZWNvcmQ+KCdUaGVTZWFtV2lkZ2V0cycpXG4iXX0=
3
+ export const THESEAM_WIDGET_DATA = new InjectionToken('TheSeamWidgetData');
4
+ export const THESEAM_WIDGET_DEFAULTS = new InjectionToken('TheSeamWidgetDefaults');
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2lkZ2V0LXRva2VuLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvdWktY29tbW9uL3dpZGdldC93aWRnZXQtdG9rZW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUs5QyxNQUFNLENBQUMsTUFBTSxlQUFlLEdBQUcsSUFBSSxjQUFjLENBQXdCLGdCQUFnQixDQUFDLENBQUE7QUFFMUYsTUFBTSxDQUFDLE1BQU0sbUJBQW1CLEdBQUcsSUFBSSxjQUFjLENBQW9CLG1CQUFtQixDQUFDLENBQUE7QUFFN0YsTUFBTSxDQUFDLE1BQU0sdUJBQXVCLEdBQUcsSUFBSSxjQUFjLENBQXdCLHVCQUF1QixDQUFDLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3Rpb25Ub2tlbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5cbmltcG9ydCB7IElXaWRnZXRSZWdpc3RyeVJlY29yZCB9IGZyb20gJy4vd2lkZ2V0LXJlZ2lzdHJ5Lm1vZGVscydcbmltcG9ydCB7IFRoZVNlYW1XaWRnZXREYXRhLCBUaGVTZWFtV2lkZ2V0RGVmYXVsdHMgfSBmcm9tICcuL3dpZGdldC5tb2RlbHMnXG5cbmV4cG9ydCBjb25zdCBUSEVTRUFNX1dJREdFVFMgPSBuZXcgSW5qZWN0aW9uVG9rZW48SVdpZGdldFJlZ2lzdHJ5UmVjb3JkPignVGhlU2VhbVdpZGdldHMnKVxuXG5leHBvcnQgY29uc3QgVEhFU0VBTV9XSURHRVRfREFUQSA9IG5ldyBJbmplY3Rpb25Ub2tlbjxUaGVTZWFtV2lkZ2V0RGF0YT4oJ1RoZVNlYW1XaWRnZXREYXRhJylcblxuZXhwb3J0IGNvbnN0IFRIRVNFQU1fV0lER0VUX0RFRkFVTFRTID0gbmV3IEluamVjdGlvblRva2VuPFRoZVNlYW1XaWRnZXREZWZhdWx0cz4oJ1RoZVNlYW1XaWRnZXREZWZhdWx0cycpXG4iXX0=
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2lkZ2V0Lm1vZGVscy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi93aWRnZXQvd2lkZ2V0Lm1vZGVscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiXHJcbmV4cG9ydCBpbnRlcmZhY2UgVGhlU2VhbVdpZGdldERhdGEge1xyXG4gIHdpZGdldElkPzogc3RyaW5nXHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgVGhlU2VhbVdpZGdldERlZmF1bHRzIHtcclxuICBjYW5Db2xsYXBzZT86IGJvb2xlYW5cclxuICBjb2xsYXBzZWQ/OiBib29sZWFuXHJcbn1cclxuIl19