@theseam/ui-common 0.3.9 → 0.3.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -51,13 +51,13 @@ export class SideNavComponent {
51
51
  this.hasHeaderToggle = true;
52
52
  this._items = new BehaviorSubject([]);
53
53
  this._expanded = new BehaviorSubject(true);
54
- this.expanded$ = this._expanded.asObservable().pipe(tap(expanded => this.toggleExpand.emit(expanded)));
54
+ this.expanded$ = this._expanded.asObservable();
55
55
  this._overlay = new BehaviorSubject(false);
56
56
  this.overlay$ = this._overlay.asObservable();
57
57
  this.toggleExpand = new EventEmitter();
58
58
  this._backdropHidden = new BehaviorSubject(true);
59
59
  this.items$ = this._items.asObservable().pipe(switchMap(items => this._sideNav.createItemsObservable(items)), shareReplay({ bufferSize: 1, refCount: true }));
60
- this.isMobile$ = this._layout.isMobile$.pipe(tap(isMobile => isMobile && this.collapse()));
60
+ this.isMobile$ = this._layout.isMobile$.pipe(tap(isMobile => isMobile ? this.collapse() : this.expand()));
61
61
  this.sideNavExpandedState$ = combineLatest([this.expanded$, this.overlay$]).pipe(map(([expanded, overlay]) => expanded
62
62
  ? overlay ? EXPANDED_OVERLAY_STATE : EXPANDED_STATE
63
63
  : overlay ? COLLAPSED_OVERLAY_STATE : COLLAPSED_STATE), distinctUntilChanged());
@@ -65,7 +65,14 @@ export class SideNavComponent {
65
65
  get items() { return this._items.value; }
66
66
  set items(value) { this._items.next(value); }
67
67
  get expanded() { return this._expanded.value; }
68
- set expanded(value) { this._expanded.next(coerceBooleanProperty(value)); }
68
+ set expanded(value) {
69
+ const expanded = coerceBooleanProperty(value);
70
+ let emit = expanded !== this.expanded;
71
+ this._expanded.next(expanded);
72
+ if (emit) {
73
+ this.toggleExpand.emit(coerceBooleanProperty(value));
74
+ }
75
+ }
69
76
  get overlay() { return this._overlay.value; }
70
77
  set overlay(value) { this._overlay.next(coerceBooleanProperty(value)); }
71
78
  ngOnInit() {
@@ -202,4 +209,4 @@ SideNavComponent.propDecorators = {
202
209
  __decorate([
203
210
  InputBoolean()
204
211
  ], SideNavComponent.prototype, "hasHeaderToggle", void 0);
205
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"side-nav.component.js","sourceRoot":"","sources":["../../../../../projects/ui-common/framework/side-nav/side-nav.component.ts"],"names":[],"mappings":";AAAA,OAAO,EACL,OAAO,EACP,YAAY,EACZ,KAAK,EACL,KAAK,EACL,KAAK,EACL,KAAK,EACL,UAAU,EACV,OAAO,EACR,MAAM,qBAAqB,CAAA;AAC5B,OAAO,EAAgB,qBAAqB,EAAE,MAAM,uBAAuB,CAAA;AAC3E,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,YAAY,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,EAAE,KAAK,EAAqB,QAAQ,EAAE,MAAM,EAAE,WAAW,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAA;AAEjN,OAAO,EAAE,eAAe,EAAE,aAAa,EAAc,OAAO,EAAE,MAAM,MAAM,CAAA;AAC1E,OAAO,EAAE,oBAAoB,EAAU,GAAG,EAAmB,WAAW,EAAa,SAAS,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAA;AAEtI,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAA;AACtD,OAAO,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAA;AAEhE,OAAO,EAAgD,uBAAuB,EAAE,MAAM,sBAAsB,CAAA;AAG5G,OAAO,EAAE,qBAAqB,EAAE,MAAM,oBAAoB,CAAA;AAC1D,OAAO,EAAE,gCAAgC,EAAE,MAAM,iEAAiE,CAAA;AAClH,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAA;AAEpD,MAAM,cAAc,GAAG,UAAU,CAAA;AACjC,MAAM,eAAe,GAAG,WAAW,CAAA;AAEnC,MAAM,sBAAsB,GAAG,kBAAkB,CAAA;AACjD,MAAM,uBAAuB,GAAG,mBAAmB,CAAA;AAEnD,MAAM,eAAe,GAAG,CAAE,cAAc,EAAE,sBAAsB,CAAE,CAAA;AAClE,MAAM,gBAAgB,GAAG,CAAE,eAAe,EAAE,uBAAuB,CAAE,CAAA;AACrE,MAAM,aAAa,GAAG,CAAE,GAAG,eAAe,EAAE,GAAG,gBAAgB,CAAE,CAAA;AAEjE,MAAM,UAAU,0BAA0B,CAAC,SAAiB,EAAE,OAAe;IAC3E,sCAAsC;IACtC,OAAO,SAAS,KAAK,OAAO;QAC1B;QACE,iEAAiE;QACjE,wEAAwE;QACxE,yEAAyE;QACzE,oEAAoE;QACpE,SAAS;QACT,EAAE;QACF,IAAI;QACJ,kEAAkE;QAClE,OAAO;QACP,kEAAkE;QAClE,IAAI;QACJ,KAAK;QACL,CACE,CAAC,eAAe,CAAC,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,IAAI,gBAAgB,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC;;gBAEvF,CAAC,eAAe,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,IAAI,gBAAgB,CAAC,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CACxF,CACF,CAAA;AACL,CAAC;AAqFD,MAAM,OAAO,gBAAgB;IA0C3B,YACmB,iBAAmC,EACnC,OAA6B,EAC7B,QAA+B,EACc,cAAqC;QAHlF,sBAAiB,GAAjB,iBAAiB,CAAkB;QACnC,YAAO,GAAP,OAAO,CAAsB;QAC7B,aAAQ,GAAR,QAAQ,CAAuB;QACc,mBAAc,GAAd,cAAc,CAAuB;QA3CpF,mBAAc,GAAG,IAAI,OAAO,EAAE,CAAA;QAE/C,iEAAiE;QACjE,kCAAkC;QAElC,+DAA+D;QAClC,mBAAc,GAAG,SAAS,CAAA;QAE9B,oBAAe,GAAG,IAAI,CAAA;QAKvC,WAAM,GAAG,IAAI,eAAe,CAAiB,EAAE,CAAC,CAAA;QAMhD,cAAS,GAAG,IAAI,eAAe,CAAU,IAAI,CAAC,CAAA;QACtC,cAAS,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,EAAE,CAAC,IAAI,CAC5D,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAClD,CAAA;QAKO,aAAQ,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAA;QACtC,aAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,YAAY,EAAE,CAAA;QAE7C,iBAAY,GAAG,IAAI,YAAY,EAAW,CAAA;QAI7C,oBAAe,GAAG,IAAI,eAAe,CAAU,IAAI,CAAC,CAAA;QAWzD,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC,IAAI,CAC3C,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,qBAAqB,CAAC,KAAK,CAAC,CAAC,EAC9D,WAAW,CAAC,EAAE,UAAU,EAAE,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAC/C,CAAA;QAED,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,IAAI,CAC1C,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC,CAC7C,CAAA;QAED,IAAI,CAAC,qBAAqB,GAAG,aAAa,CAAC,CAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,QAAQ,CAAE,CAAC,CAAC,IAAI,CAChF,GAAG,CAAC,CAAC,CAAE,QAAQ,EAAE,OAAO,CAAE,EAAE,EAAE,CAAC,QAAQ;YACrC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,sBAAsB,CAAC,CAAC,CAAC,cAAc;YACnD,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,uBAAuB,CAAC,CAAC,CAAC,eAAe,CACtD,EACD,oBAAoB,EAAE,CACvB,CAAA;IACH,CAAC;IAnDD,IACI,KAAK,KAAqB,OAAO,IAAI,CAAC,MAAM,CAAC,KAAK,CAAA,CAAC,CAAC;IACxD,IAAI,KAAK,CAAC,KAAqB,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA,CAAC,CAAC;IAI5D,IACI,QAAQ,KAAc,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,CAAA,CAAC,CAAC;IACvD,IAAI,QAAQ,CAAC,KAAc,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,qBAAqB,CAAC,KAAK,CAAC,CAAC,CAAA,CAAC,CAAC;IAMlF,IACI,OAAO,KAAc,OAAO,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAA,CAAC,CAAC;IACrD,IAAI,OAAO,CAAC,KAAc,IAAI,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,qBAAqB,CAAC,KAAK,CAAC,CAAC,CAAA,CAAC,CAAC;IAqChF,QAAQ;QACN,IAAI,IAAI,CAAC,cAAc,EAAE;YAAE,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,IAAI,CAAC,CAAA;SAAE;QAElE,IAAI,CAAC,SAAS;aACX,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;aACpC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC,CAAA;QAEnC,IAAI,CAAC,qBAAqB;aACvB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;aACpC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,cAAc,GAAG,CAAC,CAAC,CAAA;QAE1C,IAAI,IAAI,CAAC,iBAAiB,EAAE;YAC1B,IAAI,CAAC,oBAAoB,GAAG,IAAI,cAAc,CAAC,IAAI,CAAC,iBAAiB,EAAE,IAAI,CAAC,iBAAiB,CAAC,CAAA;SAC/F;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,CAAA;QAC1B,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE,CAAA;QAC9B,IAAI,IAAI,CAAC,cAAc,EAAE;YAAE,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC,IAAI,CAAC,CAAA;SAAE;IACtE,CAAC;IAEM,MAAM;QACX,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAA;IACtB,CAAC;IAEM,QAAQ;QACb,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAA;IACvB,CAAC;IAEM,MAAM;QACX,IAAI,CAAC,QAAQ,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAA;IAChC,CAAC;IAEM,YAAY;QACjB,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;SACjC;IACH,CAAC;IAEM,UAAU;QACf,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;SAChC;IACH,CAAC;;;YAjMF,SAAS,SAAC;gBACT,QAAQ,EAAE,eAAe;gBACzB,i6CAAwC;gBAExC,SAAS,EAAE;oBACT,qBAAqB;iBACtB;gBACD,UAAU,EAAE;oBAEV,EAAE;oBACF,wEAAwE;oBACxE,eAAe;oBACf,EAAE;oBAEF,OAAO,CAAC,aAAa,EAAE;wBACrB,UAAU,CAAC,0BAA0B,EAAE;4BACrC,KAAK,CAAC;gCACJ,KAAK,CAAC,kBAAkB,EAAE,YAAY,EAAE,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;gCAC7D,KAAK,CAAC,gBAAgB,EAAE,YAAY,EAAE,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;6BAC5D,CAAC;yBACH,CAAC;qBACH,CAAC;oBAEF,OAAO,CAAC,iBAAiB,EAAE;wBACzB,KAAK,CAAC,sBAAsB,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,CAAC;wBACtD,KAAK,CAAC,uBAAuB,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,CAAC;wBAEvD,wDAAwD;wBACxD,0EAA0E;wBAC1E,iBAAiB;wBACjB,UAAU;wBAEV,UAAU,CAAC,0BAA0B,EAAE,OAAO,CAAC,kBAAkB,CAAC,CAAC;qBACpE,CAAC;oBAEF,OAAO,CAAC,eAAe,EAAE;wBACvB,iCAAiC;wBACjC,KAAK,CAAC,cAAc,EAAE,KAAK,CAAC,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,CAAC;wBAChD,KAAK,CAAC,eAAe,EAAE,KAAK,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,QAAQ,EAAE,CAAC,CAAC;wBAExE,KAAK,CAAC,sBAAsB,EAAE,KAAK,CAAC;4BAClC,QAAQ,EAAE,UAAU;4BACpB,GAAG,EAAE,CAAC;4BACN,MAAM,EAAE,MAAM;4BACd,MAAM,EAAE,CAAC;4BACT,IAAI,EAAE,CAAC;4BACP,KAAK,EAAE,MAAM;4BACb,MAAM,EAAE,MAAM;4BACd,KAAK,EAAE,oBAAoB;4BAC3B,SAAS,EAAE,eAAe;yBAC3B,CAAC,CAAC;wBACH,KAAK,CAAC,uBAAuB,EAAE,KAAK,CAAC;4BACnC,QAAQ,EAAE,UAAU;4BACpB,GAAG,EAAE,CAAC;4BACN,MAAM,EAAE,MAAM;4BACd,MAAM,EAAE,CAAC;4BACT,IAAI,EAAE,CAAC;4BACP,KAAK,EAAE,MAAM;4BACb,MAAM,EAAE,MAAM;4BACd,KAAK,EAAE,oBAAoB;4BAC3B,SAAS,EAAE,iCAAiC;4BAC5C,YAAY,EAAE,QAAQ;yBACvB,CAAC,CAAC;wBAEH,uFAAuF;wBAEvF,UAAU,CAAC,0BAA0B,EAAE,OAAO,CAAC,kBAAkB,CAAC,CAAC;wBAEnE,2DAA2D;wBAC3D,4DAA4D;wBAC5D,4DAA4D;wBAC5D,YAAY;wBACZ,2DAA2D;wBAC3D,2DAA2D;wBAC3D,iEAAiE;wBACjE,kCAAkC;wBAClC,OAAO;wBACP,MAAM;qBACP,CAAC;iBACH;gBACD,eAAe,EAAE,uBAAuB,CAAC,MAAM;gBAC/C,aAAa,EAAE,iBAAiB,CAAC,IAAI;;aACtC;;;YAnIsJ,gBAAgB;YAM9J,oBAAoB;YAKpB,qBAAqB;4CAuKzB,QAAQ,YAAI,MAAM,SAAC,uBAAuB;;;6BArC5C,WAAW,SAAC,cAAc;8BAE1B,KAAK;oBAEL,KAAK;uBAML,KAAK;sBAQL,KAAK;2BAML,MAAM;gCAMN,YAAY,SAAC,gCAAgC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,WAAW,EAAE;;AA5B1D;IAAf,YAAY,EAAE;yDAAuB","sourcesContent":["import {\n  animate,\n  animateChild,\n  group,\n  query,\n  state,\n  style,\n  transition,\n  trigger\n} from '@angular/animations'\nimport { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion'\nimport { ChangeDetectionStrategy, Component, ContentChild, EventEmitter, HostBinding, Inject, Input, OnDestroy, OnInit, Optional, Output, TemplateRef, ViewContainerRef, ViewEncapsulation } from '@angular/core'\nimport { ActivatedRoute, NavigationEnd, Router } from '@angular/router'\nimport { BehaviorSubject, combineLatest, Observable, Subject } from 'rxjs'\nimport { distinctUntilChanged, filter, map, mapTo, pairwise, shareReplay, startWith, switchMap, takeUntil, tap } from 'rxjs/operators'\n\nimport { InputBoolean } from '@theseam/ui-common/core'\nimport { TheSeamLayoutService } from '@theseam/ui-common/layout'\n\nimport { ITheSeamBaseLayoutNav, ITheSeamBaseLayoutRef, THESEAM_BASE_LAYOUT_REF } from '../base-layout/index'\n\nimport { ISideNavItem } from './side-nav.models'\nimport { TheSeamSideNavService } from './side-nav.service'\nimport { BaseLayoutSideBarFooterDirective } from '../base-layout/directives/base-layout-side-bar-footer.directive'\nimport { TemplatePortal } from '@angular/cdk/portal'\n\nconst EXPANDED_STATE = 'expanded'\nconst COLLAPSED_STATE = 'collapsed'\n\nconst EXPANDED_OVERLAY_STATE = 'expanded-overlay'\nconst COLLAPSED_OVERLAY_STATE = 'collapsed-overlay'\n\nconst EXPANDED_STATES = [ EXPANDED_STATE, EXPANDED_OVERLAY_STATE ]\nconst COLLAPSED_STATES = [ COLLAPSED_STATE, COLLAPSED_OVERLAY_STATE ]\nconst EXPAND_STATES = [ ...EXPANDED_STATES, ...COLLAPSED_STATES ]\n\nexport function sideNavExpandStateChangeFn(fromState: string, toState: string) {\n  // console.log({ fromState, toState })\n  return fromState !== toState &&\n    (\n      // NOTE: The current way the side nav is being used it causes the\n      // component to sometimes get placed in the wrong location initially. It\n      // is fast enough to not be noticed without an initial animation usually,\n      // so it is commented out below until the initial placement issue it\n      // fixed.\n      //\n      // (\n      //   fromState === 'void' && EXPAND_STATES.indexOf(toState) !== -1\n      //   ||\n      //   toState === 'void' && EXPAND_STATES.indexOf(fromState) !== -1\n      // )\n      // ||\n      (\n        (EXPANDED_STATES.indexOf(fromState) !== -1 && COLLAPSED_STATES.indexOf(toState) !== -1)\n        ||\n        (EXPANDED_STATES.indexOf(toState) !== -1 && COLLAPSED_STATES.indexOf(fromState) !== -1)\n      )\n    )\n}\n\n@Component({\n  selector: 'seam-side-nav',\n  templateUrl: './side-nav.component.html',\n  styleUrls: ['./side-nav.component.scss'],\n  providers: [\n    TheSeamSideNavService\n  ],\n  animations: [\n\n    //\n    // TODO: This animation code turned into a mess. Clean it up and make it\n    // more smooth.\n    //\n\n    trigger('sideNavAnim', [\n      transition(sideNavExpandStateChangeFn, [\n        group([\n          query('@sideNavBackdrop', animateChild(), { optional: true }),\n          query('@sideNavExpand', animateChild(), { optional: true }),\n        ]),\n      ]),\n    ]),\n\n    trigger('sideNavBackdrop', [\n      state(EXPANDED_OVERLAY_STATE, style({ opacity: '1' })),\n      state(COLLAPSED_OVERLAY_STATE, style({ opacity: '0' })),\n\n      // transition((fromState, toState, element, params) => {\n      //   console.log('sideNavBackdrop v', fromState, toState, element, params)\n      //   return false\n      // }, []),\n\n      transition(sideNavExpandStateChangeFn, animate('0.2s ease-in-out')),\n    ]),\n\n    trigger('sideNavExpand', [\n      // TODO: Make width configurable.\n      state(EXPANDED_STATE, style({ width: '260px' })),\n      state(COLLAPSED_STATE, style({ width: '50px', 'overflow-x': 'hidden' })),\n\n      state(EXPANDED_OVERLAY_STATE, style({\n        position: 'absolute',\n        top: 0,\n        height: '100%',\n        bottom: 0,\n        left: 0,\n        float: 'left',\n        zIndex: '9999',\n        width: 'calc(100vw - 50px)',\n        transform: 'translateX(0)'\n      })),\n      state(COLLAPSED_OVERLAY_STATE, style({\n        position: 'absolute',\n        top: 0,\n        height: '100%',\n        bottom: 0,\n        left: 0,\n        float: 'left',\n        zIndex: '9999',\n        width: 'calc(100vw - 50px)',\n        transform: 'translateX(calc(-100vw + 50px))',\n        'overflow-x': 'hidden'\n      })),\n\n      // transition(`${EXPANDED_STATE} <=> ${COLLAPSED_STATE}`, animate('0.2s ease-in-out')),\n\n      transition(sideNavExpandStateChangeFn, animate('0.2s ease-in-out')),\n\n      // transition(`${EXPANDED_STATE} <=> ${COLLAPSED_STATE}`, [\n      //   // query(':leave', animateChild(), { optional: true }),\n      //   // query(':enter', animateChild(), { optional: true }),\n      //   group([\n      //     query(':leave', animateChild(), { optional: true }),\n      //     query(':enter', animateChild(), { optional: true }),\n      //     query('@compactAnim', animateChild(), { optional: true }),\n      //     animate('5.2s ease-in-out')\n      //   ])\n      // ]),\n    ])\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None\n})\nexport class SideNavComponent implements OnInit, OnDestroy, ITheSeamBaseLayoutNav {\n  static ngAcceptInputType_hasHeaderToggle: BooleanInput\n\n  private readonly _ngUnsubscribe = new Subject()\n\n  // @HostBinding('@sideNavExpand') _sideNavExpand = EXPANDED_STATE\n  // _sideNavExpand = EXPANDED_STATE\n\n  // @HostBinding('@sideNavAnim') _sideNavExpand = EXPANDED_STATE\n  @HostBinding('@sideNavAnim') _sideNavExpand = 'initial'\n\n  @Input() @InputBoolean() hasHeaderToggle = true\n\n  @Input()\n  get items(): ISideNavItem[] { return this._items.value }\n  set items(value: ISideNavItem[]) { this._items.next(value) }\n  private _items = new BehaviorSubject<ISideNavItem[]>([])\n  public readonly items$: Observable<ISideNavItem[]>\n\n  @Input()\n  get expanded(): boolean { return this._expanded.value }\n  set expanded(value: boolean) { this._expanded.next(coerceBooleanProperty(value)) }\n  private _expanded = new BehaviorSubject<boolean>(true)\n  public readonly expanded$ = this._expanded.asObservable().pipe(\n    tap(expanded => this.toggleExpand.emit(expanded))\n  )\n\n  @Input()\n  get overlay(): boolean { return this._overlay.value }\n  set overlay(value: boolean) { this._overlay.next(coerceBooleanProperty(value)) }\n  private _overlay = new BehaviorSubject<boolean>(false)\n  public readonly overlay$ = this._overlay.asObservable()\n\n  @Output() toggleExpand = new EventEmitter<boolean>()\n\n  public readonly isMobile$: Observable<boolean>\n  public readonly sideNavExpandedState$: Observable<string>\n  public _backdropHidden = new BehaviorSubject<boolean>(true)\n\n  @ContentChild(BaseLayoutSideBarFooterDirective, { static: true, read: TemplateRef }) _sideBarFooterTpl?: TemplateRef<any> | null\n  _sideBarFooterPortal?: TemplatePortal\n\n  constructor(\n    private readonly _viewContainerRef: ViewContainerRef,\n    private readonly _layout: TheSeamLayoutService,\n    private readonly _sideNav: TheSeamSideNavService,\n    @Optional() @Inject(THESEAM_BASE_LAYOUT_REF) private readonly _baseLayoutRef: ITheSeamBaseLayoutRef\n  ) {\n    this.items$ = this._items.asObservable().pipe(\n      switchMap(items => this._sideNav.createItemsObservable(items)),\n      shareReplay({ bufferSize: 1, refCount: true }),\n    )\n\n    this.isMobile$ = this._layout.isMobile$.pipe(\n      tap(isMobile => isMobile && this.collapse())\n    )\n\n    this.sideNavExpandedState$ = combineLatest([ this.expanded$, this.overlay$ ]).pipe(\n      map(([ expanded, overlay ]) => expanded\n        ? overlay ? EXPANDED_OVERLAY_STATE : EXPANDED_STATE\n        : overlay ? COLLAPSED_OVERLAY_STATE : COLLAPSED_STATE\n      ),\n      distinctUntilChanged()\n    )\n  }\n\n  ngOnInit() {\n    if (this._baseLayoutRef) { this._baseLayoutRef.registerNav(this) }\n\n    this.isMobile$\n      .pipe(takeUntil(this._ngUnsubscribe))\n      .subscribe(b => this.overlay = b)\n\n    this.sideNavExpandedState$\n      .pipe(takeUntil(this._ngUnsubscribe))\n      .subscribe(v => this._sideNavExpand = v)\n\n    if (this._sideBarFooterTpl) {\n      this._sideBarFooterPortal = new TemplatePortal(this._sideBarFooterTpl, this._viewContainerRef)\n    }\n  }\n\n  ngOnDestroy() {\n    this._ngUnsubscribe.next()\n    this._ngUnsubscribe.complete()\n    if (this._baseLayoutRef) { this._baseLayoutRef.unregisterNav(this) }\n  }\n\n  public expand() {\n    this.expanded = true\n  }\n\n  public collapse() {\n    this.expanded = false\n  }\n\n  public toggle() {\n    this.expanded = !this.expanded\n  }\n\n  public animateStart() {\n    if (this.expanded) {\n      this._backdropHidden.next(false)\n    }\n  }\n\n  public animateEnd() {\n    if (!this.expanded) {\n      this._backdropHidden.next(true)\n    }\n  }\n\n}\n"]}
212
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"side-nav.component.js","sourceRoot":"","sources":["../../../../../projects/ui-common/framework/side-nav/side-nav.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  animate,\n  animateChild,\n  group,\n  query,\n  state,\n  style,\n  transition,\n  trigger\n} from '@angular/animations'\nimport { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion'\nimport { ChangeDetectionStrategy, Component, ContentChild, EventEmitter, HostBinding, Inject, Input, OnDestroy, OnInit, Optional, Output, TemplateRef, ViewContainerRef, ViewEncapsulation } from '@angular/core'\nimport { ActivatedRoute, NavigationEnd, Router } from '@angular/router'\nimport { BehaviorSubject, combineLatest, Observable, Subject } from 'rxjs'\nimport { distinctUntilChanged, filter, map, mapTo, pairwise, shareReplay, startWith, switchMap, takeUntil, tap } from 'rxjs/operators'\n\nimport { InputBoolean } from '@theseam/ui-common/core'\nimport { TheSeamLayoutService } from '@theseam/ui-common/layout'\n\nimport { ITheSeamBaseLayoutNav, ITheSeamBaseLayoutRef, THESEAM_BASE_LAYOUT_REF } from '../base-layout/index'\n\nimport { ISideNavItem } from './side-nav.models'\nimport { TheSeamSideNavService } from './side-nav.service'\nimport { BaseLayoutSideBarFooterDirective } from '../base-layout/directives/base-layout-side-bar-footer.directive'\nimport { TemplatePortal } from '@angular/cdk/portal'\n\nconst EXPANDED_STATE = 'expanded'\nconst COLLAPSED_STATE = 'collapsed'\n\nconst EXPANDED_OVERLAY_STATE = 'expanded-overlay'\nconst COLLAPSED_OVERLAY_STATE = 'collapsed-overlay'\n\nconst EXPANDED_STATES = [ EXPANDED_STATE, EXPANDED_OVERLAY_STATE ]\nconst COLLAPSED_STATES = [ COLLAPSED_STATE, COLLAPSED_OVERLAY_STATE ]\nconst EXPAND_STATES = [ ...EXPANDED_STATES, ...COLLAPSED_STATES ]\n\nexport function sideNavExpandStateChangeFn(fromState: string, toState: string) {\n  // console.log({ fromState, toState })\n  return fromState !== toState &&\n    (\n      // NOTE: The current way the side nav is being used it causes the\n      // component to sometimes get placed in the wrong location initially. It\n      // is fast enough to not be noticed without an initial animation usually,\n      // so it is commented out below until the initial placement issue it\n      // fixed.\n      //\n      // (\n      //   fromState === 'void' && EXPAND_STATES.indexOf(toState) !== -1\n      //   ||\n      //   toState === 'void' && EXPAND_STATES.indexOf(fromState) !== -1\n      // )\n      // ||\n      (\n        (EXPANDED_STATES.indexOf(fromState) !== -1 && COLLAPSED_STATES.indexOf(toState) !== -1)\n        ||\n        (EXPANDED_STATES.indexOf(toState) !== -1 && COLLAPSED_STATES.indexOf(fromState) !== -1)\n      )\n    )\n}\n\n@Component({\n  selector: 'seam-side-nav',\n  templateUrl: './side-nav.component.html',\n  styleUrls: ['./side-nav.component.scss'],\n  providers: [\n    TheSeamSideNavService\n  ],\n  animations: [\n\n    //\n    // TODO: This animation code turned into a mess. Clean it up and make it\n    // more smooth.\n    //\n\n    trigger('sideNavAnim', [\n      transition(sideNavExpandStateChangeFn, [\n        group([\n          query('@sideNavBackdrop', animateChild(), { optional: true }),\n          query('@sideNavExpand', animateChild(), { optional: true }),\n        ]),\n      ]),\n    ]),\n\n    trigger('sideNavBackdrop', [\n      state(EXPANDED_OVERLAY_STATE, style({ opacity: '1' })),\n      state(COLLAPSED_OVERLAY_STATE, style({ opacity: '0' })),\n\n      // transition((fromState, toState, element, params) => {\n      //   console.log('sideNavBackdrop v', fromState, toState, element, params)\n      //   return false\n      // }, []),\n\n      transition(sideNavExpandStateChangeFn, animate('0.2s ease-in-out')),\n    ]),\n\n    trigger('sideNavExpand', [\n      // TODO: Make width configurable.\n      state(EXPANDED_STATE, style({ width: '260px' })),\n      state(COLLAPSED_STATE, style({ width: '50px', 'overflow-x': 'hidden' })),\n\n      state(EXPANDED_OVERLAY_STATE, style({\n        position: 'absolute',\n        top: 0,\n        height: '100%',\n        bottom: 0,\n        left: 0,\n        float: 'left',\n        zIndex: '9999',\n        width: 'calc(100vw - 50px)',\n        transform: 'translateX(0)'\n      })),\n      state(COLLAPSED_OVERLAY_STATE, style({\n        position: 'absolute',\n        top: 0,\n        height: '100%',\n        bottom: 0,\n        left: 0,\n        float: 'left',\n        zIndex: '9999',\n        width: 'calc(100vw - 50px)',\n        transform: 'translateX(calc(-100vw + 50px))',\n        'overflow-x': 'hidden'\n      })),\n\n      // transition(`${EXPANDED_STATE} <=> ${COLLAPSED_STATE}`, animate('0.2s ease-in-out')),\n\n      transition(sideNavExpandStateChangeFn, animate('0.2s ease-in-out')),\n\n      // transition(`${EXPANDED_STATE} <=> ${COLLAPSED_STATE}`, [\n      //   // query(':leave', animateChild(), { optional: true }),\n      //   // query(':enter', animateChild(), { optional: true }),\n      //   group([\n      //     query(':leave', animateChild(), { optional: true }),\n      //     query(':enter', animateChild(), { optional: true }),\n      //     query('@compactAnim', animateChild(), { optional: true }),\n      //     animate('5.2s ease-in-out')\n      //   ])\n      // ]),\n    ])\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None\n})\nexport class SideNavComponent implements OnInit, OnDestroy, ITheSeamBaseLayoutNav {\n  static ngAcceptInputType_hasHeaderToggle: BooleanInput\n\n  private readonly _ngUnsubscribe = new Subject()\n\n  // @HostBinding('@sideNavExpand') _sideNavExpand = EXPANDED_STATE\n  // _sideNavExpand = EXPANDED_STATE\n\n  // @HostBinding('@sideNavAnim') _sideNavExpand = EXPANDED_STATE\n  @HostBinding('@sideNavAnim') _sideNavExpand = 'initial'\n\n  @Input() @InputBoolean() hasHeaderToggle = true\n\n  @Input()\n  get items(): ISideNavItem[] { return this._items.value }\n  set items(value: ISideNavItem[]) { this._items.next(value) }\n  private _items = new BehaviorSubject<ISideNavItem[]>([])\n  public readonly items$: Observable<ISideNavItem[]>\n\n  @Input()\n  get expanded(): boolean { return this._expanded.value }\n  set expanded(value: boolean) {\n    const expanded = coerceBooleanProperty(value)\n    let emit = expanded !== this.expanded\n    this._expanded.next(expanded)\n\n    if (emit) {\n      this.toggleExpand.emit(coerceBooleanProperty(value))\n    }\n  }\n  private _expanded = new BehaviorSubject<boolean>(true)\n  public readonly expanded$ = this._expanded.asObservable()\n\n  @Input()\n  get overlay(): boolean { return this._overlay.value }\n  set overlay(value: boolean) { this._overlay.next(coerceBooleanProperty(value)) }\n  private _overlay = new BehaviorSubject<boolean>(false)\n  public readonly overlay$ = this._overlay.asObservable()\n\n  @Output() toggleExpand = new EventEmitter<boolean>()\n\n  public readonly isMobile$: Observable<boolean>\n  public readonly sideNavExpandedState$: Observable<string>\n  public _backdropHidden = new BehaviorSubject<boolean>(true)\n\n  @ContentChild(BaseLayoutSideBarFooterDirective, { static: true, read: TemplateRef }) _sideBarFooterTpl?: TemplateRef<any> | null\n  _sideBarFooterPortal?: TemplatePortal\n\n  constructor(\n    private readonly _viewContainerRef: ViewContainerRef,\n    private readonly _layout: TheSeamLayoutService,\n    private readonly _sideNav: TheSeamSideNavService,\n    @Optional() @Inject(THESEAM_BASE_LAYOUT_REF) private readonly _baseLayoutRef: ITheSeamBaseLayoutRef\n  ) {\n    this.items$ = this._items.asObservable().pipe(\n      switchMap(items => this._sideNav.createItemsObservable(items)),\n      shareReplay({ bufferSize: 1, refCount: true }),\n    )\n\n    this.isMobile$ = this._layout.isMobile$.pipe(\n      tap(isMobile => isMobile ? this.collapse() : this.expand())\n    )\n\n    this.sideNavExpandedState$ = combineLatest([ this.expanded$, this.overlay$ ]).pipe(\n      map(([ expanded, overlay ]) => expanded\n        ? overlay ? EXPANDED_OVERLAY_STATE : EXPANDED_STATE\n        : overlay ? COLLAPSED_OVERLAY_STATE : COLLAPSED_STATE\n      ),\n      distinctUntilChanged()\n    )\n  }\n\n  ngOnInit() {\n    if (this._baseLayoutRef) { this._baseLayoutRef.registerNav(this) }\n\n    this.isMobile$\n      .pipe(takeUntil(this._ngUnsubscribe))\n      .subscribe(b => this.overlay = b)\n\n    this.sideNavExpandedState$\n      .pipe(takeUntil(this._ngUnsubscribe))\n      .subscribe(v => this._sideNavExpand = v)\n\n    if (this._sideBarFooterTpl) {\n      this._sideBarFooterPortal = new TemplatePortal(this._sideBarFooterTpl, this._viewContainerRef)\n    }\n  }\n\n  ngOnDestroy() {\n    this._ngUnsubscribe.next()\n    this._ngUnsubscribe.complete()\n    if (this._baseLayoutRef) { this._baseLayoutRef.unregisterNav(this) }\n  }\n\n  public expand() {\n    this.expanded = true\n  }\n\n  public collapse() {\n    this.expanded = false\n  }\n\n  public toggle() {\n    this.expanded = !this.expanded\n  }\n\n  public animateStart() {\n    if (this.expanded) {\n      this._backdropHidden.next(false)\n    }\n  }\n\n  public animateEnd() {\n    if (!this.expanded) {\n      this._backdropHidden.next(true)\n    }\n  }\n\n}\n"]}
@@ -1275,13 +1275,13 @@ class SideNavComponent {
1275
1275
  this.hasHeaderToggle = true;
1276
1276
  this._items = new BehaviorSubject([]);
1277
1277
  this._expanded = new BehaviorSubject(true);
1278
- this.expanded$ = this._expanded.asObservable().pipe(tap(expanded => this.toggleExpand.emit(expanded)));
1278
+ this.expanded$ = this._expanded.asObservable();
1279
1279
  this._overlay = new BehaviorSubject(false);
1280
1280
  this.overlay$ = this._overlay.asObservable();
1281
1281
  this.toggleExpand = new EventEmitter();
1282
1282
  this._backdropHidden = new BehaviorSubject(true);
1283
1283
  this.items$ = this._items.asObservable().pipe(switchMap(items => this._sideNav.createItemsObservable(items)), shareReplay({ bufferSize: 1, refCount: true }));
1284
- this.isMobile$ = this._layout.isMobile$.pipe(tap(isMobile => isMobile && this.collapse()));
1284
+ this.isMobile$ = this._layout.isMobile$.pipe(tap(isMobile => isMobile ? this.collapse() : this.expand()));
1285
1285
  this.sideNavExpandedState$ = combineLatest([this.expanded$, this.overlay$]).pipe(map(([expanded, overlay]) => expanded
1286
1286
  ? overlay ? EXPANDED_OVERLAY_STATE : EXPANDED_STATE$1
1287
1287
  : overlay ? COLLAPSED_OVERLAY_STATE : COLLAPSED_STATE$1), distinctUntilChanged());
@@ -1289,7 +1289,14 @@ class SideNavComponent {
1289
1289
  get items() { return this._items.value; }
1290
1290
  set items(value) { this._items.next(value); }
1291
1291
  get expanded() { return this._expanded.value; }
1292
- set expanded(value) { this._expanded.next(coerceBooleanProperty(value)); }
1292
+ set expanded(value) {
1293
+ const expanded = coerceBooleanProperty(value);
1294
+ let emit = expanded !== this.expanded;
1295
+ this._expanded.next(expanded);
1296
+ if (emit) {
1297
+ this.toggleExpand.emit(coerceBooleanProperty(value));
1298
+ }
1299
+ }
1293
1300
  get overlay() { return this._overlay.value; }
1294
1301
  set overlay(value) { this._overlay.next(coerceBooleanProperty(value)); }
1295
1302
  ngOnInit() {