@theseam/ui-common 0.4.7 → 0.4.9
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/esm2020/framework/dashboard/dashboard-widgets/dashboard-widgets.component.mjs +2 -1
- package/esm2020/framework/dashboard/dashboard-widgets/dashboard-widgets.service.mjs +12 -9
- package/esm2020/services/preferences/preferences-record.mjs +5 -7
- package/esm2020/story-helpers/story-preferences-accessor.service.mjs +2 -2
- package/fesm2015/theseam-ui-common-framework.mjs +12 -8
- package/fesm2015/theseam-ui-common-framework.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-services.mjs +4 -6
- package/fesm2015/theseam-ui-common-services.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-story-helpers.mjs +1 -1
- package/fesm2015/theseam-ui-common-story-helpers.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-framework.mjs +12 -8
- package/fesm2020/theseam-ui-common-framework.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-services.mjs +4 -6
- package/fesm2020/theseam-ui-common-services.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-story-helpers.mjs +1 -1
- package/fesm2020/theseam-ui-common-story-helpers.mjs.map +1 -1
- package/package.json +1 -1
- package/story-helpers/story-preferences-accessor.service.d.ts +1 -1
|
@@ -51,6 +51,7 @@ export class DashboardWidgetsComponent {
|
|
|
51
51
|
this._layoutChange = new Subject();
|
|
52
52
|
this.widgetsChange = new EventEmitter();
|
|
53
53
|
this._widthChange = new Subject();
|
|
54
|
+
this._dashboardWidgets.setViewContainerRef(this._viewContainerRef);
|
|
54
55
|
this.containers$ = this._containers.asObservable();
|
|
55
56
|
this._gapStyleSize$ = this._gapSize.pipe(auditTime(0), map(size => size / 2), shareReplay({ bufferSize: 1, refCount: true }));
|
|
56
57
|
this._widthChange.pipe(debounceTime(30), tap(width => {
|
|
@@ -203,4 +204,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
|
|
|
203
204
|
}], widgetsChange: [{
|
|
204
205
|
type: Output
|
|
205
206
|
}] } });
|
|
206
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dashboard-widgets.component.js","sourceRoot":"","sources":["../../../../../../projects/ui-common/framework/dashboard/dashboard-widgets/dashboard-widgets.component.ts","../../../../../../projects/ui-common/framework/dashboard/dashboard-widgets/dashboard-widgets.component.html"],"names":[],"mappings":";AAAA,OAAO,EAAgB,qBAAqB,EAAE,oBAAoB,EAAe,MAAM,uBAAuB,CAAA;AAC9G,OAAO,EAAE,OAAO,EAAe,eAAe,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAA;AACjG,OAAO,EAEL,uBAAuB,EAEvB,SAAS,EACT,YAAY,EACZ,UAAU,EACV,MAAM,EACN,KAAK,EAGL,QAAQ,EACR,MAAM,EAGN,SAAS,EACT,YAAY,EAEZ,iBAAiB,EAClB,MAAM,eAAe,CAAA;AACtB,OAAO,EAAE,eAAe,EAAc,OAAO,EAAE,MAAM,MAAM,CAAA;AAC3D,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,oBAAoB,EAAE,QAAQ,EAAE,GAAG,EAAE,WAAW,EAAE,SAAS,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAA;AAEtJ,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,mCAAmC,CAAA;AAEpE,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAA;AAEtD,OAAO,EAAE,uBAAuB,EAAE,MAAM,2BAA2B,CAAA;AAGnE,OAAO,EAAE,uBAAuB,EAAE,MAAM,sCAAsC,CAAA;AAC9E,OAAO,EAAE,iCAAiC,EAAE,MAAM,oEAAoE,CAAA;AAEtH,OAAO,EAA4B,kCAAkC,EAAE,MAAM,6BAA6B,CAAA;;;;;;;;;;;AAuB1G,MAAM,OAAO,yBAAyB;IAcpC,IACI,OAAO,KAAa,OAAO,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAA,CAAC,CAAC;IACpD,IAAI,OAAO,CAAC,GAAW;QACrB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC,CAAC,CAAA;IAC/C,CAAC;IAKD,IACI,iBAAiB,KAAc,OAAO,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAA,CAAC,CAAC;IACzE,IAAI,iBAAiB,CAAC,GAAY;QAChC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,qBAAqB,CAAC,GAAG,CAAC,CAAC,CAAA;IAC1D,CAAC;IAGD,IACI,UAAU,KAAa,OAAO,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAA,CAAC,CAAC;IACrE,IAAI,UAAU,CAAC,GAAW;QACxB,IAAI,CAAC,iBAAiB,CAAC,UAAU,GAAG,oBAAoB,CAAC,GAAG,CAAC,CAAA;IAC/D,CAAC;IAED,IACI,OAAO,CAAC,KAAiC,IAAI,IAAI,CAAC,iBAAiB,CAAC,OAAO,GAAG,KAAK,IAAI,EAAE,CAAA,CAAC,CAAC;IAC/F,IAAI,OAAO,KAAiC,OAAO,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAA,CAAC,CAAC;IAoBnF,YACU,iBAA0C,EAC1C,iBAAmC,EACnC,IAAuB,EACsB,cAAsC;QAHnF,sBAAiB,GAAjB,iBAAiB,CAAyB;QAC1C,sBAAiB,GAAjB,iBAAiB,CAAkB;QACnC,SAAI,GAAJ,IAAI,CAAmB;QACsB,mBAAc,GAAd,cAAc,CAAwB;QAvD7F,WAAM,GAAG,MAAM,CAAA;QACf,aAAQ,GAAG,QAAQ,CAAA;QAEH,gCAA2B,GAAG,oBAAoB,CAAA;QAEjD,mBAAc,GAAG,IAAI,OAAO,EAAQ,CAAA;QAOpC,aAAQ,GAAG,IAAI,eAAe,CAAS,EAAE,CAAC,CAAA;QAElC,qBAAgB,GAAG,KAAK,CAAA;QAOzC,uBAAkB,GAAG,IAAI,eAAe,CAAU,IAAI,CAAC,CAAA;QAuBvD,gBAAW,GAAG,IAAI,eAAe,CAAsC,EAAE,CAAC,CAAA;QAC1E,kBAAa,GAAG,IAAI,OAAO,EAAQ,CAAA;QAEjC,kBAAa,GAAG,IAAI,YAAY,EAA2B,CAAA;QAEpD,iBAAY,GAAG,IAAI,OAAO,EAAU,CAAA;QAQnD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,YAAY,EAAE,CAAA;QAElD,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CACtC,SAAS,CAAC,CAAC,CAAC,EACZ,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,GAAG,CAAC,CAAC,EACrB,WAAW,CAAC,EAAE,UAAU,EAAE,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAC/C,CAAA;QAED,IAAI,CAAC,YAAY,CAAC,IAAI,CACpB,YAAY,CAAC,EAAE,CAAC,EAChB,GAAG,CAAC,KAAK,CAAC,EAAE;YACV,IAAI,KAAK,GAAG,IAAI,EAAE;gBAChB,IAAI,CAAC,UAAU,GAAG,CAAC,CAAA;aACpB;iBAAM,IAAI,KAAK,GAAG,GAAG,EAAE;gBACtB,IAAI,CAAC,UAAU,GAAG,CAAC,CAAA;aACpB;iBAAM;gBACL,IAAI,CAAC,UAAU,GAAG,CAAC,CAAA;aACpB;QACH,CAAC,CAAC,EACF,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAC/B,CAAC,SAAS,EAAE,CAAA;QAEb,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAA;QACvD,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,iBAAiB,CAAC,cAAc,CAAA;IAC7D,CAAC;IAED,QAAQ;QACN,qEAAqE;QAErE,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CACpC,IAAI,CAAC,CAAC,CAAC,EACP,GAAG,CAAC,WAAW,CAAC,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACxD,gFAAgF;QAChF,4CAA4C;QAC5C,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC,eAAe,EAAE,CAAC,CAC1D,CAAC,EACF,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAC/B,CAAC,SAAS,EAAE,CAAA;IACf,CAAC;IAED,WAAW;QACT,IAAI,CAAC,uBAAuB,EAAE,CAAA;QAC9B,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;QACnC,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE,CAAA;IAChC,CAAC;IAED,eAAe;QACb,IAAI,IAAI,CAAC,cAAc,EAAE;YACvB,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAC1B,oBAAoB,EAAE,EACtB,GAAG,CAAC,OAAO,CAAC,EAAE;gBACZ,MAAM,YAAY,GAAG,IAAI,CAAC,+BAA+B,EAAE,CAAA;gBAC3D,IAAI,OAAO,IAAI,CAAC,YAAY,EAAE;oBAC5B,IAAI,CAAC,qBAAqB,EAAE,CAAA;iBAC7B;qBAAM,IAAI,CAAC,OAAO,IAAI,YAAY,EAAE;oBACnC,IAAI,CAAC,uBAAuB,EAAE,CAAA;iBAC/B;YACH,CAAC,CAAC,EACF,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAC/B,CAAC,SAAS,EAAE,CAAA;SACd;QAED,IAAI,CAAC,UAAU,EAAE,OAAO,CAAC,IAAI,CAC3B,SAAS,CAAC,SAAS,CAAC,EACpB,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,EAC3C,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,EAC9B,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAC1C,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAA;IAC5C,CAAC;IAEO,qBAAqB;QAC3B,IAAI,IAAI,CAAC,cAAc,EAAE;YACvB,oEAAoE;YACpE,8DAA8D;YAC9D,IAAI,IAAI,CAAC,aAAa,EAAE;gBACtB,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC;oBACjC,kBAAkB;oBAClB,IAAI,EAAE,UAAU;oBAChB,IAAI,EAAE,IAAI,CAAC,2BAA2B;oBACtC,KAAK,EAAE,wBAAwB;oBAC/B,gBAAgB;oBAChB,0BAA0B;oBAC1B,KAAK;oBACL,QAAQ,EAAE,IAAI,CAAC,aAAa;iBAC7B,CAAC,CAAA;aACH;SACF;IACH,CAAC;IAEO,uBAAuB;QAC7B,IAAI,IAAI,CAAC,cAAc,EAAE;YACvB,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC,IAAI,CAAC,2BAA2B,CAAC,CAAA;SACvE;IACH,CAAC;IAEO,+BAA+B;QACrC,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE;YACxB,OAAO,KAAK,CAAA;SACb;QACD,OAAO,IAAI,CAAC,cAAc,CAAC,kBAAkB,CAAC,IAAI,CAAC,2BAA2B,CAAC,CAAA;IACjF,CAAC;IAED,IAAI,CAAC,KAA4B;QAC/B,IAAI,KAAK,CAAC,iBAAiB,KAAK,KAAK,CAAC,SAAS,EAAE;YAC/C,eAAe,CAAC,KAAK,CAAC,SAAS,CAAC,IAAI,EAAE,KAAK,CAAC,aAAa,EAAE,KAAK,CAAC,YAAY,CAAC,CAAA;YAC9E,IAAI,CAAC,iBAAiB,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC,CAAA;SAChF;aAAM;YACL,iBAAiB,CACf,KAAK,CAAC,iBAAiB,CAAC,IAAI,EAC5B,KAAK,CAAC,SAAS,CAAC,IAAI,EACpB,KAAK,CAAC,aAAa,EACnB,KAAK,CAAC,YAAY,CACnB,CAAA;YACD,IAAI,CAAC,iBAAiB,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC,CAAA;SAChF;IACH,CAAC;IAED,mBAAmB,CAAC,KAAa,EAAE,IAA2B;QAC5D,OAAO,IAAI,CAAC,QAAQ,CAAA;IACtB,CAAC;IAED,iBAAiB,CAAC,KAAa,EAAE,MAAqC;QACpE,OAAO,MAAM,CAAC,MAAM,CAAA;IACtB,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,gBAAgB,GAAG,CAAC,IAAI,CAAC,gBAAgB,CAAA;QAC9C,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAA;IAC3B,CAAC;IAED,QAAQ,CAAC,KAA2B;QAClC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;IAC1C,CAAC;;sHArMU,yBAAyB,0HA8Dd,uBAAuB;0GA9DlC,yBAAyB,0PAfzB;QACT;YACE,OAAO,EAAE,uBAAuB;YAChC,iDAAiD;YACjD,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,yBAAyB,CAAC;SACzD;QACD;YACE,OAAO,EAAE,kCAAkC;YAC3C,iDAAiD;YACjD,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,yBAAyB,CAAC;SACzD;KACF,uKAkDa,iCAAiC,uEACjC,OAAO,gDCzGvB,k1DAuCA;ADwC2B;IAAf,YAAY,EAAE;mEAAyB;2FArBtC,yBAAyB;kBAnBrC,SAAS;+BACE,wBAAwB,aAGvB;wBACT;4BACE,OAAO,EAAE,uBAAuB;4BAChC,iDAAiD;4BACjD,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,0BAA0B,CAAC;yBACzD;wBACD;4BACE,OAAO,EAAE,kCAAkC;4BAC3C,iDAAiD;4BACjD,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,0BAA0B,CAAC;yBACzD;qBACF,mBACgB,uBAAuB,CAAC,MAAM,iBAChC,iBAAiB,CAAC,IAAI;;0BAgElC,QAAQ;;0BAAI,MAAM;2BAAC,uBAAuB;4CA/CzC,OAAO;sBADV,KAAK;gBAOmB,gBAAgB;sBAAxC,KAAK;gBAGF,iBAAiB;sBADpB,KAAK;gBAQF,UAAU;sBADb,KAAK;gBAOF,OAAO;sBADV,KAAK;gBAU2C,UAAU;sBAA1D,YAAY;uBAAC,iCAAiC;gBACxB,iBAAiB;sBAAvC,YAAY;uBAAC,OAAO;gBAEwB,aAAa;sBAAzD,SAAS;uBAAC,cAAc,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAKjC,aAAa;sBAAtB,MAAM","sourcesContent":["import { BooleanInput, coerceBooleanProperty, coerceNumberProperty, NumberInput } from '@angular/cdk/coercion'\nimport { CdkDrag, CdkDragDrop, moveItemInArray, transferArrayItem } from '@angular/cdk/drag-drop'\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  forwardRef,\n  Inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  QueryList,\n  TemplateRef,\n  ViewChild,\n  ViewChildren,\n  ViewContainerRef,\n  ViewEncapsulation\n} from '@angular/core'\nimport { BehaviorSubject, Observable, Subject } from 'rxjs'\nimport { auditTime, debounceTime, distinctUntilChanged, finalize, map, shareReplay, startWith, switchMap, take, takeUntil, tap } from 'rxjs/operators'\n\nimport { faLock, faUnlock } from '@fortawesome/free-solid-svg-icons'\n\nimport { InputBoolean } from '@theseam/ui-common/core'\nimport type { IElementResizedEvent } from '@theseam/ui-common/shared'\nimport { THESEAM_WIDGET_ACCESSOR } from '@theseam/ui-common/widget'\n\nimport type { ITheSeamBaseLayoutRef } from '../../base-layout/base-layout-ref'\nimport { THESEAM_BASE_LAYOUT_REF } from '../../base-layout/base-layout-tokens'\nimport { DashboardWidgetContainerComponent } from '../dashboard-widget-container/dashboard-widget-container.component'\n\nimport { DashboardWidgetsAccessor, THESEAM_DASHBOARD_WIDGETS_ACCESSOR } from '../dashboard-widgets-tokens'\nimport type { IDashboardWidgetsColumnRecord, IDashboardWidgetsItem, IDashboardWidgetsItemDef } from './dashboard-widgets-item'\nimport { DashboardWidgetsService } from './dashboard-widgets.service'\n\n@Component({\n  selector: 'seam-dashboard-widgets',\n  templateUrl: './dashboard-widgets.component.html',\n  styleUrls: ['./dashboard-widgets.component.scss'],\n  providers: [\n    {\n      provide: THESEAM_WIDGET_ACCESSOR,\n      // tslint:disable-next-line:no-use-before-declare\n      useExisting: forwardRef(() => DashboardWidgetsComponent)\n    },\n    {\n      provide: THESEAM_DASHBOARD_WIDGETS_ACCESSOR,\n      // tslint:disable-next-line:no-use-before-declare\n      useExisting: forwardRef(() => DashboardWidgetsComponent)\n    },\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None\n})\nexport class DashboardWidgetsComponent implements OnInit, OnDestroy, AfterViewInit, DashboardWidgetsAccessor {\n  static ngAcceptInputType_gapSize: NumberInput\n  static ngAcceptInputType_numColumns: NumberInput\n  static ngAcceptInputType_widgetsDraggable: BooleanInput\n  static ngAcceptInputType_dragToggleVisible: BooleanInput\n  static ngAcceptInputType_widgets: IDashboardWidgetsItemDef[] | undefined | null\n\n  faLock = faLock\n  faUnlock = faUnlock\n\n  public readonly _actionWidgetDragToggleName = 'widget-drag-toggle'\n\n  private readonly _ngUnsubscribe = new Subject<void>()\n\n  @Input()\n  get gapSize(): number { return this._gapSize.value }\n  set gapSize(val: number) {\n    this._gapSize.next(coerceNumberProperty(val))\n  }\n  private readonly _gapSize = new BehaviorSubject<number>(30)\n\n  @Input() @InputBoolean() widgetsDraggable = false\n\n  @Input()\n  get dragToggleVisible(): boolean { return this._dragToggleVisible.value }\n  set dragToggleVisible(val: boolean) {\n    this._dragToggleVisible.next(coerceBooleanProperty(val))\n  }\n  private _dragToggleVisible = new BehaviorSubject<boolean>(true)\n\n  @Input()\n  get numColumns(): number { return this._dashboardWidgets.numColumns }\n  set numColumns(val: number) {\n    this._dashboardWidgets.numColumns = coerceNumberProperty(val)\n  }\n\n  @Input()\n  set widgets(value: IDashboardWidgetsItemDef[]) { this._dashboardWidgets.widgets = value || [] }\n  get widgets(): IDashboardWidgetsItemDef[] { return this._dashboardWidgets.widgets }\n\n  public widgetItems$: Observable<IDashboardWidgetsItem[]>\n  public widgetColumns$: Observable<IDashboardWidgetsColumnRecord[]>\n  public containers$: Observable<DashboardWidgetContainerComponent[]>\n\n  readonly _gapStyleSize$: Observable<number>\n\n  @ViewChildren(DashboardWidgetContainerComponent) containers?: QueryList<DashboardWidgetContainerComponent>\n  @ViewChildren(CdkDrag) cdkDragDirectives?: QueryList<CdkDrag>\n\n  @ViewChild('toggleBtnTpl', { static: true }) _toggleBtnTpl?: TemplateRef<any>\n\n  private _containers = new BehaviorSubject<DashboardWidgetContainerComponent[]>([])\n  private _layoutChange = new Subject<void>()\n\n  @Output() widgetsChange = new EventEmitter<IDashboardWidgetsItem[]>()\n\n  private readonly _widthChange = new Subject<number>()\n\n  constructor(\n    private _dashboardWidgets: DashboardWidgetsService,\n    private _viewContainerRef: ViewContainerRef,\n    private _cdr: ChangeDetectorRef,\n    @Optional() @Inject(THESEAM_BASE_LAYOUT_REF) private _baseLayoutRef?: ITheSeamBaseLayoutRef\n  ) {\n    this.containers$ = this._containers.asObservable()\n\n    this._gapStyleSize$ = this._gapSize.pipe(\n      auditTime(0),\n      map(size => size / 2),\n      shareReplay({ bufferSize: 1, refCount: true })\n    )\n\n    this._widthChange.pipe(\n      debounceTime(30),\n      tap(width => {\n        if (width > 1300) {\n          this.numColumns = 3\n        } else if (width > 800) {\n          this.numColumns = 2\n        } else {\n          this.numColumns = 1\n        }\n      }),\n      takeUntil(this._ngUnsubscribe)\n    ).subscribe()\n\n    this.widgetItems$ = this._dashboardWidgets.widgetItems$\n    this.widgetColumns$ = this._dashboardWidgets.widgetColumns$\n  }\n\n  ngOnInit() {\n    // this._dashboardWidgets.setViewContainerRef(this._viewContainerRef)\n\n    this._layoutChange.pipe(\n      switchMap(() => this.widgetItems$.pipe(\n        take(1),\n        tap(widgetItems => this.widgetsChange.emit(widgetItems)),\n        // map(widgetItems => this._dashboardWidgets.toSerializeableItems(widgetItems)),\n        // tap(v => console.log('serializable', v)),\n        switchMap(() => this._dashboardWidgets.savePreferences())\n      )),\n      takeUntil(this._ngUnsubscribe)\n    ).subscribe()\n  }\n\n  ngOnDestroy() {\n    this._unregisterToggleAction()\n    this._ngUnsubscribe.next(undefined)\n    this._ngUnsubscribe.complete()\n  }\n\n  ngAfterViewInit() {\n    if (this._baseLayoutRef) {\n      this._dragToggleVisible.pipe(\n        distinctUntilChanged(),\n        tap(visible => {\n          const isRegistered = this._isActionToggleActionRegistered()\n          if (visible && !isRegistered) {\n            this._registerToggleAction()\n          } else if (!visible && isRegistered) {\n            this._unregisterToggleAction()\n          }\n        }),\n        takeUntil(this._ngUnsubscribe)\n      ).subscribe()\n    }\n\n    this.containers?.changes.pipe(\n      startWith(undefined),\n      map(() => this.containers?.toArray() || []),\n      takeUntil(this._ngUnsubscribe),\n      finalize(() => this._containers.next([]))\n    ).subscribe(v => this._containers.next(v))\n  }\n\n  private _registerToggleAction() {\n    if (this._baseLayoutRef) {\n      // This should probably use a component dynamically created from the\n      // config and return a ref to it, instead of using a template.\n      if (this._toggleBtnTpl) {\n        this._baseLayoutRef.registerAction({\n          // type: 'button',\n          type: 'template',\n          name: this._actionWidgetDragToggleName,\n          label: 'Toggle Widget Dragging',\n          // exec: () => {\n          //   console.log('toggle')\n          // },\n          template: this._toggleBtnTpl\n        })\n      }\n    }\n  }\n\n  private _unregisterToggleAction() {\n    if (this._baseLayoutRef) {\n      this._baseLayoutRef.unregisterAction(this._actionWidgetDragToggleName)\n    }\n  }\n\n  private _isActionToggleActionRegistered() {\n    if (!this._baseLayoutRef) {\n      return false\n    }\n    return this._baseLayoutRef.isActionRegistered(this._actionWidgetDragToggleName)\n  }\n\n  drop(event: CdkDragDrop<string[]>) {\n    if (event.previousContainer === event.container) {\n      moveItemInArray(event.container.data, event.previousIndex, event.currentIndex)\n      this._dashboardWidgets.updateOrder().subscribe(() => this._layoutChange.next())\n    } else {\n      transferArrayItem(\n        event.previousContainer.data,\n        event.container.data,\n        event.previousIndex,\n        event.currentIndex\n      )\n      this._dashboardWidgets.updateOrder().subscribe(() => this._layoutChange.next())\n    }\n  }\n\n  _containerTrackByFn(index: number, item: IDashboardWidgetsItem) {\n    return item.widgetId\n  }\n\n  _columnsTrackByFn(index: number, record: IDashboardWidgetsColumnRecord) {\n    return record.column\n  }\n\n  toggleDragging() {\n    this.widgetsDraggable = !this.widgetsDraggable\n    this._cdr.detectChanges()\n  }\n\n  _resized(event: IElementResizedEvent) {\n    this._widthChange.next(event.size.width)\n  }\n\n}\n","<!--\n  This is an ugly trick I am using to render the component into an <ng-content>\n  wrapped in an <ng-template> to move the component to different outlets without\n  reinitializing it. This way the widget won't reload when moving between\n  columns. When I remember how I programatically did this I will remove this\n  weirdness.\n -->\n <seam-dashboard-widget-container *ngFor=\"let item of widgetItems$ | async; trackBy: _containerTrackByFn\" [def]=\"$any(item)\">\n  <!-- <ng-template [cdkPortalOutlet]=\"item.portal\"></ng-template> -->\n  <ng-template [seamDashboardWidgetPortalOutlet]=\"item.portal\"></ng-template>\n</seam-dashboard-widget-container>\n\n<div class=\"dashboard-widgets-base d-flex flex-row justify-content-around\"\n  style=\"flex: 1410px;\"\n  [style.padding.px]=\"_gapStyleSize$ | async\"\n  (seamElemResized)=\"_resized($event)\"\n  cdkDropListGroup>\n  <div *ngFor=\"let col of widgetColumns$ | async; trackBy: _columnsTrackByFn\"\n    class=\"d-flex flex-column flex-grow-1 dashboard-widgets-list\"\n    cdkDropList\n    [cdkDropListData]=\"col.items\"\n    (cdkDropListDropped)=\"drop($any($event))\">\n    <div *ngFor=\"let item of col.items; trackBy: _containerTrackByFn\"\n      class=\"dashboard-widgets-list-item\"\n      [attr.data-widget-id]=\"item.widgetId\"\n      cdkDrag\n      [cdkDragDisabled]=\"!widgetsDraggable\">\n      <div [style.margin.px]=\"_gapStyleSize$ | async\">\n        <seam-dashboard-widget-template-container [item]=\"item\"></seam-dashboard-widget-template-container>\n      </div>\n    </div>\n  </div>\n</div>\n\n<ng-template #toggleBtnTpl>\n  <button seamButton theme=\"baselayout-action\" title=\"{{ widgetsDraggable ? 'Lock the Dashboard' : 'Modify Dashboard' }}\" (click)=\"toggleDragging()\">\n    <seam-icon [icon]=\"widgetsDraggable ? faUnlock : faLock\"></seam-icon>\n  </button>\n</ng-template>\n"]}
|
|
207
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dashboard-widgets.component.js","sourceRoot":"","sources":["../../../../../../projects/ui-common/framework/dashboard/dashboard-widgets/dashboard-widgets.component.ts","../../../../../../projects/ui-common/framework/dashboard/dashboard-widgets/dashboard-widgets.component.html"],"names":[],"mappings":"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","sourcesContent":["import { BooleanInput, coerceBooleanProperty, coerceNumberProperty, NumberInput } from '@angular/cdk/coercion'\nimport { CdkDrag, CdkDragDrop, moveItemInArray, transferArrayItem } from '@angular/cdk/drag-drop'\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  forwardRef,\n  Inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  QueryList,\n  TemplateRef,\n  ViewChild,\n  ViewChildren,\n  ViewContainerRef,\n  ViewEncapsulation\n} from '@angular/core'\nimport { BehaviorSubject, Observable, Subject } from 'rxjs'\nimport { auditTime, debounceTime, distinctUntilChanged, finalize, map, shareReplay, startWith, switchMap, take, takeUntil, tap } from 'rxjs/operators'\n\nimport { faLock, faUnlock } from '@fortawesome/free-solid-svg-icons'\n\nimport { InputBoolean } from '@theseam/ui-common/core'\nimport type { IElementResizedEvent } from '@theseam/ui-common/shared'\nimport { THESEAM_WIDGET_ACCESSOR } from '@theseam/ui-common/widget'\n\nimport type { ITheSeamBaseLayoutRef } from '../../base-layout/base-layout-ref'\nimport { THESEAM_BASE_LAYOUT_REF } from '../../base-layout/base-layout-tokens'\nimport { DashboardWidgetContainerComponent } from '../dashboard-widget-container/dashboard-widget-container.component'\n\nimport { DashboardWidgetsAccessor, THESEAM_DASHBOARD_WIDGETS_ACCESSOR } from '../dashboard-widgets-tokens'\nimport type { IDashboardWidgetsColumnRecord, IDashboardWidgetsItem, IDashboardWidgetsItemDef } from './dashboard-widgets-item'\nimport { DashboardWidgetsService } from './dashboard-widgets.service'\n\n@Component({\n  selector: 'seam-dashboard-widgets',\n  templateUrl: './dashboard-widgets.component.html',\n  styleUrls: ['./dashboard-widgets.component.scss'],\n  providers: [\n    {\n      provide: THESEAM_WIDGET_ACCESSOR,\n      // tslint:disable-next-line:no-use-before-declare\n      useExisting: forwardRef(() => DashboardWidgetsComponent)\n    },\n    {\n      provide: THESEAM_DASHBOARD_WIDGETS_ACCESSOR,\n      // tslint:disable-next-line:no-use-before-declare\n      useExisting: forwardRef(() => DashboardWidgetsComponent)\n    },\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None\n})\nexport class DashboardWidgetsComponent implements OnInit, OnDestroy, AfterViewInit, DashboardWidgetsAccessor {\n  static ngAcceptInputType_gapSize: NumberInput\n  static ngAcceptInputType_numColumns: NumberInput\n  static ngAcceptInputType_widgetsDraggable: BooleanInput\n  static ngAcceptInputType_dragToggleVisible: BooleanInput\n  static ngAcceptInputType_widgets: IDashboardWidgetsItemDef[] | undefined | null\n\n  faLock = faLock\n  faUnlock = faUnlock\n\n  public readonly _actionWidgetDragToggleName = 'widget-drag-toggle'\n\n  private readonly _ngUnsubscribe = new Subject<void>()\n\n  @Input()\n  get gapSize(): number { return this._gapSize.value }\n  set gapSize(val: number) {\n    this._gapSize.next(coerceNumberProperty(val))\n  }\n  private readonly _gapSize = new BehaviorSubject<number>(30)\n\n  @Input() @InputBoolean() widgetsDraggable = false\n\n  @Input()\n  get dragToggleVisible(): boolean { return this._dragToggleVisible.value }\n  set dragToggleVisible(val: boolean) {\n    this._dragToggleVisible.next(coerceBooleanProperty(val))\n  }\n  private _dragToggleVisible = new BehaviorSubject<boolean>(true)\n\n  @Input()\n  get numColumns(): number { return this._dashboardWidgets.numColumns }\n  set numColumns(val: number) {\n    this._dashboardWidgets.numColumns = coerceNumberProperty(val)\n  }\n\n  @Input()\n  set widgets(value: IDashboardWidgetsItemDef[]) { this._dashboardWidgets.widgets = value || [] }\n  get widgets(): IDashboardWidgetsItemDef[] { return this._dashboardWidgets.widgets }\n\n  public widgetItems$: Observable<IDashboardWidgetsItem[]>\n  public widgetColumns$: Observable<IDashboardWidgetsColumnRecord[]>\n  public containers$: Observable<DashboardWidgetContainerComponent[]>\n\n  readonly _gapStyleSize$: Observable<number>\n\n  @ViewChildren(DashboardWidgetContainerComponent) containers?: QueryList<DashboardWidgetContainerComponent>\n  @ViewChildren(CdkDrag) cdkDragDirectives?: QueryList<CdkDrag>\n\n  @ViewChild('toggleBtnTpl', { static: true }) _toggleBtnTpl?: TemplateRef<any>\n\n  private _containers = new BehaviorSubject<DashboardWidgetContainerComponent[]>([])\n  private _layoutChange = new Subject<void>()\n\n  @Output() widgetsChange = new EventEmitter<IDashboardWidgetsItem[]>()\n\n  private readonly _widthChange = new Subject<number>()\n\n  constructor(\n    private _dashboardWidgets: DashboardWidgetsService,\n    private _viewContainerRef: ViewContainerRef,\n    private _cdr: ChangeDetectorRef,\n    @Optional() @Inject(THESEAM_BASE_LAYOUT_REF) private _baseLayoutRef?: ITheSeamBaseLayoutRef\n  ) {\n    this._dashboardWidgets.setViewContainerRef(this._viewContainerRef)\n\n    this.containers$ = this._containers.asObservable()\n\n    this._gapStyleSize$ = this._gapSize.pipe(\n      auditTime(0),\n      map(size => size / 2),\n      shareReplay({ bufferSize: 1, refCount: true })\n    )\n\n    this._widthChange.pipe(\n      debounceTime(30),\n      tap(width => {\n        if (width > 1300) {\n          this.numColumns = 3\n        } else if (width > 800) {\n          this.numColumns = 2\n        } else {\n          this.numColumns = 1\n        }\n      }),\n      takeUntil(this._ngUnsubscribe)\n    ).subscribe()\n\n    this.widgetItems$ = this._dashboardWidgets.widgetItems$\n    this.widgetColumns$ = this._dashboardWidgets.widgetColumns$\n  }\n\n  ngOnInit() {\n    // this._dashboardWidgets.setViewContainerRef(this._viewContainerRef)\n\n    this._layoutChange.pipe(\n      switchMap(() => this.widgetItems$.pipe(\n        take(1),\n        tap(widgetItems => this.widgetsChange.emit(widgetItems)),\n        // map(widgetItems => this._dashboardWidgets.toSerializeableItems(widgetItems)),\n        // tap(v => console.log('serializable', v)),\n        switchMap(() => this._dashboardWidgets.savePreferences())\n      )),\n      takeUntil(this._ngUnsubscribe)\n    ).subscribe()\n  }\n\n  ngOnDestroy() {\n    this._unregisterToggleAction()\n    this._ngUnsubscribe.next(undefined)\n    this._ngUnsubscribe.complete()\n  }\n\n  ngAfterViewInit() {\n    if (this._baseLayoutRef) {\n      this._dragToggleVisible.pipe(\n        distinctUntilChanged(),\n        tap(visible => {\n          const isRegistered = this._isActionToggleActionRegistered()\n          if (visible && !isRegistered) {\n            this._registerToggleAction()\n          } else if (!visible && isRegistered) {\n            this._unregisterToggleAction()\n          }\n        }),\n        takeUntil(this._ngUnsubscribe)\n      ).subscribe()\n    }\n\n    this.containers?.changes.pipe(\n      startWith(undefined),\n      map(() => this.containers?.toArray() || []),\n      takeUntil(this._ngUnsubscribe),\n      finalize(() => this._containers.next([]))\n    ).subscribe(v => this._containers.next(v))\n  }\n\n  private _registerToggleAction() {\n    if (this._baseLayoutRef) {\n      // This should probably use a component dynamically created from the\n      // config and return a ref to it, instead of using a template.\n      if (this._toggleBtnTpl) {\n        this._baseLayoutRef.registerAction({\n          // type: 'button',\n          type: 'template',\n          name: this._actionWidgetDragToggleName,\n          label: 'Toggle Widget Dragging',\n          // exec: () => {\n          //   console.log('toggle')\n          // },\n          template: this._toggleBtnTpl\n        })\n      }\n    }\n  }\n\n  private _unregisterToggleAction() {\n    if (this._baseLayoutRef) {\n      this._baseLayoutRef.unregisterAction(this._actionWidgetDragToggleName)\n    }\n  }\n\n  private _isActionToggleActionRegistered() {\n    if (!this._baseLayoutRef) {\n      return false\n    }\n    return this._baseLayoutRef.isActionRegistered(this._actionWidgetDragToggleName)\n  }\n\n  drop(event: CdkDragDrop<string[]>) {\n    if (event.previousContainer === event.container) {\n      moveItemInArray(event.container.data, event.previousIndex, event.currentIndex)\n      this._dashboardWidgets.updateOrder().subscribe(() => this._layoutChange.next())\n    } else {\n      transferArrayItem(\n        event.previousContainer.data,\n        event.container.data,\n        event.previousIndex,\n        event.currentIndex\n      )\n      this._dashboardWidgets.updateOrder().subscribe(() => this._layoutChange.next())\n    }\n  }\n\n  _containerTrackByFn(index: number, item: IDashboardWidgetsItem) {\n    return item.widgetId\n  }\n\n  _columnsTrackByFn(index: number, record: IDashboardWidgetsColumnRecord) {\n    return record.column\n  }\n\n  toggleDragging() {\n    this.widgetsDraggable = !this.widgetsDraggable\n    this._cdr.detectChanges()\n  }\n\n  _resized(event: IElementResizedEvent) {\n    this._widthChange.next(event.size.width)\n  }\n\n}\n","<!--\n  This is an ugly trick I am using to render the component into an <ng-content>\n  wrapped in an <ng-template> to move the component to different outlets without\n  reinitializing it. This way the widget won't reload when moving between\n  columns. When I remember how I programatically did this I will remove this\n  weirdness.\n -->\n <seam-dashboard-widget-container *ngFor=\"let item of widgetItems$ | async; trackBy: _containerTrackByFn\" [def]=\"$any(item)\">\n  <!-- <ng-template [cdkPortalOutlet]=\"item.portal\"></ng-template> -->\n  <ng-template [seamDashboardWidgetPortalOutlet]=\"item.portal\"></ng-template>\n</seam-dashboard-widget-container>\n\n<div class=\"dashboard-widgets-base d-flex flex-row justify-content-around\"\n  style=\"flex: 1410px;\"\n  [style.padding.px]=\"_gapStyleSize$ | async\"\n  (seamElemResized)=\"_resized($event)\"\n  cdkDropListGroup>\n  <div *ngFor=\"let col of widgetColumns$ | async; trackBy: _columnsTrackByFn\"\n    class=\"d-flex flex-column flex-grow-1 dashboard-widgets-list\"\n    cdkDropList\n    [cdkDropListData]=\"col.items\"\n    (cdkDropListDropped)=\"drop($any($event))\">\n    <div *ngFor=\"let item of col.items; trackBy: _containerTrackByFn\"\n      class=\"dashboard-widgets-list-item\"\n      [attr.data-widget-id]=\"item.widgetId\"\n      cdkDrag\n      [cdkDragDisabled]=\"!widgetsDraggable\">\n      <div [style.margin.px]=\"_gapStyleSize$ | async\">\n        <seam-dashboard-widget-template-container [item]=\"item\"></seam-dashboard-widget-template-container>\n      </div>\n    </div>\n  </div>\n</div>\n\n<ng-template #toggleBtnTpl>\n  <button seamButton theme=\"baselayout-action\" title=\"{{ widgetsDraggable ? 'Lock the Dashboard' : 'Modify Dashboard' }}\" (click)=\"toggleDragging()\">\n    <seam-icon [icon]=\"widgetsDraggable ? faUnlock : faLock\"></seam-icon>\n  </button>\n</ng-template>\n"]}
|
|
@@ -77,21 +77,24 @@ export class DashboardWidgetsService {
|
|
|
77
77
|
})));
|
|
78
78
|
}
|
|
79
79
|
createWidgetPortal(def, vcr) {
|
|
80
|
+
const injector = Injector.create({ providers: [
|
|
81
|
+
{ provide: THESEAM_WIDGET_DATA, useValue: { widgetId: def.widgetId } }
|
|
82
|
+
], parent: this._viewContainerRefSubject.value?.injector });
|
|
83
|
+
// TODO: I still use the ViewContainerRef injector, but I don't pass it to
|
|
84
|
+
// the portal, because it throws an error and I am not sure why. I would
|
|
85
|
+
// like to find out why, even though I don't think it is needed, because our
|
|
86
|
+
// code has been leaving it undefined for a while, when I thought it was
|
|
87
|
+
// being used.
|
|
80
88
|
if (typeof def.component === 'string') {
|
|
81
|
-
const injector = Injector.create({ providers: [
|
|
82
|
-
{ provide: THESEAM_WIDGET_DATA, useValue: { widgetId: def.widgetId } }
|
|
83
|
-
], parent: this._viewContainerRefSubject.value?.injector });
|
|
84
89
|
return this._dynamicComponentLoaderModule
|
|
85
90
|
.getComponentFactory(def.component)
|
|
86
91
|
.pipe(map(componentFactory => {
|
|
87
|
-
return new ComponentPortal(componentFactory.componentType,
|
|
88
|
-
// undefined,
|
|
89
|
-
injector, componentFactory /* ComponentFactoryBoundToModule */.ngModule.componentFactoryResolver);
|
|
92
|
+
return new ComponentPortal(componentFactory.componentType, undefined, injector, componentFactory /* ComponentFactoryBoundToModule */.ngModule.componentFactoryResolver);
|
|
90
93
|
}), take(1));
|
|
91
94
|
}
|
|
92
95
|
return def.componentFactoryResolver
|
|
93
|
-
? of(new ComponentPortal(def.component,
|
|
94
|
-
: of(new ComponentPortal(def.component,
|
|
96
|
+
? of(new ComponentPortal(def.component, undefined, injector, def.componentFactoryResolver))
|
|
97
|
+
: of(new ComponentPortal(def.component, undefined, injector));
|
|
95
98
|
}
|
|
96
99
|
updateOrder() {
|
|
97
100
|
return this.widgetColumns$
|
|
@@ -175,4 +178,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
|
|
|
175
178
|
providedIn: 'root'
|
|
176
179
|
}]
|
|
177
180
|
}], ctorParameters: function () { return [{ type: i1.TheSeamDynamicComponentLoader }, { type: i2.DashboardWidgetsPreferencesService }]; } });
|
|
178
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dashboard-widgets.service.js","sourceRoot":"","sources":["../../../../../../projects/ui-common/framework/dashboard/dashboard-widgets/dashboard-widgets.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentPortal } from '@angular/cdk/portal'\nimport { Injectable, Injector, isDevMode, ViewContainerRef } from '@angular/core'\nimport { BehaviorSubject, combineLatest, Observable, of } from 'rxjs'\nimport { auditTime, map, mapTo, shareReplay, switchMap, take, tap } from 'rxjs/operators'\n\nimport { TheSeamDynamicComponentLoader } from '@theseam/ui-common/dynamic-component-loader'\nimport { notNullOrUndefined } from '@theseam/ui-common/utils'\n\nimport {\n  IDashboardWidgetItemLayoutPreference,\n  IDashboardWidgetsColumnRecord,\n  IDashboardWidgetsItem,\n  IDashboardWidgetsItemDef\n} from './dashboard-widgets-item'\nimport { DashboardWidgetsPreferencesService } from './dashboard-widgets-preferences.service'\nimport { THESEAM_WIDGET_DATA } from '@theseam/ui-common/widget'\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class DashboardWidgetsService {\n\n  public readonly preferenceKey: string = 'datatable-widgets'\n\n  public readonly defaultNumColumns: number = 3\n\n  /** Used for operations, such as 'addWidget', if the column is not specified. */\n  public readonly defaultColumn: number = 0\n\n  get widgets(): IDashboardWidgetsItemDef[] { return this._widgets.value }\n  set widgets(value: IDashboardWidgetsItemDef[]) { this._widgets.next(value) }\n  private _widgets = new BehaviorSubject<IDashboardWidgetsItemDef[]>([])\n\n  get numColumns(): number { return this._numColumns.value }\n  set numColumns(value: number) {\n    if (value !== this._numColumns.value) {\n      this._numColumns.next(value)\n    }\n  }\n  private _numColumns = new BehaviorSubject<number>(this.defaultNumColumns)\n\n  public readonly numColumns$: Observable<number>\n  public readonly widgetItems$: Observable<IDashboardWidgetsItem[]>\n  public readonly widgetColumns$: Observable<IDashboardWidgetsColumnRecord[]>\n\n  private readonly _viewContainerRefSubject = new BehaviorSubject<ViewContainerRef | undefined>(undefined)\n\n  constructor(\n    private readonly _dynamicComponentLoaderModule: TheSeamDynamicComponentLoader,\n    private readonly _preferences: DashboardWidgetsPreferencesService\n  ) {\n    this.numColumns$ = this._numColumns.asObservable()\n\n    // Widget items without preferences\n    const _widgetItems$ = combineLatest([ this._widgets, this._viewContainerRefSubject ])\n      .pipe(switchMap(([ defs, vcr ]) => this.createWidgetItems(defs, vcr)))\n\n    // Widget items with preferences\n    this.widgetItems$ = combineLatest([ _widgetItems$, this.numColumns$ ])\n      .pipe(\n        // Wait until the current tick is done, incase both the widgets and\n        // number of columns are set durring the same tick. Without the audit,\n        // this would get called twice when the component is initialized with\n        // both inputs set one after the other individually.\n        auditTime(0),\n        switchMap(([ items, numColumns ]) =>\n          this._preferences.selectLayout(this.preferenceKey, this._layoutName(numColumns)).pipe(\n            map(layout => layout ? this.withLayoutPreferences(items, layout) : items)\n          )\n        ),\n        shareReplay({ bufferSize: 1, refCount: true })\n      )\n\n    this.widgetColumns$ = this.widgetItems$\n      .pipe(\n        map(items => this.toColumnRecords(items)),\n        shareReplay({ bufferSize: 1, refCount: true })\n      )\n  }\n\n  private _layoutName(numColumns: number): string {\n    return `columns-${numColumns}`\n  }\n\n  public setViewContainerRef(vcr: ViewContainerRef | undefined) {\n    this._viewContainerRefSubject.next(vcr)\n  }\n\n  public createWidgetItems(defs: IDashboardWidgetsItemDef[], vcr?: ViewContainerRef): Observable<IDashboardWidgetsItem[]> {\n    const _createObservables = (defs || []).map(d => this.createWidgetItem(d, vcr))\n    const items$ = _createObservables.length > 0 ? combineLatest(_createObservables) : of([])\n    return items$.pipe(\n      map(items => items.filter(notNullOrUndefined)),\n      tap(items => {\n        if (isDevMode()) {\n          const ids: string[] = items.map(v => v.widgetId)\n          if ((new Set(ids)).size !== ids.length) {\n            // eslint-disable-next-line no-console\n            console.warn(`[DashboardWidgetsService] Duplicate widget's with the same 'widgetId' found.`)\n          }\n        }\n      })\n    )\n  }\n\n  public createWidgetItem(def: IDashboardWidgetsItemDef, vcr?: ViewContainerRef): Observable<IDashboardWidgetsItem | undefined> {\n    if (!def.widgetId || typeof def.widgetId !== 'string' || def.widgetId.length < 1) {\n      if (isDevMode()) {\n        // eslint-disable-next-line no-console\n        console.warn(`[DashboardWidgetsService] Widget ignored. All widgets must have a 'widgetId'.`, def)\n      }\n      return of(undefined)\n    }\n\n    return this.createWidgetPortal(def, vcr).pipe(\n      map(portal => ({\n        ...def,\n        col: def.col || this.defaultColumn,\n        order: def.order || 0,\n        portal,\n        __itemDef: def\n      }))\n    )\n  }\n\n  public createWidgetPortal(def: IDashboardWidgetsItemDef, vcr?: ViewContainerRef): Observable<ComponentPortal<any>> {\n    if (typeof def.component === 'string') {\n      const injector = Injector.create({ providers: [\n        { provide: THESEAM_WIDGET_DATA, useValue: { widgetId: def.widgetId } }\n      ], parent: this._viewContainerRefSubject.value?.injector })\n      return this._dynamicComponentLoaderModule\n        .getComponentFactory(def.component)\n        .pipe(\n          map(componentFactory => {\n            return new ComponentPortal(\n              componentFactory.componentType,\n              vcr,\n              // undefined,\n              injector,\n              (componentFactory as any /* ComponentFactoryBoundToModule */).ngModule.componentFactoryResolver\n            )\n          }),\n          take(1)\n        )\n    }\n\n    return def.componentFactoryResolver\n      ? of(new ComponentPortal(def.component, vcr, undefined, def.componentFactoryResolver))\n      : of(new ComponentPortal(def.component, vcr))\n  }\n\n  public updateOrder(): Observable<void> {\n    return this.widgetColumns$\n      .pipe(\n        take(1),\n        tap(columns => columns.forEach(col => {\n          let i = 0\n          col.items.forEach(itm => itm.order = i++)\n        })),\n        mapTo(undefined)\n      )\n  }\n\n  public toColumnRecords(items: IDashboardWidgetsItem[]): IDashboardWidgetsColumnRecord[] {\n    let columns: IDashboardWidgetsColumnRecord[] = []\n\n    for (let i = 0; i < this.numColumns; i++) {\n      columns.push({ column: i, items: [] })\n    }\n\n    const colNotFound: IDashboardWidgetsItem[] = []\n\n    // Distribute items into columns\n    for (const item of items) {\n      const col: IDashboardWidgetsColumnRecord | undefined = columns.find(c => c.column === item.col)\n      if (!col) {\n        // columns.push({ column: item.col, items: [ item ] })\n        // if (item.col < 0) {\n        //   const col0: IDashboardWidgetsColumnRecord | undefined = columns.find(c => c.column === 0)\n        //   if (col0) {\n        //     col0.items.push(item)\n        //   }\n        // } else if (item.col > this.numColumns - 1) {\n        //   const colMax: IDashboardWidgetsColumnRecord | undefined = columns.find(c => c.column === this.numColumns - 1)\n        //   if (colMax) {\n        //     colMax.items.push(item)\n        //   }\n        // }\n        colNotFound.push(item)\n      } else {\n        col.items.push(item)\n      }\n    }\n\n    for (let i = 0; i < colNotFound.length; i++) {\n      const item = colNotFound[i]\n\n      const col: IDashboardWidgetsColumnRecord | undefined = columns\n        .find(c => c.column === i % this.numColumns)\n\n      if (col) {\n        col.items.push(item)\n      }\n    }\n\n    // Sort columns\n    columns = columns.sort((a, b) => a.column - b.column)\n\n    // Sort columns items\n    columns.forEach(col => col.items.sort((a, b) => a.order - b.order))\n\n    return columns\n  }\n\n  public withLayoutPreferences(items: IDashboardWidgetsItem[], layout: IDashboardWidgetItemLayoutPreference): IDashboardWidgetsItem[] {\n    const _items: IDashboardWidgetsItem[] = []\n\n    for (const item of items) {\n      const itemPref = layout.items.find(x => x.widgetId === item.widgetId)\n      _items.push({\n        ...item,\n        ...(itemPref || {})\n      })\n    }\n\n    return _items\n  }\n\n  public savePreferences(): Observable<void> {\n    // Right now the items are moved between the column record arrays, but the\n    // 'col' prop is not updated, so it is mapped to corrected items here from\n    // the column records.\n    const items$ = this.widgetColumns$.pipe(\n      map(columns => ([] as IDashboardWidgetsItem[])\n        .concat(...(columns.map(c => c.items.map(itm => ({ ...itm, col: c.column })))))\n      ),\n    )\n\n    return combineLatest([ items$, this.numColumns$ ]).pipe(\n      auditTime(0),\n      take(1),\n      switchMap(([ items, numColumns ]) => {\n        return this._preferences.updateLayout(this.preferenceKey, {\n          name: this._layoutName(numColumns),\n          items\n        })\n      }),\n      mapTo(undefined)\n    )\n  }\n\n}\n"]}
|
|
181
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dashboard-widgets.service.js","sourceRoot":"","sources":["../../../../../../projects/ui-common/framework/dashboard/dashboard-widgets/dashboard-widgets.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentPortal } from '@angular/cdk/portal'\nimport { Injectable, Injector, isDevMode, ViewContainerRef } from '@angular/core'\nimport { BehaviorSubject, combineLatest, Observable, of } from 'rxjs'\nimport { auditTime, map, mapTo, shareReplay, switchMap, take, tap } from 'rxjs/operators'\n\nimport { TheSeamDynamicComponentLoader } from '@theseam/ui-common/dynamic-component-loader'\nimport { notNullOrUndefined } from '@theseam/ui-common/utils'\nimport { THESEAM_WIDGET_DATA } from '@theseam/ui-common/widget'\n\nimport {\n  IDashboardWidgetItemLayoutPreference,\n  IDashboardWidgetsColumnRecord,\n  IDashboardWidgetsItem,\n  IDashboardWidgetsItemDef\n} from './dashboard-widgets-item'\nimport { DashboardWidgetsPreferencesService } from './dashboard-widgets-preferences.service'\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class DashboardWidgetsService {\n\n  public readonly preferenceKey: string = 'datatable-widgets'\n\n  public readonly defaultNumColumns: number = 3\n\n  /** Used for operations, such as 'addWidget', if the column is not specified. */\n  public readonly defaultColumn: number = 0\n\n  get widgets(): IDashboardWidgetsItemDef[] { return this._widgets.value }\n  set widgets(value: IDashboardWidgetsItemDef[]) { this._widgets.next(value) }\n  private _widgets = new BehaviorSubject<IDashboardWidgetsItemDef[]>([])\n\n  get numColumns(): number { return this._numColumns.value }\n  set numColumns(value: number) {\n    if (value !== this._numColumns.value) {\n      this._numColumns.next(value)\n    }\n  }\n  private _numColumns = new BehaviorSubject<number>(this.defaultNumColumns)\n\n  public readonly numColumns$: Observable<number>\n  public readonly widgetItems$: Observable<IDashboardWidgetsItem[]>\n  public readonly widgetColumns$: Observable<IDashboardWidgetsColumnRecord[]>\n\n  private readonly _viewContainerRefSubject = new BehaviorSubject<ViewContainerRef | undefined>(undefined)\n\n  constructor(\n    private readonly _dynamicComponentLoaderModule: TheSeamDynamicComponentLoader,\n    private readonly _preferences: DashboardWidgetsPreferencesService\n  ) {\n    this.numColumns$ = this._numColumns.asObservable()\n\n    // Widget items without preferences\n    const _widgetItems$ = combineLatest([ this._widgets, this._viewContainerRefSubject ])\n      .pipe(switchMap(([ defs, vcr ]) => this.createWidgetItems(defs, vcr)))\n\n    // Widget items with preferences\n    this.widgetItems$ = combineLatest([ _widgetItems$, this.numColumns$ ])\n      .pipe(\n        // Wait until the current tick is done, incase both the widgets and\n        // number of columns are set durring the same tick. Without the audit,\n        // this would get called twice when the component is initialized with\n        // both inputs set one after the other individually.\n        auditTime(0),\n        switchMap(([ items, numColumns ]) =>\n          this._preferences.selectLayout(this.preferenceKey, this._layoutName(numColumns)).pipe(\n            map(layout => layout ? this.withLayoutPreferences(items, layout) : items)\n          )\n        ),\n        shareReplay({ bufferSize: 1, refCount: true })\n      )\n\n    this.widgetColumns$ = this.widgetItems$\n      .pipe(\n        map(items => this.toColumnRecords(items)),\n        shareReplay({ bufferSize: 1, refCount: true })\n      )\n  }\n\n  private _layoutName(numColumns: number): string {\n    return `columns-${numColumns}`\n  }\n\n  public setViewContainerRef(vcr: ViewContainerRef | undefined) {\n    this._viewContainerRefSubject.next(vcr)\n  }\n\n  public createWidgetItems(defs: IDashboardWidgetsItemDef[], vcr?: ViewContainerRef): Observable<IDashboardWidgetsItem[]> {\n    const _createObservables = (defs || []).map(d => this.createWidgetItem(d, vcr))\n    const items$ = _createObservables.length > 0 ? combineLatest(_createObservables) : of([])\n    return items$.pipe(\n      map(items => items.filter(notNullOrUndefined)),\n      tap(items => {\n        if (isDevMode()) {\n          const ids: string[] = items.map(v => v.widgetId)\n          if ((new Set(ids)).size !== ids.length) {\n            // eslint-disable-next-line no-console\n            console.warn(`[DashboardWidgetsService] Duplicate widget's with the same 'widgetId' found.`)\n          }\n        }\n      })\n    )\n  }\n\n  public createWidgetItem(def: IDashboardWidgetsItemDef, vcr?: ViewContainerRef): Observable<IDashboardWidgetsItem | undefined> {\n    if (!def.widgetId || typeof def.widgetId !== 'string' || def.widgetId.length < 1) {\n      if (isDevMode()) {\n        // eslint-disable-next-line no-console\n        console.warn(`[DashboardWidgetsService] Widget ignored. All widgets must have a 'widgetId'.`, def)\n      }\n      return of(undefined)\n    }\n\n    return this.createWidgetPortal(def, vcr).pipe(\n      map(portal => ({\n        ...def,\n        col: def.col || this.defaultColumn,\n        order: def.order || 0,\n        portal,\n        __itemDef: def\n      }))\n    )\n  }\n\n  public createWidgetPortal(def: IDashboardWidgetsItemDef, vcr?: ViewContainerRef): Observable<ComponentPortal<any>> {\n    const injector = Injector.create({ providers: [\n      { provide: THESEAM_WIDGET_DATA, useValue: { widgetId: def.widgetId } }\n    ], parent: this._viewContainerRefSubject.value?.injector })\n\n    // TODO: I still use the ViewContainerRef injector, but I don't pass it to\n    // the portal, because it throws an error and I am not sure why. I would\n    // like to find out why, even though I don't think it is needed, because our\n    // code has been leaving it undefined for a while, when I thought it was\n    // being used.\n\n    if (typeof def.component === 'string') {\n      return this._dynamicComponentLoaderModule\n        .getComponentFactory(def.component)\n        .pipe(\n          map(componentFactory => {\n            return new ComponentPortal(\n              componentFactory.componentType,\n              undefined,\n              injector,\n              (componentFactory as any /* ComponentFactoryBoundToModule */).ngModule.componentFactoryResolver\n            )\n          }),\n          take(1)\n        )\n    }\n\n    return def.componentFactoryResolver\n      ? of(new ComponentPortal(def.component, undefined, injector, def.componentFactoryResolver))\n      : of(new ComponentPortal(def.component, undefined, injector))\n  }\n\n  public updateOrder(): Observable<void> {\n    return this.widgetColumns$\n      .pipe(\n        take(1),\n        tap(columns => columns.forEach(col => {\n          let i = 0\n          col.items.forEach(itm => itm.order = i++)\n        })),\n        mapTo(undefined)\n      )\n  }\n\n  public toColumnRecords(items: IDashboardWidgetsItem[]): IDashboardWidgetsColumnRecord[] {\n    let columns: IDashboardWidgetsColumnRecord[] = []\n\n    for (let i = 0; i < this.numColumns; i++) {\n      columns.push({ column: i, items: [] })\n    }\n\n    const colNotFound: IDashboardWidgetsItem[] = []\n\n    // Distribute items into columns\n    for (const item of items) {\n      const col: IDashboardWidgetsColumnRecord | undefined = columns.find(c => c.column === item.col)\n      if (!col) {\n        // columns.push({ column: item.col, items: [ item ] })\n        // if (item.col < 0) {\n        //   const col0: IDashboardWidgetsColumnRecord | undefined = columns.find(c => c.column === 0)\n        //   if (col0) {\n        //     col0.items.push(item)\n        //   }\n        // } else if (item.col > this.numColumns - 1) {\n        //   const colMax: IDashboardWidgetsColumnRecord | undefined = columns.find(c => c.column === this.numColumns - 1)\n        //   if (colMax) {\n        //     colMax.items.push(item)\n        //   }\n        // }\n        colNotFound.push(item)\n      } else {\n        col.items.push(item)\n      }\n    }\n\n    for (let i = 0; i < colNotFound.length; i++) {\n      const item = colNotFound[i]\n\n      const col: IDashboardWidgetsColumnRecord | undefined = columns\n        .find(c => c.column === i % this.numColumns)\n\n      if (col) {\n        col.items.push(item)\n      }\n    }\n\n    // Sort columns\n    columns = columns.sort((a, b) => a.column - b.column)\n\n    // Sort columns items\n    columns.forEach(col => col.items.sort((a, b) => a.order - b.order))\n\n    return columns\n  }\n\n  public withLayoutPreferences(items: IDashboardWidgetsItem[], layout: IDashboardWidgetItemLayoutPreference): IDashboardWidgetsItem[] {\n    const _items: IDashboardWidgetsItem[] = []\n\n    for (const item of items) {\n      const itemPref = layout.items.find(x => x.widgetId === item.widgetId)\n      _items.push({\n        ...item,\n        ...(itemPref || {})\n      })\n    }\n\n    return _items\n  }\n\n  public savePreferences(): Observable<void> {\n    // Right now the items are moved between the column record arrays, but the\n    // 'col' prop is not updated, so it is mapped to corrected items here from\n    // the column records.\n    const items$ = this.widgetColumns$.pipe(\n      map(columns => ([] as IDashboardWidgetsItem[])\n        .concat(...(columns.map(c => c.items.map(itm => ({ ...itm, col: c.column })))))\n      ),\n    )\n\n    return combineLatest([ items$, this.numColumns$ ]).pipe(\n      auditTime(0),\n      take(1),\n      switchMap(([ items, numColumns ]) => {\n        return this._preferences.updateLayout(this.preferenceKey, {\n          name: this._layoutName(numColumns),\n          items\n        })\n      }),\n      mapTo(undefined)\n    )\n  }\n\n}\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { isDevMode } from '@angular/core';
|
|
2
|
-
import { map, of, shareReplay, startWith, Subject, switchMap, tap } from 'rxjs';
|
|
2
|
+
import { map, of, shareReplay, startWith, Subject, switchMap, take, tap } from 'rxjs';
|
|
3
3
|
import { notNullOrUndefined } from '@theseam/ui-common/utils';
|
|
4
4
|
export class TheSeamPreferencesMapRecord {
|
|
5
5
|
constructor(_key, _accessor, _emptyPrefs) {
|
|
@@ -32,17 +32,15 @@ export class TheSeamPreferencesMapRecord {
|
|
|
32
32
|
}
|
|
33
33
|
return null;
|
|
34
34
|
}
|
|
35
|
-
}), map(v => notNullOrUndefined(v) ? v : this._emptyPrefs),
|
|
36
|
-
// tap(v => console.log('preferences$', v)),
|
|
37
|
-
tap(() => {
|
|
35
|
+
}), map(v => notNullOrUndefined(v) ? v : this._emptyPrefs), tap(() => {
|
|
38
36
|
this._setStatus('loaded');
|
|
39
37
|
}))), shareReplay({ bufferSize: 1, refCount: true }));
|
|
40
38
|
}
|
|
41
39
|
update(value) {
|
|
42
|
-
this._accessor.update(this._key, JSON.stringify(value));
|
|
40
|
+
this._accessor.update(this._key, JSON.stringify(value)).pipe(take(1)).subscribe();
|
|
43
41
|
}
|
|
44
42
|
delete() {
|
|
45
|
-
this._accessor.delete(this._key);
|
|
43
|
+
this._accessor.delete(this._key).pipe(take(1)).subscribe();
|
|
46
44
|
}
|
|
47
45
|
refresh() {
|
|
48
46
|
this._setStatus('pending');
|
|
@@ -71,4 +69,4 @@ export class TheSeamPreferencesMapRecord {
|
|
|
71
69
|
return prefs;
|
|
72
70
|
}
|
|
73
71
|
}
|
|
74
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
72
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"preferences-record.js","sourceRoot":"","sources":["../../../../../projects/ui-common/services/preferences/preferences-record.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAA;AACzC,OAAO,EAAE,GAAG,EAAc,EAAE,EAAE,WAAW,EAAE,SAAS,EAAE,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,GAAG,EAAE,MAAM,MAAM,CAAA;AAEjG,OAAO,EAAE,kBAAkB,EAAE,MAAM,0BAA0B,CAAA;AAY7D,MAAM,OAAO,2BAA2B;IAUtC,YACmB,IAAY,EACZ,SAAqC,EACrC,WAAmC;QAFnC,SAAI,GAAJ,IAAI,CAAQ;QACZ,cAAS,GAAT,SAAS,CAA4B;QACrC,gBAAW,GAAX,WAAW,CAAwB;QAXrC,oBAAe,GAAG,IAAI,OAAO,EAAQ,CAAA;QACrC,yBAAoB,GAAG,IAAI,OAAO,EAAwC,CAAA;QAEnF,YAAO,GAAmC,SAAS,CAAA;QAUzD,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,iBAAiB,EAAE,CAAA;QAC1C,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,oBAAoB,CAAC,YAAY,EAAE,CAAA;IAC9D,CAAC;IAEO,iBAAiB;QACvB,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YACnB,OAAO,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,CAAA;SAC5B;QAED,MAAM,QAAQ,GAAG,CAAC,GAAW,EAAsB,EAAE,CACnD,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAA;QAEjF,OAAO,IAAI,CAAC,eAAe,CAAC,IAAI,CAC9B,SAAS,CAAC,SAAS,CAAC,EACpB,SAAS,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,CACtC,GAAG,CAAC,CAAC,CAAC,EAAE;YACN,IAAI,CAAC,CAAC,EAAE;gBACN,OAAO,IAAI,CAAA;aACZ;YAED,2EAA2E;YAC3E,IAAI;gBACF,OAAO,IAAI,CAAC,wBAAwB,CAAC,CAAC,CAAC,CAAA;aACxC;YAAC,OAAO,KAAK,EAAE;gBACd,IAAI,SAAS,EAAE,EAAE;oBACf,sCAAsC;oBACtC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;iBACrB;gBACD,OAAO,IAAI,CAAA;aACZ;QACH,CAAC,CAAC,EACF,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,EACtD,GAAG,CAAC,GAAG,EAAE;YACP,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAA;QAC3B,CAAC,CAAC,CACH,CAAC,EACF,WAAW,CAAC,EAAE,UAAU,EAAE,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAC/C,CAAA;IACH,CAAC;IAEM,MAAM,CAAC,KAA6B;QACzC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,CAAA;IACnF,CAAC;IAEM,MAAM;QACX,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,CAAA;IAC5D,CAAC;IAEM,OAAO;QACZ,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAA;QAC1B,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,CAAA;IAC7B,CAAC;IAEM,cAAc,CAAC,QAAoC;QACxD,OAAO,IAAI,CAAC,SAAS,KAAK,QAAQ,CAAA;IACpC,CAAC;IAEM,gBAAgB,CAAC,UAAkC;QACxD,OAAO,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAA;IACxE,CAAC;IAED,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAA;IACrB,CAAC;IAEO,UAAU,CAAC,MAAsC;QACvD,IAAI,IAAI,CAAC,OAAO,KAAK,MAAM,EAAE;YAC3B,OAAM;SACP;QACD,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,CAAA;QACzB,IAAI,CAAC,OAAO,GAAG,MAAM,CAAA;QACrB,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC,CAAA;IACrE,CAAC;IAEO,wBAAwB,CAAC,UAAkB;QACjD,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAA;QAEpC,4BAA4B;QAE5B,OAAO,KAAK,CAAA;IACd,CAAC;CACF","sourcesContent":["import { isDevMode } from '@angular/core'\r\nimport { map, Observable, of, shareReplay, startWith, Subject, switchMap, take, tap } from 'rxjs'\r\n\r\nimport { notNullOrUndefined } from '@theseam/ui-common/utils'\r\n\r\nimport { TheSeamPreferencesAccessor } from './preferences-accessor'\r\nimport { TheSeamPreferencesBase } from './preferences.models'\r\n\r\nexport type TheSeamPreferencesRecordStatus = 'pending' | 'loaded'\r\n\r\nexport interface TheSeamPreferencesRecordStatusChange {\r\n  previous: TheSeamPreferencesRecordStatus\r\n  current: TheSeamPreferencesRecordStatus\r\n}\r\n\r\nexport class TheSeamPreferencesMapRecord {\r\n\r\n  private readonly _refreshSubject = new Subject<void>()\r\n  private readonly _statusChangeSubject = new Subject<TheSeamPreferencesRecordStatusChange>()\r\n\r\n  private _status: TheSeamPreferencesRecordStatus = 'pending'\r\n\r\n  public readonly observable: Observable<TheSeamPreferencesBase>\r\n  public readonly statusChange: Observable<TheSeamPreferencesRecordStatusChange>\r\n\r\n  constructor(\r\n    private readonly _key: string,\r\n    private readonly _accessor: TheSeamPreferencesAccessor,\r\n    private readonly _emptyPrefs: TheSeamPreferencesBase,\r\n  ) {\r\n    this.observable = this._createObservable()\r\n    this.statusChange = this._statusChangeSubject.asObservable()\r\n  }\r\n\r\n  private _createObservable(): Observable<TheSeamPreferencesBase> {\r\n    if (!this._accessor) {\r\n      return of(this._emptyPrefs)\r\n    }\r\n\r\n    const accessor = (key: string): Observable<string> =>\r\n      this._accessor ? this._accessor.get(key) : of(JSON.stringify(this._emptyPrefs))\r\n\r\n    return this._refreshSubject.pipe(\r\n      startWith(undefined),\r\n      switchMap(() => accessor(this._key).pipe(\r\n        map(v => {\r\n          if (!v) {\r\n            return null\r\n          }\r\n\r\n          // TODO: Add a schema validator and migration tool to avoid parsing issues.\r\n          try {\r\n            return this._descerializePreferences(v)\r\n          } catch (error) {\r\n            if (isDevMode()) {\r\n              // eslint-disable-next-line no-console\r\n              console.error(error)\r\n            }\r\n            return null\r\n          }\r\n        }),\r\n        map(v => notNullOrUndefined(v) ? v : this._emptyPrefs),\r\n        tap(() => {\r\n          this._setStatus('loaded')\r\n        })\r\n      )),\r\n      shareReplay({ bufferSize: 1, refCount: true }),\r\n    )\r\n  }\r\n\r\n  public update(value: TheSeamPreferencesBase): void {\r\n    this._accessor.update(this._key, JSON.stringify(value)).pipe(take(1)).subscribe()\r\n  }\r\n\r\n  public delete(): void {\r\n    this._accessor.delete(this._key).pipe(take(1)).subscribe()\r\n  }\r\n\r\n  public refresh(): void {\r\n    this._setStatus('pending')\r\n    this._refreshSubject.next()\r\n  }\r\n\r\n  public isSameAccessor(accessor: TheSeamPreferencesAccessor): boolean {\r\n    return this._accessor === accessor\r\n  }\r\n\r\n  public isSameEmptyPrefs(emptyPrefs: TheSeamPreferencesBase): boolean {\r\n    return JSON.stringify(this._emptyPrefs) === JSON.stringify(emptyPrefs)\r\n  }\r\n\r\n  get status(): TheSeamPreferencesRecordStatus {\r\n    return this._status\r\n  }\r\n\r\n  private _setStatus(status: TheSeamPreferencesRecordStatus): void {\r\n    if (this._status === status) {\r\n      return\r\n    }\r\n    const prev = this._status\r\n    this._status = status\r\n    this._statusChangeSubject.next({ previous: prev, current: status })\r\n  }\r\n\r\n  private _descerializePreferences(serialized: string): TheSeamPreferencesBase {\r\n    const prefs = JSON.parse(serialized)\r\n\r\n    // TODO: Implement migration\r\n\r\n    return prefs\r\n  }\r\n}\r\n"]}
|
|
@@ -7,7 +7,7 @@ export class StoryPreferencesAccessorService {
|
|
|
7
7
|
* Gets a preference.
|
|
8
8
|
*/
|
|
9
9
|
get(name) {
|
|
10
|
-
|
|
10
|
+
console.log('get', name);
|
|
11
11
|
return of(localStorage.getItem(`${ACCESSOR_PREFIX}-${name}`) || '{}');
|
|
12
12
|
}
|
|
13
13
|
/**
|
|
@@ -31,4 +31,4 @@ StoryPreferencesAccessorService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion
|
|
|
31
31
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: StoryPreferencesAccessorService, decorators: [{
|
|
32
32
|
type: Injectable
|
|
33
33
|
}] });
|
|
34
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RvcnktcHJlZmVyZW5jZXMtYWNjZXNzb3Iuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi9zdG9yeS1oZWxwZXJzL3N0b3J5LXByZWZlcmVuY2VzLWFjY2Vzc29yLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUMxQyxPQUFPLEVBQWMsRUFBRSxFQUFFLE1BQU0sTUFBTSxDQUFBOztBQUlyQyxNQUFNLGVBQWUsR0FBRyxZQUFZLENBQUE7QUFHcEMsTUFBTSxPQUFPLCtCQUErQjtJQUUxQzs7T0FFRztJQUNJLEdBQUcsQ0FBQyxJQUFZO1FBQ3JCLE9BQU8sQ0FBQyxHQUFHLENBQUMsS0FBSyxFQUFFLElBQUksQ0FBQyxDQUFBO1FBQ3hCLE9BQU8sRUFBRSxDQUFDLFlBQVksQ0FBQyxPQUFPLENBQUMsR0FBRyxlQUFlLElBQUksSUFBSSxFQUFFLENBQUMsSUFBSSxJQUFJLENBQUMsQ0FBQTtJQUN2RSxDQUFDO0lBRUQ7O09BRUc7SUFDSSxNQUFNLENBQUMsSUFBWSxFQUFFLEtBQWE7UUFDdkMsOEJBQThCO1FBQzlCLFlBQVksQ0FBQyxPQUFPLENBQUMsR0FBRyxlQUFlLElBQUksSUFBSSxFQUFFLEVBQUUsS0FBSyxDQUFDLENBQUE7UUFDekQsT0FBTyxJQUFJLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFBO0lBQ3ZCLENBQUM7SUFFRDs7T0FFRztJQUNJLE1BQU0sQ0FBQyxJQUFZO1FBQ3hCLFlBQVksQ0FBQyxVQUFVLENBQUMsR0FBRyxlQUFlLElBQUksSUFBSSxFQUFFLENBQUMsQ0FBQTtRQUNyRCxPQUFPLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQTtJQUNqQixDQUFDOzs0SEF6QlUsK0JBQStCO2dJQUEvQiwrQkFBK0I7MkZBQS9CLCtCQUErQjtrQkFEM0MsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJ1xyXG5pbXBvcnQgeyBPYnNlcnZhYmxlLCBvZiB9IGZyb20gJ3J4anMnXHJcblxyXG5pbXBvcnQgeyBUaGVTZWFtUHJlZmVyZW5jZXNBY2Nlc3NvciB9IGZyb20gJ0B0aGVzZWFtL3VpLWNvbW1vbi9zZXJ2aWNlcydcclxuXHJcbmNvbnN0IEFDQ0VTU09SX1BSRUZJWCA9ICdzdG9yeS1wcmVmJ1xyXG5cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgU3RvcnlQcmVmZXJlbmNlc0FjY2Vzc29yU2VydmljZSBpbXBsZW1lbnRzIFRoZVNlYW1QcmVmZXJlbmNlc0FjY2Vzc29yIHtcclxuXHJcbiAgLyoqXHJcbiAgICogR2V0cyBhIHByZWZlcmVuY2UuXHJcbiAgICovXHJcbiAgcHVibGljIGdldChuYW1lOiBzdHJpbmcpOiBPYnNlcnZhYmxlPHN0cmluZz4ge1xyXG4gICAgY29uc29sZS5sb2coJ2dldCcsIG5hbWUpXHJcbiAgICByZXR1cm4gb2YobG9jYWxTdG9yYWdlLmdldEl0ZW0oYCR7QUNDRVNTT1JfUFJFRklYfS0ke25hbWV9YCkgfHwgJ3t9JylcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIFVwZGF0ZSBhIHByZWZlcmVuY2UuXHJcbiAgICovXHJcbiAgcHVibGljIHVwZGF0ZShuYW1lOiBzdHJpbmcsIHZhbHVlOiBzdHJpbmcpOiBPYnNlcnZhYmxlPHN0cmluZz4ge1xyXG4gICAgLy8gY29uc29sZS5sb2coJ3VwZGF0ZScsIG5hbWUpXHJcbiAgICBsb2NhbFN0b3JhZ2Uuc2V0SXRlbShgJHtBQ0NFU1NPUl9QUkVGSVh9LSR7bmFtZX1gLCB2YWx1ZSlcclxuICAgIHJldHVybiB0aGlzLmdldChuYW1lKVxyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogRGVsZXRlIGEgcHJlZmVyZW5jZS5cclxuICAgKi9cclxuICBwdWJsaWMgZGVsZXRlKG5hbWU6IHN0cmluZyk6IE9ic2VydmFibGU8Ym9vbGVhbj4ge1xyXG4gICAgbG9jYWxTdG9yYWdlLnJlbW92ZUl0ZW0oYCR7QUNDRVNTT1JfUFJFRklYfS0ke25hbWV9YClcclxuICAgIHJldHVybiBvZih0cnVlKVxyXG4gIH1cclxuXHJcbn1cclxuIl19
|
|
@@ -742,21 +742,24 @@ class DashboardWidgetsService {
|
|
|
742
742
|
}
|
|
743
743
|
createWidgetPortal(def, vcr) {
|
|
744
744
|
var _a;
|
|
745
|
+
const injector = Injector.create({ providers: [
|
|
746
|
+
{ provide: THESEAM_WIDGET_DATA, useValue: { widgetId: def.widgetId } }
|
|
747
|
+
], parent: (_a = this._viewContainerRefSubject.value) === null || _a === void 0 ? void 0 : _a.injector });
|
|
748
|
+
// TODO: I still use the ViewContainerRef injector, but I don't pass it to
|
|
749
|
+
// the portal, because it throws an error and I am not sure why. I would
|
|
750
|
+
// like to find out why, even though I don't think it is needed, because our
|
|
751
|
+
// code has been leaving it undefined for a while, when I thought it was
|
|
752
|
+
// being used.
|
|
745
753
|
if (typeof def.component === 'string') {
|
|
746
|
-
const injector = Injector.create({ providers: [
|
|
747
|
-
{ provide: THESEAM_WIDGET_DATA, useValue: { widgetId: def.widgetId } }
|
|
748
|
-
], parent: (_a = this._viewContainerRefSubject.value) === null || _a === void 0 ? void 0 : _a.injector });
|
|
749
754
|
return this._dynamicComponentLoaderModule
|
|
750
755
|
.getComponentFactory(def.component)
|
|
751
756
|
.pipe(map(componentFactory => {
|
|
752
|
-
return new ComponentPortal(componentFactory.componentType,
|
|
753
|
-
// undefined,
|
|
754
|
-
injector, componentFactory /* ComponentFactoryBoundToModule */.ngModule.componentFactoryResolver);
|
|
757
|
+
return new ComponentPortal(componentFactory.componentType, undefined, injector, componentFactory /* ComponentFactoryBoundToModule */.ngModule.componentFactoryResolver);
|
|
755
758
|
}), take(1));
|
|
756
759
|
}
|
|
757
760
|
return def.componentFactoryResolver
|
|
758
|
-
? of(new ComponentPortal(def.component,
|
|
759
|
-
: of(new ComponentPortal(def.component,
|
|
761
|
+
? of(new ComponentPortal(def.component, undefined, injector, def.componentFactoryResolver))
|
|
762
|
+
: of(new ComponentPortal(def.component, undefined, injector));
|
|
760
763
|
}
|
|
761
764
|
updateOrder() {
|
|
762
765
|
return this.widgetColumns$
|
|
@@ -869,6 +872,7 @@ class DashboardWidgetsComponent {
|
|
|
869
872
|
this._layoutChange = new Subject();
|
|
870
873
|
this.widgetsChange = new EventEmitter();
|
|
871
874
|
this._widthChange = new Subject();
|
|
875
|
+
this._dashboardWidgets.setViewContainerRef(this._viewContainerRef);
|
|
872
876
|
this.containers$ = this._containers.asObservable();
|
|
873
877
|
this._gapStyleSize$ = this._gapSize.pipe(auditTime(0), map(size => size / 2), shareReplay({ bufferSize: 1, refCount: true }));
|
|
874
878
|
this._widthChange.pipe(debounceTime(30), tap(width => {
|