@rivet-health/design-system 28.2.4 → 28.2.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/input/date-range/date-range.component.mjs +8 -4
- package/esm2020/lib/navigation/views/view-menu/view-menu.component.mjs +2 -2
- package/esm2020/lib/navigation/views/views/views.component.mjs +3 -6
- package/esm2020/lib/overlay/callout/menu/menu.component.mjs +2 -2
- package/fesm2015/rivet-health-design-system.mjs +13 -12
- package/fesm2015/rivet-health-design-system.mjs.map +1 -1
- package/fesm2020/rivet-health-design-system.mjs +13 -12
- package/fesm2020/rivet-health-design-system.mjs.map +1 -1
- package/lib/navigation/views/views/views.component.d.ts +0 -1
- package/package.json +1 -1
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, Input, Output, } from '@angular/core';
|
|
2
2
|
import { timeDay, timeMonth, timeSunday, timeWeek, timeYear } from 'd3-time';
|
|
3
|
-
import { BehaviorSubject, Subject, combineLatest, distinctUntilChanged, filter, map, merge, scan, shareReplay, skipUntil, startWith,
|
|
3
|
+
import { BehaviorSubject, Subject, combineLatest, distinctUntilChanged, filter, map, merge, scan, shareReplay, skipUntil, startWith, } from 'rxjs';
|
|
4
4
|
import { DatePipe } from '../../format/pipes/date.pipe';
|
|
5
5
|
import { LocalStorage } from '../../util/local-storage';
|
|
6
6
|
import { CalendarComponent } from '../calendar/calendar.component';
|
|
@@ -82,9 +82,13 @@ export class DateRangeComponent extends InputLabelComponent {
|
|
|
82
82
|
return null;
|
|
83
83
|
}));
|
|
84
84
|
this.favoritePresetIds$ = new LocalStorage(this.STORAGE_KEY, []);
|
|
85
|
-
this.favoritePresets$ =
|
|
85
|
+
this.favoritePresets$ = combineLatest([
|
|
86
|
+
this.favoritePresetIds$,
|
|
87
|
+
this.filteredPresetOptions$,
|
|
88
|
+
this.alternativePresetList$,
|
|
89
|
+
]).pipe(map(([ids, presets, alternativePresetList]) => {
|
|
86
90
|
const favoritePresets = ids
|
|
87
|
-
.map(id =>
|
|
91
|
+
.map(id => presets.find(preset => preset.id === id))
|
|
88
92
|
.filter((p) => p !== undefined);
|
|
89
93
|
if (alternativePresetList.length == 0) {
|
|
90
94
|
return favoritePresets;
|
|
@@ -455,4 +459,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
455
459
|
},
|
|
456
460
|
];
|
|
457
461
|
})(DateRangeComponent || (DateRangeComponent = {}));
|
|
458
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-range.component.js","sourceRoot":"","sources":["../../../../../../projects/riv/src/lib/input/date-range/date-range.component.ts","../../../../../../projects/riv/src/lib/input/date-range/date-range.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,KAAK,EACL,MAAM,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAC7E,OAAO,EACL,eAAe,EAEf,OAAO,EACP,aAAa,EACb,oBAAoB,EACpB,MAAM,EACN,GAAG,EACH,KAAK,EACL,IAAI,EACJ,WAAW,EACX,SAAS,EACT,SAAS,EACT,cAAc,GACf,MAAM,MAAM,CAAC;AACd,OAAO,EAAE,QAAQ,EAAE,MAAM,8BAA8B,CAAC;AACxD,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AACxD,OAAO,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAC;AACnE,OAAO,EAAE,mBAAmB,EAAE,MAAM,sCAAsC,CAAC;;;;;;;;;;;;;AAC3E,MAAM,WAAW,GAAG,SAAS,CAAC,KAAK,CAAC,CAAC,CAAE,CAAC;AAExC,6EAA6E;AAC7E,2BAA2B;AAC3B,mGAAmG;AAOnG,MAAM,OAAO,kBAAmB,SAAQ,mBAAmB;IAN3D;;QAOW,UAAK,GAAG,IAAI,IAAI,EAAE,CAAC;QACnB,gBAAW,GAAG,oBAAoB,CAAC;QAE3B,iBAAY,GAAG,IAAI,eAAe,CAAU,IAAI,CAAC,CAAC;QAS1D,SAAI,GAAG,IAAI,eAAe,CAAO,iBAAiB,CAAC,UAAU,CAAC,CAAC;QAS/D,SAAI,GAAG,IAAI,eAAe,CAAO,iBAAiB,CAAC,UAAU,CAAC,CAAC;QAS/D,WAAM,GAAG,IAAI,eAAe,CAA2B,SAAS,CAAC,CAAC;QASlE,iBAAY,GAAG,IAAI,eAAe,CAAS,sBAAsB,CAAC,CAAC;QASnE,cAAS,GAAG,IAAI,eAAe,CAAC,KAAK,CAAC,CAAC;QASvC,2BAAsB,GAAG,IAAI,eAAe,CAEnD,EAAE,CAAC,CAAC;QASG,UAAK,GAAG,IAAI,eAAe,CAAC,KAAK,CAAC,CAAC;QAEnC,wBAAmB,GAC1B,IAAI,OAAO,EAAoC,CAAC;QAEzC,sBAAiB,GAAG,IAAI,OAAO,EAAoB,CAAC;QACpD,mBAAc,GAAgD,KAAK,CAC1E,IAAI,CAAC,MAAM,EACX,IAAI,CAAC,iBAAiB,CAAC,IAAI,CACzB,IAAI,CACF,CAAC,QAAyC,EAAE,IAAsB,EAAE,EAAE;YACpE,IAAI,QAAQ,YAAY,IAAI,IAAI,IAAI,YAAY,IAAI,EAAE;gBACpD,IAAI,IAAI,CAAC,OAAO,EAAE,IAAI,QAAQ,CAAC,OAAO,EAAE,EAAE;oBACxC,MAAM,IAAI,GAAiB,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;oBAC5C,OAAO,IAAI,CAAC;iBACb;aACF;YACD,OAAO,IAAI,CAAC;QACd,CAAC,CACF,CACF,EACD,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAC3B,MAAM,CAAC,CAAC,MAAM,EAAuC,EAAE,CAAC,MAAM,KAAK,IAAI,CAAC,EACxE,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,CAC5B,CACF,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAE9C,2BAAsB,GAAG,aAAa,CAAC;YAC9C,IAAI,CAAC,IAAI;YACT,IAAI,CAAC,IAAI;YACT,IAAI,CAAC,sBAAsB;SAC5B,CAAC,CAAC,IAAI,CACL,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,qBAAqB,CAAC,EAAE,EAAE;YACxC,MAAM,uBAAuB,GAAG,kBAAkB,CAAC,OAAO,CAAC,MAAM,CAC/D,CAAC,CAAC,EAAE,CACF,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE,IAAI,GAAG,CAAC,OAAO,EAAE;gBACrC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE,IAAI,GAAG,CAAC,OAAO,EAAE,CACxC,CAAC;YACF,IAAI,qBAAqB,CAAC,MAAM,IAAI,CAAC,EAAE;gBACrC,OAAO,uBAAuB,CAAC;aAChC;iBAAM;gBACL,MAAM,sCAAsC,GAC1C,uBAAuB,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CACjC,qBAAqB,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CACrC,CAAC;gBACJ,OAAO,sCAAsC,CAAC;aAC/C;QACH,CAAC,CAAC,EACF,WAAW,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,CAC/C,CAAC;QAEO,oBAAe,GACtB,aAAa,CAAC;YACZ,IAAI,CAAC,cAAc;YACnB,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;SAC/C,CAAC,CAAC,IAAI,CACL,GAAG,CAAC,CAAC,CAAC,aAAa,EAAE,kBAAkB,CAAC,EAAE,EAAE;YAC1C,IAAI,aAAa,YAAY,KAAK,EAAE;gBAClC,MAAM,OAAO,GAAG,kBAAkB,CAAC,OAAO,CAAC,MAAM,CAC/C,MAAM,CAAC,EAAE,CACP,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE,KAAK,aAAa,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE;oBACxD,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE,KAAK,aAAa,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE,CAC3D,CAAC;gBACF,IAAI,OAAO,CAAC,MAAM,EAAE;oBAClB,+DAA+D;oBAC/D,kEAAkE;oBAClE,gEAAgE;oBAChE,+DAA+D;oBAC/D,kBAAkB;oBAClB,MAAM,UAAU,GAAG,OAAO,CAAC,IAAI,CAC7B,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,KAAK,kBAAkB,EAAE,EAAE,CAC/C,CAAC;oBACF,IAAI,UAAU;wBAAE,OAAO,UAAU,CAAC;oBAClC,OAAO,OAAO,CAAC,CAAC,CAAC,CAAC;iBACnB;aACF;YACD,OAAO,IAAI,CAAC;QACd,CAAC,CAAC,CACH,CAAC;QAEK,uBAAkB,GAAG,IAAI,YAAY,CAC5C,IAAI,CAAC,WAAW,EAChB,EAAE,CACH,CAAC;QAYO,qBAAgB,GACvB,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAC1B,cAAc,CAAC,IAAI,CAAC,sBAAsB,CAAC,EAC3C,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,qBAAqB,CAAC,EAAE,EAAE;YACnC,MAAM,eAAe,GAAG,GAAG;iBACxB,GAAG,CAAC,EAAE,CAAC,EAAE,CACR,kBAAkB,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,KAAK,EAAE,CAAC,CAC5D;iBACA,MAAM,CAAC,CAAC,CAAC,EAAkC,EAAE,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC;YAElE,IAAI,qBAAqB,CAAC,MAAM,IAAI,CAAC,EAAE;gBACrC,OAAO,eAAe,CAAC;aACxB;iBAAM;gBACL,MAAM,wCAAwC,GAC5C,eAAe,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CACzB,qBAAqB,CAAC,QAAQ,CACG,CAAC,CAAC,EAAE,CACpC,CACF,CAAC;gBACJ,OAAO,wCAAwC,CAAC;aACjD;QACH,CAAC,CAAC,EACF,WAAW,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,CAC/C,CAAC;QAEK,6BAAwB,GAAG,IAAI,OAAO,EAAQ,CAAC;QAC/C,8BAAyB,GAAG,IAAI,OAAO,EAAQ,CAAC;QAEhD,aAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAChC,WAAW,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,CAC/C,CAAC;QACO,aAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAChC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EACpD,WAAW,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,CAC/C,CAAC;QACO,cAAS,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CACjC,WAAW,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,CAC/C,CAAC;QAEO,yBAAoB,GAAG,aAAa,CAAC;YAC5C,IAAI,CAAC,QAAQ;YACb,KAAK,CACH,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAChC,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CACvC,EACD,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAC3B,MAAM,CACJ,CAAC,MAAM,EAAuC,EAAE,CAAC,MAAM,KAAK,IAAI,CACjE,EACD,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,SAAS,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAChD,EACD,IAAI,CAAC,MAAM,CAAC,IAAI,CACd,MAAM,CAAC,CAAC,CAAC,EAAqB,EAAE,CAAC,CAAC,KAAK,SAAS,CAAC,EACjD,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAChC,CACF;SACF,CAAC,CAAC,IAAI,CACL,GAAG,CAAC,CAAC,CAAC,OAAO,EAAE,IAAI,CAAC,EAAE,EAAE;YACtB,IAAI,IAAI,CAAC,OAAO,EAAE,IAAI,OAAO,CAAC,OAAO,EAAE;gBAAE,OAAO,SAAS,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;;gBACpE,OAAO,IAAI,CAAC;QACnB,CAAC,CAAC,EACF,WAAW,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,CAC/C,CAAC;QAEO,0BAAqB,GAAG,aAAa,CAAC;YAC7C,IAAI,CAAC,oBAAoB;YACzB,KAAK,CACH,IAAI,CAAC,yBAAyB,CAAC,IAAI,CACjC,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CACtC,EACD,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAC3B,MAAM,CACJ,CAAC,MAAM,EAAuC,EAAE,CAAC,MAAM,KAAK,IAAI,CACjE,EACD,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,SAAS,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAChD,EACD,IAAI,CAAC,MAAM,CAAC,IAAI,CACd,MAAM,CAAC,CAAC,CAAC,EAAqB,EAAE,CAAC,CAAC,KAAK,SAAS,CAAC,EACjD,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAChC,CACF;YACD,IAAI,CAAC,SAAS;SACf,CAAC,CAAC,IAAI,CACL,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,SAAS,EAAE,SAAS,CAAC,EAAE,EAAE;YACnC,IAAI,IAAI,CAAC,OAAO,EAAE,IAAI,SAAS,CAAC,OAAO,EAAE;gBACvC,OAAO,SAAS,CAAC,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;iBAC/C,IAAI,SAAS,CAAC,OAAO,EAAE,IAAI,SAAS,CAAC,OAAO,EAAE;gBACjD,OAAO,SAAS,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;;gBAC/B,OAAO,SAAS,CAAC;QACxB,CAAC,CAAC,EACF,WAAW,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,CAC/C,CAAC;QAEO,cAAS,GAAG,IAAI,CAAC,oBAAoB,CAAC,IAAI,CACjD,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,SAAS,CAAC,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC,EACvD,WAAW,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,CAC/C,CAAC;QAEO,mBAAc,GACrB,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAC7B,GAAG,CAAqB,oBAAoB,CAAC,EAAE;YAC7C,MAAM,KAAK,GAAG,SAAS,CAAC,KAAK,CAAC,oBAAoB,CAAC,CAAC;YACpD,MAAM,IAAI,GAAG,OAAO,CAAC,MAAM,CACzB,SAAS,CAAC,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,oBAAoB,EAAE,CAAC,CAAC,CAAC,EAC1D,CAAC,CAAC,CACH,CAAC;YACF,OAAO,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;QACvB,CAAC,CAAC,EACF,WAAW,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,CAC/C,CAAC;QAEK,oBAAe,GAAG,KAAK,CAC9B,IAAI,CAAC,iBAAiB,EACtB,IAAI,CAAC,mBAAmB,CACzB,CAAC;QAGO,gBAAW,GAClB,IAAI,CAAC,cAAc,CAAC,IAAI,CACtB,SAAS,CACP,KAAK,CACH,IAAI,CAAC,eAAe,EACpB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CACvD,CACF,EACD,MAAM,CAAC,CAAC,CAAC,EAAiC,EAAE,CAAC,CAAC,CAAC,CAAC,YAAY,IAAI,CAAC,CAAC,EAClE,oBAAoB,CAClB,CAAC,QAAQ,EAAE,OAAO,EAAE,EAAE,CACpB,QAAQ,EAAE,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE,KAAK,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE;YAClD,QAAQ,EAAE,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE,KAAK,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE,CACrD,EACD,WAAW,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,CAC/C,CAAC;QAEK,kBAAa,GACpB,IAAI,CAAC,WAAW,CAAC,IAAI,CACnB,GAAG,CAAC,CAAC,CAAC,EAAE;YACN,IAAI,CAAC,EAAE;gBACL,OAAO,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,QAAQ,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;aAClE;YACD,OAAO,SAAS,CAAC;QACnB,CAAC,CAAC,EACF,WAAW,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,CAC/C,CAAC;KACL;IA/SC,IACI,WAAW,CAAC,CAAU;QACxB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC5B,CAAC;IACD,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;IACtC,CAAC;IAGD,IACI,GAAG,CAAC,CAAO;QACb,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACpB,CAAC;IACD,IAAI,GAAG;QACL,OAAO,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;IAC9B,CAAC;IAGD,IACI,GAAG,CAAC,CAAO;QACb,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACpB,CAAC;IACD,IAAI,GAAG;QACL,OAAO,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;IAC9B,CAAC;IAGD,IACI,KAAK,CAAC,CAA2B;QACnC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACtB,CAAC;IACD,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;IAChC,CAAC;IAGD,IACI,WAAW,CAAC,CAAS;QACvB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC5B,CAAC;IACD,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;IACtC,CAAC;IAGD,IACI,QAAQ,CAAC,CAAU;QACrB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACzB,CAAC;IACD,IAAI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;IACnC,CAAC;IAKD,IACI,qBAAqB,CAAC,CAAkC;QAC1D,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACtC,CAAC;IACD,IAAI,qBAAqB;QACvB,OAAO,IAAI,CAAC,sBAAsB,CAAC,QAAQ,EAAE,CAAC;IAChD,CAAC;IAuFD,WAAW,CAAC,MAAiC,EAAE,QAAiB;QAC9D,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,IAAI,CAAC,kBAAkB,CAAC,QAAQ,EAAE,CAAC,CAAC;QACxD,IAAI,QAAQ,EAAE;YACZ,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;SACpB;aAAM;YACL,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;SACvB;QACD,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC;IACzC,CAAC;;+GAlKU,kBAAkB;mGAAlB,kBAAkB,wSCrC/B,y3MAmLA;2FD9Ia,kBAAkB;kBAN9B,SAAS;+BACE,gBAAgB,mBAGT,uBAAuB,CAAC,MAAM;8BAQ3C,WAAW;sBADd,KAAK;gBAUF,GAAG;sBADN,KAAK;gBAUF,GAAG;sBADN,KAAK;gBAUF,KAAK;sBADR,KAAK;gBAUF,WAAW;sBADd,KAAK;gBAUF,QAAQ;sBADX,KAAK;gBAYF,qBAAqB;sBADxB,KAAK;gBA4NG,WAAW;sBADnB,MAAM;;AA8BT,WAAiB,kBAAkB;IACjC,MAAM,KAAK,GAAG,IAAI,IAAI,EAAE,CAAC;IAEzB,IAAY,UA2BX;IA3BD,WAAY,UAAU;QACpB,6BAAe,CAAA;QACf,qCAAuB,CAAA;QACvB,mCAAqB,CAAA;QACrB,qCAAuB,CAAA;QACvB,mDAAqC,CAAA;QACrC,qCAAuB,CAAA;QACvB,qCAAuB,CAAA;QACvB,uCAAyB,CAAA;QACzB,qDAAuC,CAAA;QACvC,uCAAyB,CAAA;QACzB,uCAAyB,CAAA;QACzB,2CAA6B,CAAA;QAC7B,yDAA2C,CAAA;QAC3C,2CAA6B,CAAA;QAC7B,2CAA6B,CAAA;QAC7B,qCAAuB,CAAA;QACvB,mDAAqC,CAAA;QACrC,qCAAuB,CAAA;QACvB,qCAAuB,CAAA;QACvB,yCAA2B,CAAA;QAC3B,2CAA6B,CAAA;QAC7B,2CAA6B,CAAA;QAC7B,2CAA6B,CAAA;QAC7B,2CAA6B,CAAA;QAC7B,6CAA+B,CAAA;QAC/B,6CAA+B,CAAA;IACjC,CAAC,EA3BW,UAAU,GAAV,6BAAU,KAAV,6BAAU,QA2BrB;IASY,0BAAO,GAAa;QAC/B;YACE,EAAE,EAAE,UAAU,CAAC,KAAK;YACpB,KAAK,EAAE,OAAO;YACd,QAAQ,EAAE,4CAA4C;YACtD,KAAK,EAAE,CAAC,OAAO,EAAE,EAAE,OAAO,EAAE,CAAC;SAC9B;QACD;YACE,EAAE,EAAE,UAAU,CAAC,SAAS;YACxB,KAAK,EAAE,WAAW;YAClB,QAAQ,EAAE,0BAA0B;YACpC,KAAK,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC;SACtE;QACD;YACE,EAAE,EAAE,UAAU,CAAC,QAAQ;YACvB,KAAK,EAAE,UAAU;YACjB,QAAQ,EAAE,sBAAsB;YAChC,KAAK,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC;SACpE;QACD;YACE,EAAE,EAAE,UAAU,CAAC,SAAS;YACxB,KAAK,EAAE,WAAW;YAClB,QAAQ,EAAE,2BAA2B;YACrC,KAAK,EAAE;gBACL,UAAU,CAAC,KAAK,CAAC,KAAK,CAAC;gBACvB,OAAO,CAAC,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;aAC3C;SACF;QACD;YACE,EAAE,EAAE,UAAU,CAAC,gBAAgB;YAC/B,KAAK,EAAE,kBAAkB;YACzB,QAAQ,EAAE,qCAAqC;YAC/C,KAAK,EAAE,CAAC,UAAU,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;SACvD;QACD;YACE,EAAE,EAAE,UAAU,CAAC,SAAS;YACxB,KAAK,EAAE,WAAW;YAClB,QAAQ,EAAE,4BAA4B;YACtC,KAAK,EAAE;gBACL,UAAU,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;gBAC5C,OAAO,CAAC,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;aAChE;SACF;QACD;YACE,EAAE,EAAE,UAAU,CAAC,SAAS;YACxB,KAAK,EAAE,WAAW;YAClB,QAAQ,EAAE,wBAAwB;YAClC,KAAK,EAAE;gBACL,UAAU,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;gBAC3C,OAAO,CAAC,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;aAC/D;SACF;QACD;YACE,EAAE,EAAE,UAAU,CAAC,UAAU;YACzB,KAAK,EAAE,YAAY;YACnB,QAAQ,EAAE,4BAA4B;YACtC,KAAK,EAAE;gBACL,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC;gBACtB,OAAO,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;aAC1C;SACF;QACD;YACE,EAAE,EAAE,UAAU,CAAC,iBAAiB;YAChC,KAAK,EAAE,mBAAmB;YAC1B,QAAQ,EAAE,sCAAsC;YAChD,KAAK,EAAE,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;SACtD;QACD;YACE,EAAE,EAAE,UAAU,CAAC,UAAU;YACzB,KAAK,EAAE,YAAY;YACnB,QAAQ,EAAE,6BAA6B;YACvC,KAAK,EAAE;gBACL,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;gBAC5C,OAAO,CAAC,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;aAChE;SACF;QACD;YACE,EAAE,EAAE,UAAU,CAAC,UAAU;YACzB,KAAK,EAAE,YAAY;YACnB,QAAQ,EAAE,yBAAyB;YACnC,KAAK,EAAE;gBACL,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;gBAC3C,OAAO,CAAC,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;aAC/D;SACF;QACD;YACE,EAAE,EAAE,UAAU,CAAC,YAAY;YAC3B,KAAK,EAAE,cAAc;YACrB,QAAQ,EAAE,qBAAqB;YAC/B,KAAK,EAAE;gBACL,WAAW,CAAC,KAAK,CAAC,KAAK,CAAC;gBACxB,OAAO,CAAC,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;aAC5C;SACF;QACD;YACE,EAAE,EAAE,UAAU,CAAC,mBAAmB;YAClC,KAAK,EAAE,qBAAqB;YAC5B,QAAQ,EAAE,+BAA+B;YACzC,KAAK,EAAE,CAAC,WAAW,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;SACxD;QACD;YACE,EAAE,EAAE,UAAU,CAAC,YAAY;YAC3B,KAAK,EAAE,cAAc;YACrB,QAAQ,EAAE,2BAA2B;YACrC,KAAK,EAAE;gBACL,WAAW,CAAC,MAAM,CAAC,WAAW,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;gBAChD,OAAO,CAAC,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;aACpE;SACF;QACD;YACE,EAAE,EAAE,UAAU,CAAC,YAAY;YAC3B,KAAK,EAAE,cAAc;YACrB,QAAQ,EAAE,uBAAuB;YACjC,KAAK,EAAE;gBACL,WAAW,CAAC,MAAM,CAAC,WAAW,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;gBAC/C,OAAO,CAAC,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;aACnE;SACF;QACD;YACE,EAAE,EAAE,UAAU,CAAC,SAAS;YACxB,KAAK,EAAE,WAAW;YAClB,QAAQ,EAAE,2BAA2B;YACrC,KAAK,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;SACzE;QACD;YACE,EAAE,EAAE,UAAU,CAAC,gBAAgB;YAC/B,KAAK,EAAE,kBAAkB;YACzB,QAAQ,EAAE,qCAAqC;YAC/C,KAAK,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;SACrD;QACD;YACE,EAAE,EAAE,UAAU,CAAC,SAAS;YACxB,KAAK,EAAE,WAAW;YAClB,QAAQ,EAAE,4BAA4B;YACtC,KAAK,EAAE;gBACL,QAAQ,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;gBAC1C,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;aAC9D;SACF;QACD;YACE,EAAE,EAAE,UAAU,CAAC,SAAS;YACxB,KAAK,EAAE,WAAW;YAClB,QAAQ,EAAE,wBAAwB;YAClC,KAAK,EAAE;gBACL,QAAQ,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;gBACzC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;aAC7D;SACF;QACD;YACE,EAAE,EAAE,UAAU,CAAC,WAAW;YAC1B,KAAK,EAAE,aAAa;YACpB,QAAQ,EAAE,kCAAkC;YAC5C,KAAK,EAAE;gBACL,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC;gBACxC,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC;aACzC;SACF;QACD;YACE,EAAE,EAAE,UAAU,CAAC,YAAY;YAC3B,KAAK,EAAE,cAAc;YACrB,QAAQ,EAAE,mCAAmC;YAC7C,KAAK,EAAE;gBACL,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC;gBACzC,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC;aACzC;SACF;QACD;YACE,EAAE,EAAE,UAAU,CAAC,YAAY;YAC3B,KAAK,EAAE,cAAc;YACrB,QAAQ,EAAE,mCAAmC;YAC7C,KAAK,EAAE;gBACL,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC;gBACzC,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC;aACzC;SACF;QACD;YACE,EAAE,EAAE,UAAU,CAAC,YAAY;YAC3B,KAAK,EAAE,cAAc;YACrB,QAAQ,EAAE,mCAAmC;YAC7C,KAAK,EAAE;gBACL,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC;gBACzC,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC;aACzC;SACF;QACD;YACE,EAAE,EAAE,UAAU,CAAC,YAAY;YAC3B,KAAK,EAAE,cAAc;YACrB,QAAQ,EAAE,mCAAmC;YAC7C,KAAK,EAAE;gBACL,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC;gBACzC,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC;aACzC;SACF;QACD;YACE,EAAE,EAAE,UAAU,CAAC,aAAa;YAC5B,KAAK,EAAE,eAAe;YACtB,QAAQ,EAAE,oCAAoC;YAC9C,KAAK,EAAE;gBACL,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,GAAG,CAAC,CAAC;gBAC1C,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC;aACzC;SACF;QACD;YACE,EAAE,EAAE,UAAU,CAAC,aAAa;YAC5B,KAAK,EAAE,eAAe;YACtB,QAAQ,EAAE,oCAAoC;YAC9C,KAAK,EAAE;gBACL,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,GAAG,CAAC,CAAC;gBAC1C,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC;aACzC;SACF;KACF,CAAC;AACJ,CAAC,EA3PgB,kBAAkB,KAAlB,kBAAkB,QA2PlC","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  Input,\n  Output,\n} from '@angular/core';\nimport { timeDay, timeMonth, timeSunday, timeWeek, timeYear } from 'd3-time';\nimport {\n  BehaviorSubject,\n  Observable,\n  Subject,\n  combineLatest,\n  distinctUntilChanged,\n  filter,\n  map,\n  merge,\n  scan,\n  shareReplay,\n  skipUntil,\n  startWith,\n  withLatestFrom,\n} from 'rxjs';\nimport { DatePipe } from '../../format/pipes/date.pipe';\nimport { LocalStorage } from '../../util/local-storage';\nimport { CalendarComponent } from '../calendar/calendar.component';\nimport { InputLabelComponent } from '../input-label/input-label.component';\nconst timeQuarter = timeMonth.every(3)!;\n\n// TODO: once we upgrade to Angular 16, this component can be cleaned up with\n// signals instead of RxJS.\n// https://www.notion.so/rivet/Resolve-TODOs-after-Angular-upgrade-1f2667eb2a3180b79f6ad92a7e576f08\n@Component({\n  selector: 'riv-date-range',\n  templateUrl: './date-range.component.html',\n  styleUrls: ['./date-range.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DateRangeComponent extends InputLabelComponent {\n  readonly TODAY = new Date();\n  readonly STORAGE_KEY = 'date-range.default';\n\n  private readonly showPresets$ = new BehaviorSubject<boolean>(true);\n  @Input()\n  set showPresets(v: boolean) {\n    this.showPresets$.next(v);\n  }\n  get showPresets(): boolean {\n    return this.showPresets$.getValue();\n  }\n\n  readonly min$ = new BehaviorSubject<Date>(CalendarComponent.defaultMin);\n  @Input()\n  set min(v: Date) {\n    this.min$.next(v);\n  }\n  get min(): Date {\n    return this.min$.getValue();\n  }\n\n  readonly max$ = new BehaviorSubject<Date>(CalendarComponent.defaultMax);\n  @Input()\n  set max(v: Date) {\n    this.max$.next(v);\n  }\n  get max(): Date {\n    return this.max$.getValue();\n  }\n\n  readonly value$ = new BehaviorSubject<[Date, Date] | undefined>(undefined);\n  @Input()\n  set value(v: [Date, Date] | undefined) {\n    this.value$.next(v);\n  }\n  get value(): [Date, Date] | undefined {\n    return this.value$.getValue();\n  }\n\n  readonly placeholder$ = new BehaviorSubject<string>('Select date range...');\n  @Input()\n  set placeholder(v: string) {\n    this.placeholder$.next(v);\n  }\n  get placeholder(): string {\n    return this.placeholder$.getValue();\n  }\n\n  readonly disabled$ = new BehaviorSubject(false);\n  @Input()\n  set disabled(v: boolean) {\n    this.disabled$.next(v);\n  }\n  get disabled(): boolean {\n    return this.disabled$.getValue();\n  }\n\n  readonly alternativePresetList$ = new BehaviorSubject<\n    DateRangeComponent.PresetType[]\n  >([]);\n  @Input()\n  set alternativePresetList(v: DateRangeComponent.PresetType[]) {\n    this.alternativePresetList$.next(v);\n  }\n  get alternativePresetList(): DateRangeComponent.PresetType[] {\n    return this.alternativePresetList$.getValue();\n  }\n\n  readonly open$ = new BehaviorSubject(false);\n\n  readonly userSelectedPreset$ =\n    new Subject<DateRangeComponent.Preset | null>();\n\n  readonly userSelectedDate$ = new Subject<Date | undefined>();\n  readonly selectedValue$: Observable<Date | [Date, Date] | undefined> = merge(\n    this.value$,\n    this.userSelectedDate$.pipe(\n      scan(\n        (previous: Date | [Date, Date] | undefined, date: Date | undefined) => {\n          if (previous instanceof Date && date instanceof Date) {\n            if (date.valueOf() >= previous.valueOf()) {\n              const pair: [Date, Date] = [previous, date];\n              return pair;\n            }\n          }\n          return date;\n        },\n      ),\n    ),\n    this.userSelectedPreset$.pipe(\n      filter((preset): preset is DateRangeComponent.Preset => preset !== null),\n      map(preset => preset.dates),\n    ),\n  ).pipe(shareReplay({ refCount: true, bufferSize: 1 }));\n\n  readonly filteredPresetOptions$ = combineLatest([\n    this.min$,\n    this.max$,\n    this.alternativePresetList$,\n  ]).pipe(\n    map(([min, max, alternativePresetList]) => {\n      const optionsFilteredOnMinMax = DateRangeComponent.Presets.filter(\n        p =>\n          p.dates[0].valueOf() >= min.valueOf() &&\n          p.dates[1].valueOf() <= max.valueOf(),\n      );\n      if (alternativePresetList.length == 0) {\n        return optionsFilteredOnMinMax;\n      } else {\n        const optionsFilteredOnAlternativePresetList =\n          optionsFilteredOnMinMax.filter(p =>\n            alternativePresetList.includes(p.id),\n          );\n        return optionsFilteredOnAlternativePresetList;\n      }\n    }),\n    shareReplay({ refCount: true, bufferSize: 1 }),\n  );\n\n  readonly selectedPreset$: Observable<DateRangeComponent.Preset | null> =\n    combineLatest([\n      this.selectedValue$,\n      this.userSelectedPreset$.pipe(startWith(null)),\n    ]).pipe(\n      map(([selectedValue, userSelectedPreset]) => {\n        if (selectedValue instanceof Array) {\n          const options = DateRangeComponent.Presets.filter(\n            preset =>\n              preset.dates[0].valueOf() === selectedValue[0].valueOf() &&\n              preset.dates[1].valueOf() === selectedValue[1].valueOf(),\n          );\n          if (options.length) {\n            // Some date ranges match multiple presets, e.g. on Jan 19th, a\n            // selected date range of Jan 1-19 would correspond to \"this month\n            // so far,\" \"this quarter so far,\" and \"this year so far.\" We'll\n            // use the user's most recent manual selection as a tie breaker\n            // where possible.\n            const mostRecent = options.find(\n              option => option.id === userSelectedPreset?.id,\n            );\n            if (mostRecent) return mostRecent;\n            return options[0];\n          }\n        }\n        return null;\n      }),\n    );\n\n  readonly favoritePresetIds$ = new LocalStorage<string[]>(\n    this.STORAGE_KEY,\n    [],\n  );\n\n  setFavorite(preset: DateRangeComponent.Preset, favorite: boolean) {\n    const ids = new Set(this.favoritePresetIds$.getValue());\n    if (favorite) {\n      ids.add(preset.id);\n    } else {\n      ids.delete(preset.id);\n    }\n    this.favoritePresetIds$.next([...ids]);\n  }\n\n  readonly favoritePresets$: Observable<DateRangeComponent.Preset[]> =\n    this.favoritePresetIds$.pipe(\n      withLatestFrom(this.alternativePresetList$),\n      map(([ids, alternativePresetList]) => {\n        const favoritePresets = ids\n          .map(id =>\n            DateRangeComponent.Presets.find(preset => preset.id === id),\n          )\n          .filter((p): p is DateRangeComponent.Preset => p !== undefined);\n\n        if (alternativePresetList.length == 0) {\n          return favoritePresets;\n        } else {\n          const favoritesFilteredOnAlternativePresetList =\n            favoritePresets.filter(p =>\n              alternativePresetList.includes(\n                <DateRangeComponent.PresetType>p.id,\n              ),\n            );\n          return favoritesFilteredOnAlternativePresetList;\n        }\n      }),\n      shareReplay({ refCount: true, bufferSize: 1 }),\n    );\n\n  readonly userLeftActiveYearMonth$ = new Subject<Date>();\n  readonly userRightActiveYearMonth$ = new Subject<Date>();\n\n  readonly leftMin$ = this.min$.pipe(\n    shareReplay({ refCount: true, bufferSize: 1 }),\n  );\n  readonly leftMax$ = this.max$.pipe(\n    map(max => timeDay.offset(timeMonth.floor(max), -1)),\n    shareReplay({ refCount: true, bufferSize: 1 }),\n  );\n  readonly rightMax$ = this.max$.pipe(\n    shareReplay({ refCount: true, bufferSize: 1 }),\n  );\n\n  readonly leftActiveYearMonth$ = combineLatest([\n    this.leftMax$,\n    merge(\n      this.userLeftActiveYearMonth$.pipe(\n        startWith(timeMonth.floor(this.TODAY)),\n      ),\n      this.userSelectedPreset$.pipe(\n        filter(\n          (preset): preset is DateRangeComponent.Preset => preset !== null,\n        ),\n        map(preset => timeMonth.floor(preset.dates[0])),\n      ),\n      this.value$.pipe(\n        filter((v): v is [Date, Date] => v !== undefined),\n        map(v => timeMonth.floor(v[0])),\n      ),\n    ),\n  ]).pipe(\n    map(([leftMax, left]) => {\n      if (left.valueOf() >= leftMax.valueOf()) return timeMonth.floor(leftMax);\n      else return left;\n    }),\n    shareReplay({ refCount: true, bufferSize: 1 }),\n  );\n\n  readonly rightActiveYearMonth$ = combineLatest([\n    this.leftActiveYearMonth$,\n    merge(\n      this.userRightActiveYearMonth$.pipe(\n        startWith(timeMonth.ceil(this.TODAY)),\n      ),\n      this.userSelectedPreset$.pipe(\n        filter(\n          (preset): preset is DateRangeComponent.Preset => preset !== null,\n        ),\n        map(preset => timeMonth.floor(preset.dates[1])),\n      ),\n      this.value$.pipe(\n        filter((v): v is [Date, Date] => v !== undefined),\n        map(v => timeMonth.floor(v[1])),\n      ),\n    ),\n    this.rightMax$,\n  ]).pipe(\n    map(([left, userRight, rightMax$]) => {\n      if (left.valueOf() >= userRight.valueOf())\n        return timeMonth.floor(timeMonth.offset(left, 1));\n      else if (userRight.valueOf() >= rightMax$.valueOf())\n        return timeMonth.floor(rightMax$);\n      else return userRight;\n    }),\n    shareReplay({ refCount: true, bufferSize: 1 }),\n  );\n\n  readonly rightMin$ = this.leftActiveYearMonth$.pipe(\n    map(left => timeMonth.floor(timeMonth.offset(left, 1))),\n    shareReplay({ refCount: true, bufferSize: 1 }),\n  );\n\n  readonly leftOmitRange$: Observable<[Date, Date]> =\n    this.rightActiveYearMonth$.pipe(\n      map<Date, [Date, Date]>(rightActiveYearMonth => {\n        const first = timeMonth.floor(rightActiveYearMonth);\n        const last = timeDay.offset(\n          timeMonth.floor(timeMonth.offset(rightActiveYearMonth, 1)),\n          -1,\n        );\n        return [first, last];\n      }),\n      shareReplay({ refCount: true, bufferSize: 1 }),\n    );\n\n  readonly userInteracted$ = merge(\n    this.userSelectedDate$,\n    this.userSelectedPreset$,\n  );\n\n  @Output()\n  readonly valueChange: Observable<[Date, Date] | undefined> =\n    this.selectedValue$.pipe(\n      skipUntil(\n        merge(\n          this.userInteracted$,\n          this.selectedValue$.pipe(filter(v => v !== undefined)),\n        ),\n      ),\n      filter((v): v is [Date, Date] | undefined => !(v instanceof Date)),\n      distinctUntilChanged(\n        (previous, current) =>\n          previous?.[0].valueOf() === current?.[0].valueOf() &&\n          previous?.[1].valueOf() === current?.[1].valueOf(),\n      ),\n      shareReplay({ refCount: true, bufferSize: 1 }),\n    );\n\n  readonly displayValue$: Observable<string | undefined> =\n    this.valueChange.pipe(\n      map(v => {\n        if (v) {\n          return v.map(date => new DatePipe().transform(date)).join(' — ');\n        }\n        return undefined;\n      }),\n      shareReplay({ refCount: true, bufferSize: 1 }),\n    );\n}\n\nexport namespace DateRangeComponent {\n  const today = new Date();\n\n  export enum PresetType {\n    TODAY = 'today',\n    YESTERDAY = 'yesterday',\n    TOMORROW = 'tomorrow',\n    THIS_WEEK = 'this_week',\n    THIS_WEEK_SO_FAR = 'this_week_so_far',\n    LAST_WEEK = 'last_week',\n    NEXT_WEEK = 'next_week',\n    THIS_MONTH = 'this_month',\n    THIS_MONTH_SO_FAR = 'this_month_so_far',\n    LAST_MONTH = 'last_month',\n    NEXT_MONTH = 'next_month',\n    THIS_QUARTER = 'this_quarter',\n    THIS_QUARTER_SO_FAR = 'this_quarter_so_far',\n    LAST_QUARTER = 'last_quarter',\n    NEXT_QUARTER = 'next_quarter',\n    THIS_YEAR = 'this_year',\n    THIS_YEAR_SO_FAR = 'this_year_so_far',\n    LAST_YEAR = 'last_year',\n    NEXT_YEAR = 'next_year',\n    LAST_7_DAYS = 'last_7_days',\n    LAST_14_DAYS = 'last_14_days',\n    LAST_30_DAYS = 'last_30_days',\n    LAST_60_DAYS = 'last_60_days',\n    LAST_90_DAYS = 'last_90_days',\n    LAST_180_DAYS = 'last_180_days',\n    LAST_365_DAYS = 'last_365_days',\n  }\n\n  export type Preset = {\n    id: PresetType;\n    title: string;\n    subtitle: string;\n    dates: [Date, Date];\n  };\n\n  export const Presets: Preset[] = [\n    {\n      id: PresetType.TODAY,\n      title: 'Today',\n      subtitle: 'Today from midnight until the current time',\n      dates: [timeDay(), timeDay()],\n    },\n    {\n      id: PresetType.YESTERDAY,\n      title: 'Yesterday',\n      subtitle: 'The previous 24 hour day',\n      dates: [timeDay.offset(timeDay(), -1), timeDay.offset(timeDay(), -1)],\n    },\n    {\n      id: PresetType.TOMORROW,\n      title: 'Tomorrow',\n      subtitle: 'The next 24 hour day',\n      dates: [timeDay.offset(timeDay(), 1), timeDay.offset(timeDay(), 1)],\n    },\n    {\n      id: PresetType.THIS_WEEK,\n      title: 'This week',\n      subtitle: 'The current calendar week',\n      dates: [\n        timeSunday.floor(today),\n        timeDay.offset(timeSunday.ceil(today), -1),\n      ],\n    },\n    {\n      id: PresetType.THIS_WEEK_SO_FAR,\n      title: 'This week so far',\n      subtitle: 'The current calendar week up to now',\n      dates: [timeSunday.floor(today), timeDay.floor(today)],\n    },\n    {\n      id: PresetType.LAST_WEEK,\n      title: 'Last week',\n      subtitle: 'The previous calendar week',\n      dates: [\n        timeSunday.offset(timeWeek.floor(today), -1),\n        timeDay.offset(timeSunday.offset(timeWeek.ceil(today), -1), -1),\n      ],\n    },\n    {\n      id: PresetType.NEXT_WEEK,\n      title: 'Next week',\n      subtitle: 'The next calendar week',\n      dates: [\n        timeSunday.offset(timeWeek.floor(today), 1),\n        timeDay.offset(timeSunday.offset(timeWeek.ceil(today), 1), -1),\n      ],\n    },\n    {\n      id: PresetType.THIS_MONTH,\n      title: 'This month',\n      subtitle: 'The current calendar month',\n      dates: [\n        timeMonth.floor(today),\n        timeDay.offset(timeMonth.ceil(today), -1),\n      ],\n    },\n    {\n      id: PresetType.THIS_MONTH_SO_FAR,\n      title: 'This month so far',\n      subtitle: 'The current calendar month up to now',\n      dates: [timeMonth.floor(today), timeDay.floor(today)],\n    },\n    {\n      id: PresetType.LAST_MONTH,\n      title: 'Last month',\n      subtitle: 'The previous calendar month',\n      dates: [\n        timeMonth.offset(timeMonth.floor(today), -1),\n        timeDay.offset(timeMonth.offset(timeMonth.ceil(today), -1), -1),\n      ],\n    },\n    {\n      id: PresetType.NEXT_MONTH,\n      title: 'Next month',\n      subtitle: 'The next calendar month',\n      dates: [\n        timeMonth.offset(timeMonth.floor(today), 1),\n        timeDay.offset(timeMonth.offset(timeMonth.ceil(today), 1), -1),\n      ],\n    },\n    {\n      id: PresetType.THIS_QUARTER,\n      title: 'This quarter',\n      subtitle: 'The current quarter',\n      dates: [\n        timeQuarter.floor(today),\n        timeDay.offset(timeQuarter.ceil(today), -1),\n      ],\n    },\n    {\n      id: PresetType.THIS_QUARTER_SO_FAR,\n      title: 'This quarter so far',\n      subtitle: 'The current quarter up to now',\n      dates: [timeQuarter.floor(today), timeDay.floor(today)],\n    },\n    {\n      id: PresetType.LAST_QUARTER,\n      title: 'Last quarter',\n      subtitle: 'The previous full quarter',\n      dates: [\n        timeQuarter.offset(timeQuarter.floor(today), -1),\n        timeDay.offset(timeQuarter.offset(timeQuarter.ceil(today), -1), -1),\n      ],\n    },\n    {\n      id: PresetType.NEXT_QUARTER,\n      title: 'Next quarter',\n      subtitle: 'The next full quarter',\n      dates: [\n        timeQuarter.offset(timeQuarter.floor(today), 1),\n        timeDay.offset(timeQuarter.offset(timeQuarter.ceil(today), 1), -1),\n      ],\n    },\n    {\n      id: PresetType.THIS_YEAR,\n      title: 'This year',\n      subtitle: 'The current calendar year',\n      dates: [timeYear.floor(today), timeDay.offset(timeYear.ceil(today), -1)],\n    },\n    {\n      id: PresetType.THIS_YEAR_SO_FAR,\n      title: 'This year so far',\n      subtitle: 'The current calendar year up to now',\n      dates: [timeYear.floor(today), timeDay.floor(today)],\n    },\n    {\n      id: PresetType.LAST_YEAR,\n      title: 'Last year',\n      subtitle: 'The previous calendar year',\n      dates: [\n        timeYear.offset(timeYear.floor(today), -1),\n        timeDay.offset(timeYear.offset(timeYear.ceil(today), -1), -1),\n      ],\n    },\n    {\n      id: PresetType.NEXT_YEAR,\n      title: 'Next year',\n      subtitle: 'The next calendar year',\n      dates: [\n        timeYear.offset(timeYear.floor(today), 1),\n        timeDay.offset(timeYear.offset(timeYear.ceil(today), 1), -1),\n      ],\n    },\n    {\n      id: PresetType.LAST_7_DAYS,\n      title: 'Last 7 days',\n      subtitle: 'The previous 7 days before today',\n      dates: [\n        timeDay.floor(timeDay.offset(today, -8)),\n        timeDay.floor(timeDay.offset(today, -1)),\n      ],\n    },\n    {\n      id: PresetType.LAST_14_DAYS,\n      title: 'Last 14 days',\n      subtitle: 'The previous 14 days before today',\n      dates: [\n        timeDay.floor(timeDay.offset(today, -15)),\n        timeDay.floor(timeDay.offset(today, -1)),\n      ],\n    },\n    {\n      id: PresetType.LAST_30_DAYS,\n      title: 'Last 30 days',\n      subtitle: 'The previous 30 days before today',\n      dates: [\n        timeDay.floor(timeDay.offset(today, -31)),\n        timeDay.floor(timeDay.offset(today, -1)),\n      ],\n    },\n    {\n      id: PresetType.LAST_60_DAYS,\n      title: 'Last 60 days',\n      subtitle: 'The previous 60 days before today',\n      dates: [\n        timeDay.floor(timeDay.offset(today, -61)),\n        timeDay.floor(timeDay.offset(today, -1)),\n      ],\n    },\n    {\n      id: PresetType.LAST_90_DAYS,\n      title: 'Last 90 days',\n      subtitle: 'The previous 90 days before today',\n      dates: [\n        timeDay.floor(timeDay.offset(today, -91)),\n        timeDay.floor(timeDay.offset(today, -1)),\n      ],\n    },\n    {\n      id: PresetType.LAST_180_DAYS,\n      title: 'Last 180 days',\n      subtitle: 'The previous 180 days before today',\n      dates: [\n        timeDay.floor(timeDay.offset(today, -181)),\n        timeDay.floor(timeDay.offset(today, -1)),\n      ],\n    },\n    {\n      id: PresetType.LAST_365_DAYS,\n      title: 'Last 365 days',\n      subtitle: 'The previous 365 days before today',\n      dates: [\n        timeDay.floor(timeDay.offset(today, -366)),\n        timeDay.floor(timeDay.offset(today, -1)),\n      ],\n    },\n  ];\n}\n","<riv-input-label\n  [label]=\"label\"\n  [help]=\"help\"\n  [required]=\"required\"\n  [labelActionText]=\"labelActionText\"\n  (labelAction)=\"labelAction.emit($event)\"\n>\n  <button\n    #trigger\n    class=\"trigger\"\n    (click)=\"open$.next(true)\"\n    [disabled]=\"disabled$ | async\"\n    type=\"button\"\n  >\n    <ng-container\n      *ngIf=\"displayValue$ | async; else placeholderValue; let display\"\n    >\n      <span class=\"value\">{{ display }}</span>\n    </ng-container>\n    <ng-template #placeholderValue>\n      <span class=\"value placeholder\">{{ placeholder$ | async }}</span>\n    </ng-template>\n    <span class=\"chevron\">\n      <riv-icon [name]=\"'Calendar'\" [size]=\"16\"></riv-icon>\n    </span>\n  </button>\n</riv-input-label>\n\n<ng-template\n  #self\n  [ngTemplateOutlet]=\"self\"\n  let-inputValue\n  [ngTemplateOutletContext]=\"{ $implicit: (value$ | async) }\"\n>\n  <ng-container *ngIf=\"open$ | async\">\n    <riv-callout\n      *riv-overlay\n      [anchor]=\"trigger\"\n      [showCaret]=\"false\"\n      [theme]=\"'light'\"\n      [allowedPositions]=\"[\n        'top-left',\n        'top-center',\n        'top-right',\n        'bottom-right',\n        'bottom-center',\n        'bottom-left'\n      ]\"\n      [preferredPosition]=\"'bottom-right'\"\n      (close)=\"open$.next(false); userSelectedDate$.next(inputValue)\"\n    >\n      <div class=\"content\">\n        <div *ngIf=\"showPresets\" class=\"presets\">\n          <riv-simple-select\n            [label]=\"'Date presets'\"\n            [filterabilityOptions]=\"{ enabled: true, placeholder: 'Search...' }\"\n            [optionGroups]=\"\n              (filteredPresetOptions$ | async) ?? [] | rivOptionGroup\n            \"\n            [selectedOption]=\"selectedPreset$ | async\"\n            (selectedOptionChange)=\"userSelectedPreset$.next($event)\"\n          >\n            <ng-template #option let-node=\"node\">\n              <ng-template\n                #self\n                [ngTemplateOutlet]=\"self\"\n                let-isFavorite\n                [ngTemplateOutletContext]=\"{\n                  $implicit: (favoritePresetIds$ | async)?.includes(node.id)\n                }\"\n              >\n                <div class=\"preset\" [class.favorite]=\"isFavorite\">\n                  <div class=\"description\">\n                    <riv-highlight\n                      class=\"title\"\n                      [text]=\"node.title\"\n                      [indices]=\"node.titleHighlightIndices || []\"\n                    ></riv-highlight>\n                    <riv-highlight\n                      class=\"subtitle\"\n                      [text]=\"node.subtitle\"\n                      [indices]=\"node.subtitleHighlightIndices || []\"\n                    ></riv-highlight>\n                  </div>\n                  <button\n                    (click)=\"\n                      setFavorite(node, !isFavorite); $event.stopPropagation()\n                    \"\n                    type=\"button\"\n                  >\n                    <riv-icon\n                      [name]=\"isFavorite ? 'HeartActive' : 'Heart'\"\n                      [size]=\"16\"\n                      [rivTooltip]=\"'Mark as favorite'\"\n                    ></riv-icon>\n                  </button>\n                </div>\n              </ng-template>\n            </ng-template>\n          </riv-simple-select>\n          <ng-template\n            #self\n            [ngTemplateOutlet]=\"self\"\n            let-favorites\n            [ngTemplateOutletContext]=\"{ $implicit: favoritePresets$ | async }\"\n          >\n            <riv-input-label *ngIf=\"favorites.length\" [label]=\"'Favorites'\">\n              <div class=\"shortcuts\">\n                <button\n                  *ngFor=\"let favorite of favorites\"\n                  class=\"shortcut\"\n                  [class.active]=\"(selectedPreset$ | async)?.id === favorite.id\"\n                  (click)=\"userSelectedPreset$.next(favorite)\"\n                  type=\"button\"\n                >\n                  <span class=\"title\">{{ favorite.title }}</span>\n                  <button\n                    (click)=\"setFavorite(favorite, false)\"\n                    [rivTooltip]=\"'Remove favorite'\"\n                    type=\"button\"\n                  >\n                    <riv-icon [name]=\"'HeartActive'\" [size]=\"16\"></riv-icon>\n                  </button>\n                </button>\n              </div>\n            </riv-input-label>\n          </ng-template>\n        </div>\n\n        <div class=\"calendars\">\n          <riv-calendar\n            class=\"left\"\n            [activeYearMonth]=\"(leftActiveYearMonth$ | async) || TODAY\"\n            (activeYearMonthChange)=\"userLeftActiveYearMonth$.next($event)\"\n            [displayMin]=\"(min$ | async) || TODAY\"\n            [displayMax]=\"(max$ | async) || TODAY\"\n            [selectableMin]=\"(leftMin$ | async) || TODAY\"\n            [selectableMax]=\"(leftMax$ | async) || TODAY\"\n            [omitRange]=\"(leftOmitRange$ | async) || [TODAY, TODAY]\"\n            [selectedValue]=\"(selectedValue$ | async) || TODAY\"\n            (dateSelect)=\"userSelectedDate$.next($event)\"\n          ></riv-calendar>\n          <riv-calendar\n            class=\"right\"\n            [activeYearMonth]=\"(rightActiveYearMonth$ | async) || TODAY\"\n            (activeYearMonthChange)=\"userRightActiveYearMonth$.next($event)\"\n            [displayMin]=\"(min$ | async) || TODAY\"\n            [displayMax]=\"(max$ | async) || TODAY\"\n            [selectableMin]=\"(rightMin$ | async) || TODAY\"\n            [selectableMax]=\"(rightMax$ | async) || TODAY\"\n            [selectedValue]=\"(selectedValue$ | async) || TODAY\"\n            (dateSelect)=\"userSelectedDate$.next($event)\"\n          ></riv-calendar>\n        </div>\n\n        <footer class=\"buttons\">\n          <button\n            rivButton\n            [size]=\"'small'\"\n            [variant]=\"'ghost'\"\n            (click)=\"userSelectedDate$.next(undefined)\"\n            type=\"button\"\n          >\n            Clear\n          </button>\n          <button\n            rivButton\n            [size]=\"'small'\"\n            [variant]=\"'primary'\"\n            (click)=\"open$.next(false)\"\n            type=\"button\"\n          >\n            Done\n          </button>\n        </footer>\n      </div>\n    </riv-callout>\n  </ng-container>\n</ng-template>\n"]}
|
|
462
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-range.component.js","sourceRoot":"","sources":["../../../../../../projects/riv/src/lib/input/date-range/date-range.component.ts","../../../../../../projects/riv/src/lib/input/date-range/date-range.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  Input,\n  Output,\n} from '@angular/core';\nimport { timeDay, timeMonth, timeSunday, timeWeek, timeYear } from 'd3-time';\nimport {\n  BehaviorSubject,\n  Observable,\n  Subject,\n  combineLatest,\n  distinctUntilChanged,\n  filter,\n  map,\n  merge,\n  scan,\n  shareReplay,\n  skipUntil,\n  startWith,\n} from 'rxjs';\nimport { DatePipe } from '../../format/pipes/date.pipe';\nimport { LocalStorage } from '../../util/local-storage';\nimport { CalendarComponent } from '../calendar/calendar.component';\nimport { InputLabelComponent } from '../input-label/input-label.component';\nconst timeQuarter = timeMonth.every(3)!;\n\n// TODO: once we upgrade to Angular 16, this component can be cleaned up with\n// signals instead of RxJS.\n// https://www.notion.so/rivet/Resolve-TODOs-after-Angular-upgrade-1f2667eb2a3180b79f6ad92a7e576f08\n@Component({\n  selector: 'riv-date-range',\n  templateUrl: './date-range.component.html',\n  styleUrls: ['./date-range.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DateRangeComponent extends InputLabelComponent {\n  readonly TODAY = new Date();\n  readonly STORAGE_KEY = 'date-range.default';\n\n  private readonly showPresets$ = new BehaviorSubject<boolean>(true);\n  @Input()\n  set showPresets(v: boolean) {\n    this.showPresets$.next(v);\n  }\n  get showPresets(): boolean {\n    return this.showPresets$.getValue();\n  }\n\n  readonly min$ = new BehaviorSubject<Date>(CalendarComponent.defaultMin);\n  @Input()\n  set min(v: Date) {\n    this.min$.next(v);\n  }\n  get min(): Date {\n    return this.min$.getValue();\n  }\n\n  readonly max$ = new BehaviorSubject<Date>(CalendarComponent.defaultMax);\n  @Input()\n  set max(v: Date) {\n    this.max$.next(v);\n  }\n  get max(): Date {\n    return this.max$.getValue();\n  }\n\n  readonly value$ = new BehaviorSubject<[Date, Date] | undefined>(undefined);\n  @Input()\n  set value(v: [Date, Date] | undefined) {\n    this.value$.next(v);\n  }\n  get value(): [Date, Date] | undefined {\n    return this.value$.getValue();\n  }\n\n  readonly placeholder$ = new BehaviorSubject<string>('Select date range...');\n  @Input()\n  set placeholder(v: string) {\n    this.placeholder$.next(v);\n  }\n  get placeholder(): string {\n    return this.placeholder$.getValue();\n  }\n\n  readonly disabled$ = new BehaviorSubject(false);\n  @Input()\n  set disabled(v: boolean) {\n    this.disabled$.next(v);\n  }\n  get disabled(): boolean {\n    return this.disabled$.getValue();\n  }\n\n  readonly alternativePresetList$ = new BehaviorSubject<\n    DateRangeComponent.PresetType[]\n  >([]);\n  @Input()\n  set alternativePresetList(v: DateRangeComponent.PresetType[]) {\n    this.alternativePresetList$.next(v);\n  }\n  get alternativePresetList(): DateRangeComponent.PresetType[] {\n    return this.alternativePresetList$.getValue();\n  }\n\n  readonly open$ = new BehaviorSubject(false);\n\n  readonly userSelectedPreset$ =\n    new Subject<DateRangeComponent.Preset | null>();\n\n  readonly userSelectedDate$ = new Subject<Date | undefined>();\n  readonly selectedValue$: Observable<Date | [Date, Date] | undefined> = merge(\n    this.value$,\n    this.userSelectedDate$.pipe(\n      scan(\n        (previous: Date | [Date, Date] | undefined, date: Date | undefined) => {\n          if (previous instanceof Date && date instanceof Date) {\n            if (date.valueOf() >= previous.valueOf()) {\n              const pair: [Date, Date] = [previous, date];\n              return pair;\n            }\n          }\n          return date;\n        },\n      ),\n    ),\n    this.userSelectedPreset$.pipe(\n      filter((preset): preset is DateRangeComponent.Preset => preset !== null),\n      map(preset => preset.dates),\n    ),\n  ).pipe(shareReplay({ refCount: true, bufferSize: 1 }));\n\n  readonly filteredPresetOptions$ = combineLatest([\n    this.min$,\n    this.max$,\n    this.alternativePresetList$,\n  ]).pipe(\n    map(([min, max, alternativePresetList]) => {\n      const optionsFilteredOnMinMax = DateRangeComponent.Presets.filter(\n        p =>\n          p.dates[0].valueOf() >= min.valueOf() &&\n          p.dates[1].valueOf() <= max.valueOf(),\n      );\n      if (alternativePresetList.length == 0) {\n        return optionsFilteredOnMinMax;\n      } else {\n        const optionsFilteredOnAlternativePresetList =\n          optionsFilteredOnMinMax.filter(p =>\n            alternativePresetList.includes(p.id),\n          );\n        return optionsFilteredOnAlternativePresetList;\n      }\n    }),\n    shareReplay({ refCount: true, bufferSize: 1 }),\n  );\n\n  readonly selectedPreset$: Observable<DateRangeComponent.Preset | null> =\n    combineLatest([\n      this.selectedValue$,\n      this.userSelectedPreset$.pipe(startWith(null)),\n    ]).pipe(\n      map(([selectedValue, userSelectedPreset]) => {\n        if (selectedValue instanceof Array) {\n          const options = DateRangeComponent.Presets.filter(\n            preset =>\n              preset.dates[0].valueOf() === selectedValue[0].valueOf() &&\n              preset.dates[1].valueOf() === selectedValue[1].valueOf(),\n          );\n          if (options.length) {\n            // Some date ranges match multiple presets, e.g. on Jan 19th, a\n            // selected date range of Jan 1-19 would correspond to \"this month\n            // so far,\" \"this quarter so far,\" and \"this year so far.\" We'll\n            // use the user's most recent manual selection as a tie breaker\n            // where possible.\n            const mostRecent = options.find(\n              option => option.id === userSelectedPreset?.id,\n            );\n            if (mostRecent) return mostRecent;\n            return options[0];\n          }\n        }\n        return null;\n      }),\n    );\n\n  readonly favoritePresetIds$ = new LocalStorage<string[]>(\n    this.STORAGE_KEY,\n    [],\n  );\n\n  setFavorite(preset: DateRangeComponent.Preset, favorite: boolean) {\n    const ids = new Set(this.favoritePresetIds$.getValue());\n    if (favorite) {\n      ids.add(preset.id);\n    } else {\n      ids.delete(preset.id);\n    }\n    this.favoritePresetIds$.next([...ids]);\n  }\n\n  readonly favoritePresets$: Observable<DateRangeComponent.Preset[]> =\n    combineLatest([\n      this.favoritePresetIds$,\n      this.filteredPresetOptions$,\n      this.alternativePresetList$,\n    ]).pipe(\n      map(([ids, presets, alternativePresetList]) => {\n        const favoritePresets = ids\n          .map(id => presets.find(preset => preset.id === id))\n          .filter((p): p is DateRangeComponent.Preset => p !== undefined);\n\n        if (alternativePresetList.length == 0) {\n          return favoritePresets;\n        } else {\n          const favoritesFilteredOnAlternativePresetList =\n            favoritePresets.filter(p =>\n              alternativePresetList.includes(\n                <DateRangeComponent.PresetType>p.id,\n              ),\n            );\n          return favoritesFilteredOnAlternativePresetList;\n        }\n      }),\n      shareReplay({ refCount: true, bufferSize: 1 }),\n    );\n\n  readonly userLeftActiveYearMonth$ = new Subject<Date>();\n  readonly userRightActiveYearMonth$ = new Subject<Date>();\n\n  readonly leftMin$ = this.min$.pipe(\n    shareReplay({ refCount: true, bufferSize: 1 }),\n  );\n  readonly leftMax$ = this.max$.pipe(\n    map(max => timeDay.offset(timeMonth.floor(max), -1)),\n    shareReplay({ refCount: true, bufferSize: 1 }),\n  );\n  readonly rightMax$ = this.max$.pipe(\n    shareReplay({ refCount: true, bufferSize: 1 }),\n  );\n\n  readonly leftActiveYearMonth$ = combineLatest([\n    this.leftMax$,\n    merge(\n      this.userLeftActiveYearMonth$.pipe(\n        startWith(timeMonth.floor(this.TODAY)),\n      ),\n      this.userSelectedPreset$.pipe(\n        filter(\n          (preset): preset is DateRangeComponent.Preset => preset !== null,\n        ),\n        map(preset => timeMonth.floor(preset.dates[0])),\n      ),\n      this.value$.pipe(\n        filter((v): v is [Date, Date] => v !== undefined),\n        map(v => timeMonth.floor(v[0])),\n      ),\n    ),\n  ]).pipe(\n    map(([leftMax, left]) => {\n      if (left.valueOf() >= leftMax.valueOf()) return timeMonth.floor(leftMax);\n      else return left;\n    }),\n    shareReplay({ refCount: true, bufferSize: 1 }),\n  );\n\n  readonly rightActiveYearMonth$ = combineLatest([\n    this.leftActiveYearMonth$,\n    merge(\n      this.userRightActiveYearMonth$.pipe(\n        startWith(timeMonth.ceil(this.TODAY)),\n      ),\n      this.userSelectedPreset$.pipe(\n        filter(\n          (preset): preset is DateRangeComponent.Preset => preset !== null,\n        ),\n        map(preset => timeMonth.floor(preset.dates[1])),\n      ),\n      this.value$.pipe(\n        filter((v): v is [Date, Date] => v !== undefined),\n        map(v => timeMonth.floor(v[1])),\n      ),\n    ),\n    this.rightMax$,\n  ]).pipe(\n    map(([left, userRight, rightMax$]) => {\n      if (left.valueOf() >= userRight.valueOf())\n        return timeMonth.floor(timeMonth.offset(left, 1));\n      else if (userRight.valueOf() >= rightMax$.valueOf())\n        return timeMonth.floor(rightMax$);\n      else return userRight;\n    }),\n    shareReplay({ refCount: true, bufferSize: 1 }),\n  );\n\n  readonly rightMin$ = this.leftActiveYearMonth$.pipe(\n    map(left => timeMonth.floor(timeMonth.offset(left, 1))),\n    shareReplay({ refCount: true, bufferSize: 1 }),\n  );\n\n  readonly leftOmitRange$: Observable<[Date, Date]> =\n    this.rightActiveYearMonth$.pipe(\n      map<Date, [Date, Date]>(rightActiveYearMonth => {\n        const first = timeMonth.floor(rightActiveYearMonth);\n        const last = timeDay.offset(\n          timeMonth.floor(timeMonth.offset(rightActiveYearMonth, 1)),\n          -1,\n        );\n        return [first, last];\n      }),\n      shareReplay({ refCount: true, bufferSize: 1 }),\n    );\n\n  readonly userInteracted$ = merge(\n    this.userSelectedDate$,\n    this.userSelectedPreset$,\n  );\n\n  @Output()\n  readonly valueChange: Observable<[Date, Date] | undefined> =\n    this.selectedValue$.pipe(\n      skipUntil(\n        merge(\n          this.userInteracted$,\n          this.selectedValue$.pipe(filter(v => v !== undefined)),\n        ),\n      ),\n      filter((v): v is [Date, Date] | undefined => !(v instanceof Date)),\n      distinctUntilChanged(\n        (previous, current) =>\n          previous?.[0].valueOf() === current?.[0].valueOf() &&\n          previous?.[1].valueOf() === current?.[1].valueOf(),\n      ),\n      shareReplay({ refCount: true, bufferSize: 1 }),\n    );\n\n  readonly displayValue$: Observable<string | undefined> =\n    this.valueChange.pipe(\n      map(v => {\n        if (v) {\n          return v.map(date => new DatePipe().transform(date)).join(' — ');\n        }\n        return undefined;\n      }),\n      shareReplay({ refCount: true, bufferSize: 1 }),\n    );\n}\n\nexport namespace DateRangeComponent {\n  const today = new Date();\n\n  export enum PresetType {\n    TODAY = 'today',\n    YESTERDAY = 'yesterday',\n    TOMORROW = 'tomorrow',\n    THIS_WEEK = 'this_week',\n    THIS_WEEK_SO_FAR = 'this_week_so_far',\n    LAST_WEEK = 'last_week',\n    NEXT_WEEK = 'next_week',\n    THIS_MONTH = 'this_month',\n    THIS_MONTH_SO_FAR = 'this_month_so_far',\n    LAST_MONTH = 'last_month',\n    NEXT_MONTH = 'next_month',\n    THIS_QUARTER = 'this_quarter',\n    THIS_QUARTER_SO_FAR = 'this_quarter_so_far',\n    LAST_QUARTER = 'last_quarter',\n    NEXT_QUARTER = 'next_quarter',\n    THIS_YEAR = 'this_year',\n    THIS_YEAR_SO_FAR = 'this_year_so_far',\n    LAST_YEAR = 'last_year',\n    NEXT_YEAR = 'next_year',\n    LAST_7_DAYS = 'last_7_days',\n    LAST_14_DAYS = 'last_14_days',\n    LAST_30_DAYS = 'last_30_days',\n    LAST_60_DAYS = 'last_60_days',\n    LAST_90_DAYS = 'last_90_days',\n    LAST_180_DAYS = 'last_180_days',\n    LAST_365_DAYS = 'last_365_days',\n  }\n\n  export type Preset = {\n    id: PresetType;\n    title: string;\n    subtitle: string;\n    dates: [Date, Date];\n  };\n\n  export const Presets: Preset[] = [\n    {\n      id: PresetType.TODAY,\n      title: 'Today',\n      subtitle: 'Today from midnight until the current time',\n      dates: [timeDay(), timeDay()],\n    },\n    {\n      id: PresetType.YESTERDAY,\n      title: 'Yesterday',\n      subtitle: 'The previous 24 hour day',\n      dates: [timeDay.offset(timeDay(), -1), timeDay.offset(timeDay(), -1)],\n    },\n    {\n      id: PresetType.TOMORROW,\n      title: 'Tomorrow',\n      subtitle: 'The next 24 hour day',\n      dates: [timeDay.offset(timeDay(), 1), timeDay.offset(timeDay(), 1)],\n    },\n    {\n      id: PresetType.THIS_WEEK,\n      title: 'This week',\n      subtitle: 'The current calendar week',\n      dates: [\n        timeSunday.floor(today),\n        timeDay.offset(timeSunday.ceil(today), -1),\n      ],\n    },\n    {\n      id: PresetType.THIS_WEEK_SO_FAR,\n      title: 'This week so far',\n      subtitle: 'The current calendar week up to now',\n      dates: [timeSunday.floor(today), timeDay.floor(today)],\n    },\n    {\n      id: PresetType.LAST_WEEK,\n      title: 'Last week',\n      subtitle: 'The previous calendar week',\n      dates: [\n        timeSunday.offset(timeWeek.floor(today), -1),\n        timeDay.offset(timeSunday.offset(timeWeek.ceil(today), -1), -1),\n      ],\n    },\n    {\n      id: PresetType.NEXT_WEEK,\n      title: 'Next week',\n      subtitle: 'The next calendar week',\n      dates: [\n        timeSunday.offset(timeWeek.floor(today), 1),\n        timeDay.offset(timeSunday.offset(timeWeek.ceil(today), 1), -1),\n      ],\n    },\n    {\n      id: PresetType.THIS_MONTH,\n      title: 'This month',\n      subtitle: 'The current calendar month',\n      dates: [\n        timeMonth.floor(today),\n        timeDay.offset(timeMonth.ceil(today), -1),\n      ],\n    },\n    {\n      id: PresetType.THIS_MONTH_SO_FAR,\n      title: 'This month so far',\n      subtitle: 'The current calendar month up to now',\n      dates: [timeMonth.floor(today), timeDay.floor(today)],\n    },\n    {\n      id: PresetType.LAST_MONTH,\n      title: 'Last month',\n      subtitle: 'The previous calendar month',\n      dates: [\n        timeMonth.offset(timeMonth.floor(today), -1),\n        timeDay.offset(timeMonth.offset(timeMonth.ceil(today), -1), -1),\n      ],\n    },\n    {\n      id: PresetType.NEXT_MONTH,\n      title: 'Next month',\n      subtitle: 'The next calendar month',\n      dates: [\n        timeMonth.offset(timeMonth.floor(today), 1),\n        timeDay.offset(timeMonth.offset(timeMonth.ceil(today), 1), -1),\n      ],\n    },\n    {\n      id: PresetType.THIS_QUARTER,\n      title: 'This quarter',\n      subtitle: 'The current quarter',\n      dates: [\n        timeQuarter.floor(today),\n        timeDay.offset(timeQuarter.ceil(today), -1),\n      ],\n    },\n    {\n      id: PresetType.THIS_QUARTER_SO_FAR,\n      title: 'This quarter so far',\n      subtitle: 'The current quarter up to now',\n      dates: [timeQuarter.floor(today), timeDay.floor(today)],\n    },\n    {\n      id: PresetType.LAST_QUARTER,\n      title: 'Last quarter',\n      subtitle: 'The previous full quarter',\n      dates: [\n        timeQuarter.offset(timeQuarter.floor(today), -1),\n        timeDay.offset(timeQuarter.offset(timeQuarter.ceil(today), -1), -1),\n      ],\n    },\n    {\n      id: PresetType.NEXT_QUARTER,\n      title: 'Next quarter',\n      subtitle: 'The next full quarter',\n      dates: [\n        timeQuarter.offset(timeQuarter.floor(today), 1),\n        timeDay.offset(timeQuarter.offset(timeQuarter.ceil(today), 1), -1),\n      ],\n    },\n    {\n      id: PresetType.THIS_YEAR,\n      title: 'This year',\n      subtitle: 'The current calendar year',\n      dates: [timeYear.floor(today), timeDay.offset(timeYear.ceil(today), -1)],\n    },\n    {\n      id: PresetType.THIS_YEAR_SO_FAR,\n      title: 'This year so far',\n      subtitle: 'The current calendar year up to now',\n      dates: [timeYear.floor(today), timeDay.floor(today)],\n    },\n    {\n      id: PresetType.LAST_YEAR,\n      title: 'Last year',\n      subtitle: 'The previous calendar year',\n      dates: [\n        timeYear.offset(timeYear.floor(today), -1),\n        timeDay.offset(timeYear.offset(timeYear.ceil(today), -1), -1),\n      ],\n    },\n    {\n      id: PresetType.NEXT_YEAR,\n      title: 'Next year',\n      subtitle: 'The next calendar year',\n      dates: [\n        timeYear.offset(timeYear.floor(today), 1),\n        timeDay.offset(timeYear.offset(timeYear.ceil(today), 1), -1),\n      ],\n    },\n    {\n      id: PresetType.LAST_7_DAYS,\n      title: 'Last 7 days',\n      subtitle: 'The previous 7 days before today',\n      dates: [\n        timeDay.floor(timeDay.offset(today, -8)),\n        timeDay.floor(timeDay.offset(today, -1)),\n      ],\n    },\n    {\n      id: PresetType.LAST_14_DAYS,\n      title: 'Last 14 days',\n      subtitle: 'The previous 14 days before today',\n      dates: [\n        timeDay.floor(timeDay.offset(today, -15)),\n        timeDay.floor(timeDay.offset(today, -1)),\n      ],\n    },\n    {\n      id: PresetType.LAST_30_DAYS,\n      title: 'Last 30 days',\n      subtitle: 'The previous 30 days before today',\n      dates: [\n        timeDay.floor(timeDay.offset(today, -31)),\n        timeDay.floor(timeDay.offset(today, -1)),\n      ],\n    },\n    {\n      id: PresetType.LAST_60_DAYS,\n      title: 'Last 60 days',\n      subtitle: 'The previous 60 days before today',\n      dates: [\n        timeDay.floor(timeDay.offset(today, -61)),\n        timeDay.floor(timeDay.offset(today, -1)),\n      ],\n    },\n    {\n      id: PresetType.LAST_90_DAYS,\n      title: 'Last 90 days',\n      subtitle: 'The previous 90 days before today',\n      dates: [\n        timeDay.floor(timeDay.offset(today, -91)),\n        timeDay.floor(timeDay.offset(today, -1)),\n      ],\n    },\n    {\n      id: PresetType.LAST_180_DAYS,\n      title: 'Last 180 days',\n      subtitle: 'The previous 180 days before today',\n      dates: [\n        timeDay.floor(timeDay.offset(today, -181)),\n        timeDay.floor(timeDay.offset(today, -1)),\n      ],\n    },\n    {\n      id: PresetType.LAST_365_DAYS,\n      title: 'Last 365 days',\n      subtitle: 'The previous 365 days before today',\n      dates: [\n        timeDay.floor(timeDay.offset(today, -366)),\n        timeDay.floor(timeDay.offset(today, -1)),\n      ],\n    },\n  ];\n}\n","<riv-input-label\n  [label]=\"label\"\n  [help]=\"help\"\n  [required]=\"required\"\n  [labelActionText]=\"labelActionText\"\n  (labelAction)=\"labelAction.emit($event)\"\n>\n  <button\n    #trigger\n    class=\"trigger\"\n    (click)=\"open$.next(true)\"\n    [disabled]=\"disabled$ | async\"\n    type=\"button\"\n  >\n    <ng-container\n      *ngIf=\"displayValue$ | async; else placeholderValue; let display\"\n    >\n      <span class=\"value\">{{ display }}</span>\n    </ng-container>\n    <ng-template #placeholderValue>\n      <span class=\"value placeholder\">{{ placeholder$ | async }}</span>\n    </ng-template>\n    <span class=\"chevron\">\n      <riv-icon [name]=\"'Calendar'\" [size]=\"16\"></riv-icon>\n    </span>\n  </button>\n</riv-input-label>\n\n<ng-template\n  #self\n  [ngTemplateOutlet]=\"self\"\n  let-inputValue\n  [ngTemplateOutletContext]=\"{ $implicit: (value$ | async) }\"\n>\n  <ng-container *ngIf=\"open$ | async\">\n    <riv-callout\n      *riv-overlay\n      [anchor]=\"trigger\"\n      [showCaret]=\"false\"\n      [theme]=\"'light'\"\n      [allowedPositions]=\"[\n        'top-left',\n        'top-center',\n        'top-right',\n        'bottom-right',\n        'bottom-center',\n        'bottom-left'\n      ]\"\n      [preferredPosition]=\"'bottom-right'\"\n      (close)=\"open$.next(false); userSelectedDate$.next(inputValue)\"\n    >\n      <div class=\"content\">\n        <div *ngIf=\"showPresets\" class=\"presets\">\n          <riv-simple-select\n            [label]=\"'Date presets'\"\n            [filterabilityOptions]=\"{ enabled: true, placeholder: 'Search...' }\"\n            [optionGroups]=\"\n              (filteredPresetOptions$ | async) ?? [] | rivOptionGroup\n            \"\n            [selectedOption]=\"selectedPreset$ | async\"\n            (selectedOptionChange)=\"userSelectedPreset$.next($event)\"\n          >\n            <ng-template #option let-node=\"node\">\n              <ng-template\n                #self\n                [ngTemplateOutlet]=\"self\"\n                let-isFavorite\n                [ngTemplateOutletContext]=\"{\n                  $implicit: (favoritePresetIds$ | async)?.includes(node.id)\n                }\"\n              >\n                <div class=\"preset\" [class.favorite]=\"isFavorite\">\n                  <div class=\"description\">\n                    <riv-highlight\n                      class=\"title\"\n                      [text]=\"node.title\"\n                      [indices]=\"node.titleHighlightIndices || []\"\n                    ></riv-highlight>\n                    <riv-highlight\n                      class=\"subtitle\"\n                      [text]=\"node.subtitle\"\n                      [indices]=\"node.subtitleHighlightIndices || []\"\n                    ></riv-highlight>\n                  </div>\n                  <button\n                    (click)=\"\n                      setFavorite(node, !isFavorite); $event.stopPropagation()\n                    \"\n                    type=\"button\"\n                  >\n                    <riv-icon\n                      [name]=\"isFavorite ? 'HeartActive' : 'Heart'\"\n                      [size]=\"16\"\n                      [rivTooltip]=\"'Mark as favorite'\"\n                    ></riv-icon>\n                  </button>\n                </div>\n              </ng-template>\n            </ng-template>\n          </riv-simple-select>\n          <ng-template\n            #self\n            [ngTemplateOutlet]=\"self\"\n            let-favorites\n            [ngTemplateOutletContext]=\"{ $implicit: favoritePresets$ | async }\"\n          >\n            <riv-input-label *ngIf=\"favorites.length\" [label]=\"'Favorites'\">\n              <div class=\"shortcuts\">\n                <button\n                  *ngFor=\"let favorite of favorites\"\n                  class=\"shortcut\"\n                  [class.active]=\"(selectedPreset$ | async)?.id === favorite.id\"\n                  (click)=\"userSelectedPreset$.next(favorite)\"\n                  type=\"button\"\n                >\n                  <span class=\"title\">{{ favorite.title }}</span>\n                  <button\n                    (click)=\"setFavorite(favorite, false)\"\n                    [rivTooltip]=\"'Remove favorite'\"\n                    type=\"button\"\n                  >\n                    <riv-icon [name]=\"'HeartActive'\" [size]=\"16\"></riv-icon>\n                  </button>\n                </button>\n              </div>\n            </riv-input-label>\n          </ng-template>\n        </div>\n\n        <div class=\"calendars\">\n          <riv-calendar\n            class=\"left\"\n            [activeYearMonth]=\"(leftActiveYearMonth$ | async) || TODAY\"\n            (activeYearMonthChange)=\"userLeftActiveYearMonth$.next($event)\"\n            [displayMin]=\"(min$ | async) || TODAY\"\n            [displayMax]=\"(max$ | async) || TODAY\"\n            [selectableMin]=\"(leftMin$ | async) || TODAY\"\n            [selectableMax]=\"(leftMax$ | async) || TODAY\"\n            [omitRange]=\"(leftOmitRange$ | async) || [TODAY, TODAY]\"\n            [selectedValue]=\"(selectedValue$ | async) || TODAY\"\n            (dateSelect)=\"userSelectedDate$.next($event)\"\n          ></riv-calendar>\n          <riv-calendar\n            class=\"right\"\n            [activeYearMonth]=\"(rightActiveYearMonth$ | async) || TODAY\"\n            (activeYearMonthChange)=\"userRightActiveYearMonth$.next($event)\"\n            [displayMin]=\"(min$ | async) || TODAY\"\n            [displayMax]=\"(max$ | async) || TODAY\"\n            [selectableMin]=\"(rightMin$ | async) || TODAY\"\n            [selectableMax]=\"(rightMax$ | async) || TODAY\"\n            [selectedValue]=\"(selectedValue$ | async) || TODAY\"\n            (dateSelect)=\"userSelectedDate$.next($event)\"\n          ></riv-calendar>\n        </div>\n\n        <footer class=\"buttons\">\n          <button\n            rivButton\n            [size]=\"'small'\"\n            [variant]=\"'ghost'\"\n            (click)=\"userSelectedDate$.next(undefined)\"\n            type=\"button\"\n          >\n            Clear\n          </button>\n          <button\n            rivButton\n            [size]=\"'small'\"\n            [variant]=\"'primary'\"\n            (click)=\"open$.next(false)\"\n            type=\"button\"\n          >\n            Done\n          </button>\n        </footer>\n      </div>\n    </riv-callout>\n  </ng-container>\n</ng-template>\n"]}
|
|
@@ -14,10 +14,10 @@ export class ViewMenuComponent {
|
|
|
14
14
|
}
|
|
15
15
|
}
|
|
16
16
|
ViewMenuComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ViewMenuComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
17
|
-
ViewMenuComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ViewMenuComponent, selector: "riv-view-menu", inputs: { manager: "manager", view: "view", menuContext: "menuContext" }, queries: [{ propertyName: "triggerTemplate", first: true, predicate: ["menuTrigger"], descendants: true }], ngImport: i0, template: "<ng-container *ngIf=\"view\">\n <riv-menu\n #menu\n [preferredPosition]=\"'bottom-right'\"\n (click)=\"$event.stopPropagation()\"\n >\n <ng-container *ngIf=\"triggerTemplate\">\n <ng-template #trigger>\n <ng-container [ngTemplateOutlet]=\"triggerTemplate\"></ng-container>\n </ng-template>\n </ng-container>\n <button\n riv-menu-item\n (click)=\"\n manager?.actions?.next({\n type: 'setEnabled',\n id: view.id,\n enabled: !view.enabled\n })\n \"\n [disabled]=\"view.system\"\n >\n {{ view.enabled ? 'Hide tab' : 'Show tab' }}\n </button>\n <riv-menu-divider></riv-menu-divider>\n <button\n riv-menu-item\n (click)=\"\n manager?.actions?.next({\n type: 'setEditingView',\n context: { id: view.id, autoRename: false, menuContext }\n })\n \"\n [disabled]=\"view.system\"\n >\n Edit view\n </button>\n <button\n riv-menu-item\n (click)=\"\n manager?.actions?.next({\n type: 'setEditingView',\n context: { id: view.id, autoRename: true, menuContext }\n })\n \"\n [disabled]=\"view.system\"\n >\n Rename view\n </button>\n <button\n riv-menu-item\n (click)=\"\n manager?.actions?.next({ type: 'duplicateView', view, menuContext })\n \"\n >\n Duplicate view\n </button>\n <button\n riv-menu-item\n (click)=\"\n manager?.actions?.next({\n type: 'setDeletingView',\n context: { id: view.id, menuContext }\n })\n \"\n [disabled]=\"view.system\"\n >\n Delete view\n </button>\n <riv-menu-divider></riv-menu-divider>\n <button\n riv-menu-item\n (click)=\"manager?.actions?.next({ type: 'copyLinkToView', view })\"\n >\n Copy link to view\n </button>\n </riv-menu>\n\n <ng-container *ngIf=\"manager?.state | async; let state\">\n <ng-container *ngIf=\"state.editingViewContext; let editingViewContext\">\n <riv-edit-view\n *ngIf=\"\n editingViewContext.id === view.id &&\n editingViewContext.menuContext === menuContext\n \"\n [view]=\"view\"\n [userSource]=\"state.userSource\"\n [autoSelectName]=\"editingViewContext.autoRename\"\n [anchor]=\"el.nativeElement\"\n (save)=\"manager?.actions?.next({ type: 'updateView', view: $event })\"\n (delete)=\"manager?.actions?.next({ type: 'deleteView', view: $event })\"\n (close)=\"\n manager?.actions?.next({ type: 'setEditingView', context: null })\n \"\n ></riv-edit-view>\n </ng-container>\n\n <ng-container *ngIf=\"state.deletingViewContext; let deletingViewContext\">\n <riv-dialog\n *ngIf=\"\n deletingViewContext.id === view.id &&\n deletingViewContext.menuContext === menuContext\n \"\n [title]=\"'Delete view'\"\n (close)=\"\n manager?.actions?.next({ type: 'setDeletingView', context: null })\n \"\n >\n <div class=\"delete-dialog\">\n <div class=\"delete-title\">\n Are you sure you want to delete the following view?\n </div>\n <p>{{ view.title }}</p>\n </div>\n <footer class=\"delete-footer\">\n <button\n rivButton\n (click)=\"\n manager?.actions?.next({ type: 'setDeletingView', context: null })\n \"\n >\n Cancel\n </button>\n <button\n rivButton\n [variant]=\"'danger'\"\n (click)=\"\n manager?.actions?.next({\n type: 'deleteView',\n view\n })\n \"\n >\n Delete view\n </button>\n </footer>\n </riv-dialog>\n </ng-container>\n </ng-container>\n</ng-container>\n", styles: [":host{display:inline-flex;
|
|
17
|
+
ViewMenuComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ViewMenuComponent, selector: "riv-view-menu", inputs: { manager: "manager", view: "view", menuContext: "menuContext" }, queries: [{ propertyName: "triggerTemplate", first: true, predicate: ["menuTrigger"], descendants: true }], ngImport: i0, template: "<ng-container *ngIf=\"view\">\n <riv-menu\n #menu\n [preferredPosition]=\"'bottom-right'\"\n (click)=\"$event.stopPropagation()\"\n >\n <ng-container *ngIf=\"triggerTemplate\">\n <ng-template #trigger>\n <ng-container [ngTemplateOutlet]=\"triggerTemplate\"></ng-container>\n </ng-template>\n </ng-container>\n <button\n riv-menu-item\n (click)=\"\n manager?.actions?.next({\n type: 'setEnabled',\n id: view.id,\n enabled: !view.enabled\n })\n \"\n [disabled]=\"view.system\"\n >\n {{ view.enabled ? 'Hide tab' : 'Show tab' }}\n </button>\n <riv-menu-divider></riv-menu-divider>\n <button\n riv-menu-item\n (click)=\"\n manager?.actions?.next({\n type: 'setEditingView',\n context: { id: view.id, autoRename: false, menuContext }\n })\n \"\n [disabled]=\"view.system\"\n >\n Edit view\n </button>\n <button\n riv-menu-item\n (click)=\"\n manager?.actions?.next({\n type: 'setEditingView',\n context: { id: view.id, autoRename: true, menuContext }\n })\n \"\n [disabled]=\"view.system\"\n >\n Rename view\n </button>\n <button\n riv-menu-item\n (click)=\"\n manager?.actions?.next({ type: 'duplicateView', view, menuContext })\n \"\n >\n Duplicate view\n </button>\n <button\n riv-menu-item\n (click)=\"\n manager?.actions?.next({\n type: 'setDeletingView',\n context: { id: view.id, menuContext }\n })\n \"\n [disabled]=\"view.system\"\n >\n Delete view\n </button>\n <riv-menu-divider></riv-menu-divider>\n <button\n riv-menu-item\n (click)=\"manager?.actions?.next({ type: 'copyLinkToView', view })\"\n >\n Copy link to view\n </button>\n </riv-menu>\n\n <ng-container *ngIf=\"manager?.state | async; let state\">\n <ng-container *ngIf=\"state.editingViewContext; let editingViewContext\">\n <riv-edit-view\n *ngIf=\"\n editingViewContext.id === view.id &&\n editingViewContext.menuContext === menuContext\n \"\n [view]=\"view\"\n [userSource]=\"state.userSource\"\n [autoSelectName]=\"editingViewContext.autoRename\"\n [anchor]=\"el.nativeElement\"\n (save)=\"manager?.actions?.next({ type: 'updateView', view: $event })\"\n (delete)=\"manager?.actions?.next({ type: 'deleteView', view: $event })\"\n (close)=\"\n manager?.actions?.next({ type: 'setEditingView', context: null })\n \"\n ></riv-edit-view>\n </ng-container>\n\n <ng-container *ngIf=\"state.deletingViewContext; let deletingViewContext\">\n <riv-dialog\n *ngIf=\"\n deletingViewContext.id === view.id &&\n deletingViewContext.menuContext === menuContext\n \"\n [title]=\"'Delete view'\"\n (close)=\"\n manager?.actions?.next({ type: 'setDeletingView', context: null })\n \"\n >\n <div class=\"delete-dialog\">\n <div class=\"delete-title\">\n Are you sure you want to delete the following view?\n </div>\n <p>{{ view.title }}</p>\n </div>\n <footer class=\"delete-footer\">\n <button\n rivButton\n (click)=\"\n manager?.actions?.next({ type: 'setDeletingView', context: null })\n \"\n >\n Cancel\n </button>\n <button\n rivButton\n [variant]=\"'danger'\"\n (click)=\"\n manager?.actions?.next({\n type: 'deleteView',\n view\n })\n \"\n >\n Delete view\n </button>\n </footer>\n </riv-dialog>\n </ng-container>\n </ng-container>\n</ng-container>\n", styles: [":host{display:inline-flex;align-items:stretch}riv-menu{width:100%;max-width:100%;height:100%;max-height:100%}.delete-dialog{padding:var(--size-xlarge);display:flex;flex-direction:column;gap:var(--size-large);width:calc(var(--base-grid-size) * 120);max-width:100%}.delete-title{font:var(--title-02)}.delete-footer{padding:var(--size-medium);display:flex;justify-content:space-between;gap:var(--size-medium)}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.ButtonComponent, selector: "[rivButton]", inputs: ["locked", "disabled", "loading", "full", "size", "variant", "icon", "iconPosition", "active"] }, { kind: "component", type: i3.DialogComponent, selector: "riv-dialog", inputs: ["title"], outputs: ["close"] }, { kind: "component", type: i4.EditViewComponent, selector: "riv-edit-view", inputs: ["anchor", "autoSelectName", "view", "userSource", "mode"], outputs: ["save", "delete", "close"] }, { kind: "component", type: i5.MenuComponent, selector: "riv-menu", inputs: ["preferredPosition"] }, { kind: "component", type: i6.MenuDividerComponent, selector: "riv-menu-divider" }, { kind: "component", type: i7.MenuItemComponent, selector: "[riv-menu-item]", inputs: ["locked", "disabled", "variant"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
18
18
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ViewMenuComponent, decorators: [{
|
|
19
19
|
type: Component,
|
|
20
|
-
args: [{ selector: 'riv-view-menu', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"view\">\n <riv-menu\n #menu\n [preferredPosition]=\"'bottom-right'\"\n (click)=\"$event.stopPropagation()\"\n >\n <ng-container *ngIf=\"triggerTemplate\">\n <ng-template #trigger>\n <ng-container [ngTemplateOutlet]=\"triggerTemplate\"></ng-container>\n </ng-template>\n </ng-container>\n <button\n riv-menu-item\n (click)=\"\n manager?.actions?.next({\n type: 'setEnabled',\n id: view.id,\n enabled: !view.enabled\n })\n \"\n [disabled]=\"view.system\"\n >\n {{ view.enabled ? 'Hide tab' : 'Show tab' }}\n </button>\n <riv-menu-divider></riv-menu-divider>\n <button\n riv-menu-item\n (click)=\"\n manager?.actions?.next({\n type: 'setEditingView',\n context: { id: view.id, autoRename: false, menuContext }\n })\n \"\n [disabled]=\"view.system\"\n >\n Edit view\n </button>\n <button\n riv-menu-item\n (click)=\"\n manager?.actions?.next({\n type: 'setEditingView',\n context: { id: view.id, autoRename: true, menuContext }\n })\n \"\n [disabled]=\"view.system\"\n >\n Rename view\n </button>\n <button\n riv-menu-item\n (click)=\"\n manager?.actions?.next({ type: 'duplicateView', view, menuContext })\n \"\n >\n Duplicate view\n </button>\n <button\n riv-menu-item\n (click)=\"\n manager?.actions?.next({\n type: 'setDeletingView',\n context: { id: view.id, menuContext }\n })\n \"\n [disabled]=\"view.system\"\n >\n Delete view\n </button>\n <riv-menu-divider></riv-menu-divider>\n <button\n riv-menu-item\n (click)=\"manager?.actions?.next({ type: 'copyLinkToView', view })\"\n >\n Copy link to view\n </button>\n </riv-menu>\n\n <ng-container *ngIf=\"manager?.state | async; let state\">\n <ng-container *ngIf=\"state.editingViewContext; let editingViewContext\">\n <riv-edit-view\n *ngIf=\"\n editingViewContext.id === view.id &&\n editingViewContext.menuContext === menuContext\n \"\n [view]=\"view\"\n [userSource]=\"state.userSource\"\n [autoSelectName]=\"editingViewContext.autoRename\"\n [anchor]=\"el.nativeElement\"\n (save)=\"manager?.actions?.next({ type: 'updateView', view: $event })\"\n (delete)=\"manager?.actions?.next({ type: 'deleteView', view: $event })\"\n (close)=\"\n manager?.actions?.next({ type: 'setEditingView', context: null })\n \"\n ></riv-edit-view>\n </ng-container>\n\n <ng-container *ngIf=\"state.deletingViewContext; let deletingViewContext\">\n <riv-dialog\n *ngIf=\"\n deletingViewContext.id === view.id &&\n deletingViewContext.menuContext === menuContext\n \"\n [title]=\"'Delete view'\"\n (close)=\"\n manager?.actions?.next({ type: 'setDeletingView', context: null })\n \"\n >\n <div class=\"delete-dialog\">\n <div class=\"delete-title\">\n Are you sure you want to delete the following view?\n </div>\n <p>{{ view.title }}</p>\n </div>\n <footer class=\"delete-footer\">\n <button\n rivButton\n (click)=\"\n manager?.actions?.next({ type: 'setDeletingView', context: null })\n \"\n >\n Cancel\n </button>\n <button\n rivButton\n [variant]=\"'danger'\"\n (click)=\"\n manager?.actions?.next({\n type: 'deleteView',\n view\n })\n \"\n >\n Delete view\n </button>\n </footer>\n </riv-dialog>\n </ng-container>\n </ng-container>\n</ng-container>\n", styles: [":host{display:inline-flex;
|
|
20
|
+
args: [{ selector: 'riv-view-menu', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"view\">\n <riv-menu\n #menu\n [preferredPosition]=\"'bottom-right'\"\n (click)=\"$event.stopPropagation()\"\n >\n <ng-container *ngIf=\"triggerTemplate\">\n <ng-template #trigger>\n <ng-container [ngTemplateOutlet]=\"triggerTemplate\"></ng-container>\n </ng-template>\n </ng-container>\n <button\n riv-menu-item\n (click)=\"\n manager?.actions?.next({\n type: 'setEnabled',\n id: view.id,\n enabled: !view.enabled\n })\n \"\n [disabled]=\"view.system\"\n >\n {{ view.enabled ? 'Hide tab' : 'Show tab' }}\n </button>\n <riv-menu-divider></riv-menu-divider>\n <button\n riv-menu-item\n (click)=\"\n manager?.actions?.next({\n type: 'setEditingView',\n context: { id: view.id, autoRename: false, menuContext }\n })\n \"\n [disabled]=\"view.system\"\n >\n Edit view\n </button>\n <button\n riv-menu-item\n (click)=\"\n manager?.actions?.next({\n type: 'setEditingView',\n context: { id: view.id, autoRename: true, menuContext }\n })\n \"\n [disabled]=\"view.system\"\n >\n Rename view\n </button>\n <button\n riv-menu-item\n (click)=\"\n manager?.actions?.next({ type: 'duplicateView', view, menuContext })\n \"\n >\n Duplicate view\n </button>\n <button\n riv-menu-item\n (click)=\"\n manager?.actions?.next({\n type: 'setDeletingView',\n context: { id: view.id, menuContext }\n })\n \"\n [disabled]=\"view.system\"\n >\n Delete view\n </button>\n <riv-menu-divider></riv-menu-divider>\n <button\n riv-menu-item\n (click)=\"manager?.actions?.next({ type: 'copyLinkToView', view })\"\n >\n Copy link to view\n </button>\n </riv-menu>\n\n <ng-container *ngIf=\"manager?.state | async; let state\">\n <ng-container *ngIf=\"state.editingViewContext; let editingViewContext\">\n <riv-edit-view\n *ngIf=\"\n editingViewContext.id === view.id &&\n editingViewContext.menuContext === menuContext\n \"\n [view]=\"view\"\n [userSource]=\"state.userSource\"\n [autoSelectName]=\"editingViewContext.autoRename\"\n [anchor]=\"el.nativeElement\"\n (save)=\"manager?.actions?.next({ type: 'updateView', view: $event })\"\n (delete)=\"manager?.actions?.next({ type: 'deleteView', view: $event })\"\n (close)=\"\n manager?.actions?.next({ type: 'setEditingView', context: null })\n \"\n ></riv-edit-view>\n </ng-container>\n\n <ng-container *ngIf=\"state.deletingViewContext; let deletingViewContext\">\n <riv-dialog\n *ngIf=\"\n deletingViewContext.id === view.id &&\n deletingViewContext.menuContext === menuContext\n \"\n [title]=\"'Delete view'\"\n (close)=\"\n manager?.actions?.next({ type: 'setDeletingView', context: null })\n \"\n >\n <div class=\"delete-dialog\">\n <div class=\"delete-title\">\n Are you sure you want to delete the following view?\n </div>\n <p>{{ view.title }}</p>\n </div>\n <footer class=\"delete-footer\">\n <button\n rivButton\n (click)=\"\n manager?.actions?.next({ type: 'setDeletingView', context: null })\n \"\n >\n Cancel\n </button>\n <button\n rivButton\n [variant]=\"'danger'\"\n (click)=\"\n manager?.actions?.next({\n type: 'deleteView',\n view\n })\n \"\n >\n Delete view\n </button>\n </footer>\n </riv-dialog>\n </ng-container>\n </ng-container>\n</ng-container>\n", styles: [":host{display:inline-flex;align-items:stretch}riv-menu{width:100%;max-width:100%;height:100%;max-height:100%}.delete-dialog{padding:var(--size-xlarge);display:flex;flex-direction:column;gap:var(--size-large);width:calc(var(--base-grid-size) * 120);max-width:100%}.delete-title{font:var(--title-02)}.delete-footer{padding:var(--size-medium);display:flex;justify-content:space-between;gap:var(--size-medium)}\n"] }]
|
|
21
21
|
}], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { manager: [{
|
|
22
22
|
type: Input
|
|
23
23
|
}], view: [{
|
|
@@ -50,10 +50,10 @@ export class ViewsComponent {
|
|
|
50
50
|
}
|
|
51
51
|
}
|
|
52
52
|
ViewsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ViewsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
53
|
-
ViewsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ViewsComponent, selector: "riv-views", inputs: { manager: "manager", sideSheetTopOffset: "sideSheetTopOffset" }, viewQueries: [{ propertyName: "overflowTrigger", first: true, predicate: ["overflowTrigger"], descendants: true, read: ElementRef }, { propertyName: "activeTab", first: true, predicate: ["activeTab"], descendants: true, read: ElementRef }], ngImport: i0, template: "<div\n (rivClientSize)=\"\n manager?.actions?.next({ type: 'setContainerWidth', width: $event.width })\n \"\n class=\"container\"\n>\n <ng-container *ngIf=\"manager?.state | async; let s\">\n <ng-container\n *ngFor=\"let view of s.displayedViews; let i = index; trackBy: trackById\"\n >\n <ng-container *ngIf=\"view.active; else inactiveTab\">\n <div\n #activeTab\n class=\"tab active\"\n [class.dragging]=\"draggedTabIndex === i\"\n [class.dragged-over-left]=\"\n draggedOverTabIndex === i &&\n draggedTabIndex !== null &&\n draggedTabIndex > i\n \"\n [class.dragged-over-right]=\"\n draggedOverTabIndex === i &&\n draggedTabIndex !== null &&\n draggedTabIndex < i\n \"\n [attr.draggable]=\"i > 0\"\n [attr.droppable]=\"i > 0\"\n (dragstart)=\"dragStart(i)\"\n (dragenter)=\"$event.preventDefault()\"\n (dragover)=\"$event.preventDefault(); dragOver(i)\"\n (drop)=\"drop(i)\"\n >\n <riv-icon\n class=\"tab-reorder\"\n [class.hidden-class]=\"i === 0\"\n [name]=\"'Reorder'\"\n [size]=\"16\"\n ></riv-icon>\n <div class=\"menu-wrapper\" rivTruncate>\n <riv-view-menu\n [manager]=\"manager\"\n [view]=\"view\"\n [menuContext]=\"'tab'\"\n class=\"active-menu\"\n >\n <ng-template #menuTrigger>\n <button class=\"menu-trigger\" rivTruncate>\n {{ view.title }}\n </button>\n </ng-template>\n </riv-view-menu>\n </div>\n </div>\n </ng-container>\n <ng-template #inactiveTab>\n <button\n class=\"tab\"\n [class.dragging]=\"draggedTabIndex === i\"\n [class.dragged-over-left]=\"\n draggedOverTabIndex === i &&\n draggedTabIndex !== null &&\n draggedTabIndex > i\n \"\n [class.dragged-over-right]=\"\n draggedOverTabIndex === i &&\n draggedTabIndex !== null &&\n draggedTabIndex < i\n \"\n [attr.draggable]=\"i > 0\"\n [attr.droppable]=\"i > 0\"\n (dragstart)=\"dragStart(i)\"\n (dragenter)=\"$event.preventDefault()\"\n (dragover)=\"$event.preventDefault(); dragOver(i)\"\n (drop)=\"drop(i)\"\n (click)=\"\n manager?.actions?.next({ type: 'setActiveView', id: view.id })\n \"\n >\n <riv-icon\n class=\"tab-reorder\"\n [class.hidden-class]=\"i === 0\"\n [name]=\"'Reorder'\"\n [size]=\"16\"\n ></riv-icon>\n <span rivTruncate>\n {{ view.title }}\n </span>\n </button>\n </ng-template>\n </ng-container>\n <button\n *ngIf=\"s.allEnabledViews.length - s.displayedViews.length; let count\"\n class=\"tab overflow\"\n rivTruncate\n #overflowTrigger\n (click)=\"\n manager?.actions?.next({ type: 'setOverflowPickerOpen', open: true })\n \"\n >\n {{ count | rivNumber }} more\n </button>\n <ng-container *ngIf=\"s.overflow.pickerOpen\">\n <riv-callout\n *riv-overlay\n [anchor]=\"overflowTrigger?.nativeElement\"\n [isModal]=\"true\"\n [showCaret]=\"false\"\n [theme]=\"'light'\"\n [preferredPosition]=\"'bottom-left'\"\n (close)=\"\n manager?.actions?.next({ type: 'setOverflowPickerOpen', open: false })\n \"\n >\n <div class=\"overflow-callout\">\n <riv-search\n [value]=\"s.overflow.search\"\n (valueChange)=\"\n manager?.actions?.next({\n type: 'setOverflowSearchQuery',\n query: $event\n })\n \"\n ></riv-search>\n <div class=\"overflow-view-list\">\n <button\n *ngFor=\"let view of s.enabledViews; let i = index\"\n class=\"overflow-view\"\n [class.system]=\"view.system\"\n [class.dragging]=\"draggedTabIndex === i\"\n [class.dragged-over-top]=\"\n draggedOverTabIndex === i &&\n draggedTabIndex !== null &&\n draggedTabIndex > i\n \"\n [class.dragged-over-bottom]=\"\n draggedOverTabIndex === i &&\n draggedTabIndex !== null &&\n draggedTabIndex < i\n \"\n [attr.draggable]=\"i > 0\"\n [attr.droppable]=\"i > 0\"\n (dragstart)=\"dragStart(i)\"\n (dragenter)=\"$event.preventDefault()\"\n (dragover)=\"$event.preventDefault(); dragOver(i)\"\n (drop)=\"drop(i)\"\n (click)=\"\n manager?.actions?.next({ type: 'setActiveView', id: view.id });\n manager?.actions?.next({\n type: 'setOverflowPickerOpen',\n open: false\n })\n \"\n >\n <riv-icon\n *ngIf=\"i > 0\"\n class=\"overflow-reorder\"\n [name]=\"'Reorder'\"\n [size]=\"16\"\n ></riv-icon>\n <div class=\"overflow-title\" rivTruncate>\n <riv-highlight\n [indices]=\"view.titleHighlightIndices ?? []\"\n [text]=\"view.title\"\n ></riv-highlight>\n </div>\n <riv-view-menu\n [manager]=\"manager\"\n [view]=\"view\"\n [menuContext]=\"'overflow'\"\n ></riv-view-menu>\n </button>\n <riv-zero-state\n *ngIf=\"!s.enabledViews.length\"\n [message]=\"'No matching views.'\"\n ></riv-zero-state>\n </div>\n </div>\n </riv-callout>\n </ng-container>\n <div class=\"all-views-button-container\">\n <button\n rivButton\n [variant]=\"'ghost'\"\n [size]=\"'medium'\"\n (click)=\"showAllViews = true\"\n >\n All views\n </button>\n </div>\n </ng-container>\n</div>\n\n<riv-all-views-modal\n *ngIf=\"showAllViews\"\n [manager]=\"manager\"\n [topOffset]=\"sideSheetTopOffset\"\n (close)=\"showAllViews = false\"\n></riv-all-views-modal>\n\n<riv-toast *ngIf=\"showLinkCopiedToast | async\" (close)=\"toastClosed.next()\">\n Link to view copied to clipboard\n</riv-toast>\n", styles: [".container{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(0,calc(var(--base-grid-size) * 81));justify-content:start;border-bottom:var(--border-width) solid var(--border-light)}.tab{font:var(--input-medium);color:var(--type-light-low-contrast);background-color:var(--surface-light-1);border:var(--border-width) solid var(--border-light);border-bottom:none;border-top-left-radius:var(--border-radius-medium);border-top-right-radius:var(--border-radius-medium);padding:var(--size-small) var(--size-large) var(--size-small) 0;cursor:pointer;transition:background-color var(--medium-transition);display:flex;justify-content:flex-start;align-items:center;position:relative}.tab:hover{background-color:var(--surface-light-2)}.tab:active{background-color:var(--surface-light-3)}.tab:not(:first-child){margin-left:calc(var(--border-width) * -1)}.tab.active{color:var(--purp-80);background-color:var(--surface-light-0);border-bottom:var(--border-width) solid var(--surface-light-0);margin-bottom:calc(var(--border-width) * -1);z-index:1}.tab.active:active{border:var(--border-width) solid var(--purp-80)}.tab.dragging{cursor:grabbing}.tab.dragged-over-left:before,.tab.dragged-over-right:before{content:\"\";position:absolute;top:0;bottom:0;width:var(--size-xxsmall);background-color:var(--brand);box-shadow:0 0 var(--size-xxsmall) var(--brand)}.tab.dragged-over-left:before{left:0}.tab.dragged-over-right:before{right:0}.tab-reorder{color:var(--type-light-low-contrast);opacity:0;transition:opacity var(--short-transition);cursor:grab;margin:0 var(--size-xsmall)}.tab:hover .tab-reorder{opacity:1}.hidden-class{visibility:hidden}.menu-wrapper{display:inline-flex}.active-menu,.menu-trigger{color:var(--type-light-link-hover);max-width:100%;cursor:pointer;font:var(--input-medium)}.tab.overflow{padding-left:var(--size-large)}.all-views-button-container{padding:var(--size-xxsmall)}.overflow-callout{padding:var(--size-large);display:flex;flex-direction:column;gap:var(--size-medium);height:calc(var(--base-grid-size) * 120);max-height:50vh;width:calc(var(--base-grid-size) * 75);max-width:50vw}.overflow-view-list{display:flex;flex-direction:column;gap:var(--size-small);flex-grow:1;overflow-y:auto}.overflow-view{display:flex;align-items:center;gap:var(--size-small);cursor:pointer;border-radius:var(--border-radius-medium);transition:background-color var(--short-transition);position:relative}.overflow-view.system{padding-left:var(--size-small)}.overflow-view:hover{background-color:var(--surface-light-2)}.overflow-view.dragged-over-top:before,.overflow-view.dragged-over-bottom:before{content:\"\";position:absolute;left:0;right:0;height:var(--size-xxsmall);background-color:var(--brand);box-shadow:0 0 var(--size-xxsmall) var(--brand)}.overflow-view.dragged-over-top:before{top:0}.overflow-view.dragged-over-bottom:before{bottom:0}.overflow-reorder{color:var(--type-light-low-contrast);cursor:grab}.overflow-title{flex-grow:1;text-align:left}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.AllViewsModalComponent, selector: "riv-all-views-modal", inputs: ["manager", "topOffset"], outputs: ["close"] }, { kind: "component", type: i3.ButtonComponent, selector: "[rivButton]", inputs: ["locked", "disabled", "loading", "full", "size", "variant", "icon", "iconPosition", "active"] }, { kind: "component", type: i4.CalloutComponent, selector: "riv-callout", inputs: ["anchor", "isModal", "preferredPosition", "allowedPositions", "fallbackDirection", "showCaret", "theme"], outputs: ["close"] }, { kind: "component", type: i5.HighlightComponent, selector: "riv-highlight", inputs: ["text", "indices"] }, { kind: "component", type: i6.IconComponent, selector: "riv-icon", inputs: ["name", "size", "customSize", "strokeWidth"] }, { kind: "directive", type: i7.OverlayDirective, selector: "[riv-overlay]" }, { kind: "component", type: i8.SearchComponent, selector: "riv-search", inputs: ["placeholder", "name", "labelTemplate"] }, { kind: "directive", type: i9.SizeDirective, selector: "[rivClientSize]", outputs: ["rivClientSize"] }, { kind: "component", type: i10.ToastComponent, selector: "riv-toast", inputs: ["variant", "icon"], outputs: ["close"] }, { kind: "component", type: i11.TruncateComponent, selector: "[rivTruncate]", inputs: ["maxTooltipWidth"] }, { kind: "component", type: i12.ViewMenuComponent, selector: "riv-view-menu", inputs: ["manager", "view", "menuContext"] }, { kind: "component", type: i13.ZeroStateComponent, selector: "riv-zero-state", inputs: ["message", "title", "icon"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i14.NumberPipe, name: "rivNumber" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
53
|
+
ViewsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ViewsComponent, selector: "riv-views", inputs: { manager: "manager", sideSheetTopOffset: "sideSheetTopOffset" }, viewQueries: [{ propertyName: "overflowTrigger", first: true, predicate: ["overflowTrigger"], descendants: true, read: ElementRef }], ngImport: i0, template: "<div\n (rivClientSize)=\"\n manager?.actions?.next({ type: 'setContainerWidth', width: $event.width })\n \"\n class=\"container\"\n>\n <ng-container *ngIf=\"manager?.state | async; let s\">\n <ng-container\n *ngFor=\"let view of s.displayedViews; let i = index; trackBy: trackById\"\n >\n <ng-container *ngIf=\"view.active; else inactiveTab\">\n <riv-view-menu\n [manager]=\"manager\"\n [view]=\"view\"\n [menuContext]=\"'tab'\"\n class=\"active-menu\"\n >\n <ng-template #menuTrigger>\n <div\n class=\"tab active\"\n [class.dragging]=\"draggedTabIndex === i\"\n [class.dragged-over-left]=\"\n draggedOverTabIndex === i &&\n draggedTabIndex !== null &&\n draggedTabIndex > i\n \"\n [class.dragged-over-right]=\"\n draggedOverTabIndex === i &&\n draggedTabIndex !== null &&\n draggedTabIndex < i\n \"\n [attr.draggable]=\"i > 0\"\n [attr.droppable]=\"i > 0\"\n (dragstart)=\"dragStart(i)\"\n (dragenter)=\"$event.preventDefault()\"\n (dragover)=\"$event.preventDefault(); dragOver(i)\"\n (drop)=\"drop(i)\"\n >\n <riv-icon\n class=\"tab-reorder\"\n [class.hidden-class]=\"i === 0\"\n [name]=\"'Reorder'\"\n [size]=\"16\"\n ></riv-icon>\n <div rivTruncate>\n {{ view.title }}\n </div>\n </div>\n </ng-template>\n </riv-view-menu>\n </ng-container>\n <ng-template #inactiveTab>\n <button\n class=\"tab\"\n [class.dragging]=\"draggedTabIndex === i\"\n [class.dragged-over-left]=\"\n draggedOverTabIndex === i &&\n draggedTabIndex !== null &&\n draggedTabIndex > i\n \"\n [class.dragged-over-right]=\"\n draggedOverTabIndex === i &&\n draggedTabIndex !== null &&\n draggedTabIndex < i\n \"\n [attr.draggable]=\"i > 0\"\n [attr.droppable]=\"i > 0\"\n (dragstart)=\"dragStart(i)\"\n (dragenter)=\"$event.preventDefault()\"\n (dragover)=\"$event.preventDefault(); dragOver(i)\"\n (drop)=\"drop(i)\"\n (click)=\"\n manager?.actions?.next({ type: 'setActiveView', id: view.id })\n \"\n >\n <riv-icon\n class=\"tab-reorder\"\n [class.hidden-class]=\"i === 0\"\n [name]=\"'Reorder'\"\n [size]=\"16\"\n ></riv-icon>\n <span rivTruncate>\n {{ view.title }}\n </span>\n </button>\n </ng-template>\n </ng-container>\n <button\n *ngIf=\"s.allEnabledViews.length - s.displayedViews.length; let count\"\n class=\"tab overflow\"\n rivTruncate\n #overflowTrigger\n (click)=\"\n manager?.actions?.next({ type: 'setOverflowPickerOpen', open: true })\n \"\n >\n {{ count | rivNumber }} more\n </button>\n <ng-container *ngIf=\"s.overflow.pickerOpen\">\n <riv-callout\n *riv-overlay\n [anchor]=\"overflowTrigger?.nativeElement\"\n [isModal]=\"true\"\n [showCaret]=\"false\"\n [theme]=\"'light'\"\n [preferredPosition]=\"'bottom-left'\"\n (close)=\"\n manager?.actions?.next({ type: 'setOverflowPickerOpen', open: false })\n \"\n >\n <div class=\"overflow-callout\">\n <riv-search\n [value]=\"s.overflow.search\"\n (valueChange)=\"\n manager?.actions?.next({\n type: 'setOverflowSearchQuery',\n query: $event\n })\n \"\n ></riv-search>\n <div class=\"overflow-view-list\">\n <button\n *ngFor=\"let view of s.enabledViews; let i = index\"\n class=\"overflow-view\"\n [class.system]=\"view.system\"\n [class.dragging]=\"draggedTabIndex === i\"\n [class.dragged-over-top]=\"\n draggedOverTabIndex === i &&\n draggedTabIndex !== null &&\n draggedTabIndex > i\n \"\n [class.dragged-over-bottom]=\"\n draggedOverTabIndex === i &&\n draggedTabIndex !== null &&\n draggedTabIndex < i\n \"\n [attr.draggable]=\"i > 0\"\n [attr.droppable]=\"i > 0\"\n (dragstart)=\"dragStart(i)\"\n (dragenter)=\"$event.preventDefault()\"\n (dragover)=\"$event.preventDefault(); dragOver(i)\"\n (drop)=\"drop(i)\"\n (click)=\"\n manager?.actions?.next({ type: 'setActiveView', id: view.id });\n manager?.actions?.next({\n type: 'setOverflowPickerOpen',\n open: false\n })\n \"\n >\n <riv-icon\n *ngIf=\"i > 0\"\n class=\"overflow-reorder\"\n [name]=\"'Reorder'\"\n [size]=\"16\"\n ></riv-icon>\n <div class=\"overflow-title\" rivTruncate>\n <riv-highlight\n [indices]=\"view.titleHighlightIndices ?? []\"\n [text]=\"view.title\"\n ></riv-highlight>\n </div>\n <riv-view-menu\n [manager]=\"manager\"\n [view]=\"view\"\n [menuContext]=\"'overflow'\"\n ></riv-view-menu>\n </button>\n <riv-zero-state\n *ngIf=\"!s.enabledViews.length\"\n [message]=\"'No matching views.'\"\n ></riv-zero-state>\n </div>\n </div>\n </riv-callout>\n </ng-container>\n <div class=\"all-views-button-container\">\n <button\n rivButton\n [variant]=\"'ghost'\"\n [size]=\"'medium'\"\n (click)=\"showAllViews = true\"\n >\n All views\n </button>\n </div>\n </ng-container>\n</div>\n\n<riv-all-views-modal\n *ngIf=\"showAllViews\"\n [manager]=\"manager\"\n [topOffset]=\"sideSheetTopOffset\"\n (close)=\"showAllViews = false\"\n></riv-all-views-modal>\n\n<riv-toast *ngIf=\"showLinkCopiedToast | async\" (close)=\"toastClosed.next()\">\n Link to view copied to clipboard\n</riv-toast>\n", styles: [".container{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(0,calc(var(--base-grid-size) * 81));justify-content:start;border-bottom:var(--border-width) solid var(--border-light)}.tab{font:var(--input-medium);color:var(--type-light-low-contrast);background-color:var(--surface-light-1);border:var(--border-width) solid var(--border-light);border-bottom:none;border-top-left-radius:var(--border-radius-medium);border-top-right-radius:var(--border-radius-medium);padding:var(--size-small) var(--size-large) var(--size-small) 0;cursor:pointer;transition:background-color var(--medium-transition);display:flex;justify-content:flex-start;align-items:center;position:relative}.tab:hover{background-color:var(--surface-light-2)}.tab:active{background-color:var(--surface-light-3)}.tab:not(:first-child),.active-menu{margin-left:calc(var(--border-width) * -1)}.tab.active{color:var(--purp-80);background-color:var(--surface-light-0);border-bottom:var(--border-width) solid var(--surface-light-0);margin-bottom:calc(var(--border-width) * -1);z-index:1;width:100%;max-width:100%;height:100%;max-height:100%}.tab.active:active{border:var(--border-width) solid var(--purp-80)}.tab.dragging{cursor:grabbing}.tab.dragged-over-left:before,.tab.dragged-over-right:before{content:\"\";position:absolute;top:0;bottom:0;width:var(--size-xxsmall);background-color:var(--brand);box-shadow:0 0 var(--size-xxsmall) var(--brand)}.tab.dragged-over-left:before{left:0}.tab.dragged-over-right:before{right:0}.tab-reorder{color:var(--type-light-low-contrast);opacity:0;transition:opacity var(--short-transition);cursor:grab;margin:0 var(--size-xsmall)}.tab:hover .tab-reorder{opacity:1}.hidden-class{visibility:hidden}.active-menu{display:inline-flex;color:var(--type-light-link-hover);--size: calc(100% + calc(var(--border-width)));width:var(--size);max-width:var(--size);height:var(--size);max-height:var(--size);cursor:pointer;font:var(--input-medium)}.tab.overflow{padding-left:var(--size-large)}.all-views-button-container{padding:var(--size-xxsmall)}.overflow-callout{padding:var(--size-large);display:flex;flex-direction:column;gap:var(--size-medium);height:calc(var(--base-grid-size) * 120);max-height:50vh;width:calc(var(--base-grid-size) * 75);max-width:50vw}.overflow-view-list{display:flex;flex-direction:column;gap:var(--size-small);flex-grow:1;overflow-y:auto}.overflow-view{display:flex;align-items:center;gap:var(--size-small);cursor:pointer;border-radius:var(--border-radius-medium);transition:background-color var(--short-transition);position:relative}.overflow-view.system{padding-left:var(--size-small)}.overflow-view:hover{background-color:var(--surface-light-2)}.overflow-view.dragged-over-top:before,.overflow-view.dragged-over-bottom:before{content:\"\";position:absolute;left:0;right:0;height:var(--size-xxsmall);background-color:var(--brand);box-shadow:0 0 var(--size-xxsmall) var(--brand)}.overflow-view.dragged-over-top:before{top:0}.overflow-view.dragged-over-bottom:before{bottom:0}.overflow-reorder{color:var(--type-light-low-contrast);cursor:grab}.overflow-title{flex-grow:1;text-align:left}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.AllViewsModalComponent, selector: "riv-all-views-modal", inputs: ["manager", "topOffset"], outputs: ["close"] }, { kind: "component", type: i3.ButtonComponent, selector: "[rivButton]", inputs: ["locked", "disabled", "loading", "full", "size", "variant", "icon", "iconPosition", "active"] }, { kind: "component", type: i4.CalloutComponent, selector: "riv-callout", inputs: ["anchor", "isModal", "preferredPosition", "allowedPositions", "fallbackDirection", "showCaret", "theme"], outputs: ["close"] }, { kind: "component", type: i5.HighlightComponent, selector: "riv-highlight", inputs: ["text", "indices"] }, { kind: "component", type: i6.IconComponent, selector: "riv-icon", inputs: ["name", "size", "customSize", "strokeWidth"] }, { kind: "directive", type: i7.OverlayDirective, selector: "[riv-overlay]" }, { kind: "component", type: i8.SearchComponent, selector: "riv-search", inputs: ["placeholder", "name", "labelTemplate"] }, { kind: "directive", type: i9.SizeDirective, selector: "[rivClientSize]", outputs: ["rivClientSize"] }, { kind: "component", type: i10.ToastComponent, selector: "riv-toast", inputs: ["variant", "icon"], outputs: ["close"] }, { kind: "component", type: i11.TruncateComponent, selector: "[rivTruncate]", inputs: ["maxTooltipWidth"] }, { kind: "component", type: i12.ViewMenuComponent, selector: "riv-view-menu", inputs: ["manager", "view", "menuContext"] }, { kind: "component", type: i13.ZeroStateComponent, selector: "riv-zero-state", inputs: ["message", "title", "icon"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i14.NumberPipe, name: "rivNumber" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
54
54
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ViewsComponent, decorators: [{
|
|
55
55
|
type: Component,
|
|
56
|
-
args: [{ selector: 'riv-views', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n (rivClientSize)=\"\n manager?.actions?.next({ type: 'setContainerWidth', width: $event.width })\n \"\n class=\"container\"\n>\n <ng-container *ngIf=\"manager?.state | async; let s\">\n <ng-container\n *ngFor=\"let view of s.displayedViews; let i = index; trackBy: trackById\"\n >\n <ng-container *ngIf=\"view.active; else inactiveTab\">\n <
|
|
56
|
+
args: [{ selector: 'riv-views', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n (rivClientSize)=\"\n manager?.actions?.next({ type: 'setContainerWidth', width: $event.width })\n \"\n class=\"container\"\n>\n <ng-container *ngIf=\"manager?.state | async; let s\">\n <ng-container\n *ngFor=\"let view of s.displayedViews; let i = index; trackBy: trackById\"\n >\n <ng-container *ngIf=\"view.active; else inactiveTab\">\n <riv-view-menu\n [manager]=\"manager\"\n [view]=\"view\"\n [menuContext]=\"'tab'\"\n class=\"active-menu\"\n >\n <ng-template #menuTrigger>\n <div\n class=\"tab active\"\n [class.dragging]=\"draggedTabIndex === i\"\n [class.dragged-over-left]=\"\n draggedOverTabIndex === i &&\n draggedTabIndex !== null &&\n draggedTabIndex > i\n \"\n [class.dragged-over-right]=\"\n draggedOverTabIndex === i &&\n draggedTabIndex !== null &&\n draggedTabIndex < i\n \"\n [attr.draggable]=\"i > 0\"\n [attr.droppable]=\"i > 0\"\n (dragstart)=\"dragStart(i)\"\n (dragenter)=\"$event.preventDefault()\"\n (dragover)=\"$event.preventDefault(); dragOver(i)\"\n (drop)=\"drop(i)\"\n >\n <riv-icon\n class=\"tab-reorder\"\n [class.hidden-class]=\"i === 0\"\n [name]=\"'Reorder'\"\n [size]=\"16\"\n ></riv-icon>\n <div rivTruncate>\n {{ view.title }}\n </div>\n </div>\n </ng-template>\n </riv-view-menu>\n </ng-container>\n <ng-template #inactiveTab>\n <button\n class=\"tab\"\n [class.dragging]=\"draggedTabIndex === i\"\n [class.dragged-over-left]=\"\n draggedOverTabIndex === i &&\n draggedTabIndex !== null &&\n draggedTabIndex > i\n \"\n [class.dragged-over-right]=\"\n draggedOverTabIndex === i &&\n draggedTabIndex !== null &&\n draggedTabIndex < i\n \"\n [attr.draggable]=\"i > 0\"\n [attr.droppable]=\"i > 0\"\n (dragstart)=\"dragStart(i)\"\n (dragenter)=\"$event.preventDefault()\"\n (dragover)=\"$event.preventDefault(); dragOver(i)\"\n (drop)=\"drop(i)\"\n (click)=\"\n manager?.actions?.next({ type: 'setActiveView', id: view.id })\n \"\n >\n <riv-icon\n class=\"tab-reorder\"\n [class.hidden-class]=\"i === 0\"\n [name]=\"'Reorder'\"\n [size]=\"16\"\n ></riv-icon>\n <span rivTruncate>\n {{ view.title }}\n </span>\n </button>\n </ng-template>\n </ng-container>\n <button\n *ngIf=\"s.allEnabledViews.length - s.displayedViews.length; let count\"\n class=\"tab overflow\"\n rivTruncate\n #overflowTrigger\n (click)=\"\n manager?.actions?.next({ type: 'setOverflowPickerOpen', open: true })\n \"\n >\n {{ count | rivNumber }} more\n </button>\n <ng-container *ngIf=\"s.overflow.pickerOpen\">\n <riv-callout\n *riv-overlay\n [anchor]=\"overflowTrigger?.nativeElement\"\n [isModal]=\"true\"\n [showCaret]=\"false\"\n [theme]=\"'light'\"\n [preferredPosition]=\"'bottom-left'\"\n (close)=\"\n manager?.actions?.next({ type: 'setOverflowPickerOpen', open: false })\n \"\n >\n <div class=\"overflow-callout\">\n <riv-search\n [value]=\"s.overflow.search\"\n (valueChange)=\"\n manager?.actions?.next({\n type: 'setOverflowSearchQuery',\n query: $event\n })\n \"\n ></riv-search>\n <div class=\"overflow-view-list\">\n <button\n *ngFor=\"let view of s.enabledViews; let i = index\"\n class=\"overflow-view\"\n [class.system]=\"view.system\"\n [class.dragging]=\"draggedTabIndex === i\"\n [class.dragged-over-top]=\"\n draggedOverTabIndex === i &&\n draggedTabIndex !== null &&\n draggedTabIndex > i\n \"\n [class.dragged-over-bottom]=\"\n draggedOverTabIndex === i &&\n draggedTabIndex !== null &&\n draggedTabIndex < i\n \"\n [attr.draggable]=\"i > 0\"\n [attr.droppable]=\"i > 0\"\n (dragstart)=\"dragStart(i)\"\n (dragenter)=\"$event.preventDefault()\"\n (dragover)=\"$event.preventDefault(); dragOver(i)\"\n (drop)=\"drop(i)\"\n (click)=\"\n manager?.actions?.next({ type: 'setActiveView', id: view.id });\n manager?.actions?.next({\n type: 'setOverflowPickerOpen',\n open: false\n })\n \"\n >\n <riv-icon\n *ngIf=\"i > 0\"\n class=\"overflow-reorder\"\n [name]=\"'Reorder'\"\n [size]=\"16\"\n ></riv-icon>\n <div class=\"overflow-title\" rivTruncate>\n <riv-highlight\n [indices]=\"view.titleHighlightIndices ?? []\"\n [text]=\"view.title\"\n ></riv-highlight>\n </div>\n <riv-view-menu\n [manager]=\"manager\"\n [view]=\"view\"\n [menuContext]=\"'overflow'\"\n ></riv-view-menu>\n </button>\n <riv-zero-state\n *ngIf=\"!s.enabledViews.length\"\n [message]=\"'No matching views.'\"\n ></riv-zero-state>\n </div>\n </div>\n </riv-callout>\n </ng-container>\n <div class=\"all-views-button-container\">\n <button\n rivButton\n [variant]=\"'ghost'\"\n [size]=\"'medium'\"\n (click)=\"showAllViews = true\"\n >\n All views\n </button>\n </div>\n </ng-container>\n</div>\n\n<riv-all-views-modal\n *ngIf=\"showAllViews\"\n [manager]=\"manager\"\n [topOffset]=\"sideSheetTopOffset\"\n (close)=\"showAllViews = false\"\n></riv-all-views-modal>\n\n<riv-toast *ngIf=\"showLinkCopiedToast | async\" (close)=\"toastClosed.next()\">\n Link to view copied to clipboard\n</riv-toast>\n", styles: [".container{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(0,calc(var(--base-grid-size) * 81));justify-content:start;border-bottom:var(--border-width) solid var(--border-light)}.tab{font:var(--input-medium);color:var(--type-light-low-contrast);background-color:var(--surface-light-1);border:var(--border-width) solid var(--border-light);border-bottom:none;border-top-left-radius:var(--border-radius-medium);border-top-right-radius:var(--border-radius-medium);padding:var(--size-small) var(--size-large) var(--size-small) 0;cursor:pointer;transition:background-color var(--medium-transition);display:flex;justify-content:flex-start;align-items:center;position:relative}.tab:hover{background-color:var(--surface-light-2)}.tab:active{background-color:var(--surface-light-3)}.tab:not(:first-child),.active-menu{margin-left:calc(var(--border-width) * -1)}.tab.active{color:var(--purp-80);background-color:var(--surface-light-0);border-bottom:var(--border-width) solid var(--surface-light-0);margin-bottom:calc(var(--border-width) * -1);z-index:1;width:100%;max-width:100%;height:100%;max-height:100%}.tab.active:active{border:var(--border-width) solid var(--purp-80)}.tab.dragging{cursor:grabbing}.tab.dragged-over-left:before,.tab.dragged-over-right:before{content:\"\";position:absolute;top:0;bottom:0;width:var(--size-xxsmall);background-color:var(--brand);box-shadow:0 0 var(--size-xxsmall) var(--brand)}.tab.dragged-over-left:before{left:0}.tab.dragged-over-right:before{right:0}.tab-reorder{color:var(--type-light-low-contrast);opacity:0;transition:opacity var(--short-transition);cursor:grab;margin:0 var(--size-xsmall)}.tab:hover .tab-reorder{opacity:1}.hidden-class{visibility:hidden}.active-menu{display:inline-flex;color:var(--type-light-link-hover);--size: calc(100% + calc(var(--border-width)));width:var(--size);max-width:var(--size);height:var(--size);max-height:var(--size);cursor:pointer;font:var(--input-medium)}.tab.overflow{padding-left:var(--size-large)}.all-views-button-container{padding:var(--size-xxsmall)}.overflow-callout{padding:var(--size-large);display:flex;flex-direction:column;gap:var(--size-medium);height:calc(var(--base-grid-size) * 120);max-height:50vh;width:calc(var(--base-grid-size) * 75);max-width:50vw}.overflow-view-list{display:flex;flex-direction:column;gap:var(--size-small);flex-grow:1;overflow-y:auto}.overflow-view{display:flex;align-items:center;gap:var(--size-small);cursor:pointer;border-radius:var(--border-radius-medium);transition:background-color var(--short-transition);position:relative}.overflow-view.system{padding-left:var(--size-small)}.overflow-view:hover{background-color:var(--surface-light-2)}.overflow-view.dragged-over-top:before,.overflow-view.dragged-over-bottom:before{content:\"\";position:absolute;left:0;right:0;height:var(--size-xxsmall);background-color:var(--brand);box-shadow:0 0 var(--size-xxsmall) var(--brand)}.overflow-view.dragged-over-top:before{top:0}.overflow-view.dragged-over-bottom:before{bottom:0}.overflow-reorder{color:var(--type-light-low-contrast);cursor:grab}.overflow-title{flex-grow:1;text-align:left}\n"] }]
|
|
57
57
|
}], propDecorators: { manager: [{
|
|
58
58
|
type: Input
|
|
59
59
|
}], sideSheetTopOffset: [{
|
|
@@ -61,8 +61,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
61
61
|
}], overflowTrigger: [{
|
|
62
62
|
type: ViewChild,
|
|
63
63
|
args: ['overflowTrigger', { read: ElementRef }]
|
|
64
|
-
}], activeTab: [{
|
|
65
|
-
type: ViewChild,
|
|
66
|
-
args: ['activeTab', { read: ElementRef }]
|
|
67
64
|
}] } });
|
|
68
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"views.component.js","sourceRoot":"","sources":["../../../../../../../projects/riv/src/lib/navigation/views/views/views.component.ts","../../../../../../../projects/riv/src/lib/navigation/views/views/views.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,UAAU,EACV,KAAK,EAGL,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,MAAM,EAAE,GAAG,EAAE,KAAK,EAAc,OAAO,EAAE,MAAM,MAAM,CAAC;;;;;;;;;;;;;;;;AAS/D,MAAM,OAAO,cAAc;IAN3B;QAaE,uBAAkB,GAAW,CAAC,CAAC;QAQxB,iBAAY,GAAY,KAAK,CAAC;QAErC,oBAAe,GAAkB,IAAI,CAAC;QACtC,wBAAmB,GAAkB,IAAI,CAAC;QAwB1C,gBAAW,GAAG,IAAI,OAAO,EAAQ,CAAC;QAYlC,cAAS,GAA6C,CACpD,CAAS,EACT,CAA0B,EAC1B,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;KACX;IAtCC,SAAS,CAAC,KAAa;QACrB,IAAI,KAAK,GAAG,CAAC;YAAE,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;IAC9C,CAAC;IAED,QAAQ,CAAC,KAAa;QACpB,IAAI,KAAK,GAAG,CAAC;YAAE,IAAI,CAAC,mBAAmB,GAAG,KAAK,CAAC;;YAC3C,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;IACvC,CAAC;IAED,IAAI,CAAC,KAAa;QAChB,IAAI,IAAI,CAAC,eAAe,KAAK,IAAI,EAAE;YACjC,IAAI,CAAC,OAAO,EAAE,OAAO,CAAC,IAAI,CAAC;gBACzB,IAAI,EAAE,iBAAiB;gBACvB,oBAAoB,EAAE,IAAI,CAAC,eAAe;gBAC1C,eAAe,EAAE,KAAK;aACvB,CAAC,CAAC;SACJ;QAED,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;QAC5B,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;IAClC,CAAC;IAID,QAAQ;QACN,IAAI,CAAC,mBAAmB,GAAG,KAAK,CAC9B,IAAI,CAAC,OAAQ,CAAC,OAAO,CAAC,IAAI,CACxB,MAAM,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,KAAK,gBAAgB,CAAC,EAC/C,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,CAChB,EACD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,CACxC,CAAC;IACJ,CAAC;;2GApDU,cAAc;+FAAd,cAAc,0NASa,UAAU,iGAGhB,UAAU,6BC9B5C,slNA0MA;2FDxLa,cAAc;kBAN1B,SAAS;+BACE,WAAW,mBAGJ,uBAAuB,CAAC,MAAM;8BAM/C,OAAO;sBADN,KAAK;gBAIN,kBAAkB;sBADjB,KAAK;gBAIN,eAAe;sBADd,SAAS;uBAAC,iBAAiB,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE;gBAIlD,SAAS;sBADR,SAAS;uBAAC,WAAW,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  Input,\n  OnInit,\n  TrackByFunction,\n  ViewChild,\n} from '@angular/core';\nimport { filter, map, merge, Observable, Subject } from 'rxjs';\nimport { RivViews } from '../state';\n\n@Component({\n  selector: 'riv-views',\n  templateUrl: './views.component.html',\n  styleUrls: ['./views.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ViewsComponent<U extends RivViews.User, V extends RivViews.View<U>>\n  implements OnInit\n{\n  @Input()\n  manager?: RivViews.Manager<U, V>;\n\n  @Input()\n  sideSheetTopOffset: number = 0;\n\n  @ViewChild('overflowTrigger', { read: ElementRef })\n  overflowTrigger?: ElementRef;\n\n  @ViewChild('activeTab', { read: ElementRef })\n  activeTab?: ElementRef;\n\n  public showAllViews: boolean = false;\n\n  draggedTabIndex: number | null = null;\n  draggedOverTabIndex: number | null = null;\n\n  dragStart(index: number): void {\n    if (index > 0) this.draggedTabIndex = index;\n  }\n\n  dragOver(index: number): void {\n    if (index > 0) this.draggedOverTabIndex = index;\n    else this.draggedOverTabIndex = null;\n  }\n\n  drop(index: number): void {\n    if (this.draggedTabIndex !== null) {\n      this.manager?.actions.next({\n        type: 'viewOrderChange',\n        previousEnabledIndex: this.draggedTabIndex,\n        newEnabledIndex: index,\n      });\n    }\n\n    this.draggedTabIndex = null;\n    this.draggedOverTabIndex = null;\n  }\n\n  toastClosed = new Subject<void>();\n  showLinkCopiedToast?: Observable<boolean>;\n  ngOnInit() {\n    this.showLinkCopiedToast = merge(\n      this.manager!.actions.pipe(\n        filter(({ type }) => type === 'copyLinkToView'),\n        map(() => true),\n      ),\n      this.toastClosed.pipe(map(() => false)),\n    );\n  }\n\n  trackById: TrackByFunction<RivViews.FullView<U, V>> = (\n    _: number,\n    v: RivViews.FullView<U, V>,\n  ) => v.id;\n}\n","<div\n  (rivClientSize)=\"\n    manager?.actions?.next({ type: 'setContainerWidth', width: $event.width })\n  \"\n  class=\"container\"\n>\n  <ng-container *ngIf=\"manager?.state | async; let s\">\n    <ng-container\n      *ngFor=\"let view of s.displayedViews; let i = index; trackBy: trackById\"\n    >\n      <ng-container *ngIf=\"view.active; else inactiveTab\">\n        <div\n          #activeTab\n          class=\"tab active\"\n          [class.dragging]=\"draggedTabIndex === i\"\n          [class.dragged-over-left]=\"\n            draggedOverTabIndex === i &&\n            draggedTabIndex !== null &&\n            draggedTabIndex > i\n          \"\n          [class.dragged-over-right]=\"\n            draggedOverTabIndex === i &&\n            draggedTabIndex !== null &&\n            draggedTabIndex < i\n          \"\n          [attr.draggable]=\"i > 0\"\n          [attr.droppable]=\"i > 0\"\n          (dragstart)=\"dragStart(i)\"\n          (dragenter)=\"$event.preventDefault()\"\n          (dragover)=\"$event.preventDefault(); dragOver(i)\"\n          (drop)=\"drop(i)\"\n        >\n          <riv-icon\n            class=\"tab-reorder\"\n            [class.hidden-class]=\"i === 0\"\n            [name]=\"'Reorder'\"\n            [size]=\"16\"\n          ></riv-icon>\n          <div class=\"menu-wrapper\" rivTruncate>\n            <riv-view-menu\n              [manager]=\"manager\"\n              [view]=\"view\"\n              [menuContext]=\"'tab'\"\n              class=\"active-menu\"\n            >\n              <ng-template #menuTrigger>\n                <button class=\"menu-trigger\" rivTruncate>\n                  {{ view.title }}\n                </button>\n              </ng-template>\n            </riv-view-menu>\n          </div>\n        </div>\n      </ng-container>\n      <ng-template #inactiveTab>\n        <button\n          class=\"tab\"\n          [class.dragging]=\"draggedTabIndex === i\"\n          [class.dragged-over-left]=\"\n            draggedOverTabIndex === i &&\n            draggedTabIndex !== null &&\n            draggedTabIndex > i\n          \"\n          [class.dragged-over-right]=\"\n            draggedOverTabIndex === i &&\n            draggedTabIndex !== null &&\n            draggedTabIndex < i\n          \"\n          [attr.draggable]=\"i > 0\"\n          [attr.droppable]=\"i > 0\"\n          (dragstart)=\"dragStart(i)\"\n          (dragenter)=\"$event.preventDefault()\"\n          (dragover)=\"$event.preventDefault(); dragOver(i)\"\n          (drop)=\"drop(i)\"\n          (click)=\"\n            manager?.actions?.next({ type: 'setActiveView', id: view.id })\n          \"\n        >\n          <riv-icon\n            class=\"tab-reorder\"\n            [class.hidden-class]=\"i === 0\"\n            [name]=\"'Reorder'\"\n            [size]=\"16\"\n          ></riv-icon>\n          <span rivTruncate>\n            {{ view.title }}\n          </span>\n        </button>\n      </ng-template>\n    </ng-container>\n    <button\n      *ngIf=\"s.allEnabledViews.length - s.displayedViews.length; let count\"\n      class=\"tab overflow\"\n      rivTruncate\n      #overflowTrigger\n      (click)=\"\n        manager?.actions?.next({ type: 'setOverflowPickerOpen', open: true })\n      \"\n    >\n      {{ count | rivNumber }} more\n    </button>\n    <ng-container *ngIf=\"s.overflow.pickerOpen\">\n      <riv-callout\n        *riv-overlay\n        [anchor]=\"overflowTrigger?.nativeElement\"\n        [isModal]=\"true\"\n        [showCaret]=\"false\"\n        [theme]=\"'light'\"\n        [preferredPosition]=\"'bottom-left'\"\n        (close)=\"\n          manager?.actions?.next({ type: 'setOverflowPickerOpen', open: false })\n        \"\n      >\n        <div class=\"overflow-callout\">\n          <riv-search\n            [value]=\"s.overflow.search\"\n            (valueChange)=\"\n              manager?.actions?.next({\n                type: 'setOverflowSearchQuery',\n                query: $event\n              })\n            \"\n          ></riv-search>\n          <div class=\"overflow-view-list\">\n            <button\n              *ngFor=\"let view of s.enabledViews; let i = index\"\n              class=\"overflow-view\"\n              [class.system]=\"view.system\"\n              [class.dragging]=\"draggedTabIndex === i\"\n              [class.dragged-over-top]=\"\n                draggedOverTabIndex === i &&\n                draggedTabIndex !== null &&\n                draggedTabIndex > i\n              \"\n              [class.dragged-over-bottom]=\"\n                draggedOverTabIndex === i &&\n                draggedTabIndex !== null &&\n                draggedTabIndex < i\n              \"\n              [attr.draggable]=\"i > 0\"\n              [attr.droppable]=\"i > 0\"\n              (dragstart)=\"dragStart(i)\"\n              (dragenter)=\"$event.preventDefault()\"\n              (dragover)=\"$event.preventDefault(); dragOver(i)\"\n              (drop)=\"drop(i)\"\n              (click)=\"\n                manager?.actions?.next({ type: 'setActiveView', id: view.id });\n                manager?.actions?.next({\n                  type: 'setOverflowPickerOpen',\n                  open: false\n                })\n              \"\n            >\n              <riv-icon\n                *ngIf=\"i > 0\"\n                class=\"overflow-reorder\"\n                [name]=\"'Reorder'\"\n                [size]=\"16\"\n              ></riv-icon>\n              <div class=\"overflow-title\" rivTruncate>\n                <riv-highlight\n                  [indices]=\"view.titleHighlightIndices ?? []\"\n                  [text]=\"view.title\"\n                ></riv-highlight>\n              </div>\n              <riv-view-menu\n                [manager]=\"manager\"\n                [view]=\"view\"\n                [menuContext]=\"'overflow'\"\n              ></riv-view-menu>\n            </button>\n            <riv-zero-state\n              *ngIf=\"!s.enabledViews.length\"\n              [message]=\"'No matching views.'\"\n            ></riv-zero-state>\n          </div>\n        </div>\n      </riv-callout>\n    </ng-container>\n    <div class=\"all-views-button-container\">\n      <button\n        rivButton\n        [variant]=\"'ghost'\"\n        [size]=\"'medium'\"\n        (click)=\"showAllViews = true\"\n      >\n        All views\n      </button>\n    </div>\n  </ng-container>\n</div>\n\n<riv-all-views-modal\n  *ngIf=\"showAllViews\"\n  [manager]=\"manager\"\n  [topOffset]=\"sideSheetTopOffset\"\n  (close)=\"showAllViews = false\"\n></riv-all-views-modal>\n\n<riv-toast *ngIf=\"showLinkCopiedToast | async\" (close)=\"toastClosed.next()\">\n  Link to view copied to clipboard\n</riv-toast>\n"]}
|
|
65
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"views.component.js","sourceRoot":"","sources":["../../../../../../../projects/riv/src/lib/navigation/views/views/views.component.ts","../../../../../../../projects/riv/src/lib/navigation/views/views/views.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,UAAU,EACV,KAAK,EAGL,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,MAAM,EAAE,GAAG,EAAE,KAAK,EAAc,OAAO,EAAE,MAAM,MAAM,CAAC;;;;;;;;;;;;;;;;AAS/D,MAAM,OAAO,cAAc;IAN3B;QAaE,uBAAkB,GAAW,CAAC,CAAC;QAKxB,iBAAY,GAAY,KAAK,CAAC;QAErC,oBAAe,GAAkB,IAAI,CAAC;QACtC,wBAAmB,GAAkB,IAAI,CAAC;QAwB1C,gBAAW,GAAG,IAAI,OAAO,EAAQ,CAAC;QAYlC,cAAS,GAA6C,CACpD,CAAS,EACT,CAA0B,EAC1B,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;KACX;IAtCC,SAAS,CAAC,KAAa;QACrB,IAAI,KAAK,GAAG,CAAC;YAAE,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;IAC9C,CAAC;IAED,QAAQ,CAAC,KAAa;QACpB,IAAI,KAAK,GAAG,CAAC;YAAE,IAAI,CAAC,mBAAmB,GAAG,KAAK,CAAC;;YAC3C,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;IACvC,CAAC;IAED,IAAI,CAAC,KAAa;QAChB,IAAI,IAAI,CAAC,eAAe,KAAK,IAAI,EAAE;YACjC,IAAI,CAAC,OAAO,EAAE,OAAO,CAAC,IAAI,CAAC;gBACzB,IAAI,EAAE,iBAAiB;gBACvB,oBAAoB,EAAE,IAAI,CAAC,eAAe;gBAC1C,eAAe,EAAE,KAAK;aACvB,CAAC,CAAC;SACJ;QAED,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;QAC5B,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;IAClC,CAAC;IAID,QAAQ;QACN,IAAI,CAAC,mBAAmB,GAAG,KAAK,CAC9B,IAAI,CAAC,OAAQ,CAAC,OAAO,CAAC,IAAI,CACxB,MAAM,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,KAAK,gBAAgB,CAAC,EAC/C,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,CAChB,EACD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,CACxC,CAAC;IACJ,CAAC;;2GAjDU,cAAc;+FAAd,cAAc,0NASa,UAAU,6BC3BlD,+hNAuMA;2FDrLa,cAAc;kBAN1B,SAAS;+BACE,WAAW,mBAGJ,uBAAuB,CAAC,MAAM;8BAM/C,OAAO;sBADN,KAAK;gBAIN,kBAAkB;sBADjB,KAAK;gBAIN,eAAe;sBADd,SAAS;uBAAC,iBAAiB,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  Input,\n  OnInit,\n  TrackByFunction,\n  ViewChild,\n} from '@angular/core';\nimport { filter, map, merge, Observable, Subject } from 'rxjs';\nimport { RivViews } from '../state';\n\n@Component({\n  selector: 'riv-views',\n  templateUrl: './views.component.html',\n  styleUrls: ['./views.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ViewsComponent<U extends RivViews.User, V extends RivViews.View<U>>\n  implements OnInit\n{\n  @Input()\n  manager?: RivViews.Manager<U, V>;\n\n  @Input()\n  sideSheetTopOffset: number = 0;\n\n  @ViewChild('overflowTrigger', { read: ElementRef })\n  overflowTrigger?: ElementRef;\n\n  public showAllViews: boolean = false;\n\n  draggedTabIndex: number | null = null;\n  draggedOverTabIndex: number | null = null;\n\n  dragStart(index: number): void {\n    if (index > 0) this.draggedTabIndex = index;\n  }\n\n  dragOver(index: number): void {\n    if (index > 0) this.draggedOverTabIndex = index;\n    else this.draggedOverTabIndex = null;\n  }\n\n  drop(index: number): void {\n    if (this.draggedTabIndex !== null) {\n      this.manager?.actions.next({\n        type: 'viewOrderChange',\n        previousEnabledIndex: this.draggedTabIndex,\n        newEnabledIndex: index,\n      });\n    }\n\n    this.draggedTabIndex = null;\n    this.draggedOverTabIndex = null;\n  }\n\n  toastClosed = new Subject<void>();\n  showLinkCopiedToast?: Observable<boolean>;\n  ngOnInit() {\n    this.showLinkCopiedToast = merge(\n      this.manager!.actions.pipe(\n        filter(({ type }) => type === 'copyLinkToView'),\n        map(() => true),\n      ),\n      this.toastClosed.pipe(map(() => false)),\n    );\n  }\n\n  trackById: TrackByFunction<RivViews.FullView<U, V>> = (\n    _: number,\n    v: RivViews.FullView<U, V>,\n  ) => v.id;\n}\n","<div\n  (rivClientSize)=\"\n    manager?.actions?.next({ type: 'setContainerWidth', width: $event.width })\n  \"\n  class=\"container\"\n>\n  <ng-container *ngIf=\"manager?.state | async; let s\">\n    <ng-container\n      *ngFor=\"let view of s.displayedViews; let i = index; trackBy: trackById\"\n    >\n      <ng-container *ngIf=\"view.active; else inactiveTab\">\n        <riv-view-menu\n          [manager]=\"manager\"\n          [view]=\"view\"\n          [menuContext]=\"'tab'\"\n          class=\"active-menu\"\n        >\n          <ng-template #menuTrigger>\n            <div\n              class=\"tab active\"\n              [class.dragging]=\"draggedTabIndex === i\"\n              [class.dragged-over-left]=\"\n                draggedOverTabIndex === i &&\n                draggedTabIndex !== null &&\n                draggedTabIndex > i\n              \"\n              [class.dragged-over-right]=\"\n                draggedOverTabIndex === i &&\n                draggedTabIndex !== null &&\n                draggedTabIndex < i\n              \"\n              [attr.draggable]=\"i > 0\"\n              [attr.droppable]=\"i > 0\"\n              (dragstart)=\"dragStart(i)\"\n              (dragenter)=\"$event.preventDefault()\"\n              (dragover)=\"$event.preventDefault(); dragOver(i)\"\n              (drop)=\"drop(i)\"\n            >\n              <riv-icon\n                class=\"tab-reorder\"\n                [class.hidden-class]=\"i === 0\"\n                [name]=\"'Reorder'\"\n                [size]=\"16\"\n              ></riv-icon>\n              <div rivTruncate>\n                {{ view.title }}\n              </div>\n            </div>\n          </ng-template>\n        </riv-view-menu>\n      </ng-container>\n      <ng-template #inactiveTab>\n        <button\n          class=\"tab\"\n          [class.dragging]=\"draggedTabIndex === i\"\n          [class.dragged-over-left]=\"\n            draggedOverTabIndex === i &&\n            draggedTabIndex !== null &&\n            draggedTabIndex > i\n          \"\n          [class.dragged-over-right]=\"\n            draggedOverTabIndex === i &&\n            draggedTabIndex !== null &&\n            draggedTabIndex < i\n          \"\n          [attr.draggable]=\"i > 0\"\n          [attr.droppable]=\"i > 0\"\n          (dragstart)=\"dragStart(i)\"\n          (dragenter)=\"$event.preventDefault()\"\n          (dragover)=\"$event.preventDefault(); dragOver(i)\"\n          (drop)=\"drop(i)\"\n          (click)=\"\n            manager?.actions?.next({ type: 'setActiveView', id: view.id })\n          \"\n        >\n          <riv-icon\n            class=\"tab-reorder\"\n            [class.hidden-class]=\"i === 0\"\n            [name]=\"'Reorder'\"\n            [size]=\"16\"\n          ></riv-icon>\n          <span rivTruncate>\n            {{ view.title }}\n          </span>\n        </button>\n      </ng-template>\n    </ng-container>\n    <button\n      *ngIf=\"s.allEnabledViews.length - s.displayedViews.length; let count\"\n      class=\"tab overflow\"\n      rivTruncate\n      #overflowTrigger\n      (click)=\"\n        manager?.actions?.next({ type: 'setOverflowPickerOpen', open: true })\n      \"\n    >\n      {{ count | rivNumber }} more\n    </button>\n    <ng-container *ngIf=\"s.overflow.pickerOpen\">\n      <riv-callout\n        *riv-overlay\n        [anchor]=\"overflowTrigger?.nativeElement\"\n        [isModal]=\"true\"\n        [showCaret]=\"false\"\n        [theme]=\"'light'\"\n        [preferredPosition]=\"'bottom-left'\"\n        (close)=\"\n          manager?.actions?.next({ type: 'setOverflowPickerOpen', open: false })\n        \"\n      >\n        <div class=\"overflow-callout\">\n          <riv-search\n            [value]=\"s.overflow.search\"\n            (valueChange)=\"\n              manager?.actions?.next({\n                type: 'setOverflowSearchQuery',\n                query: $event\n              })\n            \"\n          ></riv-search>\n          <div class=\"overflow-view-list\">\n            <button\n              *ngFor=\"let view of s.enabledViews; let i = index\"\n              class=\"overflow-view\"\n              [class.system]=\"view.system\"\n              [class.dragging]=\"draggedTabIndex === i\"\n              [class.dragged-over-top]=\"\n                draggedOverTabIndex === i &&\n                draggedTabIndex !== null &&\n                draggedTabIndex > i\n              \"\n              [class.dragged-over-bottom]=\"\n                draggedOverTabIndex === i &&\n                draggedTabIndex !== null &&\n                draggedTabIndex < i\n              \"\n              [attr.draggable]=\"i > 0\"\n              [attr.droppable]=\"i > 0\"\n              (dragstart)=\"dragStart(i)\"\n              (dragenter)=\"$event.preventDefault()\"\n              (dragover)=\"$event.preventDefault(); dragOver(i)\"\n              (drop)=\"drop(i)\"\n              (click)=\"\n                manager?.actions?.next({ type: 'setActiveView', id: view.id });\n                manager?.actions?.next({\n                  type: 'setOverflowPickerOpen',\n                  open: false\n                })\n              \"\n            >\n              <riv-icon\n                *ngIf=\"i > 0\"\n                class=\"overflow-reorder\"\n                [name]=\"'Reorder'\"\n                [size]=\"16\"\n              ></riv-icon>\n              <div class=\"overflow-title\" rivTruncate>\n                <riv-highlight\n                  [indices]=\"view.titleHighlightIndices ?? []\"\n                  [text]=\"view.title\"\n                ></riv-highlight>\n              </div>\n              <riv-view-menu\n                [manager]=\"manager\"\n                [view]=\"view\"\n                [menuContext]=\"'overflow'\"\n              ></riv-view-menu>\n            </button>\n            <riv-zero-state\n              *ngIf=\"!s.enabledViews.length\"\n              [message]=\"'No matching views.'\"\n            ></riv-zero-state>\n          </div>\n        </div>\n      </riv-callout>\n    </ng-container>\n    <div class=\"all-views-button-container\">\n      <button\n        rivButton\n        [variant]=\"'ghost'\"\n        [size]=\"'medium'\"\n        (click)=\"showAllViews = true\"\n      >\n        All views\n      </button>\n    </div>\n  </ng-container>\n</div>\n\n<riv-all-views-modal\n  *ngIf=\"showAllViews\"\n  [manager]=\"manager\"\n  [topOffset]=\"sideSheetTopOffset\"\n  (close)=\"showAllViews = false\"\n></riv-all-views-modal>\n\n<riv-toast *ngIf=\"showLinkCopiedToast | async\" (close)=\"toastClosed.next()\">\n  Link to view copied to clipboard\n</riv-toast>\n"]}
|