@rivet-health/design-system 28.2.3 → 28.2.5

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.
@@ -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, withLatestFrom, } from 'rxjs';
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$ = this.favoritePresetIds$.pipe(withLatestFrom(this.alternativePresetList$), map(([ids, alternativePresetList]) => {
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 => DateRangeComponent.Presets.find(preset => preset.id === 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":"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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  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"]}
@@ -7,8 +7,9 @@ import * as i3 from "../../../visualization/highlight/highlight.component";
7
7
  import * as i4 from "../../../icon/icon.component";
8
8
  import * as i5 from "../../../input/search/search.component";
9
9
  import * as i6 from "../../../overlay/modal/side-sheet/side-sheet.component";
10
- import * as i7 from "../../../format/truncate/truncate.component";
11
- import * as i8 from "../view-menu/view-menu.component";
10
+ import * as i7 from "../../../overlay/callout/tooltip/tooltip.directive";
11
+ import * as i8 from "../../../format/truncate/truncate.component";
12
+ import * as i9 from "../view-menu/view-menu.component";
12
13
  export class AllViewsModalComponent {
13
14
  constructor() {
14
15
  this.topOffset = 0;
@@ -28,10 +29,10 @@ export class AllViewsModalComponent {
28
29
  }
29
30
  }
30
31
  AllViewsModalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: AllViewsModalComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
31
- AllViewsModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: AllViewsModalComponent, selector: "riv-all-views-modal", inputs: { manager: "manager", topOffset: "topOffset" }, outputs: { close: "close" }, ngImport: i0, template: "<ng-container *ngIf=\"manager?.state | async; let s\">\n <riv-side-sheet [topOffset]=\"topOffset\" (close)=\"close.emit()\">\n <div class=\"content\">\n <header>\n <span class=\"title\">All views</span>\n <button\n rivButton\n [variant]=\"'ghost'\"\n [icon]=\"'X'\"\n (click)=\"close.emit()\"\n ></button>\n </header>\n\n <riv-search\n (valueChange)=\"\n manager?.actions?.next({\n type: 'setAllViewsSearchQuery',\n query: $event\n })\n \"\n [value]=\"s.all.search\"\n placeholder=\"Search\"\n ></riv-search>\n\n <div class=\"views\">\n <!-- View sections by permission type -->\n <ng-container\n *ngIf=\"s.all.privateViews.length > 0\"\n [ngTemplateOutlet]=\"permissionSection\"\n [ngTemplateOutletContext]=\"{\n permission: 'private',\n open: s.all.privateOpen,\n openChange: getOpenChange('private'),\n views: s.all.privateViews,\n title: getPermissionTitle('private'),\n description: getPermissionDescription('private')\n }\"\n ></ng-container>\n <ng-container\n *ngIf=\"s.all.sharedViews.length > 0\"\n [ngTemplateOutlet]=\"permissionSection\"\n [ngTemplateOutletContext]=\"{\n permission: 'shared',\n open: s.all.sharedOpen,\n openChange: getOpenChange('shared'),\n views: s.all.sharedViews,\n title: getPermissionTitle('shared'),\n description: getPermissionDescription('shared')\n }\"\n ></ng-container>\n <ng-container\n *ngIf=\"s.all.publicViews.length > 0\"\n [ngTemplateOutlet]=\"permissionSection\"\n [ngTemplateOutletContext]=\"{\n permission: 'public',\n open: s.all.publicOpen,\n openChange: getOpenChange('public'),\n views: s.all.publicViews,\n title: getPermissionTitle('public'),\n description: getPermissionDescription('public')\n }\"\n ></ng-container>\n\n <!-- Permission section -->\n <ng-template\n #permissionSection\n let-permission=\"permission\"\n let-open=\"open\"\n let-openChange=\"openChange\"\n let-views=\"views\"\n let-title=\"title\"\n let-description=\"description\"\n >\n <div class=\"permission-section\">\n <button\n class=\"permission-header\"\n (click)=\"openChange(!open)\"\n [disabled]=\"!!s.all.search\"\n >\n <div class=\"permission-header-content\">\n <h3 class=\"permission-title\">{{ title }}</h3>\n <span class=\"permission-description\">{{ description }}</span>\n </div>\n <riv-icon\n [name]=\"open ? 'ChevronUp' : 'ChevronDown'\"\n [size]=\"20\"\n ></riv-icon>\n </button>\n\n <div class=\"permission-content\" *ngIf=\"open\">\n <div class=\"views-list\" *ngIf=\"views.length > 0\">\n <button\n *ngFor=\"let view of views; trackBy: trackById\"\n class=\"view-item\"\n (click)=\"\n manager?.actions?.next({\n type: 'setActiveView',\n id: view.id\n });\n close.emit()\n \"\n >\n <div class=\"view-title\" rivTruncate>\n <riv-highlight\n [text]=\"view.title\"\n [indices]=\"view.titleHighlightIndices ?? []\"\n >\n </riv-highlight>\n </div>\n <riv-view-menu\n [manager]=\"manager\"\n [view]=\"view\"\n [menuContext]=\"'all-views'\"\n ></riv-view-menu>\n <button\n class=\"enable-view\"\n [class.enabled]=\"view.enabled\"\n (click)=\"\n $event.stopPropagation();\n manager?.actions?.next({\n type: 'setEnabled',\n id: view.id,\n enabled: !view.enabled\n })\n \"\n [disabled]=\"view.system\"\n >\n <riv-icon\n [name]=\"\n view.system ? 'Lock' : view.enabled ? 'Eye' : 'EyeOff'\n \"\n [size]=\"20\"\n ></riv-icon>\n </button>\n </button>\n </div>\n </div>\n </div>\n </ng-template>\n </div>\n </div>\n </riv-side-sheet>\n</ng-container>\n", styles: [".content{padding:var(--size-large);display:flex;flex-direction:column;gap:var(--size-medium);height:100%}header{display:flex;justify-content:space-between;align-items:center}.title{font:var(--title-02)}.views{flex-grow:1;overflow-y:auto;display:flex;flex-direction:column;gap:var(--size-xlarge)}.permission-section{display:flex;flex-direction:column}.permission-header{display:flex;justify-content:space-between;align-items:center;width:100%;padding:var(--size-xsmall);border:none;background:none;cursor:pointer;gap:var(--size-small);border-radius:var(--border-radius-medium);transition:background-color var(--short-transition)}.permission-header:disabled{cursor:default;color:var(--type-light-disabled)}.permission-header:hover:not(:disabled){background-color:var(--surface-light-1)}.permission-header:active:not(:disabled){background-color:var(--surface-light-2)}.permission-header-content{display:flex;flex-direction:column;align-items:flex-start;text-align:left}.permission-title{font:var(--title-02)}.permission-description{font:var(--body-medium);color:var(--type-light-low-contrast)}.permission-content{padding-left:var(--size-small);padding-top:var(--size-small)}.views-list{display:flex;flex-direction:column;gap:var(--size-small)}.view-item{display:flex;align-items:center;padding:var(--size-xsmall) var(--size-small);border-radius:var(--border-radius-small);cursor:pointer;background-color:var(--surface-light-0);transition:background-color var(--short-transition)}.view-item:hover{background-color:var(--surface-light-1)}.view-item:active{background-color:var(--surface-light-2)}.view-title{text-align:left;flex-grow:1;font:var(--input-medium)}.view-item riv-view-menu{align-self:flex-end;opacity:0;transition:opacity var(--short-transition)}.view-item:hover riv-view-menu{opacity:1}.enable-view{cursor:pointer;display:inline-flex;justify-content:center;align-items:center;padding:0 var(--size-xsmall);transition:color var(--medium-transition);color:var(--type-light-low-contrast)}.enable-view.enabled{color:var(--type-light-link)}.enable-view.enabled:hover{color:var(--type-light-link-hover)}.enable-view.enabled:active{color:var(--type-light-link-active)}\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: "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.HighlightComponent, selector: "riv-highlight", inputs: ["text", "indices"] }, { kind: "component", type: i4.IconComponent, selector: "riv-icon", inputs: ["name", "size", "customSize", "strokeWidth"] }, { kind: "component", type: i5.SearchComponent, selector: "riv-search", inputs: ["placeholder", "name", "labelTemplate"] }, { kind: "component", type: i6.SideSheetComponent, selector: "riv-side-sheet", inputs: ["topOffset", "width", "obscure"], outputs: ["close"] }, { kind: "component", type: i7.TruncateComponent, selector: "[rivTruncate]", inputs: ["maxTooltipWidth"] }, { kind: "component", type: i8.ViewMenuComponent, selector: "riv-view-menu", inputs: ["manager", "view", "menuContext"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
32
+ AllViewsModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: AllViewsModalComponent, selector: "riv-all-views-modal", inputs: { manager: "manager", topOffset: "topOffset" }, outputs: { close: "close" }, ngImport: i0, template: "<ng-container *ngIf=\"manager?.state | async; let s\">\n <riv-side-sheet [topOffset]=\"topOffset\" (close)=\"close.emit()\">\n <div class=\"content\">\n <header>\n <span class=\"title\">All views</span>\n <button\n rivButton\n [variant]=\"'ghost'\"\n [icon]=\"'X'\"\n (click)=\"close.emit()\"\n ></button>\n </header>\n\n <riv-search\n (valueChange)=\"\n manager?.actions?.next({\n type: 'setAllViewsSearchQuery',\n query: $event\n })\n \"\n [value]=\"s.all.search\"\n placeholder=\"Search\"\n ></riv-search>\n\n <div class=\"views\">\n <!-- View sections by permission type -->\n <ng-container\n *ngIf=\"s.all.privateViews.length > 0\"\n [ngTemplateOutlet]=\"permissionSection\"\n [ngTemplateOutletContext]=\"{\n permission: 'private',\n open: s.all.privateOpen,\n openChange: getOpenChange('private'),\n views: s.all.privateViews,\n title: getPermissionTitle('private'),\n description: getPermissionDescription('private')\n }\"\n ></ng-container>\n <ng-container\n *ngIf=\"s.all.sharedViews.length > 0\"\n [ngTemplateOutlet]=\"permissionSection\"\n [ngTemplateOutletContext]=\"{\n permission: 'shared',\n open: s.all.sharedOpen,\n openChange: getOpenChange('shared'),\n views: s.all.sharedViews,\n title: getPermissionTitle('shared'),\n description: getPermissionDescription('shared')\n }\"\n ></ng-container>\n <ng-container\n *ngIf=\"s.all.publicViews.length > 0\"\n [ngTemplateOutlet]=\"permissionSection\"\n [ngTemplateOutletContext]=\"{\n permission: 'public',\n open: s.all.publicOpen,\n openChange: getOpenChange('public'),\n views: s.all.publicViews,\n title: getPermissionTitle('public'),\n description: getPermissionDescription('public')\n }\"\n ></ng-container>\n\n <!-- Permission section -->\n <ng-template\n #permissionSection\n let-permission=\"permission\"\n let-open=\"open\"\n let-openChange=\"openChange\"\n let-views=\"views\"\n let-title=\"title\"\n let-description=\"description\"\n >\n <div class=\"permission-section\">\n <button\n class=\"permission-header\"\n (click)=\"openChange(!open)\"\n [disabled]=\"!!s.all.search\"\n >\n <div class=\"permission-header-content\">\n <h3 class=\"permission-title\">{{ title }}</h3>\n <span class=\"permission-description\">{{ description }}</span>\n </div>\n <riv-icon\n [name]=\"open ? 'ChevronUp' : 'ChevronDown'\"\n [size]=\"20\"\n ></riv-icon>\n </button>\n\n <div class=\"permission-content\" *ngIf=\"open\">\n <div class=\"views-list\" *ngIf=\"views.length > 0\">\n <button\n *ngFor=\"let view of views; trackBy: trackById\"\n class=\"view-item\"\n (click)=\"\n manager?.actions?.next({\n type: 'setActiveView',\n id: view.id\n });\n close.emit()\n \"\n >\n <div class=\"view-title\" rivTruncate>\n <riv-highlight\n [text]=\"view.title\"\n [indices]=\"view.titleHighlightIndices ?? []\"\n >\n </riv-highlight>\n </div>\n <riv-view-menu\n [manager]=\"manager\"\n [view]=\"view\"\n [menuContext]=\"'all-views'\"\n ></riv-view-menu>\n <button\n class=\"enable-view\"\n [class.enabled]=\"view.enabled && !view.system\"\n (click)=\"\n $event.stopPropagation();\n manager?.actions?.next({\n type: 'setEnabled',\n id: view.id,\n enabled: !view.enabled\n })\n \"\n [disabled]=\"view.system\"\n >\n <riv-icon\n *ngIf=\"view.enabled\"\n [name]=\"view.system ? 'Lock' : 'Eye'\"\n [rivTooltip]=\"view.system ? '' : 'Hide tab'\"\n [size]=\"20\"\n ></riv-icon>\n <riv-icon\n *ngIf=\"!view.enabled\"\n [name]=\"'EyeOff'\"\n [rivTooltip]=\"'Show tab'\"\n [size]=\"20\"\n ></riv-icon>\n </button>\n </button>\n </div>\n </div>\n </div>\n </ng-template>\n </div>\n </div>\n </riv-side-sheet>\n</ng-container>\n", styles: [".content{padding:var(--size-large);display:flex;flex-direction:column;gap:var(--size-medium);height:100%}header{display:flex;justify-content:space-between;align-items:center}.title{font:var(--title-02)}.views{flex-grow:1;overflow-y:auto;display:flex;flex-direction:column;gap:var(--size-xlarge)}.permission-section{display:flex;flex-direction:column}.permission-header{display:flex;justify-content:space-between;align-items:center;width:100%;padding:var(--size-xsmall);border:none;background:none;cursor:pointer;gap:var(--size-small);border-radius:var(--border-radius-medium);transition:background-color var(--short-transition)}.permission-header:disabled{cursor:default;color:var(--type-light-disabled)}.permission-header:hover:not(:disabled){background-color:var(--surface-light-1)}.permission-header:active:not(:disabled){background-color:var(--surface-light-2)}.permission-header-content{display:flex;flex-direction:column;align-items:flex-start;text-align:left}.permission-title{font:var(--title-02)}.permission-description{font:var(--body-medium);color:var(--type-light-low-contrast)}.permission-content{padding-left:var(--size-small);padding-top:var(--size-small)}.views-list{display:flex;flex-direction:column;gap:var(--size-small)}.view-item{display:flex;align-items:center;padding:var(--size-xsmall) var(--size-small);border-radius:var(--border-radius-small);cursor:pointer;background-color:var(--surface-light-0);transition:background-color var(--short-transition)}.view-item:hover{background-color:var(--surface-light-1)}.view-item:active{background-color:var(--surface-light-2)}.view-title{text-align:left;flex-grow:1;font:var(--input-medium)}.view-item riv-view-menu{align-self:flex-end;opacity:0;transition:opacity var(--short-transition)}.view-item:hover riv-view-menu{opacity:1}.enable-view{cursor:pointer;display:inline-flex;justify-content:center;align-items:center;padding:0 var(--size-xsmall);transition:color var(--medium-transition);color:var(--type-light-low-contrast)}.enable-view.enabled{color:var(--type-light-link)}.enable-view.enabled:hover{color:var(--type-light-link-hover)}.enable-view.enabled:active{color:var(--type-light-link-active)}\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: "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.HighlightComponent, selector: "riv-highlight", inputs: ["text", "indices"] }, { kind: "component", type: i4.IconComponent, selector: "riv-icon", inputs: ["name", "size", "customSize", "strokeWidth"] }, { kind: "component", type: i5.SearchComponent, selector: "riv-search", inputs: ["placeholder", "name", "labelTemplate"] }, { kind: "component", type: i6.SideSheetComponent, selector: "riv-side-sheet", inputs: ["topOffset", "width", "obscure"], outputs: ["close"] }, { kind: "directive", type: i7.TooltipDirective, selector: "[rivTooltip]", inputs: ["rivTooltip", "rivTooltipTheme", "rivTooltipMaxWidth", "rivTooltipPreferredPosition", "rivTooltipCloseDelay"] }, { kind: "component", type: i8.TruncateComponent, selector: "[rivTruncate]", inputs: ["maxTooltipWidth"] }, { kind: "component", type: i9.ViewMenuComponent, selector: "riv-view-menu", inputs: ["manager", "view", "menuContext"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
32
33
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: AllViewsModalComponent, decorators: [{
33
34
  type: Component,
34
- args: [{ selector: 'riv-all-views-modal', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"manager?.state | async; let s\">\n <riv-side-sheet [topOffset]=\"topOffset\" (close)=\"close.emit()\">\n <div class=\"content\">\n <header>\n <span class=\"title\">All views</span>\n <button\n rivButton\n [variant]=\"'ghost'\"\n [icon]=\"'X'\"\n (click)=\"close.emit()\"\n ></button>\n </header>\n\n <riv-search\n (valueChange)=\"\n manager?.actions?.next({\n type: 'setAllViewsSearchQuery',\n query: $event\n })\n \"\n [value]=\"s.all.search\"\n placeholder=\"Search\"\n ></riv-search>\n\n <div class=\"views\">\n <!-- View sections by permission type -->\n <ng-container\n *ngIf=\"s.all.privateViews.length > 0\"\n [ngTemplateOutlet]=\"permissionSection\"\n [ngTemplateOutletContext]=\"{\n permission: 'private',\n open: s.all.privateOpen,\n openChange: getOpenChange('private'),\n views: s.all.privateViews,\n title: getPermissionTitle('private'),\n description: getPermissionDescription('private')\n }\"\n ></ng-container>\n <ng-container\n *ngIf=\"s.all.sharedViews.length > 0\"\n [ngTemplateOutlet]=\"permissionSection\"\n [ngTemplateOutletContext]=\"{\n permission: 'shared',\n open: s.all.sharedOpen,\n openChange: getOpenChange('shared'),\n views: s.all.sharedViews,\n title: getPermissionTitle('shared'),\n description: getPermissionDescription('shared')\n }\"\n ></ng-container>\n <ng-container\n *ngIf=\"s.all.publicViews.length > 0\"\n [ngTemplateOutlet]=\"permissionSection\"\n [ngTemplateOutletContext]=\"{\n permission: 'public',\n open: s.all.publicOpen,\n openChange: getOpenChange('public'),\n views: s.all.publicViews,\n title: getPermissionTitle('public'),\n description: getPermissionDescription('public')\n }\"\n ></ng-container>\n\n <!-- Permission section -->\n <ng-template\n #permissionSection\n let-permission=\"permission\"\n let-open=\"open\"\n let-openChange=\"openChange\"\n let-views=\"views\"\n let-title=\"title\"\n let-description=\"description\"\n >\n <div class=\"permission-section\">\n <button\n class=\"permission-header\"\n (click)=\"openChange(!open)\"\n [disabled]=\"!!s.all.search\"\n >\n <div class=\"permission-header-content\">\n <h3 class=\"permission-title\">{{ title }}</h3>\n <span class=\"permission-description\">{{ description }}</span>\n </div>\n <riv-icon\n [name]=\"open ? 'ChevronUp' : 'ChevronDown'\"\n [size]=\"20\"\n ></riv-icon>\n </button>\n\n <div class=\"permission-content\" *ngIf=\"open\">\n <div class=\"views-list\" *ngIf=\"views.length > 0\">\n <button\n *ngFor=\"let view of views; trackBy: trackById\"\n class=\"view-item\"\n (click)=\"\n manager?.actions?.next({\n type: 'setActiveView',\n id: view.id\n });\n close.emit()\n \"\n >\n <div class=\"view-title\" rivTruncate>\n <riv-highlight\n [text]=\"view.title\"\n [indices]=\"view.titleHighlightIndices ?? []\"\n >\n </riv-highlight>\n </div>\n <riv-view-menu\n [manager]=\"manager\"\n [view]=\"view\"\n [menuContext]=\"'all-views'\"\n ></riv-view-menu>\n <button\n class=\"enable-view\"\n [class.enabled]=\"view.enabled\"\n (click)=\"\n $event.stopPropagation();\n manager?.actions?.next({\n type: 'setEnabled',\n id: view.id,\n enabled: !view.enabled\n })\n \"\n [disabled]=\"view.system\"\n >\n <riv-icon\n [name]=\"\n view.system ? 'Lock' : view.enabled ? 'Eye' : 'EyeOff'\n \"\n [size]=\"20\"\n ></riv-icon>\n </button>\n </button>\n </div>\n </div>\n </div>\n </ng-template>\n </div>\n </div>\n </riv-side-sheet>\n</ng-container>\n", styles: [".content{padding:var(--size-large);display:flex;flex-direction:column;gap:var(--size-medium);height:100%}header{display:flex;justify-content:space-between;align-items:center}.title{font:var(--title-02)}.views{flex-grow:1;overflow-y:auto;display:flex;flex-direction:column;gap:var(--size-xlarge)}.permission-section{display:flex;flex-direction:column}.permission-header{display:flex;justify-content:space-between;align-items:center;width:100%;padding:var(--size-xsmall);border:none;background:none;cursor:pointer;gap:var(--size-small);border-radius:var(--border-radius-medium);transition:background-color var(--short-transition)}.permission-header:disabled{cursor:default;color:var(--type-light-disabled)}.permission-header:hover:not(:disabled){background-color:var(--surface-light-1)}.permission-header:active:not(:disabled){background-color:var(--surface-light-2)}.permission-header-content{display:flex;flex-direction:column;align-items:flex-start;text-align:left}.permission-title{font:var(--title-02)}.permission-description{font:var(--body-medium);color:var(--type-light-low-contrast)}.permission-content{padding-left:var(--size-small);padding-top:var(--size-small)}.views-list{display:flex;flex-direction:column;gap:var(--size-small)}.view-item{display:flex;align-items:center;padding:var(--size-xsmall) var(--size-small);border-radius:var(--border-radius-small);cursor:pointer;background-color:var(--surface-light-0);transition:background-color var(--short-transition)}.view-item:hover{background-color:var(--surface-light-1)}.view-item:active{background-color:var(--surface-light-2)}.view-title{text-align:left;flex-grow:1;font:var(--input-medium)}.view-item riv-view-menu{align-self:flex-end;opacity:0;transition:opacity var(--short-transition)}.view-item:hover riv-view-menu{opacity:1}.enable-view{cursor:pointer;display:inline-flex;justify-content:center;align-items:center;padding:0 var(--size-xsmall);transition:color var(--medium-transition);color:var(--type-light-low-contrast)}.enable-view.enabled{color:var(--type-light-link)}.enable-view.enabled:hover{color:var(--type-light-link-hover)}.enable-view.enabled:active{color:var(--type-light-link-active)}\n"] }]
35
+ args: [{ selector: 'riv-all-views-modal', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"manager?.state | async; let s\">\n <riv-side-sheet [topOffset]=\"topOffset\" (close)=\"close.emit()\">\n <div class=\"content\">\n <header>\n <span class=\"title\">All views</span>\n <button\n rivButton\n [variant]=\"'ghost'\"\n [icon]=\"'X'\"\n (click)=\"close.emit()\"\n ></button>\n </header>\n\n <riv-search\n (valueChange)=\"\n manager?.actions?.next({\n type: 'setAllViewsSearchQuery',\n query: $event\n })\n \"\n [value]=\"s.all.search\"\n placeholder=\"Search\"\n ></riv-search>\n\n <div class=\"views\">\n <!-- View sections by permission type -->\n <ng-container\n *ngIf=\"s.all.privateViews.length > 0\"\n [ngTemplateOutlet]=\"permissionSection\"\n [ngTemplateOutletContext]=\"{\n permission: 'private',\n open: s.all.privateOpen,\n openChange: getOpenChange('private'),\n views: s.all.privateViews,\n title: getPermissionTitle('private'),\n description: getPermissionDescription('private')\n }\"\n ></ng-container>\n <ng-container\n *ngIf=\"s.all.sharedViews.length > 0\"\n [ngTemplateOutlet]=\"permissionSection\"\n [ngTemplateOutletContext]=\"{\n permission: 'shared',\n open: s.all.sharedOpen,\n openChange: getOpenChange('shared'),\n views: s.all.sharedViews,\n title: getPermissionTitle('shared'),\n description: getPermissionDescription('shared')\n }\"\n ></ng-container>\n <ng-container\n *ngIf=\"s.all.publicViews.length > 0\"\n [ngTemplateOutlet]=\"permissionSection\"\n [ngTemplateOutletContext]=\"{\n permission: 'public',\n open: s.all.publicOpen,\n openChange: getOpenChange('public'),\n views: s.all.publicViews,\n title: getPermissionTitle('public'),\n description: getPermissionDescription('public')\n }\"\n ></ng-container>\n\n <!-- Permission section -->\n <ng-template\n #permissionSection\n let-permission=\"permission\"\n let-open=\"open\"\n let-openChange=\"openChange\"\n let-views=\"views\"\n let-title=\"title\"\n let-description=\"description\"\n >\n <div class=\"permission-section\">\n <button\n class=\"permission-header\"\n (click)=\"openChange(!open)\"\n [disabled]=\"!!s.all.search\"\n >\n <div class=\"permission-header-content\">\n <h3 class=\"permission-title\">{{ title }}</h3>\n <span class=\"permission-description\">{{ description }}</span>\n </div>\n <riv-icon\n [name]=\"open ? 'ChevronUp' : 'ChevronDown'\"\n [size]=\"20\"\n ></riv-icon>\n </button>\n\n <div class=\"permission-content\" *ngIf=\"open\">\n <div class=\"views-list\" *ngIf=\"views.length > 0\">\n <button\n *ngFor=\"let view of views; trackBy: trackById\"\n class=\"view-item\"\n (click)=\"\n manager?.actions?.next({\n type: 'setActiveView',\n id: view.id\n });\n close.emit()\n \"\n >\n <div class=\"view-title\" rivTruncate>\n <riv-highlight\n [text]=\"view.title\"\n [indices]=\"view.titleHighlightIndices ?? []\"\n >\n </riv-highlight>\n </div>\n <riv-view-menu\n [manager]=\"manager\"\n [view]=\"view\"\n [menuContext]=\"'all-views'\"\n ></riv-view-menu>\n <button\n class=\"enable-view\"\n [class.enabled]=\"view.enabled && !view.system\"\n (click)=\"\n $event.stopPropagation();\n manager?.actions?.next({\n type: 'setEnabled',\n id: view.id,\n enabled: !view.enabled\n })\n \"\n [disabled]=\"view.system\"\n >\n <riv-icon\n *ngIf=\"view.enabled\"\n [name]=\"view.system ? 'Lock' : 'Eye'\"\n [rivTooltip]=\"view.system ? '' : 'Hide tab'\"\n [size]=\"20\"\n ></riv-icon>\n <riv-icon\n *ngIf=\"!view.enabled\"\n [name]=\"'EyeOff'\"\n [rivTooltip]=\"'Show tab'\"\n [size]=\"20\"\n ></riv-icon>\n </button>\n </button>\n </div>\n </div>\n </div>\n </ng-template>\n </div>\n </div>\n </riv-side-sheet>\n</ng-container>\n", styles: [".content{padding:var(--size-large);display:flex;flex-direction:column;gap:var(--size-medium);height:100%}header{display:flex;justify-content:space-between;align-items:center}.title{font:var(--title-02)}.views{flex-grow:1;overflow-y:auto;display:flex;flex-direction:column;gap:var(--size-xlarge)}.permission-section{display:flex;flex-direction:column}.permission-header{display:flex;justify-content:space-between;align-items:center;width:100%;padding:var(--size-xsmall);border:none;background:none;cursor:pointer;gap:var(--size-small);border-radius:var(--border-radius-medium);transition:background-color var(--short-transition)}.permission-header:disabled{cursor:default;color:var(--type-light-disabled)}.permission-header:hover:not(:disabled){background-color:var(--surface-light-1)}.permission-header:active:not(:disabled){background-color:var(--surface-light-2)}.permission-header-content{display:flex;flex-direction:column;align-items:flex-start;text-align:left}.permission-title{font:var(--title-02)}.permission-description{font:var(--body-medium);color:var(--type-light-low-contrast)}.permission-content{padding-left:var(--size-small);padding-top:var(--size-small)}.views-list{display:flex;flex-direction:column;gap:var(--size-small)}.view-item{display:flex;align-items:center;padding:var(--size-xsmall) var(--size-small);border-radius:var(--border-radius-small);cursor:pointer;background-color:var(--surface-light-0);transition:background-color var(--short-transition)}.view-item:hover{background-color:var(--surface-light-1)}.view-item:active{background-color:var(--surface-light-2)}.view-title{text-align:left;flex-grow:1;font:var(--input-medium)}.view-item riv-view-menu{align-self:flex-end;opacity:0;transition:opacity var(--short-transition)}.view-item:hover riv-view-menu{opacity:1}.enable-view{cursor:pointer;display:inline-flex;justify-content:center;align-items:center;padding:0 var(--size-xsmall);transition:color var(--medium-transition);color:var(--type-light-low-contrast)}.enable-view.enabled{color:var(--type-light-link)}.enable-view.enabled:hover{color:var(--type-light-link-hover)}.enable-view.enabled:active{color:var(--type-light-link-active)}\n"] }]
35
36
  }], propDecorators: { manager: [{
36
37
  type: Input
37
38
  }], topOffset: [{
@@ -39,4 +40,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
39
40
  }], close: [{
40
41
  type: Output
41
42
  }] } });
42
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"all-views-modal.component.js","sourceRoot":"","sources":["../../../../../../../projects/riv/src/lib/navigation/views/all-views-modal/all-views-modal.component.ts","../../../../../../../projects/riv/src/lib/navigation/views/all-views-modal/all-views-modal.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,KAAK,EACL,MAAM,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,QAAQ,EAAE,MAAM,UAAU,CAAC;;;;;;;;;;AAQpC,MAAM,OAAO,sBAAsB;IANnC;QAcE,cAAS,GAAW,CAAC,CAAC;QAGtB,UAAK,GAAG,IAAI,YAAY,EAAQ,CAAC;QAWjC,uBAAkB,GAAG,QAAQ,CAAC,kBAAkB,CAAC;QACjD,6BAAwB,GAAG,QAAQ,CAAC,wBAAwB,CAAC;KAK9D;IAfC,aAAa,CAAC,UAAmC;QAC/C,OAAO,CAAC,IAAa,EAAE,EAAE,CACvB,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,IAAI,CAAC;YAC1B,IAAI,EAAE,mBAAmB;YACzB,UAAU;YACV,IAAI;SACL,CAAC,CAAC;IACP,CAAC;IAKD,SAAS,CAAC,CAAS,EAAE,IAA6B;QAChD,OAAO,IAAI,CAAC,EAAE,CAAC;IACjB,CAAC;;mHA3BU,sBAAsB;uGAAtB,sBAAsB,gJCfnC,49JA+IA;2FDhIa,sBAAsB;kBANlC,SAAS;+BACE,qBAAqB,mBAGd,uBAAuB,CAAC,MAAM;8BAO/C,OAAO;sBADN,KAAK;gBAIN,SAAS;sBADR,KAAK;gBAIN,KAAK;sBADJ,MAAM","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n} from '@angular/core';\nimport { RivViews } from '../state';\n\n@Component({\n  selector: 'riv-all-views-modal',\n  templateUrl: './all-views-modal.component.html',\n  styleUrls: ['./all-views-modal.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class AllViewsModalComponent<\n  U extends RivViews.User,\n  V extends RivViews.View<U>,\n> {\n  @Input()\n  manager?: RivViews.Manager<U, V>;\n\n  @Input()\n  topOffset: number = 0;\n\n  @Output()\n  close = new EventEmitter<void>();\n\n  getOpenChange(permission: RivViews.ViewPermission): (open: boolean) => void {\n    return (open: boolean) =>\n      this.manager?.actions?.next({\n        type: 'setAllViewsToggle',\n        permission,\n        open,\n      });\n  }\n\n  getPermissionTitle = RivViews.getPermissionTitle;\n  getPermissionDescription = RivViews.getPermissionDescription;\n\n  trackById(_: number, view: RivViews.FullView<U, V>): V['id'] {\n    return view.id;\n  }\n}\n","<ng-container *ngIf=\"manager?.state | async; let s\">\n  <riv-side-sheet [topOffset]=\"topOffset\" (close)=\"close.emit()\">\n    <div class=\"content\">\n      <header>\n        <span class=\"title\">All views</span>\n        <button\n          rivButton\n          [variant]=\"'ghost'\"\n          [icon]=\"'X'\"\n          (click)=\"close.emit()\"\n        ></button>\n      </header>\n\n      <riv-search\n        (valueChange)=\"\n          manager?.actions?.next({\n            type: 'setAllViewsSearchQuery',\n            query: $event\n          })\n        \"\n        [value]=\"s.all.search\"\n        placeholder=\"Search\"\n      ></riv-search>\n\n      <div class=\"views\">\n        <!-- View sections by permission type -->\n        <ng-container\n          *ngIf=\"s.all.privateViews.length > 0\"\n          [ngTemplateOutlet]=\"permissionSection\"\n          [ngTemplateOutletContext]=\"{\n            permission: 'private',\n            open: s.all.privateOpen,\n            openChange: getOpenChange('private'),\n            views: s.all.privateViews,\n            title: getPermissionTitle('private'),\n            description: getPermissionDescription('private')\n          }\"\n        ></ng-container>\n        <ng-container\n          *ngIf=\"s.all.sharedViews.length > 0\"\n          [ngTemplateOutlet]=\"permissionSection\"\n          [ngTemplateOutletContext]=\"{\n            permission: 'shared',\n            open: s.all.sharedOpen,\n            openChange: getOpenChange('shared'),\n            views: s.all.sharedViews,\n            title: getPermissionTitle('shared'),\n            description: getPermissionDescription('shared')\n          }\"\n        ></ng-container>\n        <ng-container\n          *ngIf=\"s.all.publicViews.length > 0\"\n          [ngTemplateOutlet]=\"permissionSection\"\n          [ngTemplateOutletContext]=\"{\n            permission: 'public',\n            open: s.all.publicOpen,\n            openChange: getOpenChange('public'),\n            views: s.all.publicViews,\n            title: getPermissionTitle('public'),\n            description: getPermissionDescription('public')\n          }\"\n        ></ng-container>\n\n        <!-- Permission section -->\n        <ng-template\n          #permissionSection\n          let-permission=\"permission\"\n          let-open=\"open\"\n          let-openChange=\"openChange\"\n          let-views=\"views\"\n          let-title=\"title\"\n          let-description=\"description\"\n        >\n          <div class=\"permission-section\">\n            <button\n              class=\"permission-header\"\n              (click)=\"openChange(!open)\"\n              [disabled]=\"!!s.all.search\"\n            >\n              <div class=\"permission-header-content\">\n                <h3 class=\"permission-title\">{{ title }}</h3>\n                <span class=\"permission-description\">{{ description }}</span>\n              </div>\n              <riv-icon\n                [name]=\"open ? 'ChevronUp' : 'ChevronDown'\"\n                [size]=\"20\"\n              ></riv-icon>\n            </button>\n\n            <div class=\"permission-content\" *ngIf=\"open\">\n              <div class=\"views-list\" *ngIf=\"views.length > 0\">\n                <button\n                  *ngFor=\"let view of views; trackBy: trackById\"\n                  class=\"view-item\"\n                  (click)=\"\n                    manager?.actions?.next({\n                      type: 'setActiveView',\n                      id: view.id\n                    });\n                    close.emit()\n                  \"\n                >\n                  <div class=\"view-title\" rivTruncate>\n                    <riv-highlight\n                      [text]=\"view.title\"\n                      [indices]=\"view.titleHighlightIndices ?? []\"\n                    >\n                    </riv-highlight>\n                  </div>\n                  <riv-view-menu\n                    [manager]=\"manager\"\n                    [view]=\"view\"\n                    [menuContext]=\"'all-views'\"\n                  ></riv-view-menu>\n                  <button\n                    class=\"enable-view\"\n                    [class.enabled]=\"view.enabled\"\n                    (click)=\"\n                      $event.stopPropagation();\n                      manager?.actions?.next({\n                        type: 'setEnabled',\n                        id: view.id,\n                        enabled: !view.enabled\n                      })\n                    \"\n                    [disabled]=\"view.system\"\n                  >\n                    <riv-icon\n                      [name]=\"\n                        view.system ? 'Lock' : view.enabled ? 'Eye' : 'EyeOff'\n                      \"\n                      [size]=\"20\"\n                    ></riv-icon>\n                  </button>\n                </button>\n              </div>\n            </div>\n          </div>\n        </ng-template>\n      </div>\n    </div>\n  </riv-side-sheet>\n</ng-container>\n"]}
43
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"all-views-modal.component.js","sourceRoot":"","sources":["../../../../../../../projects/riv/src/lib/navigation/views/all-views-modal/all-views-modal.component.ts","../../../../../../../projects/riv/src/lib/navigation/views/all-views-modal/all-views-modal.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,KAAK,EACL,MAAM,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,QAAQ,EAAE,MAAM,UAAU,CAAC;;;;;;;;;;;AAQpC,MAAM,OAAO,sBAAsB;IANnC;QAcE,cAAS,GAAW,CAAC,CAAC;QAGtB,UAAK,GAAG,IAAI,YAAY,EAAQ,CAAC;QAWjC,uBAAkB,GAAG,QAAQ,CAAC,kBAAkB,CAAC;QACjD,6BAAwB,GAAG,QAAQ,CAAC,wBAAwB,CAAC;KAK9D;IAfC,aAAa,CAAC,UAAmC;QAC/C,OAAO,CAAC,IAAa,EAAE,EAAE,CACvB,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,IAAI,CAAC;YAC1B,IAAI,EAAE,mBAAmB;YACzB,UAAU;YACV,IAAI;SACL,CAAC,CAAC;IACP,CAAC;IAKD,SAAS,CAAC,CAAS,EAAE,IAA6B;QAChD,OAAO,IAAI,CAAC,EAAE,CAAC;IACjB,CAAC;;mHA3BU,sBAAsB;uGAAtB,sBAAsB,gJCfnC,uwKAqJA;2FDtIa,sBAAsB;kBANlC,SAAS;+BACE,qBAAqB,mBAGd,uBAAuB,CAAC,MAAM;8BAO/C,OAAO;sBADN,KAAK;gBAIN,SAAS;sBADR,KAAK;gBAIN,KAAK;sBADJ,MAAM","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n} from '@angular/core';\nimport { RivViews } from '../state';\n\n@Component({\n  selector: 'riv-all-views-modal',\n  templateUrl: './all-views-modal.component.html',\n  styleUrls: ['./all-views-modal.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class AllViewsModalComponent<\n  U extends RivViews.User,\n  V extends RivViews.View<U>,\n> {\n  @Input()\n  manager?: RivViews.Manager<U, V>;\n\n  @Input()\n  topOffset: number = 0;\n\n  @Output()\n  close = new EventEmitter<void>();\n\n  getOpenChange(permission: RivViews.ViewPermission): (open: boolean) => void {\n    return (open: boolean) =>\n      this.manager?.actions?.next({\n        type: 'setAllViewsToggle',\n        permission,\n        open,\n      });\n  }\n\n  getPermissionTitle = RivViews.getPermissionTitle;\n  getPermissionDescription = RivViews.getPermissionDescription;\n\n  trackById(_: number, view: RivViews.FullView<U, V>): V['id'] {\n    return view.id;\n  }\n}\n","<ng-container *ngIf=\"manager?.state | async; let s\">\n  <riv-side-sheet [topOffset]=\"topOffset\" (close)=\"close.emit()\">\n    <div class=\"content\">\n      <header>\n        <span class=\"title\">All views</span>\n        <button\n          rivButton\n          [variant]=\"'ghost'\"\n          [icon]=\"'X'\"\n          (click)=\"close.emit()\"\n        ></button>\n      </header>\n\n      <riv-search\n        (valueChange)=\"\n          manager?.actions?.next({\n            type: 'setAllViewsSearchQuery',\n            query: $event\n          })\n        \"\n        [value]=\"s.all.search\"\n        placeholder=\"Search\"\n      ></riv-search>\n\n      <div class=\"views\">\n        <!-- View sections by permission type -->\n        <ng-container\n          *ngIf=\"s.all.privateViews.length > 0\"\n          [ngTemplateOutlet]=\"permissionSection\"\n          [ngTemplateOutletContext]=\"{\n            permission: 'private',\n            open: s.all.privateOpen,\n            openChange: getOpenChange('private'),\n            views: s.all.privateViews,\n            title: getPermissionTitle('private'),\n            description: getPermissionDescription('private')\n          }\"\n        ></ng-container>\n        <ng-container\n          *ngIf=\"s.all.sharedViews.length > 0\"\n          [ngTemplateOutlet]=\"permissionSection\"\n          [ngTemplateOutletContext]=\"{\n            permission: 'shared',\n            open: s.all.sharedOpen,\n            openChange: getOpenChange('shared'),\n            views: s.all.sharedViews,\n            title: getPermissionTitle('shared'),\n            description: getPermissionDescription('shared')\n          }\"\n        ></ng-container>\n        <ng-container\n          *ngIf=\"s.all.publicViews.length > 0\"\n          [ngTemplateOutlet]=\"permissionSection\"\n          [ngTemplateOutletContext]=\"{\n            permission: 'public',\n            open: s.all.publicOpen,\n            openChange: getOpenChange('public'),\n            views: s.all.publicViews,\n            title: getPermissionTitle('public'),\n            description: getPermissionDescription('public')\n          }\"\n        ></ng-container>\n\n        <!-- Permission section -->\n        <ng-template\n          #permissionSection\n          let-permission=\"permission\"\n          let-open=\"open\"\n          let-openChange=\"openChange\"\n          let-views=\"views\"\n          let-title=\"title\"\n          let-description=\"description\"\n        >\n          <div class=\"permission-section\">\n            <button\n              class=\"permission-header\"\n              (click)=\"openChange(!open)\"\n              [disabled]=\"!!s.all.search\"\n            >\n              <div class=\"permission-header-content\">\n                <h3 class=\"permission-title\">{{ title }}</h3>\n                <span class=\"permission-description\">{{ description }}</span>\n              </div>\n              <riv-icon\n                [name]=\"open ? 'ChevronUp' : 'ChevronDown'\"\n                [size]=\"20\"\n              ></riv-icon>\n            </button>\n\n            <div class=\"permission-content\" *ngIf=\"open\">\n              <div class=\"views-list\" *ngIf=\"views.length > 0\">\n                <button\n                  *ngFor=\"let view of views; trackBy: trackById\"\n                  class=\"view-item\"\n                  (click)=\"\n                    manager?.actions?.next({\n                      type: 'setActiveView',\n                      id: view.id\n                    });\n                    close.emit()\n                  \"\n                >\n                  <div class=\"view-title\" rivTruncate>\n                    <riv-highlight\n                      [text]=\"view.title\"\n                      [indices]=\"view.titleHighlightIndices ?? []\"\n                    >\n                    </riv-highlight>\n                  </div>\n                  <riv-view-menu\n                    [manager]=\"manager\"\n                    [view]=\"view\"\n                    [menuContext]=\"'all-views'\"\n                  ></riv-view-menu>\n                  <button\n                    class=\"enable-view\"\n                    [class.enabled]=\"view.enabled && !view.system\"\n                    (click)=\"\n                      $event.stopPropagation();\n                      manager?.actions?.next({\n                        type: 'setEnabled',\n                        id: view.id,\n                        enabled: !view.enabled\n                      })\n                    \"\n                    [disabled]=\"view.system\"\n                  >\n                    <riv-icon\n                      *ngIf=\"view.enabled\"\n                      [name]=\"view.system ? 'Lock' : 'Eye'\"\n                      [rivTooltip]=\"view.system ? '' : 'Hide tab'\"\n                      [size]=\"20\"\n                    ></riv-icon>\n                    <riv-icon\n                      *ngIf=\"!view.enabled\"\n                      [name]=\"'EyeOff'\"\n                      [rivTooltip]=\"'Show tab'\"\n                      [size]=\"20\"\n                    ></riv-icon>\n                  </button>\n                </button>\n              </div>\n            </div>\n          </div>\n        </ng-template>\n      </div>\n    </div>\n  </riv-side-sheet>\n</ng-container>\n"]}
@@ -3,7 +3,7 @@ import * as i1 from '@angular/common';
3
3
  import { DOCUMENT, DatePipe as DatePipe$1, DecimalPipe, CurrencyPipe, PercentPipe, CommonModule } from '@angular/common';
4
4
  import * as i0 from '@angular/core';
5
5
  import { Injectable, Inject, Pipe, Directive, Input, EventEmitter, Output, Component, ChangeDetectionStrategy, ViewChild, HostListener, ViewContainerRef, Self, HostBinding, Optional, ContentChild, ElementRef, ContentChildren, TemplateRef, NgModule } from '@angular/core';
6
- import { BehaviorSubject, Subject, merge, scan, startWith, connectable, map, ReplaySubject, filter, distinctUntilChanged, combineLatest, shareReplay, withLatestFrom, skipUntil, mergeScan, from, fromEvent, tap, switchMap, takeUntil, concatWith, of } from 'rxjs';
6
+ import { BehaviorSubject, Subject, merge, scan, startWith, connectable, map, ReplaySubject, filter, distinctUntilChanged, combineLatest, shareReplay, skipUntil, mergeScan, from, fromEvent, tap, switchMap, takeUntil, concatWith, of } from 'rxjs';
7
7
  import { timeYears, timeYear, timeMonths, timeMonth, timeDays, timeDay, timeSunday, timeWeek, utcYear, utcMonth, utcWeek, utcDay } from 'd3-time';
8
8
  import { timeFormat, utcFormat } from 'd3-time-format';
9
9
  import { defaultsDeep, sortBy, flattenDeep, debounce, isEqual, cloneDeep, orderBy, range, difference, union } from 'lodash';
@@ -3010,9 +3010,13 @@ class DateRangeComponent extends InputLabelComponent {
3010
3010
  return null;
3011
3011
  }));
3012
3012
  this.favoritePresetIds$ = new LocalStorage(this.STORAGE_KEY, []);
3013
- this.favoritePresets$ = this.favoritePresetIds$.pipe(withLatestFrom(this.alternativePresetList$), map(([ids, alternativePresetList]) => {
3013
+ this.favoritePresets$ = combineLatest([
3014
+ this.favoritePresetIds$,
3015
+ this.filteredPresetOptions$,
3016
+ this.alternativePresetList$,
3017
+ ]).pipe(map(([ids, presets, alternativePresetList]) => {
3014
3018
  const favoritePresets = ids
3015
- .map(id => DateRangeComponent.Presets.find(preset => preset.id === id))
3019
+ .map(id => presets.find(preset => preset.id === id))
3016
3020
  .filter((p) => p !== undefined);
3017
3021
  if (alternativePresetList.length == 0) {
3018
3022
  return favoritePresets;
@@ -4217,10 +4221,10 @@ class AllViewsModalComponent {
4217
4221
  }
4218
4222
  }
4219
4223
  AllViewsModalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: AllViewsModalComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
4220
- AllViewsModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: AllViewsModalComponent, selector: "riv-all-views-modal", inputs: { manager: "manager", topOffset: "topOffset" }, outputs: { close: "close" }, ngImport: i0, template: "<ng-container *ngIf=\"manager?.state | async; let s\">\n <riv-side-sheet [topOffset]=\"topOffset\" (close)=\"close.emit()\">\n <div class=\"content\">\n <header>\n <span class=\"title\">All views</span>\n <button\n rivButton\n [variant]=\"'ghost'\"\n [icon]=\"'X'\"\n (click)=\"close.emit()\"\n ></button>\n </header>\n\n <riv-search\n (valueChange)=\"\n manager?.actions?.next({\n type: 'setAllViewsSearchQuery',\n query: $event\n })\n \"\n [value]=\"s.all.search\"\n placeholder=\"Search\"\n ></riv-search>\n\n <div class=\"views\">\n <!-- View sections by permission type -->\n <ng-container\n *ngIf=\"s.all.privateViews.length > 0\"\n [ngTemplateOutlet]=\"permissionSection\"\n [ngTemplateOutletContext]=\"{\n permission: 'private',\n open: s.all.privateOpen,\n openChange: getOpenChange('private'),\n views: s.all.privateViews,\n title: getPermissionTitle('private'),\n description: getPermissionDescription('private')\n }\"\n ></ng-container>\n <ng-container\n *ngIf=\"s.all.sharedViews.length > 0\"\n [ngTemplateOutlet]=\"permissionSection\"\n [ngTemplateOutletContext]=\"{\n permission: 'shared',\n open: s.all.sharedOpen,\n openChange: getOpenChange('shared'),\n views: s.all.sharedViews,\n title: getPermissionTitle('shared'),\n description: getPermissionDescription('shared')\n }\"\n ></ng-container>\n <ng-container\n *ngIf=\"s.all.publicViews.length > 0\"\n [ngTemplateOutlet]=\"permissionSection\"\n [ngTemplateOutletContext]=\"{\n permission: 'public',\n open: s.all.publicOpen,\n openChange: getOpenChange('public'),\n views: s.all.publicViews,\n title: getPermissionTitle('public'),\n description: getPermissionDescription('public')\n }\"\n ></ng-container>\n\n <!-- Permission section -->\n <ng-template\n #permissionSection\n let-permission=\"permission\"\n let-open=\"open\"\n let-openChange=\"openChange\"\n let-views=\"views\"\n let-title=\"title\"\n let-description=\"description\"\n >\n <div class=\"permission-section\">\n <button\n class=\"permission-header\"\n (click)=\"openChange(!open)\"\n [disabled]=\"!!s.all.search\"\n >\n <div class=\"permission-header-content\">\n <h3 class=\"permission-title\">{{ title }}</h3>\n <span class=\"permission-description\">{{ description }}</span>\n </div>\n <riv-icon\n [name]=\"open ? 'ChevronUp' : 'ChevronDown'\"\n [size]=\"20\"\n ></riv-icon>\n </button>\n\n <div class=\"permission-content\" *ngIf=\"open\">\n <div class=\"views-list\" *ngIf=\"views.length > 0\">\n <button\n *ngFor=\"let view of views; trackBy: trackById\"\n class=\"view-item\"\n (click)=\"\n manager?.actions?.next({\n type: 'setActiveView',\n id: view.id\n });\n close.emit()\n \"\n >\n <div class=\"view-title\" rivTruncate>\n <riv-highlight\n [text]=\"view.title\"\n [indices]=\"view.titleHighlightIndices ?? []\"\n >\n </riv-highlight>\n </div>\n <riv-view-menu\n [manager]=\"manager\"\n [view]=\"view\"\n [menuContext]=\"'all-views'\"\n ></riv-view-menu>\n <button\n class=\"enable-view\"\n [class.enabled]=\"view.enabled\"\n (click)=\"\n $event.stopPropagation();\n manager?.actions?.next({\n type: 'setEnabled',\n id: view.id,\n enabled: !view.enabled\n })\n \"\n [disabled]=\"view.system\"\n >\n <riv-icon\n [name]=\"\n view.system ? 'Lock' : view.enabled ? 'Eye' : 'EyeOff'\n \"\n [size]=\"20\"\n ></riv-icon>\n </button>\n </button>\n </div>\n </div>\n </div>\n </ng-template>\n </div>\n </div>\n </riv-side-sheet>\n</ng-container>\n", styles: [".content{padding:var(--size-large);display:flex;flex-direction:column;gap:var(--size-medium);height:100%}header{display:flex;justify-content:space-between;align-items:center}.title{font:var(--title-02)}.views{flex-grow:1;overflow-y:auto;display:flex;flex-direction:column;gap:var(--size-xlarge)}.permission-section{display:flex;flex-direction:column}.permission-header{display:flex;justify-content:space-between;align-items:center;width:100%;padding:var(--size-xsmall);border:none;background:none;cursor:pointer;gap:var(--size-small);border-radius:var(--border-radius-medium);transition:background-color var(--short-transition)}.permission-header:disabled{cursor:default;color:var(--type-light-disabled)}.permission-header:hover:not(:disabled){background-color:var(--surface-light-1)}.permission-header:active:not(:disabled){background-color:var(--surface-light-2)}.permission-header-content{display:flex;flex-direction:column;align-items:flex-start;text-align:left}.permission-title{font:var(--title-02)}.permission-description{font:var(--body-medium);color:var(--type-light-low-contrast)}.permission-content{padding-left:var(--size-small);padding-top:var(--size-small)}.views-list{display:flex;flex-direction:column;gap:var(--size-small)}.view-item{display:flex;align-items:center;padding:var(--size-xsmall) var(--size-small);border-radius:var(--border-radius-small);cursor:pointer;background-color:var(--surface-light-0);transition:background-color var(--short-transition)}.view-item:hover{background-color:var(--surface-light-1)}.view-item:active{background-color:var(--surface-light-2)}.view-title{text-align:left;flex-grow:1;font:var(--input-medium)}.view-item riv-view-menu{align-self:flex-end;opacity:0;transition:opacity var(--short-transition)}.view-item:hover riv-view-menu{opacity:1}.enable-view{cursor:pointer;display:inline-flex;justify-content:center;align-items:center;padding:0 var(--size-xsmall);transition:color var(--medium-transition);color:var(--type-light-low-contrast)}.enable-view.enabled{color:var(--type-light-link)}.enable-view.enabled:hover{color:var(--type-light-link-hover)}.enable-view.enabled:active{color:var(--type-light-link-active)}\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: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: ButtonComponent, selector: "[rivButton]", inputs: ["locked", "disabled", "loading", "full", "size", "variant", "icon", "iconPosition", "active"] }, { kind: "component", type: HighlightComponent, selector: "riv-highlight", inputs: ["text", "indices"] }, { kind: "component", type: IconComponent, selector: "riv-icon", inputs: ["name", "size", "customSize", "strokeWidth"] }, { kind: "component", type: SearchComponent, selector: "riv-search", inputs: ["placeholder", "name", "labelTemplate"] }, { kind: "component", type: SideSheetComponent, selector: "riv-side-sheet", inputs: ["topOffset", "width", "obscure"], outputs: ["close"] }, { kind: "component", type: TruncateComponent, selector: "[rivTruncate]", inputs: ["maxTooltipWidth"] }, { kind: "component", type: ViewMenuComponent, selector: "riv-view-menu", inputs: ["manager", "view", "menuContext"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
4224
+ AllViewsModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: AllViewsModalComponent, selector: "riv-all-views-modal", inputs: { manager: "manager", topOffset: "topOffset" }, outputs: { close: "close" }, ngImport: i0, template: "<ng-container *ngIf=\"manager?.state | async; let s\">\n <riv-side-sheet [topOffset]=\"topOffset\" (close)=\"close.emit()\">\n <div class=\"content\">\n <header>\n <span class=\"title\">All views</span>\n <button\n rivButton\n [variant]=\"'ghost'\"\n [icon]=\"'X'\"\n (click)=\"close.emit()\"\n ></button>\n </header>\n\n <riv-search\n (valueChange)=\"\n manager?.actions?.next({\n type: 'setAllViewsSearchQuery',\n query: $event\n })\n \"\n [value]=\"s.all.search\"\n placeholder=\"Search\"\n ></riv-search>\n\n <div class=\"views\">\n <!-- View sections by permission type -->\n <ng-container\n *ngIf=\"s.all.privateViews.length > 0\"\n [ngTemplateOutlet]=\"permissionSection\"\n [ngTemplateOutletContext]=\"{\n permission: 'private',\n open: s.all.privateOpen,\n openChange: getOpenChange('private'),\n views: s.all.privateViews,\n title: getPermissionTitle('private'),\n description: getPermissionDescription('private')\n }\"\n ></ng-container>\n <ng-container\n *ngIf=\"s.all.sharedViews.length > 0\"\n [ngTemplateOutlet]=\"permissionSection\"\n [ngTemplateOutletContext]=\"{\n permission: 'shared',\n open: s.all.sharedOpen,\n openChange: getOpenChange('shared'),\n views: s.all.sharedViews,\n title: getPermissionTitle('shared'),\n description: getPermissionDescription('shared')\n }\"\n ></ng-container>\n <ng-container\n *ngIf=\"s.all.publicViews.length > 0\"\n [ngTemplateOutlet]=\"permissionSection\"\n [ngTemplateOutletContext]=\"{\n permission: 'public',\n open: s.all.publicOpen,\n openChange: getOpenChange('public'),\n views: s.all.publicViews,\n title: getPermissionTitle('public'),\n description: getPermissionDescription('public')\n }\"\n ></ng-container>\n\n <!-- Permission section -->\n <ng-template\n #permissionSection\n let-permission=\"permission\"\n let-open=\"open\"\n let-openChange=\"openChange\"\n let-views=\"views\"\n let-title=\"title\"\n let-description=\"description\"\n >\n <div class=\"permission-section\">\n <button\n class=\"permission-header\"\n (click)=\"openChange(!open)\"\n [disabled]=\"!!s.all.search\"\n >\n <div class=\"permission-header-content\">\n <h3 class=\"permission-title\">{{ title }}</h3>\n <span class=\"permission-description\">{{ description }}</span>\n </div>\n <riv-icon\n [name]=\"open ? 'ChevronUp' : 'ChevronDown'\"\n [size]=\"20\"\n ></riv-icon>\n </button>\n\n <div class=\"permission-content\" *ngIf=\"open\">\n <div class=\"views-list\" *ngIf=\"views.length > 0\">\n <button\n *ngFor=\"let view of views; trackBy: trackById\"\n class=\"view-item\"\n (click)=\"\n manager?.actions?.next({\n type: 'setActiveView',\n id: view.id\n });\n close.emit()\n \"\n >\n <div class=\"view-title\" rivTruncate>\n <riv-highlight\n [text]=\"view.title\"\n [indices]=\"view.titleHighlightIndices ?? []\"\n >\n </riv-highlight>\n </div>\n <riv-view-menu\n [manager]=\"manager\"\n [view]=\"view\"\n [menuContext]=\"'all-views'\"\n ></riv-view-menu>\n <button\n class=\"enable-view\"\n [class.enabled]=\"view.enabled && !view.system\"\n (click)=\"\n $event.stopPropagation();\n manager?.actions?.next({\n type: 'setEnabled',\n id: view.id,\n enabled: !view.enabled\n })\n \"\n [disabled]=\"view.system\"\n >\n <riv-icon\n *ngIf=\"view.enabled\"\n [name]=\"view.system ? 'Lock' : 'Eye'\"\n [rivTooltip]=\"view.system ? '' : 'Hide tab'\"\n [size]=\"20\"\n ></riv-icon>\n <riv-icon\n *ngIf=\"!view.enabled\"\n [name]=\"'EyeOff'\"\n [rivTooltip]=\"'Show tab'\"\n [size]=\"20\"\n ></riv-icon>\n </button>\n </button>\n </div>\n </div>\n </div>\n </ng-template>\n </div>\n </div>\n </riv-side-sheet>\n</ng-container>\n", styles: [".content{padding:var(--size-large);display:flex;flex-direction:column;gap:var(--size-medium);height:100%}header{display:flex;justify-content:space-between;align-items:center}.title{font:var(--title-02)}.views{flex-grow:1;overflow-y:auto;display:flex;flex-direction:column;gap:var(--size-xlarge)}.permission-section{display:flex;flex-direction:column}.permission-header{display:flex;justify-content:space-between;align-items:center;width:100%;padding:var(--size-xsmall);border:none;background:none;cursor:pointer;gap:var(--size-small);border-radius:var(--border-radius-medium);transition:background-color var(--short-transition)}.permission-header:disabled{cursor:default;color:var(--type-light-disabled)}.permission-header:hover:not(:disabled){background-color:var(--surface-light-1)}.permission-header:active:not(:disabled){background-color:var(--surface-light-2)}.permission-header-content{display:flex;flex-direction:column;align-items:flex-start;text-align:left}.permission-title{font:var(--title-02)}.permission-description{font:var(--body-medium);color:var(--type-light-low-contrast)}.permission-content{padding-left:var(--size-small);padding-top:var(--size-small)}.views-list{display:flex;flex-direction:column;gap:var(--size-small)}.view-item{display:flex;align-items:center;padding:var(--size-xsmall) var(--size-small);border-radius:var(--border-radius-small);cursor:pointer;background-color:var(--surface-light-0);transition:background-color var(--short-transition)}.view-item:hover{background-color:var(--surface-light-1)}.view-item:active{background-color:var(--surface-light-2)}.view-title{text-align:left;flex-grow:1;font:var(--input-medium)}.view-item riv-view-menu{align-self:flex-end;opacity:0;transition:opacity var(--short-transition)}.view-item:hover riv-view-menu{opacity:1}.enable-view{cursor:pointer;display:inline-flex;justify-content:center;align-items:center;padding:0 var(--size-xsmall);transition:color var(--medium-transition);color:var(--type-light-low-contrast)}.enable-view.enabled{color:var(--type-light-link)}.enable-view.enabled:hover{color:var(--type-light-link-hover)}.enable-view.enabled:active{color:var(--type-light-link-active)}\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: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: ButtonComponent, selector: "[rivButton]", inputs: ["locked", "disabled", "loading", "full", "size", "variant", "icon", "iconPosition", "active"] }, { kind: "component", type: HighlightComponent, selector: "riv-highlight", inputs: ["text", "indices"] }, { kind: "component", type: IconComponent, selector: "riv-icon", inputs: ["name", "size", "customSize", "strokeWidth"] }, { kind: "component", type: SearchComponent, selector: "riv-search", inputs: ["placeholder", "name", "labelTemplate"] }, { kind: "component", type: SideSheetComponent, selector: "riv-side-sheet", inputs: ["topOffset", "width", "obscure"], outputs: ["close"] }, { kind: "directive", type: TooltipDirective, selector: "[rivTooltip]", inputs: ["rivTooltip", "rivTooltipTheme", "rivTooltipMaxWidth", "rivTooltipPreferredPosition", "rivTooltipCloseDelay"] }, { kind: "component", type: TruncateComponent, selector: "[rivTruncate]", inputs: ["maxTooltipWidth"] }, { kind: "component", type: ViewMenuComponent, selector: "riv-view-menu", inputs: ["manager", "view", "menuContext"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
4221
4225
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: AllViewsModalComponent, decorators: [{
4222
4226
  type: Component,
4223
- args: [{ selector: 'riv-all-views-modal', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"manager?.state | async; let s\">\n <riv-side-sheet [topOffset]=\"topOffset\" (close)=\"close.emit()\">\n <div class=\"content\">\n <header>\n <span class=\"title\">All views</span>\n <button\n rivButton\n [variant]=\"'ghost'\"\n [icon]=\"'X'\"\n (click)=\"close.emit()\"\n ></button>\n </header>\n\n <riv-search\n (valueChange)=\"\n manager?.actions?.next({\n type: 'setAllViewsSearchQuery',\n query: $event\n })\n \"\n [value]=\"s.all.search\"\n placeholder=\"Search\"\n ></riv-search>\n\n <div class=\"views\">\n <!-- View sections by permission type -->\n <ng-container\n *ngIf=\"s.all.privateViews.length > 0\"\n [ngTemplateOutlet]=\"permissionSection\"\n [ngTemplateOutletContext]=\"{\n permission: 'private',\n open: s.all.privateOpen,\n openChange: getOpenChange('private'),\n views: s.all.privateViews,\n title: getPermissionTitle('private'),\n description: getPermissionDescription('private')\n }\"\n ></ng-container>\n <ng-container\n *ngIf=\"s.all.sharedViews.length > 0\"\n [ngTemplateOutlet]=\"permissionSection\"\n [ngTemplateOutletContext]=\"{\n permission: 'shared',\n open: s.all.sharedOpen,\n openChange: getOpenChange('shared'),\n views: s.all.sharedViews,\n title: getPermissionTitle('shared'),\n description: getPermissionDescription('shared')\n }\"\n ></ng-container>\n <ng-container\n *ngIf=\"s.all.publicViews.length > 0\"\n [ngTemplateOutlet]=\"permissionSection\"\n [ngTemplateOutletContext]=\"{\n permission: 'public',\n open: s.all.publicOpen,\n openChange: getOpenChange('public'),\n views: s.all.publicViews,\n title: getPermissionTitle('public'),\n description: getPermissionDescription('public')\n }\"\n ></ng-container>\n\n <!-- Permission section -->\n <ng-template\n #permissionSection\n let-permission=\"permission\"\n let-open=\"open\"\n let-openChange=\"openChange\"\n let-views=\"views\"\n let-title=\"title\"\n let-description=\"description\"\n >\n <div class=\"permission-section\">\n <button\n class=\"permission-header\"\n (click)=\"openChange(!open)\"\n [disabled]=\"!!s.all.search\"\n >\n <div class=\"permission-header-content\">\n <h3 class=\"permission-title\">{{ title }}</h3>\n <span class=\"permission-description\">{{ description }}</span>\n </div>\n <riv-icon\n [name]=\"open ? 'ChevronUp' : 'ChevronDown'\"\n [size]=\"20\"\n ></riv-icon>\n </button>\n\n <div class=\"permission-content\" *ngIf=\"open\">\n <div class=\"views-list\" *ngIf=\"views.length > 0\">\n <button\n *ngFor=\"let view of views; trackBy: trackById\"\n class=\"view-item\"\n (click)=\"\n manager?.actions?.next({\n type: 'setActiveView',\n id: view.id\n });\n close.emit()\n \"\n >\n <div class=\"view-title\" rivTruncate>\n <riv-highlight\n [text]=\"view.title\"\n [indices]=\"view.titleHighlightIndices ?? []\"\n >\n </riv-highlight>\n </div>\n <riv-view-menu\n [manager]=\"manager\"\n [view]=\"view\"\n [menuContext]=\"'all-views'\"\n ></riv-view-menu>\n <button\n class=\"enable-view\"\n [class.enabled]=\"view.enabled\"\n (click)=\"\n $event.stopPropagation();\n manager?.actions?.next({\n type: 'setEnabled',\n id: view.id,\n enabled: !view.enabled\n })\n \"\n [disabled]=\"view.system\"\n >\n <riv-icon\n [name]=\"\n view.system ? 'Lock' : view.enabled ? 'Eye' : 'EyeOff'\n \"\n [size]=\"20\"\n ></riv-icon>\n </button>\n </button>\n </div>\n </div>\n </div>\n </ng-template>\n </div>\n </div>\n </riv-side-sheet>\n</ng-container>\n", styles: [".content{padding:var(--size-large);display:flex;flex-direction:column;gap:var(--size-medium);height:100%}header{display:flex;justify-content:space-between;align-items:center}.title{font:var(--title-02)}.views{flex-grow:1;overflow-y:auto;display:flex;flex-direction:column;gap:var(--size-xlarge)}.permission-section{display:flex;flex-direction:column}.permission-header{display:flex;justify-content:space-between;align-items:center;width:100%;padding:var(--size-xsmall);border:none;background:none;cursor:pointer;gap:var(--size-small);border-radius:var(--border-radius-medium);transition:background-color var(--short-transition)}.permission-header:disabled{cursor:default;color:var(--type-light-disabled)}.permission-header:hover:not(:disabled){background-color:var(--surface-light-1)}.permission-header:active:not(:disabled){background-color:var(--surface-light-2)}.permission-header-content{display:flex;flex-direction:column;align-items:flex-start;text-align:left}.permission-title{font:var(--title-02)}.permission-description{font:var(--body-medium);color:var(--type-light-low-contrast)}.permission-content{padding-left:var(--size-small);padding-top:var(--size-small)}.views-list{display:flex;flex-direction:column;gap:var(--size-small)}.view-item{display:flex;align-items:center;padding:var(--size-xsmall) var(--size-small);border-radius:var(--border-radius-small);cursor:pointer;background-color:var(--surface-light-0);transition:background-color var(--short-transition)}.view-item:hover{background-color:var(--surface-light-1)}.view-item:active{background-color:var(--surface-light-2)}.view-title{text-align:left;flex-grow:1;font:var(--input-medium)}.view-item riv-view-menu{align-self:flex-end;opacity:0;transition:opacity var(--short-transition)}.view-item:hover riv-view-menu{opacity:1}.enable-view{cursor:pointer;display:inline-flex;justify-content:center;align-items:center;padding:0 var(--size-xsmall);transition:color var(--medium-transition);color:var(--type-light-low-contrast)}.enable-view.enabled{color:var(--type-light-link)}.enable-view.enabled:hover{color:var(--type-light-link-hover)}.enable-view.enabled:active{color:var(--type-light-link-active)}\n"] }]
4227
+ args: [{ selector: 'riv-all-views-modal', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"manager?.state | async; let s\">\n <riv-side-sheet [topOffset]=\"topOffset\" (close)=\"close.emit()\">\n <div class=\"content\">\n <header>\n <span class=\"title\">All views</span>\n <button\n rivButton\n [variant]=\"'ghost'\"\n [icon]=\"'X'\"\n (click)=\"close.emit()\"\n ></button>\n </header>\n\n <riv-search\n (valueChange)=\"\n manager?.actions?.next({\n type: 'setAllViewsSearchQuery',\n query: $event\n })\n \"\n [value]=\"s.all.search\"\n placeholder=\"Search\"\n ></riv-search>\n\n <div class=\"views\">\n <!-- View sections by permission type -->\n <ng-container\n *ngIf=\"s.all.privateViews.length > 0\"\n [ngTemplateOutlet]=\"permissionSection\"\n [ngTemplateOutletContext]=\"{\n permission: 'private',\n open: s.all.privateOpen,\n openChange: getOpenChange('private'),\n views: s.all.privateViews,\n title: getPermissionTitle('private'),\n description: getPermissionDescription('private')\n }\"\n ></ng-container>\n <ng-container\n *ngIf=\"s.all.sharedViews.length > 0\"\n [ngTemplateOutlet]=\"permissionSection\"\n [ngTemplateOutletContext]=\"{\n permission: 'shared',\n open: s.all.sharedOpen,\n openChange: getOpenChange('shared'),\n views: s.all.sharedViews,\n title: getPermissionTitle('shared'),\n description: getPermissionDescription('shared')\n }\"\n ></ng-container>\n <ng-container\n *ngIf=\"s.all.publicViews.length > 0\"\n [ngTemplateOutlet]=\"permissionSection\"\n [ngTemplateOutletContext]=\"{\n permission: 'public',\n open: s.all.publicOpen,\n openChange: getOpenChange('public'),\n views: s.all.publicViews,\n title: getPermissionTitle('public'),\n description: getPermissionDescription('public')\n }\"\n ></ng-container>\n\n <!-- Permission section -->\n <ng-template\n #permissionSection\n let-permission=\"permission\"\n let-open=\"open\"\n let-openChange=\"openChange\"\n let-views=\"views\"\n let-title=\"title\"\n let-description=\"description\"\n >\n <div class=\"permission-section\">\n <button\n class=\"permission-header\"\n (click)=\"openChange(!open)\"\n [disabled]=\"!!s.all.search\"\n >\n <div class=\"permission-header-content\">\n <h3 class=\"permission-title\">{{ title }}</h3>\n <span class=\"permission-description\">{{ description }}</span>\n </div>\n <riv-icon\n [name]=\"open ? 'ChevronUp' : 'ChevronDown'\"\n [size]=\"20\"\n ></riv-icon>\n </button>\n\n <div class=\"permission-content\" *ngIf=\"open\">\n <div class=\"views-list\" *ngIf=\"views.length > 0\">\n <button\n *ngFor=\"let view of views; trackBy: trackById\"\n class=\"view-item\"\n (click)=\"\n manager?.actions?.next({\n type: 'setActiveView',\n id: view.id\n });\n close.emit()\n \"\n >\n <div class=\"view-title\" rivTruncate>\n <riv-highlight\n [text]=\"view.title\"\n [indices]=\"view.titleHighlightIndices ?? []\"\n >\n </riv-highlight>\n </div>\n <riv-view-menu\n [manager]=\"manager\"\n [view]=\"view\"\n [menuContext]=\"'all-views'\"\n ></riv-view-menu>\n <button\n class=\"enable-view\"\n [class.enabled]=\"view.enabled && !view.system\"\n (click)=\"\n $event.stopPropagation();\n manager?.actions?.next({\n type: 'setEnabled',\n id: view.id,\n enabled: !view.enabled\n })\n \"\n [disabled]=\"view.system\"\n >\n <riv-icon\n *ngIf=\"view.enabled\"\n [name]=\"view.system ? 'Lock' : 'Eye'\"\n [rivTooltip]=\"view.system ? '' : 'Hide tab'\"\n [size]=\"20\"\n ></riv-icon>\n <riv-icon\n *ngIf=\"!view.enabled\"\n [name]=\"'EyeOff'\"\n [rivTooltip]=\"'Show tab'\"\n [size]=\"20\"\n ></riv-icon>\n </button>\n </button>\n </div>\n </div>\n </div>\n </ng-template>\n </div>\n </div>\n </riv-side-sheet>\n</ng-container>\n", styles: [".content{padding:var(--size-large);display:flex;flex-direction:column;gap:var(--size-medium);height:100%}header{display:flex;justify-content:space-between;align-items:center}.title{font:var(--title-02)}.views{flex-grow:1;overflow-y:auto;display:flex;flex-direction:column;gap:var(--size-xlarge)}.permission-section{display:flex;flex-direction:column}.permission-header{display:flex;justify-content:space-between;align-items:center;width:100%;padding:var(--size-xsmall);border:none;background:none;cursor:pointer;gap:var(--size-small);border-radius:var(--border-radius-medium);transition:background-color var(--short-transition)}.permission-header:disabled{cursor:default;color:var(--type-light-disabled)}.permission-header:hover:not(:disabled){background-color:var(--surface-light-1)}.permission-header:active:not(:disabled){background-color:var(--surface-light-2)}.permission-header-content{display:flex;flex-direction:column;align-items:flex-start;text-align:left}.permission-title{font:var(--title-02)}.permission-description{font:var(--body-medium);color:var(--type-light-low-contrast)}.permission-content{padding-left:var(--size-small);padding-top:var(--size-small)}.views-list{display:flex;flex-direction:column;gap:var(--size-small)}.view-item{display:flex;align-items:center;padding:var(--size-xsmall) var(--size-small);border-radius:var(--border-radius-small);cursor:pointer;background-color:var(--surface-light-0);transition:background-color var(--short-transition)}.view-item:hover{background-color:var(--surface-light-1)}.view-item:active{background-color:var(--surface-light-2)}.view-title{text-align:left;flex-grow:1;font:var(--input-medium)}.view-item riv-view-menu{align-self:flex-end;opacity:0;transition:opacity var(--short-transition)}.view-item:hover riv-view-menu{opacity:1}.enable-view{cursor:pointer;display:inline-flex;justify-content:center;align-items:center;padding:0 var(--size-xsmall);transition:color var(--medium-transition);color:var(--type-light-low-contrast)}.enable-view.enabled{color:var(--type-light-link)}.enable-view.enabled:hover{color:var(--type-light-link-hover)}.enable-view.enabled:active{color:var(--type-light-link-active)}\n"] }]
4224
4228
  }], propDecorators: { manager: [{
4225
4229
  type: Input
4226
4230
  }], topOffset: [{