@dereekb/dbx-web 9.9.5 → 9.10.0
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/lib/interaction/popup/popup.component.mjs +1 -1
- package/esm2020/lib/interaction/popup/popup.service.mjs +3 -3
- package/esm2020/lib/layout/column/two/two.column.right.component.mjs +3 -3
- package/esm2020/lib/layout/column/two/two.column.store.mjs +17 -4
- package/fesm2015/dereekb-dbx-web.mjs +21 -8
- package/fesm2015/dereekb-dbx-web.mjs.map +1 -1
- package/fesm2020/dereekb-dbx-web.mjs +20 -7
- package/fesm2020/dereekb-dbx-web.mjs.map +1 -1
- package/lib/interaction/popup/_popup.scss +1 -1
- package/lib/interaction/popup/popup.component.d.ts +3 -1
- package/lib/interaction/prompt/_prompt.scss +1 -1
- package/lib/layout/column/two/two.column.store.d.ts +16 -0
- package/mapbox/package.json +3 -3
- package/package.json +3 -3
|
@@ -125,4 +125,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImpor
|
|
|
125
125
|
]
|
|
126
126
|
}]
|
|
127
127
|
}], ctorParameters: function () { return [{ type: i1.NgPopoverRef }, { type: i2.CompactContextStore }, { type: i3.DbxRouterTransitionService }, { type: i0.NgZone }]; } });
|
|
128
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popup.component.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/src/lib/interaction/popup/popup.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, NgZone, Type, OnDestroy } from '@angular/core';\nimport { NgPopoverRef } from 'ng-overlay-container';\nimport { Maybe } from '@dereekb/util';\nimport { CompactMode, CompactContextStore } from '../../layout';\nimport { BehaviorSubject, Subject, filter, first, map, shareReplay, startWith } from 'rxjs';\nimport { PopupGlobalPositionStrategy, PopupPosition, PopupPositionOffset } from './popup.position.strategy';\nimport { AbstractTransitionWatcherDirective, DbxInjectionComponentConfig, DbxRouterTransitionService } from '@dereekb/dbx-core';\nimport { DbxPopupController, DbxPopupKey, DbxPopupWindowState } from './popup';\n\nexport const APP_POPUP_NORMAL_WIDTH = '700px';\nexport const APP_POPUP_MINIMIZED_WIDTH = '300px';\nexport const APP_POPUP_NORMAL_HEIGHT = 'auto';\n\nexport abstract class DbxPopupComponentController<O, I> extends DbxPopupController<O, I> {\n  getClosingValueFn?: (value?: I) => Promise<O>;\n}\n\nexport interface DbxPopupComponentConfig<O, I, T> {\n  /**\n   * Key used for uniquely identifying a limited instance.\n   *\n   * Only one popup should exist at a time given a certain key.\n   */\n  key: DbxPopupKey;\n  position?: PopupPosition;\n  offset?: PopupPositionOffset;\n  closeOnTransition?: boolean;\n  componentClass: Type<T>;\n  data?: I;\n  isDraggable?: boolean;\n  init?: (component: T, controller: DbxPopupController<O, I>) => void;\n}\n\n/**\n * Popup component.\n */\n@Component({\n  template: `\n    <dbx-popup-coordinator>\n      <div class=\"dbx-popup-component\" dbx-injection [config]=\"contentConfig\"></div>\n    </dbx-popup-coordinator>\n  `,\n  providers: [\n    {\n      provide: DbxPopupController,\n      useExisting: DbxPopupComponent\n    },\n    {\n      provide: CompactContextStore\n    }\n  ]\n})\nexport class DbxPopupComponent<O = unknown, I = unknown, T = unknown> extends AbstractTransitionWatcherDirective implements DbxPopupController<O, I>, OnDestroy {\n  private _position: PopupGlobalPositionStrategy;\n\n  readonly contentConfig: DbxInjectionComponentConfig = {\n    componentClass: this.config.componentClass,\n    init: this.config.init ? (instance) => (this.config as Required<DbxPopupComponentConfig<O, I, T>>).init(instance as T, this) : undefined\n  };\n\n  private readonly closing = new Subject<void>();\n  readonly isClosing$ = this.closing.pipe(\n    first(),\n    map(() => true),\n    startWith(false),\n    shareReplay(1)\n  );\n  readonly closing$ = this.isClosing$.pipe(filter((x) => x));\n\n  private readonly _windowState = new BehaviorSubject<DbxPopupWindowState>(DbxPopupWindowState.NORMAL);\n  readonly windowState$ = this._windowState.asObservable();\n\n  getClosingValueFn?: (value?: I) => Promise<O>;\n\n  constructor(private popoverRef: NgPopoverRef<DbxPopupComponentConfig<O, I, T>, O>, private compactContextState: CompactContextStore, dbxRouterTransitionService: DbxRouterTransitionService, ngZone: NgZone) {\n    super(dbxRouterTransitionService, ngZone);\n\n    this.compactContextState.setMode(CompactMode.COMPACT);\n    this._position = new PopupGlobalPositionStrategy(this.config.position, this.config.offset);\n    this.popoverRef.overlay.updatePositionStrategy(this._position);\n  }\n\n  get config(): DbxPopupComponentConfig<O, I, T> {\n    return this.popoverRef.data;\n  }\n\n  get key(): DbxPopupKey {\n    return this.config.key;\n  }\n\n  get data(): Maybe<I> {\n    return this.config.data;\n  }\n\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    this.closing.complete();\n    this._windowState.complete();\n  }\n\n  protected updateForSuccessfulTransition(): void {\n    if (this.config.closeOnTransition !== false) {\n      this.close();\n    }\n  }\n\n  // Popup Controls\n  public close(): void {\n    this.closing.next();\n\n    if (this.getClosingValueFn) {\n      this.getClosingValueFn().then(\n        (x) => {\n          this.return(x);\n        },\n        () => {\n          this.return();\n        }\n      );\n    } else {\n      this.return();\n    }\n  }\n\n  public return(value?: O): void {\n    this.closing.next();\n    this.popoverRef.close(value);\n  }\n\n  public minimize(): void {\n    this.popoverRef.isDraggable = false;\n    this.popoverRef.resize(APP_POPUP_MINIMIZED_WIDTH, APP_POPUP_NORMAL_HEIGHT);\n    this.popoverRef.overlay.updatePosition();\n    this._windowState.next(DbxPopupWindowState.MINIMIZED);\n  }\n\n  public normalscreen(): void {\n    this.popoverRef.isDraggable = this.config.isDraggable;\n    this.popoverRef.resize(APP_POPUP_NORMAL_WIDTH, APP_POPUP_NORMAL_HEIGHT);\n    this.popoverRef.overlay.updatePosition();\n    this._windowState.next(DbxPopupWindowState.NORMAL);\n  }\n\n  public fullscreen(): void {\n    this.popoverRef.isDraggable = false;\n    this.popoverRef.resize('100%', '100%');\n    this.popoverRef.overlay.updatePosition();\n    this._windowState.next(DbxPopupWindowState.FULLSCREEN);\n  }\n}\n"]}
|
|
128
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popup.component.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-web/src/lib/interaction/popup/popup.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, NgZone, Type, OnDestroy } from '@angular/core';\nimport { NgPopoverRef } from 'ng-overlay-container';\nimport { Maybe, PixelsString } from '@dereekb/util';\nimport { CompactMode, CompactContextStore } from '../../layout';\nimport { BehaviorSubject, Subject, filter, first, map, shareReplay, startWith } from 'rxjs';\nimport { PopupGlobalPositionStrategy, PopupPosition, PopupPositionOffset } from './popup.position.strategy';\nimport { AbstractTransitionWatcherDirective, DbxInjectionComponentConfig, DbxRouterTransitionService } from '@dereekb/dbx-core';\nimport { DbxPopupController, DbxPopupKey, DbxPopupWindowState } from './popup';\n\nexport const APP_POPUP_NORMAL_WIDTH = '700px';\nexport const APP_POPUP_MINIMIZED_WIDTH = '300px';\nexport const APP_POPUP_NORMAL_HEIGHT = 'auto';\n\nexport abstract class DbxPopupComponentController<O, I> extends DbxPopupController<O, I> {\n  getClosingValueFn?: (value?: I) => Promise<O>;\n}\n\nexport interface DbxPopupComponentConfig<O, I, T> {\n  /**\n   * Key used for uniquely identifying a limited instance.\n   *\n   * Only one popup should exist at a time given a certain key.\n   */\n  key: DbxPopupKey;\n  position?: PopupPosition;\n  offset?: PopupPositionOffset;\n  closeOnTransition?: boolean;\n  componentClass: Type<T>;\n  data?: I;\n  isDraggable?: boolean;\n  init?: (component: T, controller: DbxPopupController<O, I>) => void;\n  width?: PixelsString;\n  height?: PixelsString;\n}\n\n/**\n * Popup component.\n */\n@Component({\n  template: `\n    <dbx-popup-coordinator>\n      <div class=\"dbx-popup-component\" dbx-injection [config]=\"contentConfig\"></div>\n    </dbx-popup-coordinator>\n  `,\n  providers: [\n    {\n      provide: DbxPopupController,\n      useExisting: DbxPopupComponent\n    },\n    {\n      provide: CompactContextStore\n    }\n  ]\n})\nexport class DbxPopupComponent<O = unknown, I = unknown, T = unknown> extends AbstractTransitionWatcherDirective implements DbxPopupController<O, I>, OnDestroy {\n  private _position: PopupGlobalPositionStrategy;\n\n  readonly contentConfig: DbxInjectionComponentConfig = {\n    componentClass: this.config.componentClass,\n    init: this.config.init ? (instance) => (this.config as Required<DbxPopupComponentConfig<O, I, T>>).init(instance as T, this) : undefined\n  };\n\n  private readonly closing = new Subject<void>();\n  readonly isClosing$ = this.closing.pipe(\n    first(),\n    map(() => true),\n    startWith(false),\n    shareReplay(1)\n  );\n  readonly closing$ = this.isClosing$.pipe(filter((x) => x));\n\n  private readonly _windowState = new BehaviorSubject<DbxPopupWindowState>(DbxPopupWindowState.NORMAL);\n  readonly windowState$ = this._windowState.asObservable();\n\n  getClosingValueFn?: (value?: I) => Promise<O>;\n\n  constructor(private popoverRef: NgPopoverRef<DbxPopupComponentConfig<O, I, T>, O>, private compactContextState: CompactContextStore, dbxRouterTransitionService: DbxRouterTransitionService, ngZone: NgZone) {\n    super(dbxRouterTransitionService, ngZone);\n\n    this.compactContextState.setMode(CompactMode.COMPACT);\n    this._position = new PopupGlobalPositionStrategy(this.config.position, this.config.offset);\n    this.popoverRef.overlay.updatePositionStrategy(this._position);\n  }\n\n  get config(): DbxPopupComponentConfig<O, I, T> {\n    return this.popoverRef.data;\n  }\n\n  get key(): DbxPopupKey {\n    return this.config.key;\n  }\n\n  get data(): Maybe<I> {\n    return this.config.data;\n  }\n\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    this.closing.complete();\n    this._windowState.complete();\n  }\n\n  protected updateForSuccessfulTransition(): void {\n    if (this.config.closeOnTransition !== false) {\n      this.close();\n    }\n  }\n\n  // Popup Controls\n  public close(): void {\n    this.closing.next();\n\n    if (this.getClosingValueFn) {\n      this.getClosingValueFn().then(\n        (x) => {\n          this.return(x);\n        },\n        () => {\n          this.return();\n        }\n      );\n    } else {\n      this.return();\n    }\n  }\n\n  public return(value?: O): void {\n    this.closing.next();\n    this.popoverRef.close(value);\n  }\n\n  public minimize(): void {\n    this.popoverRef.isDraggable = false;\n    this.popoverRef.resize(APP_POPUP_MINIMIZED_WIDTH, APP_POPUP_NORMAL_HEIGHT);\n    this.popoverRef.overlay.updatePosition();\n    this._windowState.next(DbxPopupWindowState.MINIMIZED);\n  }\n\n  public normalscreen(): void {\n    this.popoverRef.isDraggable = this.config.isDraggable;\n    this.popoverRef.resize(APP_POPUP_NORMAL_WIDTH, APP_POPUP_NORMAL_HEIGHT);\n    this.popoverRef.overlay.updatePosition();\n    this._windowState.next(DbxPopupWindowState.NORMAL);\n  }\n\n  public fullscreen(): void {\n    this.popoverRef.isDraggable = false;\n    this.popoverRef.resize('100%', '100%');\n    this.popoverRef.overlay.updatePosition();\n    this._windowState.next(DbxPopupWindowState.FULLSCREEN);\n  }\n}\n"]}
|
|
@@ -25,8 +25,8 @@ export class DbxPopupService {
|
|
|
25
25
|
position
|
|
26
26
|
},
|
|
27
27
|
configuration: {
|
|
28
|
-
width: APP_POPUP_NORMAL_WIDTH,
|
|
29
|
-
height: APP_POPUP_NORMAL_HEIGHT,
|
|
28
|
+
width: config.width ?? APP_POPUP_NORMAL_WIDTH,
|
|
29
|
+
height: config.height ?? APP_POPUP_NORMAL_HEIGHT,
|
|
30
30
|
useGlobalPositionStrategy: true,
|
|
31
31
|
hasBackdrop: false,
|
|
32
32
|
isResizable: false,
|
|
@@ -40,4 +40,4 @@ DbxPopupService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", vers
|
|
|
40
40
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: DbxPopupService, decorators: [{
|
|
41
41
|
type: Injectable
|
|
42
42
|
}], ctorParameters: function () { return [{ type: i1.Overlay }, { type: i0.Injector }]; } });
|
|
43
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
43
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9wdXAuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC13ZWIvc3JjL2xpYi9pbnRlcmFjdGlvbi9wb3B1cC9wb3B1cC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxpQkFBaUIsRUFBMkIsdUJBQXVCLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUNoSSxPQUFPLEVBQUUsVUFBVSxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNyRCxPQUFPLEVBQUUseUJBQXlCLEVBQWdCLE1BQU0sc0JBQXNCLENBQUM7QUFDL0UsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLHNCQUFzQixDQUFDOzs7QUFNL0M7O0dBRUc7QUFFSCxNQUFNLE9BQU8sZUFBZTtJQUcxQixZQUFvQixRQUFpQixFQUFVLFNBQW1CO1FBQTlDLGFBQVEsR0FBUixRQUFRLENBQVM7UUFBVSxjQUFTLEdBQVQsU0FBUyxDQUFVO1FBQ2hFLElBQUksQ0FBQyx3QkFBd0IsR0FBRyxJQUFJLHlCQUF5QixDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO0lBQy9GLENBQUM7SUFFRCxJQUFJLENBQVUsTUFBK0I7UUFDM0MsTUFBTSxPQUFPLEdBQUcsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsSUFBSSx5QkFBeUIsQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLHdCQUF3QixDQUFDO1FBQ2hJLE1BQU0sV0FBVyxHQUFHLE1BQU0sQ0FBQyxXQUFXLElBQUksS0FBSyxDQUFDO1FBQ2hELE1BQU0sUUFBUSxHQUFHLE1BQU0sQ0FBQyxRQUFRLElBQUksY0FBYyxDQUFDO1FBRW5ELE9BQU8sT0FBTyxDQUFDLElBQUksQ0FBc0M7WUFDdkQsT0FBTyxFQUFFLGlCQUFpQjtZQUMxQixJQUFJLEVBQUU7Z0JBQ0osR0FBRyxNQUFNO2dCQUNULFdBQVc7Z0JBQ1gsUUFBUTthQUNUO1lBQ0QsYUFBYSxFQUFFO2dCQUNiLEtBQUssRUFBRSxNQUFNLENBQUMsS0FBSyxJQUFJLHNCQUFzQjtnQkFDN0MsTUFBTSxFQUFFLE1BQU0sQ0FBQyxNQUFNLElBQUksdUJBQXVCO2dCQUNoRCx5QkFBeUIsRUFBRSxJQUFJO2dCQUMvQixXQUFXLEVBQUUsS0FBSztnQkFDbEIsV0FBVyxFQUFFLEtBQUs7Z0JBQ2xCLFdBQVc7YUFDWjtTQUNGLENBQUMsQ0FBQztJQUNMLENBQUM7OzRHQTVCVSxlQUFlO2dIQUFmLGVBQWU7MkZBQWYsZUFBZTtrQkFEM0IsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERieFBvcHVwQ29tcG9uZW50LCBEYnhQb3B1cENvbXBvbmVudENvbmZpZywgQVBQX1BPUFVQX05PUk1BTF9IRUlHSFQsIEFQUF9QT1BVUF9OT1JNQUxfV0lEVEggfSBmcm9tICcuL3BvcHVwLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBJbmplY3RhYmxlLCBJbmplY3RvciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTmdPdmVybGF5Q29udGFpbmVyU2VydmljZSwgTmdQb3BvdmVyUmVmIH0gZnJvbSAnbmctb3ZlcmxheS1jb250YWluZXInO1xuaW1wb3J0IHsgT3ZlcmxheSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9vdmVybGF5JztcblxuZXhwb3J0IGludGVyZmFjZSBEYnhQb3B1cENvbmZpZzxPLCBJLCBUPiBleHRlbmRzIERieFBvcHVwQ29tcG9uZW50Q29uZmlnPE8sIEksIFQ+IHtcbiAgaW5qZWN0b3I/OiBJbmplY3Rvcjtcbn1cblxuLyoqXG4gKiBVc2VkIGZvciBkaXNwbGF5aW5nIGEgcG9wdXAuXG4gKi9cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBEYnhQb3B1cFNlcnZpY2Uge1xuICBwcml2YXRlIF9vdmVybGF5Q29udGFpbmVyU2VydmljZTogTmdPdmVybGF5Q29udGFpbmVyU2VydmljZTtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIF9vdmVybGF5OiBPdmVybGF5LCBwcml2YXRlIF9pbmplY3RvcjogSW5qZWN0b3IpIHtcbiAgICB0aGlzLl9vdmVybGF5Q29udGFpbmVyU2VydmljZSA9IG5ldyBOZ092ZXJsYXlDb250YWluZXJTZXJ2aWNlKHRoaXMuX292ZXJsYXksIHRoaXMuX2luamVjdG9yKTtcbiAgfVxuXG4gIG9wZW48TywgSSwgVD4oY29uZmlnOiBEYnhQb3B1cENvbmZpZzxPLCBJLCBUPik6IE5nUG9wb3ZlclJlZjxEYnhQb3B1cENvbXBvbmVudENvbmZpZzxPLCBJLCBUPiwgTz4ge1xuICAgIGNvbnN0IHNlcnZpY2UgPSBjb25maWcuaW5qZWN0b3IgPyBuZXcgTmdPdmVybGF5Q29udGFpbmVyU2VydmljZSh0aGlzLl9vdmVybGF5LCBjb25maWcuaW5qZWN0b3IpIDogdGhpcy5fb3ZlcmxheUNvbnRhaW5lclNlcnZpY2U7XG4gICAgY29uc3QgaXNEcmFnZ2FibGUgPSBjb25maWcuaXNEcmFnZ2FibGUgPz8gZmFsc2U7XG4gICAgY29uc3QgcG9zaXRpb24gPSBjb25maWcucG9zaXRpb24gPz8gJ2JvdHRvbV9yaWdodCc7XG5cbiAgICByZXR1cm4gc2VydmljZS5vcGVuPERieFBvcHVwQ29tcG9uZW50Q29uZmlnPE8sIEksIFQ+LCBPPih7XG4gICAgICBjb250ZW50OiBEYnhQb3B1cENvbXBvbmVudCxcbiAgICAgIGRhdGE6IHtcbiAgICAgICAgLi4uY29uZmlnLFxuICAgICAgICBpc0RyYWdnYWJsZSxcbiAgICAgICAgcG9zaXRpb25cbiAgICAgIH0sXG4gICAgICBjb25maWd1cmF0aW9uOiB7XG4gICAgICAgIHdpZHRoOiBjb25maWcud2lkdGggPz8gQVBQX1BPUFVQX05PUk1BTF9XSURUSCxcbiAgICAgICAgaGVpZ2h0OiBjb25maWcuaGVpZ2h0ID8/IEFQUF9QT1BVUF9OT1JNQUxfSEVJR0hULFxuICAgICAgICB1c2VHbG9iYWxQb3NpdGlvblN0cmF0ZWd5OiB0cnVlLFxuICAgICAgICBoYXNCYWNrZHJvcDogZmFsc2UsXG4gICAgICAgIGlzUmVzaXphYmxlOiBmYWxzZSxcbiAgICAgICAgaXNEcmFnZ2FibGVcbiAgICAgIH1cbiAgICB9KTtcbiAgfVxufVxuIl19
|
|
@@ -25,12 +25,12 @@ export class DbxTwoColumnRightComponent {
|
|
|
25
25
|
}
|
|
26
26
|
ngAfterViewInit() {
|
|
27
27
|
setTimeout(() => {
|
|
28
|
-
this.twoColumnsContextStore.
|
|
28
|
+
this.twoColumnsContextStore.setHasRight(true);
|
|
29
29
|
});
|
|
30
30
|
}
|
|
31
31
|
ngOnDestroy() {
|
|
32
32
|
this._showBack.complete();
|
|
33
|
-
this.twoColumnsContextStore.
|
|
33
|
+
this.twoColumnsContextStore.setHasRight(false);
|
|
34
34
|
}
|
|
35
35
|
get showBack() {
|
|
36
36
|
return this._showBack.value;
|
|
@@ -67,4 +67,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImpor
|
|
|
67
67
|
}], minRightWidth: [{
|
|
68
68
|
type: Input
|
|
69
69
|
}] } });
|
|
70
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHdvLmNvbHVtbi5yaWdodC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvbGF5b3V0L2NvbHVtbi90d28vdHdvLmNvbHVtbi5yaWdodC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtd2ViL3NyYy9saWIvbGF5b3V0L2NvbHVtbi90d28vdHdvLmNvbHVtbi5yaWdodC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQTRCLFNBQVMsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ25GLE9BQU8sRUFBRSxlQUFlLEVBQWMsYUFBYSxFQUFFLEdBQUcsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUV2RSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQzs7Ozs7Ozs7QUFHNUQ7Ozs7R0FJRztBQVFILE1BQU0sT0FBTywwQkFBMEI7SUFnQnJDLFlBQTZELHNCQUE4QztRQUE5QywyQkFBc0IsR0FBdEIsc0JBQXNCLENBQXdCO1FBVG5HLGNBQVMsR0FBRyxJQUFJLGVBQWUsQ0FBVSxJQUFJLENBQUMsQ0FBQztRQUU5QyxTQUFJLEdBQXVDLElBQUksQ0FBQyxzQkFBc0IsQ0FBQyxRQUFRLENBQUM7UUFFaEYsY0FBUyxHQUF3QixhQUFhLENBQUM7WUFDdEQsSUFBSSxDQUFDLFNBQVM7WUFDZCxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQywwREFBMEQ7U0FDMUYsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQXFCLEVBQUUsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBRXlELENBQUM7SUFFL0csZUFBZTtRQUNiLFVBQVUsQ0FBQyxHQUFHLEVBQUU7WUFDZCxJQUFJLENBQUMsc0JBQXNCLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ2hELENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsU0FBUyxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQzFCLElBQUksQ0FBQyxzQkFBc0IsQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDakQsQ0FBQztJQUVELElBQ0ksUUFBUTtRQUNWLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUM7SUFDOUIsQ0FBQztJQUVELElBQUksUUFBUSxDQUFDLFFBQWlCO1FBQzVCLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ2hDLENBQUM7SUFFRDs7T0FFRztJQUNILElBQ0ksYUFBYSxDQUFDLGFBQWlDO1FBQ2pELElBQUksQ0FBQyxzQkFBc0IsQ0FBQyxnQkFBZ0IsQ0FBQyxPQUFPLGFBQWEsS0FBSyxRQUFRLENBQUMsQ0FBQyxDQUFDLGFBQWEsQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDOUcsQ0FBQztJQUVNLFdBQVc7UUFDaEIsSUFBSSxDQUFDLHNCQUFzQixDQUFDLElBQUksRUFBRSxDQUFDO0lBQ3JDLENBQUM7O3VIQWhEVSwwQkFBMEIsa0JBZ0JqQixzQkFBc0I7MkdBaEIvQiwwQkFBMEIsME5DbEJ2QyxtM0JBc0JBOzJGREphLDBCQUEwQjtrQkFQdEMsU0FBUzsrQkFDRSxzQkFBc0IsUUFFMUI7d0JBQ0osS0FBSyxFQUFFLDhCQUE4QjtxQkFDdEM7OzBCQWtCWSxNQUFNOzJCQUFDLHNCQUFzQjs0Q0FkMUMsTUFBTTtzQkFETCxLQUFLO2dCQUlOLEtBQUs7c0JBREosS0FBSztnQkEwQkYsUUFBUTtzQkFEWCxLQUFLO2dCQWFGLGFBQWE7c0JBRGhCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBZnRlclZpZXdJbml0LCBPbkRlc3Ryb3ksIENvbXBvbmVudCwgSW5qZWN0LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQmVoYXZpb3JTdWJqZWN0LCBPYnNlcnZhYmxlLCBjb21iaW5lTGF0ZXN0LCBtYXAgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IENsaWNrYWJsZUFuY2hvciB9IGZyb20gJ0BkZXJlZWtiL2RieC1jb3JlJztcbmltcG9ydCB7IFR3b0NvbHVtbnNDb250ZXh0U3RvcmUgfSBmcm9tICcuL3R3by5jb2x1bW4uc3RvcmUnO1xuaW1wb3J0IHsgTWF5YmUgfSBmcm9tICdAZGVyZWVrYi91dGlsJztcblxuLyoqXG4gKiBPcHRpb25hbCByZXNwb25zaXZlIGNvbXBvbmVudCB0aGF0IHdyYXBzIGNvbnRlbnQgb24gdGhlIHJpZ2h0IHNpZGUgYW5kIHNob3dzIGEgbmF2aWdhdGlvbiBiYXIuXG4gKlxuICogV2hlbiByZW5kZXJlZCBpdCB3aWxsIHRyaWdnZXIgdGhlIGNvbnRleHQgdG8gc2hvdyBsZWZ0LlxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdkYngtdHdvLWNvbHVtbi1yaWdodCcsXG4gIHRlbXBsYXRlVXJsOiAnLi90d28uY29sdW1uLnJpZ2h0LmNvbXBvbmVudC5odG1sJyxcbiAgaG9zdDoge1xuICAgIGNsYXNzOiAnZGJ4LXR3by1jb2x1bW4tcmlnaHQgZC1ibG9jaydcbiAgfVxufSlcbmV4cG9ydCBjbGFzcyBEYnhUd29Db2x1bW5SaWdodENvbXBvbmVudCBpbXBsZW1lbnRzIEFmdGVyVmlld0luaXQsIE9uRGVzdHJveSB7XG4gIEBJbnB1dCgpXG4gIGhlYWRlcj86IHN0cmluZztcblxuICBASW5wdXQoKVxuICBibG9jaz86IGJvb2xlYW47XG5cbiAgcHJpdmF0ZSBfc2hvd0JhY2sgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PGJvb2xlYW4+KHRydWUpO1xuXG4gIHJlYWRvbmx5IHJlZiQ6IE9ic2VydmFibGU8TWF5YmU8Q2xpY2thYmxlQW5jaG9yPj4gPSB0aGlzLnR3b0NvbHVtbnNDb250ZXh0U3RvcmUuYmFja1JlZiQ7XG5cbiAgcmVhZG9ubHkgc2hvd0JhY2skOiBPYnNlcnZhYmxlPGJvb2xlYW4+ID0gY29tYmluZUxhdGVzdChbXG4gICAgdGhpcy5fc2hvd0JhY2ssXG4gICAgdGhpcy5yZWYkLnBpcGUobWFwKCh4KSA9PiAheCkpIC8vIFRPRE86IElzIHRoaXMgY29ycmVjdD8gU2hvdyBiYWNrIGlmIHJlZiBpcyBub3QgZGVmaW5lZD9cbiAgXSkucGlwZShtYXAoKFthLCBiXTogW2Jvb2xlYW4sIGJvb2xlYW5dKSA9PiBhICYmIGIpKTtcblxuICBjb25zdHJ1Y3RvcihASW5qZWN0KFR3b0NvbHVtbnNDb250ZXh0U3RvcmUpIHByaXZhdGUgcmVhZG9ubHkgdHdvQ29sdW1uc0NvbnRleHRTdG9yZTogVHdvQ29sdW1uc0NvbnRleHRTdG9yZSkge31cblxuICBuZ0FmdGVyVmlld0luaXQoKTogdm9pZCB7XG4gICAgc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICB0aGlzLnR3b0NvbHVtbnNDb250ZXh0U3RvcmUuc2V0SGFzUmlnaHQodHJ1ZSk7XG4gICAgfSk7XG4gIH1cblxuICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICB0aGlzLl9zaG93QmFjay5jb21wbGV0ZSgpO1xuICAgIHRoaXMudHdvQ29sdW1uc0NvbnRleHRTdG9yZS5zZXRIYXNSaWdodChmYWxzZSk7XG4gIH1cblxuICBASW5wdXQoKVxuICBnZXQgc2hvd0JhY2soKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHRoaXMuX3Nob3dCYWNrLnZhbHVlO1xuICB9XG5cbiAgc2V0IHNob3dCYWNrKHNob3dCYWNrOiBib29sZWFuKSB7XG4gICAgdGhpcy5fc2hvd0JhY2submV4dChzaG93QmFjayk7XG4gIH1cblxuICAvKipcbiAgICogTWluaW11bSByaWdodC1zaWRlIHdpZHRoIGFsbG93ZWQgaW4gcGl4ZWxzLlxuICAgKi9cbiAgQElucHV0KClcbiAgc2V0IG1pblJpZ2h0V2lkdGgobWluUmlnaHRXaWR0aDogTWF5YmU8bnVtYmVyIHwgJyc+KSB7XG4gICAgdGhpcy50d29Db2x1bW5zQ29udGV4dFN0b3JlLnNldE1pblJpZ2h0V2lkdGgodHlwZW9mIG1pblJpZ2h0V2lkdGggPT09ICdudW1iZXInID8gbWluUmlnaHRXaWR0aCA6IHVuZGVmaW5lZCk7XG4gIH1cblxuICBwdWJsaWMgYmFja0NsaWNrZWQoKTogdm9pZCB7XG4gICAgdGhpcy50d29Db2x1bW5zQ29udGV4dFN0b3JlLmJhY2soKTtcbiAgfVxufVxuIiwiPGRieC10d28tY29sdW1uLWhlYWQgW2Jsb2NrXT1cImJsb2NrXCIgW2Z1bGxdPVwidHJ1ZVwiPlxuICA8IS0tIEJhY2sgQnV0dG9ucyAtLT5cbiAgPG5nLWNvbnRhaW5lciAqbmdJZj1cInNob3dCYWNrJCB8IGFzeW5jXCI+XG4gICAgPGJ1dHRvbiBtYXQtaWNvbi1idXR0b24gY2xhc3M9XCJiYWNrLWJ1dHRvblwiIChjbGljayk9XCJiYWNrQ2xpY2tlZCgpXCIgYXJpYS1sYWJlbD1cImJhY2sgYnV0dG9uXCI+XG4gICAgICA8bWF0LWljb24+bmF2aWdhdGVfYmVmb3JlPC9tYXQtaWNvbj5cbiAgICA8L2J1dHRvbj5cbiAgPC9uZy1jb250YWluZXI+XG4gIDxuZy1jb250YWluZXIgKm5nSWY9XCJyZWYkIHwgYXN5bmNcIj5cbiAgICA8ZGJ4LWFuY2hvciBbYW5jaG9yXT1cInJlZiQgfCBhc3luY1wiPlxuICAgICAgPGJ1dHRvbiBtYXQtaWNvbi1idXR0b24gY2xhc3M9XCJiYWNrLWJ1dHRvblwiIGFyaWEtbGFiZWw9XCJiYWNrIGJ1dHRvblwiPlxuICAgICAgICA8bWF0LWljb24+bmF2aWdhdGVfYmVmb3JlPC9tYXQtaWNvbj5cbiAgICAgIDwvYnV0dG9uPlxuICAgIDwvZGJ4LWFuY2hvcj5cbiAgPC9uZy1jb250YWluZXI+XG4gIDxzcGFuICpuZ0lmPVwiaGVhZGVyXCIgY2xhc3M9XCJyaWdodC1uYXYtdGl0bGVcIj57eyBoZWFkZXIgfX08L3NwYW4+XG4gIDxzcGFuIGNsYXNzPVwicmlnaHQtbmF2LXNwYWNlclwiPjwvc3Bhbj5cbiAgPHNwYW4gY2xhc3M9XCJzcGFjZXJcIj48L3NwYW4+XG4gIDxuZy1jb250ZW50IHNlbGVjdD1cIltuYXZdXCI+PC9uZy1jb250ZW50PlxuPC9kYngtdHdvLWNvbHVtbi1oZWFkPlxuPGRpdiBjbGFzcz1cImRieC10d28tY29sdW1uLXJpZ2h0LWNvbnRlbnRcIj5cbiAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuPC9kaXY+XG4iXX0=
|
|
@@ -7,6 +7,7 @@ export const DEFAULT_TWO_COLUMNS_MIN_RIGHT_WIDTH = 320;
|
|
|
7
7
|
const INITIAL_STATE = {
|
|
8
8
|
reverseSizing: false,
|
|
9
9
|
showRight: false,
|
|
10
|
+
hasRight: false,
|
|
10
11
|
fullLeft: false,
|
|
11
12
|
minRightWidth: DEFAULT_TWO_COLUMNS_MIN_RIGHT_WIDTH
|
|
12
13
|
};
|
|
@@ -30,11 +31,19 @@ export class TwoColumnsContextStore extends ComponentStore {
|
|
|
30
31
|
/**
|
|
31
32
|
* Pipes the current state of showRight.
|
|
32
33
|
*/
|
|
33
|
-
this.
|
|
34
|
+
this.hasRight$ = this.state$.pipe(map((x) => x.showRight));
|
|
35
|
+
/**
|
|
36
|
+
* Pipes the current state of showRight.
|
|
37
|
+
*/
|
|
38
|
+
this.currentShowRight$ = this.state$.pipe(map((x) => x.showRight));
|
|
39
|
+
/**
|
|
40
|
+
* Pipes the current state of showRight and hasRight
|
|
41
|
+
*/
|
|
42
|
+
this.showRight$ = this.state$.pipe(map((x) => x.hasRight && x.showRight));
|
|
34
43
|
/**
|
|
35
44
|
* Convenience function for the showRight compliment.
|
|
36
45
|
*/
|
|
37
|
-
this.hideRight$ = this.
|
|
46
|
+
this.hideRight$ = this.showRight$.pipe(map((x) => !x));
|
|
38
47
|
/**
|
|
39
48
|
* Pipes the current state of fullLeft.
|
|
40
49
|
*/
|
|
@@ -42,7 +51,7 @@ export class TwoColumnsContextStore extends ComponentStore {
|
|
|
42
51
|
/**
|
|
43
52
|
* Whether or not to show the full left.
|
|
44
53
|
*/
|
|
45
|
-
this.showFullLeft$ = this.state$.pipe(map((x) => !x.showRight && x.fullLeft));
|
|
54
|
+
this.showFullLeft$ = this.state$.pipe(map((x) => !(x.hasRight && x.showRight) && x.fullLeft));
|
|
46
55
|
/**
|
|
47
56
|
* Pipes the current backRef value.
|
|
48
57
|
*/
|
|
@@ -60,6 +69,10 @@ export class TwoColumnsContextStore extends ComponentStore {
|
|
|
60
69
|
* Changes the state to show right or not.
|
|
61
70
|
*/
|
|
62
71
|
this.setReverseSizing = this.updater((state, reverseSizing) => (isMaybeNot(reverseSizing) ? state : { ...state, reverseSizing }));
|
|
72
|
+
/**
|
|
73
|
+
* Changes the state to have right content or not.
|
|
74
|
+
*/
|
|
75
|
+
this.setHasRight = this.updater((state, hasRight) => (isMaybeNot(hasRight) ? state : { ...state, hasRight }));
|
|
63
76
|
/**
|
|
64
77
|
* Changes the state to show right or not.
|
|
65
78
|
*/
|
|
@@ -106,4 +119,4 @@ export function provideTwoColumnsContext() {
|
|
|
106
119
|
}
|
|
107
120
|
];
|
|
108
121
|
}
|
|
109
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"two.column.store.js","sourceRoot":"","sources":["../../../../../../../../packages/dbx-web/src/lib/layout/column/two/two.column.store.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAuB,MAAM,eAAe,CAAC;AAChE,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AACvD,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,GAAG,EAAE,MAAM,MAAM,CAAC;AAE9C,OAAO,EAAE,UAAU,EAAS,MAAM,eAAe,CAAC;;AA6BlD,MAAM,CAAC,MAAM,mCAAmC,GAAG,GAAG,CAAC;AAEvD,MAAM,aAAa,GAAoB;IACrC,aAAa,EAAE,KAAK;IACpB,SAAS,EAAE,KAAK;IAChB,QAAQ,EAAE,KAAK;IACf,aAAa,EAAE,mCAAmC;CACnD,CAAC;AAGF,MAAM,OAAO,sBAAuB,SAAQ,cAA+B;IAGzE;QACE,KAAK,CAAC,EAAE,GAAG,aAAa,EAAE,CAAC,CAAC;QAHb,UAAK,GAAG,IAAI,OAAO,EAAQ,CAAC;QAM7C,kBAAkB;QACT,cAAS,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CACnC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;YACR;;eAEG;YACH,MAAM,kBAAkB,GAAG,CAAC,CAAC,CAAC,UAAU,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;YACnD,MAAM,QAAQ,GAAG,CAAC,CAAC,SAAS,IAAI,kBAAkB,GAAG,CAAC,CAAC,aAAa,CAAC;YACrE,OAAO,QAAQ,CAAC;QAClB,CAAC,CAAC,CACH,CAAC;QAEF;;WAEG;QACM,mBAAc,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC;QAExE;;WAEG;QACM,eAAU,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;QAEhE;;WAEG;QACM,eAAU,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;QAEjE;;WAEG;QACM,cAAS,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC;QAE9D;;WAEG;QACM,kBAAa,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS,IAAI,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC;QAElF;;WAEG;QACM,aAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAClC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,EACrB,QAAQ,EAAE,CACX,CAAC;QAEF;;WAEG;QACM,UAAK,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,CAAC;QAE3C,sBAAsB;QACtB;;WAEG;QACM,UAAK,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,GAAG,aAAa,EAAE,CAAC,CAAC,CAAC;QAE5D;;WAEG;QACM,qBAAgB,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,aAA6B,EAAE,EAAE,CAAC,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,GAAG,KAAK,EAAE,aAAa,EAAE,CAAC,CAAC,CAAC;QAEtJ;;WAEG;QACM,iBAAY,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,SAAyB,EAAE,EAAE,CAAC,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,GAAG,KAAK,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC;QAEtI;;WAEG;QACM,gBAAW,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,QAAwB,EAAE,EAAE,CAAC,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,GAAG,KAAK,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC;QAElI;;WAEG;QACM,eAAU,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,OAAwB,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,KAAK,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC;QAEjG;;WAEG;QACM,kBAAa,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,UAAyB,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,KAAK,EAAE,UAAU,EAAE,CAAC,CAAC,CAAC;QAExG;;WAEG;QACM,qBAAgB,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,aAA4B,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,KAAK,EAAE,aAAa,EAAE,aAAa,IAAI,mCAAmC,EAAE,CAAC,CAAC,CAAC;IAtFvK,CAAC;IAwFD;;OAEG;IACH,IAAI;QACF,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;IACpB,CAAC;IAED,iBAAiB;IACR,WAAW;QAClB,KAAK,CAAC,WAAW,EAAE,CAAC;QACpB,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;IACxB,CAAC;;mHAxGU,sBAAsB;uHAAtB,sBAAsB;2FAAtB,sBAAsB;kBADlC,UAAU;;AA4GX,MAAM,UAAU,wBAAwB;IACtC,OAAO;QACL;YACE,OAAO,EAAE,sBAAsB;YAC/B,QAAQ,EAAE,sBAAsB;SACjC;KACF,CAAC;AACJ,CAAC","sourcesContent":["import { Injectable, OnDestroy, Provider } from '@angular/core';\nimport { ComponentStore } from '@ngrx/component-store';\nimport { Subject, distinct, map } from 'rxjs';\nimport { SegueRef } from '@dereekb/dbx-core';\nimport { isMaybeNot, Maybe } from '@dereekb/util';\n\nexport interface TwoColumnsState {\n  /**\n   * Whether or not to reverse the sizing.\n   */\n  reverseSizing: boolean;\n  /**\n   * Whether or not the right side should be shown.\n   */\n  showRight: boolean;\n  /**\n   * Whether or not to allow the left to fill up the screen when no right is shown.\n   */\n  fullLeft: boolean;\n  /**\n   * Optional ref to use with TwoColumns that use an sref for the back button.\n   */\n  backRef?: Maybe<SegueRef>;\n  /**\n   * Size of the view's total width in pixels.\n   */\n  totalWidth?: Maybe<number>;\n  /**\n   * Minimum right side size allowed before hiding the left content.\n   */\n  minRightWidth: number;\n}\n\nexport const DEFAULT_TWO_COLUMNS_MIN_RIGHT_WIDTH = 320;\n\nconst INITIAL_STATE: TwoColumnsState = {\n  reverseSizing: false,\n  showRight: false,\n  fullLeft: false,\n  minRightWidth: DEFAULT_TWO_COLUMNS_MIN_RIGHT_WIDTH\n};\n\n@Injectable()\nexport class TwoColumnsContextStore extends ComponentStore<TwoColumnsState> implements OnDestroy {\n  private readonly _back = new Subject<void>();\n\n  constructor() {\n    super({ ...INITIAL_STATE });\n  }\n\n  // MARK: Accessors\n  readonly hideLeft$ = this.state$.pipe(\n    map((x) => {\n      /**\n       * The right side is less-than or equal to half the total width when resizing, so we can use the total width to guess the best case current scenario.\n       */\n      const expectedRightWidth = (x.totalWidth ?? 0) / 2;\n      const hideLeft = x.showRight && expectedRightWidth < x.minRightWidth;\n      return hideLeft;\n    })\n  );\n\n  /**\n   * Pipes the current state of reverseSizing.\n   */\n  readonly reverseSizing$ = this.state$.pipe(map((x) => x.reverseSizing));\n\n  /**\n   * Pipes the current state of showRight.\n   */\n  readonly showRight$ = this.state$.pipe(map((x) => x.showRight));\n\n  /**\n   * Convenience function for the showRight compliment.\n   */\n  readonly hideRight$ = this.state$.pipe(map((x) => !x.showRight));\n\n  /**\n   * Pipes the current state of fullLeft.\n   */\n  readonly fullLeft$ = this.state$.pipe(map((x) => x.fullLeft));\n\n  /**\n   * Whether or not to show the full left.\n   */\n  readonly showFullLeft$ = this.state$.pipe(map((x) => !x.showRight && x.fullLeft));\n\n  /**\n   * Pipes the current backRef value.\n   */\n  readonly backRef$ = this.state$.pipe(\n    map((x) => x.backRef),\n    distinct()\n  );\n\n  /**\n   * Emits back events.\n   */\n  readonly back$ = this._back.asObservable();\n\n  // MARK: State Changes\n  /**\n   * Completely resets the store.\n   */\n  readonly reset = this.updater(() => ({ ...INITIAL_STATE }));\n\n  /**\n   * Changes the state to show right or not.\n   */\n  readonly setReverseSizing = this.updater((state, reverseSizing: Maybe<boolean>) => (isMaybeNot(reverseSizing) ? state : { ...state, reverseSizing }));\n\n  /**\n   * Changes the state to show right or not.\n   */\n  readonly setShowRight = this.updater((state, showRight: Maybe<boolean>) => (isMaybeNot(showRight) ? state : { ...state, showRight }));\n\n  /**\n   * Sets the full left. If undefined is passed, no change occurs.\n   */\n  readonly setFullLeft = this.updater((state, fullLeft: Maybe<boolean>) => (isMaybeNot(fullLeft) ? state : { ...state, fullLeft }));\n\n  /**\n   * Sets the new back ref.\n   */\n  readonly setBackRef = this.updater((state, backRef: Maybe<SegueRef>) => ({ ...state, backRef }));\n\n  /**\n   * Sets the new total width.\n   */\n  readonly setTotalWidth = this.updater((state, totalWidth: Maybe<number>) => ({ ...state, totalWidth }));\n\n  /**\n   * Sets the new min right width.\n   */\n  readonly setMinRightWidth = this.updater((state, minRightWidth: Maybe<number>) => ({ ...state, minRightWidth: minRightWidth ?? DEFAULT_TWO_COLUMNS_MIN_RIGHT_WIDTH }));\n\n  /**\n   * Emits a back event.\n   */\n  back(): void {\n    this._back.next();\n  }\n\n  // MARK: Internal\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    this._back.complete();\n  }\n}\n\nexport function provideTwoColumnsContext(): Provider[] {\n  return [\n    {\n      provide: TwoColumnsContextStore,\n      useClass: TwoColumnsContextStore\n    }\n  ];\n}\n"]}
|
|
122
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"two.column.store.js","sourceRoot":"","sources":["../../../../../../../../packages/dbx-web/src/lib/layout/column/two/two.column.store.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, OnDestroy, Provider } from '@angular/core';\nimport { ComponentStore } from '@ngrx/component-store';\nimport { Subject, distinct, map } from 'rxjs';\nimport { SegueRef } from '@dereekb/dbx-core';\nimport { isMaybeNot, Maybe } from '@dereekb/util';\n\nexport interface TwoColumnsState {\n  /**\n   * Whether or not to reverse the sizing.\n   */\n  reverseSizing: boolean;\n  /**\n   * Whether or not the right side should be shown.\n   */\n  showRight: boolean;\n  /**\n   * Whether or not there is any registered right content currently.\n   */\n  hasRight: boolean;\n  /**\n   * Whether or not to allow the left to fill up the screen when no right is shown.\n   */\n  fullLeft: boolean;\n  /**\n   * Optional ref to use with TwoColumns that use an sref for the back button.\n   */\n  backRef?: Maybe<SegueRef>;\n  /**\n   * Size of the view's total width in pixels.\n   */\n  totalWidth?: Maybe<number>;\n  /**\n   * Minimum right side size allowed before hiding the left content.\n   */\n  minRightWidth: number;\n}\n\nexport const DEFAULT_TWO_COLUMNS_MIN_RIGHT_WIDTH = 320;\n\nconst INITIAL_STATE: TwoColumnsState = {\n  reverseSizing: false,\n  showRight: false,\n  hasRight: false,\n  fullLeft: false,\n  minRightWidth: DEFAULT_TWO_COLUMNS_MIN_RIGHT_WIDTH\n};\n\n@Injectable()\nexport class TwoColumnsContextStore extends ComponentStore<TwoColumnsState> implements OnDestroy {\n  private readonly _back = new Subject<void>();\n\n  constructor() {\n    super({ ...INITIAL_STATE });\n  }\n\n  // MARK: Accessors\n  readonly hideLeft$ = this.state$.pipe(\n    map((x) => {\n      /**\n       * The right side is less-than or equal to half the total width when resizing, so we can use the total width to guess the best case current scenario.\n       */\n      const expectedRightWidth = (x.totalWidth ?? 0) / 2;\n      const hideLeft = x.showRight && expectedRightWidth < x.minRightWidth;\n      return hideLeft;\n    })\n  );\n\n  /**\n   * Pipes the current state of reverseSizing.\n   */\n  readonly reverseSizing$ = this.state$.pipe(map((x) => x.reverseSizing));\n\n  /**\n   * Pipes the current state of showRight.\n   */\n  readonly hasRight$ = this.state$.pipe(map((x) => x.showRight));\n\n  /**\n   * Pipes the current state of showRight.\n   */\n  readonly currentShowRight$ = this.state$.pipe(map((x) => x.showRight));\n\n  /**\n   * Pipes the current state of showRight and hasRight\n   */\n  readonly showRight$ = this.state$.pipe(map((x) => x.hasRight && x.showRight));\n\n  /**\n   * Convenience function for the showRight compliment.\n   */\n  readonly hideRight$ = this.showRight$.pipe(map((x) => !x));\n\n  /**\n   * Pipes the current state of fullLeft.\n   */\n  readonly fullLeft$ = this.state$.pipe(map((x) => x.fullLeft));\n\n  /**\n   * Whether or not to show the full left.\n   */\n  readonly showFullLeft$ = this.state$.pipe(map((x) => !(x.hasRight && x.showRight) && x.fullLeft));\n\n  /**\n   * Pipes the current backRef value.\n   */\n  readonly backRef$ = this.state$.pipe(\n    map((x) => x.backRef),\n    distinct()\n  );\n\n  /**\n   * Emits back events.\n   */\n  readonly back$ = this._back.asObservable();\n\n  // MARK: State Changes\n  /**\n   * Completely resets the store.\n   */\n  readonly reset = this.updater(() => ({ ...INITIAL_STATE }));\n\n  /**\n   * Changes the state to show right or not.\n   */\n  readonly setReverseSizing = this.updater((state, reverseSizing: Maybe<boolean>) => (isMaybeNot(reverseSizing) ? state : { ...state, reverseSizing }));\n\n  /**\n   * Changes the state to have right content or not.\n   */\n  readonly setHasRight = this.updater((state, hasRight: Maybe<boolean>) => (isMaybeNot(hasRight) ? state : { ...state, hasRight }));\n\n  /**\n   * Changes the state to show right or not.\n   */\n  readonly setShowRight = this.updater((state, showRight: Maybe<boolean>) => (isMaybeNot(showRight) ? state : { ...state, showRight }));\n\n  /**\n   * Sets the full left. If undefined is passed, no change occurs.\n   */\n  readonly setFullLeft = this.updater((state, fullLeft: Maybe<boolean>) => (isMaybeNot(fullLeft) ? state : { ...state, fullLeft }));\n\n  /**\n   * Sets the new back ref.\n   */\n  readonly setBackRef = this.updater((state, backRef: Maybe<SegueRef>) => ({ ...state, backRef }));\n\n  /**\n   * Sets the new total width.\n   */\n  readonly setTotalWidth = this.updater((state, totalWidth: Maybe<number>) => ({ ...state, totalWidth }));\n\n  /**\n   * Sets the new min right width.\n   */\n  readonly setMinRightWidth = this.updater((state, minRightWidth: Maybe<number>) => ({ ...state, minRightWidth: minRightWidth ?? DEFAULT_TWO_COLUMNS_MIN_RIGHT_WIDTH }));\n\n  /**\n   * Emits a back event.\n   */\n  back(): void {\n    this._back.next();\n  }\n\n  // MARK: Internal\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    this._back.complete();\n  }\n}\n\nexport function provideTwoColumnsContext(): Provider[] {\n  return [\n    {\n      provide: TwoColumnsContextStore,\n      useClass: TwoColumnsContextStore\n    }\n  ];\n}\n"]}
|
|
@@ -2458,6 +2458,7 @@ const DEFAULT_TWO_COLUMNS_MIN_RIGHT_WIDTH = 320;
|
|
|
2458
2458
|
const INITIAL_STATE = {
|
|
2459
2459
|
reverseSizing: false,
|
|
2460
2460
|
showRight: false,
|
|
2461
|
+
hasRight: false,
|
|
2461
2462
|
fullLeft: false,
|
|
2462
2463
|
minRightWidth: DEFAULT_TWO_COLUMNS_MIN_RIGHT_WIDTH
|
|
2463
2464
|
};
|
|
@@ -2482,11 +2483,19 @@ class TwoColumnsContextStore extends ComponentStore {
|
|
|
2482
2483
|
/**
|
|
2483
2484
|
* Pipes the current state of showRight.
|
|
2484
2485
|
*/
|
|
2485
|
-
this.
|
|
2486
|
+
this.hasRight$ = this.state$.pipe(map((x) => x.showRight));
|
|
2487
|
+
/**
|
|
2488
|
+
* Pipes the current state of showRight.
|
|
2489
|
+
*/
|
|
2490
|
+
this.currentShowRight$ = this.state$.pipe(map((x) => x.showRight));
|
|
2491
|
+
/**
|
|
2492
|
+
* Pipes the current state of showRight and hasRight
|
|
2493
|
+
*/
|
|
2494
|
+
this.showRight$ = this.state$.pipe(map((x) => x.hasRight && x.showRight));
|
|
2486
2495
|
/**
|
|
2487
2496
|
* Convenience function for the showRight compliment.
|
|
2488
2497
|
*/
|
|
2489
|
-
this.hideRight$ = this.
|
|
2498
|
+
this.hideRight$ = this.showRight$.pipe(map((x) => !x));
|
|
2490
2499
|
/**
|
|
2491
2500
|
* Pipes the current state of fullLeft.
|
|
2492
2501
|
*/
|
|
@@ -2494,7 +2503,7 @@ class TwoColumnsContextStore extends ComponentStore {
|
|
|
2494
2503
|
/**
|
|
2495
2504
|
* Whether or not to show the full left.
|
|
2496
2505
|
*/
|
|
2497
|
-
this.showFullLeft$ = this.state$.pipe(map((x) => !x.showRight && x.fullLeft));
|
|
2506
|
+
this.showFullLeft$ = this.state$.pipe(map((x) => !(x.hasRight && x.showRight) && x.fullLeft));
|
|
2498
2507
|
/**
|
|
2499
2508
|
* Pipes the current backRef value.
|
|
2500
2509
|
*/
|
|
@@ -2512,6 +2521,10 @@ class TwoColumnsContextStore extends ComponentStore {
|
|
|
2512
2521
|
* Changes the state to show right or not.
|
|
2513
2522
|
*/
|
|
2514
2523
|
this.setReverseSizing = this.updater((state, reverseSizing) => (isMaybeNot(reverseSizing) ? state : Object.assign(Object.assign({}, state), { reverseSizing })));
|
|
2524
|
+
/**
|
|
2525
|
+
* Changes the state to have right content or not.
|
|
2526
|
+
*/
|
|
2527
|
+
this.setHasRight = this.updater((state, hasRight) => (isMaybeNot(hasRight) ? state : Object.assign(Object.assign({}, state), { hasRight })));
|
|
2515
2528
|
/**
|
|
2516
2529
|
* Changes the state to show right or not.
|
|
2517
2530
|
*/
|
|
@@ -2792,12 +2805,12 @@ class DbxTwoColumnRightComponent {
|
|
|
2792
2805
|
}
|
|
2793
2806
|
ngAfterViewInit() {
|
|
2794
2807
|
setTimeout(() => {
|
|
2795
|
-
this.twoColumnsContextStore.
|
|
2808
|
+
this.twoColumnsContextStore.setHasRight(true);
|
|
2796
2809
|
});
|
|
2797
2810
|
}
|
|
2798
2811
|
ngOnDestroy() {
|
|
2799
2812
|
this._showBack.complete();
|
|
2800
|
-
this.twoColumnsContextStore.
|
|
2813
|
+
this.twoColumnsContextStore.setHasRight(false);
|
|
2801
2814
|
}
|
|
2802
2815
|
get showBack() {
|
|
2803
2816
|
return this._showBack.value;
|
|
@@ -6847,7 +6860,7 @@ class DbxPopupService {
|
|
|
6847
6860
|
this._overlayContainerService = new NgOverlayContainerService(this._overlay, this._injector);
|
|
6848
6861
|
}
|
|
6849
6862
|
open(config) {
|
|
6850
|
-
var _a, _b;
|
|
6863
|
+
var _a, _b, _c, _d;
|
|
6851
6864
|
const service = config.injector ? new NgOverlayContainerService(this._overlay, config.injector) : this._overlayContainerService;
|
|
6852
6865
|
const isDraggable = (_a = config.isDraggable) !== null && _a !== void 0 ? _a : false;
|
|
6853
6866
|
const position = (_b = config.position) !== null && _b !== void 0 ? _b : 'bottom_right';
|
|
@@ -6856,8 +6869,8 @@ class DbxPopupService {
|
|
|
6856
6869
|
data: Object.assign(Object.assign({}, config), { isDraggable,
|
|
6857
6870
|
position }),
|
|
6858
6871
|
configuration: {
|
|
6859
|
-
width: APP_POPUP_NORMAL_WIDTH,
|
|
6860
|
-
height: APP_POPUP_NORMAL_HEIGHT,
|
|
6872
|
+
width: (_c = config.width) !== null && _c !== void 0 ? _c : APP_POPUP_NORMAL_WIDTH,
|
|
6873
|
+
height: (_d = config.height) !== null && _d !== void 0 ? _d : APP_POPUP_NORMAL_HEIGHT,
|
|
6861
6874
|
useGlobalPositionStrategy: true,
|
|
6862
6875
|
hasBackdrop: false,
|
|
6863
6876
|
isResizable: false,
|