@rivet-health/design-system 30.9.0 → 30.10.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/input/select/state.mjs +57 -4
- package/fesm2015/rivet-health-design-system.mjs +50 -3
- package/fesm2015/rivet-health-design-system.mjs.map +1 -1
- package/fesm2020/rivet-health-design-system.mjs +56 -3
- package/fesm2020/rivet-health-design-system.mjs.map +1 -1
- package/lib/input/select/state.d.ts +1 -1
- package/package.json +1 -1
|
@@ -67,8 +67,17 @@ export var RivSelect;
|
|
|
67
67
|
const defaultedInitialState = defaultsDeep({}, options?.initialState, defaultState);
|
|
68
68
|
const actions = new Subject();
|
|
69
69
|
const internalActions = new Subject();
|
|
70
|
-
const
|
|
71
|
-
|
|
70
|
+
const coreStateWithSelectionSnapshot = merge(actions, internalActions).pipe(scan(([state, snapshot], action) => {
|
|
71
|
+
const newState = sideEffects(reduce(state, action), action, source, internalActions);
|
|
72
|
+
const newSelectionSnapshot = action.type === 'openChange' && action.open
|
|
73
|
+
? createSelectionSnapshotWithAncestors(newState)
|
|
74
|
+
: snapshot;
|
|
75
|
+
return [newState, newSelectionSnapshot];
|
|
76
|
+
}, [defaultedInitialState, new OptionSet()]), startWith([
|
|
77
|
+
defaultedInitialState,
|
|
78
|
+
new OptionSet(),
|
|
79
|
+
]));
|
|
80
|
+
const state = connectable(coreStateWithSelectionSnapshot.pipe(map(([s, selectionAtOpen]) => {
|
|
72
81
|
const allOptionGroups = s.sourceOptionGroups.map(optionGroup => {
|
|
73
82
|
return {
|
|
74
83
|
...optionGroup,
|
|
@@ -76,7 +85,10 @@ export var RivSelect;
|
|
|
76
85
|
};
|
|
77
86
|
});
|
|
78
87
|
const topLevelOptions = getTopLevelOptions(allOptionGroups);
|
|
79
|
-
const
|
|
88
|
+
const sortedOptionGroups = options?.allowMultiSelect
|
|
89
|
+
? sortOptionsByPreviouslySelectedState(allOptionGroups, selectionAtOpen)
|
|
90
|
+
: allOptionGroups;
|
|
91
|
+
const displayLimitedOptionGroups = applyDisplayLimit(sortedOptionGroups, options?.displayLimit);
|
|
80
92
|
const fullOptionGroups = applySelectedOptionLimit(s, displayLimitedOptionGroups, topLevelOptions, options);
|
|
81
93
|
return {
|
|
82
94
|
...s,
|
|
@@ -332,6 +344,25 @@ export var RivSelect;
|
|
|
332
344
|
//////////////////////////////////
|
|
333
345
|
// State reducer (with helpers) //
|
|
334
346
|
//////////////////////////////////
|
|
347
|
+
function createSelectionSnapshotWithAncestors(state) {
|
|
348
|
+
const snapshot = new OptionSet(state.selection.selected);
|
|
349
|
+
const topLevelOptions = getTopLevelOptions(state.sourceOptionGroups);
|
|
350
|
+
const [parents] = getRelationshipMaps(topLevelOptions);
|
|
351
|
+
// For each selected option, add all its ancestors to the snapshot
|
|
352
|
+
for (const selectedOption of state.selection.selected) {
|
|
353
|
+
let currentId = selectedOption.id;
|
|
354
|
+
let parentId = parents.get(currentId);
|
|
355
|
+
while (parentId !== undefined) {
|
|
356
|
+
const parentOption = findOption(topLevelOptions, parentId);
|
|
357
|
+
if (parentOption) {
|
|
358
|
+
snapshot.add(parentOption);
|
|
359
|
+
}
|
|
360
|
+
currentId = parentId;
|
|
361
|
+
parentId = parents.get(currentId);
|
|
362
|
+
}
|
|
363
|
+
}
|
|
364
|
+
return snapshot;
|
|
365
|
+
}
|
|
335
366
|
function getDisplayLimitMessage(displayedOptionCount, totalOptionCount, query) {
|
|
336
367
|
if (displayedOptionCount === totalOptionCount)
|
|
337
368
|
return null;
|
|
@@ -399,6 +430,28 @@ export var RivSelect;
|
|
|
399
430
|
}, startingValue);
|
|
400
431
|
return resolvedGroups;
|
|
401
432
|
}
|
|
433
|
+
/*
|
|
434
|
+
Sort options so that previously selected options (from prior sessions)
|
|
435
|
+
appear at the top of their peer/sibling lists.
|
|
436
|
+
*/
|
|
437
|
+
function sortOptionsByPreviouslySelectedState(optionGroups, selectionAtOpen) {
|
|
438
|
+
function sortOptions(options) {
|
|
439
|
+
return sortBy(options, option => !selectionAtOpen.has(option)).map(option => {
|
|
440
|
+
if (option.children) {
|
|
441
|
+
return {
|
|
442
|
+
...option,
|
|
443
|
+
children: sortOptions(option.children),
|
|
444
|
+
};
|
|
445
|
+
}
|
|
446
|
+
else
|
|
447
|
+
return option;
|
|
448
|
+
});
|
|
449
|
+
}
|
|
450
|
+
return optionGroups.map(group => ({
|
|
451
|
+
...group,
|
|
452
|
+
options: sortOptions(group.options),
|
|
453
|
+
}));
|
|
454
|
+
}
|
|
402
455
|
/*
|
|
403
456
|
If we are restricting how many options are selected to a specific limit,
|
|
404
457
|
when we are at that limit, disable all options not currently selected.
|
|
@@ -726,4 +779,4 @@ export var RivSelect;
|
|
|
726
779
|
}
|
|
727
780
|
}
|
|
728
781
|
})(RivSelect || (RivSelect = {}));
|
|
729
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"state.js","sourceRoot":"","sources":["../../../../../../projects/riv/src/lib/input/select/state.ts"],"names":[],"mappings":"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","sourcesContent":["import Fuse, {\n  FuseResult,\n  FuseResultMatch,\n  IFuseOptions,\n  RangeTuple,\n} from 'fuse.js';\nimport { defaultsDeep, flattenDeep, isNumber, sortBy } from 'lodash';\nimport {\n  connectable,\n  Connectable,\n  map,\n  merge,\n  Observable,\n  ReplaySubject,\n  scan,\n  startWith,\n  Subject,\n} from 'rxjs';\nimport { DeepPartial } from 'utility-types';\nimport { NumberPipe } from '../../format/pipes/number.pipe';\nimport { HighlightComponent } from '../../visualization/highlight/highlight.component';\n\nexport namespace RivSelect {\n  /////////////\n  // Options //\n  /////////////\n\n  /**\n   * ┌─────────────────────-------------------───┐\n   * │ BaseOption                                │\n   * │                                           │\n   * │ The core data required for each option    │\n   * │ (such as id and title).                   │\n   * ├──────────────────────-------------------──┤\n   * │ Option (BaseOption + children)            │\n   * │                                           │\n   * │ Provides recursive type safety to the     │\n   * │ type safety to the BaseOption.            │\n   * └─------------------┬-------────────────────┘\n   *                     |\n   * ┌───────────────────▼───────────────────────┐\n   * │ SourceOption (Option + search highlights) │\n   * │                                           │\n   * │ Adds search highlights to the Option and  │\n   * │ is the return type for the option Source  │\n   * │ (data fetcher) function.                  │\n   * └───────────────────┬───────────────────────┘\n   *                     |\n   * ┌───────────────────▼───────────────────────┐\n   * │ FullOption (SourceOption + UI state)      │\n   * │                                           │\n   * │ Augments the SourceOption with all of the │\n   * │ UI information from other parts of the    │\n   * │ state, such as selection status, whether  │\n   * │ or not the node is expanded, etc.         │\n   * └───────────────────────────────────────────┘\n   *\n   * Note that the usages of Omit<...> in this section are not required, but\n   * do help in-editor type hints to be more clear and direct.\n   */\n\n  export type BaseOption = {\n    id: string | number;\n    title: string;\n    subtitle?: string;\n    help?: string;\n    count?: number;\n    disabled?: boolean;\n  };\n  export type Option<O extends BaseOption = BaseOption> = O & {\n    children?: Option<O>[];\n  };\n\n  export type SourceOption<O extends BaseOption> = Omit<\n    Option<O>,\n    'children'\n  > & {\n    titleHighlightIndices?: HighlightComponent.HighlightIndices[];\n    subtitleHighlightIndices?: HighlightComponent.HighlightIndices[];\n    children?: SourceOption<O>[];\n  };\n\n  export type MultiSelectionState = boolean | 'indeterminate';\n\n  export type FullOption<O extends BaseOption> = Omit<\n    SourceOption<O>,\n    'children'\n  > & {\n    selected: MultiSelectionState;\n    expanded: boolean;\n    selectable: boolean;\n    expandable: boolean;\n    children?: FullOption<O>[];\n  };\n\n  ///////////////////\n  // Option groups //\n  ///////////////////\n\n  /**\n   * The relationships between OptionGroup, SourceOptionGroup, and\n   * FullOptionGroup is analogous to the option types above.\n   *\n   * As with before, the use of Omit<...> is not required but helpful.\n   */\n\n  export type OptionGroup<O extends BaseOption> = {\n    header?: string;\n    options: Option<O>[];\n  };\n\n  export type SourceOptionGroup<O extends BaseOption> = Omit<\n    OptionGroup<O>,\n    'options'\n  > & {\n    options: SourceOption<O>[];\n  };\n\n  export type FullOptionGroup<O extends BaseOption> = Omit<\n    SourceOptionGroup<O>,\n    'options'\n  > & {\n    options: FullOption<O>[];\n  };\n\n  /**\n   * The OptionSet class provides Set-like functionality, but uniqueness is\n   * determined by the option's ID rather than the object reference.\n   */\n  export class OptionSet<O extends BaseOption> extends Set<SourceOption<O>> {\n    override has(option: SourceOption<O>) {\n      return !![...this].find(o => o.id === option.id);\n    }\n\n    override add(option: SourceOption<O>) {\n      if (this.has(option)) {\n        // The Set already has some version of this option, but we'll make sure\n        // it has the most recent object reference (while keeping insertion\n        // order consistent).\n        const newOptions = [...this].map(o =>\n          o.id === option.id ? option : o,\n        );\n        this.clear();\n        newOptions.forEach(o => {\n          super.add(o);\n        });\n      } else {\n        super.add(option);\n      }\n      return this;\n    }\n\n    override delete(option: SourceOption<O>) {\n      const existing = [...this].find(o => o.id === option.id);\n      if (existing) {\n        super.delete(existing);\n        return true;\n      } else {\n        return false;\n      }\n    }\n  }\n\n  ///////////\n  // State //\n  ///////////\n\n  /**\n   * The CoreState provides all of the foundational pieces of state required\n   * for a working component. FullState is a pure derivation of CoreState plus\n   * the configuration options, and provides conveniences for rendering the\n   * components. Actions and the core state are passed to the reducer to\n   * produce new CoreStates (which are then used to calculate new FullStates).\n   *\n   * ┌──────┐\n   * │  UI  ◄────────┐\n   * └──┬───┘        │\n   *    │            │\n   * ┌──▼────────┐   │\n   * │  Actions  │   │\n   * └──┬────────┘   │\n   *    │            │\n   * ┌──▼────────────┴─┐\n   * │  State reducer  │\n   * └─────────────────┘\n   */\n\n  export type OrderBy = 'title' | 'count' | 'source';\n\n  const MIN_OPTIONS_FOR_CONTROLS = 5;\n\n  export type CoreState<O extends BaseOption> = {\n    query: {\n      search: string;\n      order: OrderBy;\n    };\n    load: {\n      loading: boolean;\n      error: unknown | null;\n    };\n    sourceOptionGroups: SourceOptionGroup<O>[];\n    selection: {\n      selected: OptionSet<O>;\n    };\n    display: {\n      placeholder: string;\n      open: boolean;\n      expandedOptions: Set<O['id']>;\n    };\n  };\n\n  export type FullState<O extends BaseOption> = CoreState<O> & {\n    query: {\n      showSearch: boolean;\n      searchPlaceholder: string;\n      showOrder: boolean;\n    };\n    fullOptionGroups: FullOptionGroup<O>[];\n    selection: {\n      allowMultiSelect: boolean;\n      allowSelectAll: boolean;\n      visibleSelectionState: MultiSelectionState;\n    };\n    display: {\n      formattedSelectedOptions: string;\n      zeroStateMessage: string | null;\n      dividers: boolean;\n      inline: boolean;\n      maxHeight: string | null;\n      maxWidth: string | null;\n      minHeight: string | null;\n      minWidth: string | null;\n      displayLimitMessage: string | null;\n      showSingleSelected: boolean;\n      pillCount: number;\n    };\n  };\n\n  /////////////\n  // Actions //\n  /////////////\n\n  export type Action<O extends BaseOption> =\n    | { type: 'load' }\n    | { type: 'openChange'; open: boolean }\n    | { type: 'searchChange'; payload: string }\n    | { type: 'orderChange'; payload: OrderBy }\n    | {\n        type: 'selectionChange';\n        payload: CoreState<O>['selection'];\n      }\n    | {\n        type: 'toggleOptionSelected';\n        id: O['id'];\n      }\n    | {\n        type: 'setSelectedOption';\n        id: O['id'];\n      }\n    | {\n        type: 'visibleSelectedChange';\n      }\n    | {\n        type: 'toggleOptionExpanded';\n        id: O['id'];\n      };\n\n  type InternalAction<O extends BaseOption> =\n    | { type: 'loadComplete'; data: SourceOptionGroup<O>[] }\n    | { type: 'loadError'; error: unknown };\n\n  ////////////\n  // Source //\n  ////////////\n\n  /**\n   * The Source's job is to fetch options (based on the current state) which\n   * then blend with the other pieces of state to produce the FullState.\n   */\n\n  export type Source<O extends BaseOption> = (\n    query: CoreState<O>['query'],\n    mostRecentAction: Action<O>,\n  ) => Promise<SourceOptionGroup<O>[]>;\n\n  /////////////\n  // Manager //\n  /////////////\n\n  export type Manager<O extends BaseOption> = {\n    actions: Subject<Action<O>>;\n    state: Connectable<FullState<O>>;\n  };\n\n  export type ManagerOptions<O extends BaseOption> = {\n    initialState?: DeepPartial<CoreState<O>>;\n    allowMultiSelect?: boolean;\n    allowSearch?: boolean;\n    allowSelectAll?: boolean;\n    allowOrder?: boolean;\n    searchPlaceholder?: string;\n    dividers?: boolean;\n    inline?: boolean;\n    maxHeight?: string | null;\n    maxWidth?: string | null;\n    minHeight?: string | null;\n    minWidth?: string | null;\n    displayLimit?: number;\n    selectedOptionLimit?: number;\n    showSingleSelected?: boolean;\n    useTopLevelOptionsForDisplay?: boolean;\n    getCustomOptionDisplay?: (selectedOptions: SourceOption<O>[]) => string;\n  };\n\n  export function createManager<O extends BaseOption>(\n    source: Source<O>,\n    options?: ManagerOptions<O>,\n  ): Manager<O> {\n    const defaultState: CoreState<O> = {\n      query: {\n        search: '',\n        order: 'title',\n      },\n      load: {\n        loading: false,\n        error: null,\n      },\n      sourceOptionGroups: [],\n      selection: {\n        selected: new OptionSet(),\n      },\n      display: {\n        placeholder: 'Select',\n        open: false,\n        expandedOptions: new Set(),\n      },\n    };\n    const defaultedInitialState: CoreState<O> = defaultsDeep(\n      {},\n      options?.initialState,\n      defaultState,\n    );\n\n    const actions: Subject<Action<O>> = new Subject();\n    const internalActions: Subject<InternalAction<O>> = new Subject();\n    const coreState: Observable<CoreState<O>> = merge(\n      actions,\n      internalActions,\n    ).pipe(\n      scan(\n        (state, action) =>\n          sideEffects(reduce(state, action), action, source, internalActions),\n        defaultedInitialState,\n      ),\n      startWith(defaultedInitialState),\n    );\n\n    const state: Connectable<FullState<O>> = connectable(\n      coreState.pipe(\n        map(s => {\n          const allOptionGroups: FullOptionGroup<O>[] =\n            s.sourceOptionGroups.map(optionGroup => {\n              return {\n                ...optionGroup,\n                options: optionGroup.options.map(option =>\n                  augmentOptionToFullOption(s, option),\n                ),\n              };\n            });\n\n          const topLevelOptions = getTopLevelOptions(allOptionGroups);\n\n          const displayLimitedOptionGroups = applyDisplayLimit(\n            allOptionGroups,\n            options?.displayLimit,\n          );\n          const fullOptionGroups = applySelectedOptionLimit(\n            s,\n            displayLimitedOptionGroups,\n            topLevelOptions,\n            options,\n          );\n\n          return {\n            ...s,\n            query: {\n              ...s.query,\n              showSearch:\n                !!options?.allowSearch &&\n                (!!s.query.search ||\n                  countAllOptions(allOptionGroups) > MIN_OPTIONS_FOR_CONTROLS),\n              searchPlaceholder: options?.searchPlaceholder ?? 'Search',\n              showOrder:\n                !!options?.allowOrder &&\n                !s.query.search &&\n                countAllOptions(allOptionGroups) > MIN_OPTIONS_FOR_CONTROLS,\n            },\n            fullOptionGroups,\n            selection: {\n              ...s.selection,\n              allowMultiSelect: !!options?.allowMultiSelect,\n              allowSelectAll:\n                !!options?.allowSelectAll &&\n                options?.selectedOptionLimit == undefined,\n              visibleSelectionState:\n                getParentMultiSelectionState(topLevelOptions),\n            },\n            display: {\n              ...s.display,\n              formattedSelectedOptions: getFormattedOptionsForDisplay(\n                s,\n                topLevelOptions,\n                options,\n              ),\n              zeroStateMessage: getZeroStateMessage(s),\n              dividers: !!options?.dividers,\n              inline: !!options?.inline,\n              maxHeight: options?.maxHeight ?? null,\n              maxWidth: options?.maxWidth ?? null,\n              minHeight: options?.minHeight ?? null,\n              minWidth: options?.minWidth ?? null,\n              displayLimitMessage: getDisplayLimitMessage(\n                countVisibleOptions(fullOptionGroups, !!s.query.search),\n                countVisibleOptions(allOptionGroups, !!s.query.search),\n                s.query,\n              ),\n              showSingleSelected: !!options?.showSingleSelected,\n              pillCount: getPillCountForDisplay(s, topLevelOptions, options),\n            },\n          };\n        }),\n      ),\n      {\n        connector: () => new ReplaySubject(1),\n        resetOnDisconnect: false,\n      },\n    );\n    state.connect();\n\n    // Load the options immediately for selects that are displayed inline.\n    if (options?.inline) actions.next({ type: 'load' });\n\n    return { actions, state };\n  }\n\n  export type InMemoryManagerOptions<O extends BaseOption> =\n    ManagerOptions<O> & {\n      fuseOptions?: IFuseOptions<O>;\n    };\n\n  export function createInMemoryManager<O extends BaseOption>(\n    fetchDataset: () => Promise<OptionGroup<O>[]> | OptionGroup<O>[],\n    options?: InMemoryManagerOptions<O>,\n  ): Manager<O> {\n    let data: OptionGroup<O>[];\n    let fuse: Fuse<O>;\n    let exactMatch: boolean = false;\n    let parents: Map<O['id'], O['id']>;\n    let children: Map<O['id'], O['id'][]>;\n\n    const source: Source<O> = async (query, mostRecentAction) => {\n      /*\n        Re-fetch the options on the load action, and rebuild the state\n        derived from the option data.\n      */\n      if (\n        mostRecentAction.type === 'load' ||\n        mostRecentAction.type === 'openChange'\n      ) {\n        data = await fetchDataset();\n        const topLevelOptions = getTopLevelOptions(data);\n\n        fuse = new Fuse(flattenOptions(topLevelOptions, false), {\n          threshold: 0.2,\n          keys: ['title'],\n          includeScore: true,\n          includeMatches: true,\n          ...options?.fuseOptions,\n        });\n\n        exactMatch = options?.fuseOptions?.threshold == 0;\n        [parents, children] = getRelationshipMaps(topLevelOptions);\n      }\n\n      /*\n        If the user is not searching options, return the full set of options\n        sorted appropriately.\n      */\n      if (!query.search) {\n        /*\n          The `source` order property allows for opting out of automatic\n          sorting, returning the data in its natural input order.\n        */\n        if (query.order === 'source') return data;\n\n        /*\n          Sort the options by title and subtitle.\n        */\n        if (query.order === 'title') {\n          function sortByTitle(options: Option<O>[]): Option<O>[] {\n            return sortBy(options, [\n              (o: Option<O>) => o.title.toLowerCase(),\n              (o: Option<O>) => o.subtitle?.toLowerCase() ?? '',\n            ]).map(option => ({\n              ...option,\n              children: option.children?.length\n                ? sortByTitle(option.children)\n                : undefined,\n            }));\n          }\n\n          return data.map(group => ({\n            ...group,\n            options: sortByTitle(group.options),\n          }));\n        }\n\n        /*\n          Sort the options by count, then by title, then by subtitle.\n        */\n        if (query.order === 'count') {\n          function sortByCount(options: Option<O>[]): Option<O>[] {\n            return sortBy(options, [\n              (o: Option<O>) => (isNumber(o.count) ? -o.count : Infinity),\n              (o: Option<O>) => o.title.toLowerCase(),\n              (o: Option<O>) => o.subtitle?.toLowerCase() ?? '',\n            ]).map(option => ({\n              ...option,\n              children: option.children?.length\n                ? sortByCount(option.children)\n                : undefined,\n            }));\n          }\n\n          return data.map(group => ({\n            ...group,\n            options: sortByCount(group.options),\n          }));\n        }\n      }\n\n      /*\n        Execute the search with fuse. Once we have the search match data,\n        rebuild just as much of the tree as is needed to render the search\n        results. Specifically, any match will need all of its ancestors (so\n        that matched leaf nodes are shown nested under their ancestors) and all\n        of its children (because a matching parent means that all of its\n        descendants match too, per the design specification), whether they\n        themselves matched or not.\n      */\n      const matchedOptions: FuseResult<O>[] = fuse.search(query.search);\n      const matchedIds: Set<O['id']> = new Set(\n        matchedOptions.map(result => result.item.id),\n      );\n\n      const matchAncestors: Set<O['id']> = new Set();\n      function collectAncestors(ids: O['id'][]) {\n        for (const id of ids) {\n          const parentId = parents.get(id);\n          if (parentId) {\n            matchAncestors.add(parentId);\n            collectAncestors([parentId]);\n          }\n        }\n      }\n      collectAncestors([...matchedIds]);\n\n      const matchDescendants: Set<O['id']> = new Set();\n      function collectDescendants(ids: O['id'][]) {\n        for (const id of ids) {\n          const childrenIds = children.get(id);\n          if (childrenIds) {\n            for (const child of childrenIds) {\n              matchDescendants.add(child);\n            }\n            collectDescendants(childrenIds);\n          }\n        }\n      }\n      collectDescendants([...matchedIds]);\n\n      /*\n        Next, we'll combine all the matched IDs with their direct ancestors and\n        descandants, and filter the original data set down to just these\n        options.\n      */\n      const filteredIds: Set<O['id']> = new Set([\n        ...matchedIds,\n        ...matchAncestors,\n        ...matchDescendants,\n      ]);\n\n      function filterOptions(options: Option<O>[]): Option<O>[] {\n        const filteredOptions: Option<O>[] = [];\n        for (const option of options) {\n          if (filteredIds.has(option.id)) {\n            filteredOptions.push({\n              ...option,\n              children: option.children?.length\n                ? filterOptions(option.children)\n                : undefined,\n            });\n          }\n        }\n        return filteredOptions;\n      }\n      const filteredOptions = filterOptions(getTopLevelOptions(data));\n\n      /*\n        At this point, we have an array of distinct trees (top-level options),\n        filtered down to only the options matching the search query. Note that\n        we don't care about section headers when searching since results should\n        be ordered by relevance. To calculate the order of these trees, we'll\n        take the total match scores for options found in the tree, divided by\n        the count of matches in the tree (the best average match score).\n      */\n\n      const scoreMap: Map<O['id'], number> = new Map(\n        matchedOptions.map(result => [result.item.id, result.score ?? 0]),\n      );\n      const ordered = sortBy(filteredOptions, (option: Option<O>): number => {\n        function calculateScore(option: Option<O>): number {\n          return (\n            (scoreMap.get(option.id) ?? 0) +\n            (option.children ?? []).reduce(\n              (score, child) => score + calculateScore(child),\n              0,\n            )\n          );\n        }\n        function calculateCount(option: Option<O>): number {\n          return (\n            1 +\n            (option.children ?? []).reduce(\n              (count, child) => count + calculateCount(child),\n              0,\n            )\n          );\n        }\n        const totalScore = calculateScore(option);\n        const totalCount = calculateCount(option);\n        return totalScore / totalCount;\n      });\n\n      /*\n        Finally, we'll add highlight indices to the matches so that they can be\n        displayed to the user.\n      */\n\n      type Highlights = {\n        titleHighlightIndices?: HighlightComponent.HighlightIndices[];\n        subtitleHighlightIndices?: HighlightComponent.HighlightIndices[];\n      };\n      const highlightMap: Map<O['id'], Highlights> = new Map(\n        matchedOptions.map(result => {\n          const highlights: Highlights = {};\n          for (const match of result.matches ?? []) {\n            // filter out inexact matches\n            if (exactMatch && match.value != null) {\n              match.indices = match.indices.filter(\n                isFuseMatchExact(match, query.search),\n              );\n            }\n            if (match.key === 'title') {\n              highlights.titleHighlightIndices = [...match.indices];\n            }\n            if (match.key === 'subtitle') {\n              highlights.subtitleHighlightIndices = [...match.indices];\n            }\n          }\n          return [result.item.id, highlights];\n        }),\n      );\n      function addHighlightsToOption(options: Option<O>[]): SourceOption<O>[] {\n        return options.map(option => ({\n          ...option,\n          ...highlightMap.get(option.id),\n          ...(option.children?.length\n            ? { children: addHighlightsToOption(option.children) }\n            : null),\n        }));\n      }\n\n      return [{ options: addHighlightsToOption(ordered) }];\n    };\n\n    return createManager(source, options);\n  }\n\n  export function isFuseMatchExact(\n    match: FuseResultMatch,\n    search: string,\n  ): (\n    value: RangeTuple,\n    index: number,\n    array: readonly RangeTuple[],\n  ) => boolean {\n    return matchedIndices => {\n      const matchedValue = match\n        .value!.slice(matchedIndices[0], matchedIndices[1] + 1)\n        .toLowerCase();\n      // fuse is weird with it's matches. For a text of \"planning\" and a search string of \"plan\"\n      // the matched value will be \"plann\" with the extra 'n' because of its fuzzy matching.\n      // so just make sure the matched value at least starts with the search string.\n      // it's extra weird because for a text of \"analytics\" and a search string of \"nalytics\",\n      // the matched value will be \"analytics\". So we just need to make sure the the matched value\n      // includes the search string because there might be extra stuff on the front or the end.\n      return matchedValue.includes(search.toLowerCase());\n    };\n  }\n\n  //////////////////////////////////\n  // State reducer (with helpers) //\n  //////////////////////////////////\n\n  function getDisplayLimitMessage<O extends BaseOption>(\n    displayedOptionCount: number,\n    totalOptionCount: number,\n    query: CoreState<O>['query'],\n  ): string | null {\n    if (displayedOptionCount === totalOptionCount) return null;\n    const rivNumber = new NumberPipe();\n    const displayed = rivNumber.transform(displayedOptionCount);\n    const total = rivNumber.transform(totalOptionCount);\n    const start = `Showing ${displayed} of ${total} options`;\n    return query.search ? `${start} matching \"${query.search}\"` : start;\n  }\n\n  function countVisibleOptions<O extends BaseOption>(\n    optionGroups: FullOptionGroup<O>[],\n    leafOnly: boolean,\n  ): number {\n    function count(options: FullOption<O>[]): number {\n      return options.reduce((acc, option) => {\n        if (option.expanded && option.children?.length) {\n          return acc + (leafOnly ? 0 : 1) + count(option.children);\n        }\n        return acc + 1;\n      }, 0);\n    }\n\n    return optionGroups.reduce(\n      (total, group) => total + count(group.options),\n      0,\n    );\n  }\n\n  function countAllOptions<O extends BaseOption>(\n    optionGroups: FullOptionGroup<O>[],\n  ): number {\n    function count(options: FullOption<O>[]): number {\n      return options.reduce((acc, option) => {\n        if (option.children?.length) {\n          return acc + 1 + count(option.children);\n        }\n        return acc + 1;\n      }, 0);\n    }\n\n    return optionGroups.reduce(\n      (total, group) => total + count(group.options),\n      0,\n    );\n  }\n\n  function applyDisplayLimit<O extends BaseOption>(\n    optionGroups: FullOptionGroup<O>[],\n    displayLimit?: number,\n  ): FullOptionGroup<O>[] {\n    if (displayLimit === undefined) return optionGroups;\n\n    type DisplayLimitOptions = [FullOption<O>[], number];\n    function filterWithLimit(\n      options: FullOption<O>[],\n      remaining: number,\n    ): DisplayLimitOptions {\n      let left = remaining;\n      const visibleOptions: FullOption<O>[] = [];\n      for (const option of options) {\n        if (left <= 0) break;\n\n        if (option.expanded && option.children?.length) {\n          const [childOptions, childRemaining] = filterWithLimit(\n            option.children,\n            left - 1,\n          );\n          visibleOptions.push({\n            ...option,\n            children: childOptions,\n          });\n          left = childRemaining;\n        } else {\n          visibleOptions.push(option);\n          left--;\n        }\n      }\n      return [visibleOptions, left];\n    }\n\n    type DisplayLimitGroups = [FullOptionGroup<O>[], number];\n    const startingValue: DisplayLimitGroups = [[], displayLimit];\n    const [resolvedGroups] = optionGroups.reduce<DisplayLimitGroups>(\n      ([groups, remaining], group) => {\n        const [options, leftAfter] = filterWithLimit(group.options, remaining);\n        if (options.length) {\n          return [[...groups, { ...group, options }], leftAfter];\n        } else {\n          return [groups, remaining];\n        }\n      },\n      startingValue,\n    );\n\n    return resolvedGroups;\n  }\n\n  /*\n    If we are restricting how many options are selected to a specific limit,\n      when we are at that limit, disable all options not currently selected.\n  */\n  function applySelectedOptionLimit<O extends BaseOption>(\n    state: CoreState<O>,\n    optionGroups: FullOptionGroup<O>[],\n    topLevelOptions: FullOption<O>[],\n    options?: ManagerOptions<O>,\n  ): FullOptionGroup<O>[] {\n    if (options?.selectedOptionLimit === undefined) {\n      return optionGroups;\n    }\n\n    const selectedOrIndeterminateTopOptions = topLevelOptions.filter(\n      option => option.selected != false,\n    );\n    const numSelectedOptions: number = options?.useTopLevelOptionsForDisplay\n      ? selectedOrIndeterminateTopOptions.length\n      : state.selection.selected.size;\n\n    const selectedOptionLimit: number = options.selectedOptionLimit;\n\n    // If we have less items selected than the limit, business as usual.\n    if (numSelectedOptions < selectedOptionLimit) {\n      return optionGroups;\n    }\n\n    // If we have equal items selected to the limit (or more), prevent users from selecting more options.\n    function disableUnselectedItems(\n      currentOptions: FullOption<O>[],\n      optionsAreChildrenOfSelectedGroup: boolean,\n    ): FullOption<O>[] {\n      const updatedItems: FullOption<O>[] = [];\n      for (const option of currentOptions) {\n        const isDisabledOrUnselected: boolean =\n          !!option.disabled || (option.selectable && option.selected == false);\n\n        const isCurrentOptionSelected: boolean =\n          option.selectable && option.selected != false;\n        const isCurrentOrParentOptionSelected: boolean =\n          isCurrentOptionSelected || optionsAreChildrenOfSelectedGroup;\n\n        const forceEnabledBasedOnParent: boolean =\n          !!options?.useTopLevelOptionsForDisplay &&\n          optionsAreChildrenOfSelectedGroup;\n        const markDisabled: boolean =\n          isDisabledOrUnselected && !forceEnabledBasedOnParent;\n\n        if (option.children?.length) {\n          const childOptions = disableUnselectedItems(\n            option.children,\n            isCurrentOrParentOptionSelected,\n          );\n          updatedItems.push({\n            ...option,\n            disabled: !!markDisabled,\n            children: childOptions,\n          });\n        } else {\n          updatedItems.push({\n            ...option,\n            disabled: !!markDisabled,\n          });\n        }\n      }\n      return updatedItems;\n    }\n\n    const groupsAfterLimit: FullOptionGroup<O>[] = [];\n    for (const currentGroup of optionGroups) {\n      groupsAfterLimit.push({\n        ...currentGroup,\n        options: disableUnselectedItems(currentGroup.options, false),\n      });\n    }\n\n    return groupsAfterLimit;\n  }\n\n  function getRelationshipMaps<O extends BaseOption>(\n    options: Option<O>[],\n  ): [Map<O['id'], O['id']>, Map<O['id'], O['id'][]>] {\n    const parents = new Map();\n    function buildParentsMap(options: Option<O>[], parent?: Option<O>): void {\n      for (const option of options) {\n        if (parent) {\n          parents.set(option.id, parent.id);\n        }\n        if (option.children?.length) {\n          buildParentsMap(option.children, option);\n        }\n      }\n    }\n    buildParentsMap(options);\n\n    const children = new Map();\n    function buildChildrenMap(options: Option<O>[]): void {\n      for (const option of options) {\n        if (option.children?.length) {\n          children.set(\n            option.id,\n            option.children.map(({ id }) => id),\n          );\n          buildChildrenMap(option.children);\n        }\n      }\n    }\n    buildChildrenMap(options);\n\n    return [parents, children];\n  }\n\n  function getTopLevelOptions<O extends BaseOption>(\n    optionGroups: FullOptionGroup<O>[],\n  ): FullOption<O>[];\n  function getTopLevelOptions<O extends BaseOption>(\n    optionGroups: SourceOptionGroup<O>[],\n  ): SourceOption<O>[];\n  function getTopLevelOptions<O extends BaseOption>(\n    optionGroups: OptionGroup<O>[],\n  ): Option<O>[];\n  function getTopLevelOptions<\n    O extends BaseOption,\n    G extends { options: readonly T[] },\n    T = G extends FullOptionGroup<O>\n      ? FullOption<O>\n      : G extends SourceOptionGroup<O>\n      ? SourceOption<O>\n      : Option<O>,\n  >(optionGroups: G[]): T[] {\n    return optionGroups.reduce<T[]>(\n      (options, group) => [...options, ...group.options],\n      [],\n    );\n  }\n\n  function getParentMultiSelectionState<O extends BaseOption>(\n    children: FullOption<O>[],\n  ): MultiSelectionState {\n    if (children.every(child => child.selected === true)) return true;\n    if (children.every(child => child.selected === false)) return false;\n    return 'indeterminate';\n  }\n\n  function augmentOptionToFullOption<O extends BaseOption>(\n    state: CoreState<O>,\n    option: SourceOption<O>,\n  ): FullOption<O> {\n    if (option.children?.length) {\n      const augmentedChildren = option.children.map(child =>\n        augmentOptionToFullOption(state, child),\n      );\n      return {\n        ...option,\n        children: augmentedChildren,\n        selected: getParentMultiSelectionState(augmentedChildren),\n        expanded: state.query.search\n          ? true\n          : state.display.expandedOptions.has(option.id),\n        selectable: !state.query.search,\n        expandable: !state.query.search,\n      };\n    }\n    return {\n      ...option,\n      children: undefined,\n      selected: state.selection.selected.has(option),\n      expanded: false,\n      selectable: true,\n      expandable: false,\n    };\n  }\n\n  function getFormattedOptionsForDisplay<O extends BaseOption>(\n    state: CoreState<O>,\n    topLevelOptions: FullOption<O>[],\n    options?: ManagerOptions<O>,\n  ): string {\n    // If we have a custom display function, use it\n    if (options?.getCustomOptionDisplay) {\n      return options.getCustomOptionDisplay([...state.selection.selected]);\n    }\n    if (options?.useTopLevelOptionsForDisplay) {\n      return getTopLevelFormattedOptionsForDisplay(topLevelOptions);\n    }\n    // Otherwise, use the default display for options - titles separated by commas.\n    return [...state.selection.selected].map(({ title }) => title).join(', ');\n  }\n\n  function getTopLevelFormattedOptionsForDisplay<O extends BaseOption>(\n    topLevelOptions: FullOption<O>[],\n  ): string {\n    if (!topLevelOptions || topLevelOptions.length == 0) {\n      return '';\n    }\n    const selectedOrIndeterminateTopOptions = topLevelOptions.filter(\n      option => option.selected != false,\n    );\n    return selectedOrIndeterminateTopOptions\n      .map(({ title }) => title)\n      .join(', ');\n  }\n\n  function getPillCountForDisplay<O extends BaseOption>(\n    state: CoreState<O>,\n    topLevelOptions: FullOption<O>[],\n    options?: ManagerOptions<O>,\n  ): number {\n    if (options?.useTopLevelOptionsForDisplay) {\n      const selectedOrIndeterminateTopOptions = topLevelOptions.filter(\n        option => option.selected != false,\n      );\n      return selectedOrIndeterminateTopOptions.length;\n    }\n    return state.selection.selected.size;\n  }\n\n  function getZeroStateMessage<O extends BaseOption>(\n    state: CoreState<O>,\n  ): string | null {\n    if (state.sourceOptionGroups.every(group => group.options.length === 0)) {\n      if (state.query.search) return 'No results found.';\n      return 'No options.';\n    }\n    return null;\n  }\n\n  function findOption<O extends BaseOption>(\n    options: SourceOption<O>[],\n    id: O['id'],\n  ): SourceOption<O> | null {\n    for (const option of options) {\n      if (option.id === id) return option;\n      if (option.children?.length) {\n        const child = findOption(option.children, id);\n        if (child) return child;\n      }\n    }\n    return null;\n  }\n\n  function flattenOptions<O extends BaseOption>(\n    options: Option<O>[],\n    leafOnly: boolean,\n  ): O[] {\n    return flattenDeep(\n      options.map(option => {\n        if (option.children?.length) {\n          const descendants = option.children.map(child =>\n            flattenOptions([child], leafOnly),\n          );\n          return leafOnly ? descendants : [option, ...descendants];\n        } else {\n          return [option];\n        }\n      }),\n    );\n  }\n\n  function toggleSelected<O extends BaseOption>(\n    state: CoreState<O>,\n    id: O['id'],\n  ): CoreState<O> {\n    const topLevelOptions = getTopLevelOptions(state.sourceOptionGroups);\n    const option = findOption(topLevelOptions, id);\n    if (!option) return state;\n\n    const newSelection = new OptionSet(state.selection.selected);\n\n    const newValue = !(\n      augmentOptionToFullOption(state, option).selected === true\n    );\n    const leaves = flattenOptions([option], true);\n    for (const leaf of leaves) {\n      if (newValue) {\n        newSelection.add(leaf);\n      } else {\n        newSelection.delete(leaf);\n      }\n    }\n\n    return {\n      ...state,\n      selection: {\n        selected: newSelection,\n      },\n    };\n  }\n\n  function setSelectedOption<O extends BaseOption>(\n    state: CoreState<O>,\n    id: O['id'],\n  ): CoreState<O> {\n    const topLevelOptions = getTopLevelOptions(state.sourceOptionGroups);\n    const option = findOption(topLevelOptions, id);\n    if (!option) return state;\n\n    const newSelection = new OptionSet<O>();\n    newSelection.add(option);\n\n    return {\n      ...state,\n      selection: {\n        selected: newSelection,\n      },\n    };\n  }\n\n  function toggleVisibleSelected<O extends BaseOption>(\n    state: CoreState<O>,\n  ): CoreState<O> {\n    const leaves = flattenOptions(\n      getTopLevelOptions(state.sourceOptionGroups),\n      true,\n    );\n    const isAllSelected = leaves.every(leaf =>\n      [...state.selection.selected].map(({ id }) => id).includes(leaf.id),\n    );\n    const newSelection = new OptionSet(state.selection.selected);\n\n    for (const leaf of leaves) {\n      if (isAllSelected) newSelection.delete(leaf);\n      else newSelection.add(leaf);\n    }\n\n    return {\n      ...state,\n      selection: {\n        ...state.selection,\n        selected: newSelection,\n      },\n    };\n  }\n\n  function toggleOptionExpanded<O extends BaseOption>(\n    state: CoreState<O>,\n    id: O['id'],\n  ): CoreState<O> {\n    const newValue = !state.display.expandedOptions.has(id);\n    const newExpandedOptions = new Set(state.display.expandedOptions);\n    if (newValue) newExpandedOptions.add(id);\n    else newExpandedOptions.delete(id);\n    return {\n      ...state,\n      display: {\n        ...state.display,\n        expandedOptions: newExpandedOptions,\n      },\n    };\n  }\n\n  function sideEffects<O extends BaseOption>(\n    state: CoreState<O>,\n    action: Action<O> | InternalAction<O>,\n    source: Source<O>,\n    internalActions: Subject<InternalAction<O>>,\n  ): CoreState<O> {\n    if (\n      action.type === 'load' ||\n      action.type === 'searchChange' ||\n      action.type === 'orderChange' ||\n      (action.type === 'openChange' && action.open)\n    ) {\n      source(state.query, action)\n        .then(data => {\n          internalActions.next({ type: 'loadComplete', data });\n        })\n        .catch(error => {\n          console.error(error);\n          internalActions.next({ type: 'loadError', error });\n        });\n      return {\n        ...state,\n        load: {\n          loading: true,\n          error: null,\n        },\n      };\n    }\n    return state;\n  }\n\n  function reduce<O extends BaseOption>(\n    state: CoreState<O>,\n    action: Action<O> | InternalAction<O>,\n  ): CoreState<O> {\n    switch (action.type) {\n      case 'load':\n        return state;\n      case 'loadComplete':\n        return {\n          ...state,\n          load: {\n            loading: false,\n            error: null,\n          },\n          sourceOptionGroups: action.data,\n        };\n      case 'loadError':\n        return {\n          ...state,\n          load: {\n            loading: false,\n            error: action.error,\n          },\n        };\n      case 'openChange':\n        return {\n          ...state,\n          query: {\n            ...state.query,\n            search: '',\n          },\n          display: {\n            ...state.display,\n            open: action.open,\n          },\n        };\n      case 'searchChange':\n        return {\n          ...state,\n          query: {\n            ...state.query,\n            search: action.payload,\n          },\n        };\n      case 'orderChange':\n        return {\n          ...state,\n          query: {\n            ...state.query,\n            order: action.payload,\n          },\n        };\n      case 'selectionChange':\n        return {\n          ...state,\n          selection: action.payload,\n        };\n      case 'toggleOptionSelected':\n        return toggleSelected(state, action.id);\n      case 'setSelectedOption':\n        return setSelectedOption(state, action.id);\n      case 'visibleSelectedChange':\n        return toggleVisibleSelected(state);\n      case 'toggleOptionExpanded':\n        return toggleOptionExpanded(state, action.id);\n    }\n  }\n}\n"]}
|
|
782
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"state.js","sourceRoot":"","sources":["../../../../../../projects/riv/src/lib/input/select/state.ts"],"names":[],"mappings":"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","sourcesContent":["import Fuse, {\n  FuseResult,\n  FuseResultMatch,\n  IFuseOptions,\n  RangeTuple,\n} from 'fuse.js';\nimport { defaultsDeep, flattenDeep, isNumber, sortBy } from 'lodash';\nimport {\n  connectable,\n  Connectable,\n  map,\n  merge,\n  Observable,\n  ReplaySubject,\n  scan,\n  startWith,\n  Subject,\n} from 'rxjs';\nimport { DeepPartial } from 'utility-types';\nimport { NumberPipe } from '../../format/pipes/number.pipe';\nimport { HighlightComponent } from '../../visualization/highlight/highlight.component';\n\nexport namespace RivSelect {\n  /////////////\n  // Options //\n  /////////////\n\n  /**\n   * ┌─────────────────────-------------------───┐\n   * │ BaseOption                                │\n   * │                                           │\n   * │ The core data required for each option    │\n   * │ (such as id and title).                   │\n   * ├──────────────────────-------------------──┤\n   * │ Option (BaseOption + children)            │\n   * │                                           │\n   * │ Provides recursive type safety to the     │\n   * │ type safety to the BaseOption.            │\n   * └─------------------┬-------────────────────┘\n   *                     |\n   * ┌───────────────────▼───────────────────────┐\n   * │ SourceOption (Option + search highlights) │\n   * │                                           │\n   * │ Adds search highlights to the Option and  │\n   * │ is the return type for the option Source  │\n   * │ (data fetcher) function.                  │\n   * └───────────────────┬───────────────────────┘\n   *                     |\n   * ┌───────────────────▼───────────────────────┐\n   * │ FullOption (SourceOption + UI state)      │\n   * │                                           │\n   * │ Augments the SourceOption with all of the │\n   * │ UI information from other parts of the    │\n   * │ state, such as selection status, whether  │\n   * │ or not the node is expanded, etc.         │\n   * └───────────────────────────────────────────┘\n   *\n   * Note that the usages of Omit<...> in this section are not required, but\n   * do help in-editor type hints to be more clear and direct.\n   */\n\n  export type BaseOption = {\n    id: string | number;\n    title: string;\n    subtitle?: string;\n    help?: string;\n    count?: number;\n    disabled?: boolean;\n  };\n  export type Option<O extends BaseOption = BaseOption> = O & {\n    children?: Option<O>[];\n  };\n\n  export type SourceOption<O extends BaseOption> = Omit<\n    Option<O>,\n    'children'\n  > & {\n    titleHighlightIndices?: HighlightComponent.HighlightIndices[];\n    subtitleHighlightIndices?: HighlightComponent.HighlightIndices[];\n    children?: SourceOption<O>[];\n  };\n\n  export type MultiSelectionState = boolean | 'indeterminate';\n\n  export type FullOption<O extends BaseOption> = Omit<\n    SourceOption<O>,\n    'children'\n  > & {\n    selected: MultiSelectionState;\n    expanded: boolean;\n    selectable: boolean;\n    expandable: boolean;\n    children?: FullOption<O>[];\n  };\n\n  ///////////////////\n  // Option groups //\n  ///////////////////\n\n  /**\n   * The relationships between OptionGroup, SourceOptionGroup, and\n   * FullOptionGroup is analogous to the option types above.\n   *\n   * As with before, the use of Omit<...> is not required but helpful.\n   */\n\n  export type OptionGroup<O extends BaseOption> = {\n    header?: string;\n    options: Option<O>[];\n  };\n\n  export type SourceOptionGroup<O extends BaseOption> = Omit<\n    OptionGroup<O>,\n    'options'\n  > & {\n    options: SourceOption<O>[];\n  };\n\n  export type FullOptionGroup<O extends BaseOption> = Omit<\n    SourceOptionGroup<O>,\n    'options'\n  > & {\n    options: FullOption<O>[];\n  };\n\n  /**\n   * The OptionSet class provides Set-like functionality, but uniqueness is\n   * determined by the option's ID rather than the object reference.\n   */\n  export class OptionSet<O extends BaseOption> extends Set<SourceOption<O>> {\n    override has(option: SourceOption<O> | FullOption<O>) {\n      return !![...this].find(o => o.id === option.id);\n    }\n\n    override add(option: SourceOption<O>) {\n      if (this.has(option)) {\n        // The Set already has some version of this option, but we'll make sure\n        // it has the most recent object reference (while keeping insertion\n        // order consistent).\n        const newOptions = [...this].map(o =>\n          o.id === option.id ? option : o,\n        );\n        this.clear();\n        newOptions.forEach(o => {\n          super.add(o);\n        });\n      } else {\n        super.add(option);\n      }\n      return this;\n    }\n\n    override delete(option: SourceOption<O>) {\n      const existing = [...this].find(o => o.id === option.id);\n      if (existing) {\n        super.delete(existing);\n        return true;\n      } else {\n        return false;\n      }\n    }\n  }\n\n  ///////////\n  // State //\n  ///////////\n\n  /**\n   * The CoreState provides all of the foundational pieces of state required\n   * for a working component. FullState is a pure derivation of CoreState plus\n   * the configuration options, and provides conveniences for rendering the\n   * components. Actions and the core state are passed to the reducer to\n   * produce new CoreStates (which are then used to calculate new FullStates).\n   *\n   * ┌──────┐\n   * │  UI  ◄────────┐\n   * └──┬───┘        │\n   *    │            │\n   * ┌──▼────────┐   │\n   * │  Actions  │   │\n   * └──┬────────┘   │\n   *    │            │\n   * ┌──▼────────────┴─┐\n   * │  State reducer  │\n   * └─────────────────┘\n   */\n\n  export type OrderBy = 'title' | 'count' | 'source';\n\n  const MIN_OPTIONS_FOR_CONTROLS = 5;\n\n  export type CoreState<O extends BaseOption> = {\n    query: {\n      search: string;\n      order: OrderBy;\n    };\n    load: {\n      loading: boolean;\n      error: unknown | null;\n    };\n    sourceOptionGroups: SourceOptionGroup<O>[];\n    selection: {\n      selected: OptionSet<O>;\n    };\n    display: {\n      placeholder: string;\n      open: boolean;\n      expandedOptions: Set<O['id']>;\n    };\n  };\n\n  export type FullState<O extends BaseOption> = CoreState<O> & {\n    query: {\n      showSearch: boolean;\n      searchPlaceholder: string;\n      showOrder: boolean;\n    };\n    fullOptionGroups: FullOptionGroup<O>[];\n    selection: {\n      allowMultiSelect: boolean;\n      allowSelectAll: boolean;\n      visibleSelectionState: MultiSelectionState;\n    };\n    display: {\n      formattedSelectedOptions: string;\n      zeroStateMessage: string | null;\n      dividers: boolean;\n      inline: boolean;\n      maxHeight: string | null;\n      maxWidth: string | null;\n      minHeight: string | null;\n      minWidth: string | null;\n      displayLimitMessage: string | null;\n      showSingleSelected: boolean;\n      pillCount: number;\n    };\n  };\n\n  /////////////\n  // Actions //\n  /////////////\n\n  export type Action<O extends BaseOption> =\n    | { type: 'load' }\n    | { type: 'openChange'; open: boolean }\n    | { type: 'searchChange'; payload: string }\n    | { type: 'orderChange'; payload: OrderBy }\n    | {\n        type: 'selectionChange';\n        payload: CoreState<O>['selection'];\n      }\n    | {\n        type: 'toggleOptionSelected';\n        id: O['id'];\n      }\n    | {\n        type: 'setSelectedOption';\n        id: O['id'];\n      }\n    | {\n        type: 'visibleSelectedChange';\n      }\n    | {\n        type: 'toggleOptionExpanded';\n        id: O['id'];\n      };\n\n  type InternalAction<O extends BaseOption> =\n    | { type: 'loadComplete'; data: SourceOptionGroup<O>[] }\n    | { type: 'loadError'; error: unknown };\n\n  ////////////\n  // Source //\n  ////////////\n\n  /**\n   * The Source's job is to fetch options (based on the current state) which\n   * then blend with the other pieces of state to produce the FullState.\n   */\n\n  export type Source<O extends BaseOption> = (\n    query: CoreState<O>['query'],\n    mostRecentAction: Action<O>,\n  ) => Promise<SourceOptionGroup<O>[]>;\n\n  /////////////\n  // Manager //\n  /////////////\n\n  export type Manager<O extends BaseOption> = {\n    actions: Subject<Action<O>>;\n    state: Connectable<FullState<O>>;\n  };\n\n  export type ManagerOptions<O extends BaseOption> = {\n    initialState?: DeepPartial<CoreState<O>>;\n    allowMultiSelect?: boolean;\n    allowSearch?: boolean;\n    allowSelectAll?: boolean;\n    allowOrder?: boolean;\n    searchPlaceholder?: string;\n    dividers?: boolean;\n    inline?: boolean;\n    maxHeight?: string | null;\n    maxWidth?: string | null;\n    minHeight?: string | null;\n    minWidth?: string | null;\n    displayLimit?: number;\n    selectedOptionLimit?: number;\n    showSingleSelected?: boolean;\n    useTopLevelOptionsForDisplay?: boolean;\n    getCustomOptionDisplay?: (selectedOptions: SourceOption<O>[]) => string;\n  };\n\n  export function createManager<O extends BaseOption>(\n    source: Source<O>,\n    options?: ManagerOptions<O>,\n  ): Manager<O> {\n    const defaultState: CoreState<O> = {\n      query: {\n        search: '',\n        order: 'title',\n      },\n      load: {\n        loading: false,\n        error: null,\n      },\n      sourceOptionGroups: [],\n      selection: {\n        selected: new OptionSet(),\n      },\n      display: {\n        placeholder: 'Select',\n        open: false,\n        expandedOptions: new Set(),\n      },\n    };\n    const defaultedInitialState: CoreState<O> = defaultsDeep(\n      {},\n      options?.initialState,\n      defaultState,\n    );\n\n    const actions: Subject<Action<O>> = new Subject();\n    const internalActions: Subject<InternalAction<O>> = new Subject();\n\n    const coreStateWithSelectionSnapshot: Observable<\n      [CoreState<O>, OptionSet<O>]\n    > = merge(actions, internalActions).pipe(\n      scan<Action<O> | InternalAction<O>, [CoreState<O>, OptionSet<O>]>(\n        ([state, snapshot], action) => {\n          const newState = sideEffects(\n            reduce(state, action),\n            action,\n            source,\n            internalActions,\n          );\n\n          const newSelectionSnapshot =\n            action.type === 'openChange' && action.open\n              ? createSelectionSnapshotWithAncestors(newState)\n              : snapshot;\n\n          return [newState, newSelectionSnapshot];\n        },\n        [defaultedInitialState, new OptionSet<O>()],\n      ),\n      startWith<[CoreState<O>, OptionSet<O>]>([\n        defaultedInitialState,\n        new OptionSet<O>(),\n      ]),\n    );\n\n    const state: Connectable<FullState<O>> = connectable(\n      coreStateWithSelectionSnapshot.pipe(\n        map(([s, selectionAtOpen]) => {\n          const allOptionGroups: FullOptionGroup<O>[] =\n            s.sourceOptionGroups.map(optionGroup => {\n              return {\n                ...optionGroup,\n                options: optionGroup.options.map(option =>\n                  augmentOptionToFullOption(s, option),\n                ),\n              };\n            });\n\n          const topLevelOptions = getTopLevelOptions(allOptionGroups);\n\n          const sortedOptionGroups = options?.allowMultiSelect\n            ? sortOptionsByPreviouslySelectedState(\n                allOptionGroups,\n                selectionAtOpen,\n              )\n            : allOptionGroups;\n\n          const displayLimitedOptionGroups = applyDisplayLimit(\n            sortedOptionGroups,\n            options?.displayLimit,\n          );\n          const fullOptionGroups = applySelectedOptionLimit(\n            s,\n            displayLimitedOptionGroups,\n            topLevelOptions,\n            options,\n          );\n\n          return {\n            ...s,\n            query: {\n              ...s.query,\n              showSearch:\n                !!options?.allowSearch &&\n                (!!s.query.search ||\n                  countAllOptions(allOptionGroups) > MIN_OPTIONS_FOR_CONTROLS),\n              searchPlaceholder: options?.searchPlaceholder ?? 'Search',\n              showOrder:\n                !!options?.allowOrder &&\n                !s.query.search &&\n                countAllOptions(allOptionGroups) > MIN_OPTIONS_FOR_CONTROLS,\n            },\n            fullOptionGroups,\n            selection: {\n              ...s.selection,\n              allowMultiSelect: !!options?.allowMultiSelect,\n              allowSelectAll:\n                !!options?.allowSelectAll &&\n                options?.selectedOptionLimit == undefined,\n              visibleSelectionState:\n                getParentMultiSelectionState(topLevelOptions),\n            },\n            display: {\n              ...s.display,\n              formattedSelectedOptions: getFormattedOptionsForDisplay(\n                s,\n                topLevelOptions,\n                options,\n              ),\n              zeroStateMessage: getZeroStateMessage(s),\n              dividers: !!options?.dividers,\n              inline: !!options?.inline,\n              maxHeight: options?.maxHeight ?? null,\n              maxWidth: options?.maxWidth ?? null,\n              minHeight: options?.minHeight ?? null,\n              minWidth: options?.minWidth ?? null,\n              displayLimitMessage: getDisplayLimitMessage(\n                countVisibleOptions(fullOptionGroups, !!s.query.search),\n                countVisibleOptions(allOptionGroups, !!s.query.search),\n                s.query,\n              ),\n              showSingleSelected: !!options?.showSingleSelected,\n              pillCount: getPillCountForDisplay(s, topLevelOptions, options),\n            },\n          };\n        }),\n      ),\n      {\n        connector: () => new ReplaySubject(1),\n        resetOnDisconnect: false,\n      },\n    );\n    state.connect();\n\n    // Load the options immediately for selects that are displayed inline.\n    if (options?.inline) actions.next({ type: 'load' });\n\n    return { actions, state };\n  }\n\n  export type InMemoryManagerOptions<O extends BaseOption> =\n    ManagerOptions<O> & {\n      fuseOptions?: IFuseOptions<O>;\n    };\n\n  export function createInMemoryManager<O extends BaseOption>(\n    fetchDataset: () => Promise<OptionGroup<O>[]> | OptionGroup<O>[],\n    options?: InMemoryManagerOptions<O>,\n  ): Manager<O> {\n    let data: OptionGroup<O>[];\n    let fuse: Fuse<O>;\n    let exactMatch: boolean = false;\n    let parents: Map<O['id'], O['id']>;\n    let children: Map<O['id'], O['id'][]>;\n\n    const source: Source<O> = async (query, mostRecentAction) => {\n      /*\n        Re-fetch the options on the load action, and rebuild the state\n        derived from the option data.\n      */\n      if (\n        mostRecentAction.type === 'load' ||\n        mostRecentAction.type === 'openChange'\n      ) {\n        data = await fetchDataset();\n        const topLevelOptions = getTopLevelOptions(data);\n\n        fuse = new Fuse(flattenOptions(topLevelOptions, false), {\n          threshold: 0.2,\n          keys: ['title'],\n          includeScore: true,\n          includeMatches: true,\n          ...options?.fuseOptions,\n        });\n\n        exactMatch = options?.fuseOptions?.threshold == 0;\n        [parents, children] = getRelationshipMaps(topLevelOptions);\n      }\n\n      /*\n        If the user is not searching options, return the full set of options\n        sorted appropriately.\n      */\n      if (!query.search) {\n        /*\n          The `source` order property allows for opting out of automatic\n          sorting, returning the data in its natural input order.\n        */\n        if (query.order === 'source') return data;\n\n        /*\n          Sort the options by title and subtitle.\n        */\n        if (query.order === 'title') {\n          function sortByTitle(options: Option<O>[]): Option<O>[] {\n            return sortBy(options, [\n              (o: Option<O>) => o.title.toLowerCase(),\n              (o: Option<O>) => o.subtitle?.toLowerCase() ?? '',\n            ]).map(option => ({\n              ...option,\n              children: option.children?.length\n                ? sortByTitle(option.children)\n                : undefined,\n            }));\n          }\n\n          return data.map(group => ({\n            ...group,\n            options: sortByTitle(group.options),\n          }));\n        }\n\n        /*\n          Sort the options by count, then by title, then by subtitle.\n        */\n        if (query.order === 'count') {\n          function sortByCount(options: Option<O>[]): Option<O>[] {\n            return sortBy(options, [\n              (o: Option<O>) => (isNumber(o.count) ? -o.count : Infinity),\n              (o: Option<O>) => o.title.toLowerCase(),\n              (o: Option<O>) => o.subtitle?.toLowerCase() ?? '',\n            ]).map(option => ({\n              ...option,\n              children: option.children?.length\n                ? sortByCount(option.children)\n                : undefined,\n            }));\n          }\n\n          return data.map(group => ({\n            ...group,\n            options: sortByCount(group.options),\n          }));\n        }\n      }\n\n      /*\n        Execute the search with fuse. Once we have the search match data,\n        rebuild just as much of the tree as is needed to render the search\n        results. Specifically, any match will need all of its ancestors (so\n        that matched leaf nodes are shown nested under their ancestors) and all\n        of its children (because a matching parent means that all of its\n        descendants match too, per the design specification), whether they\n        themselves matched or not.\n      */\n      const matchedOptions: FuseResult<O>[] = fuse.search(query.search);\n      const matchedIds: Set<O['id']> = new Set(\n        matchedOptions.map(result => result.item.id),\n      );\n\n      const matchAncestors: Set<O['id']> = new Set();\n      function collectAncestors(ids: O['id'][]) {\n        for (const id of ids) {\n          const parentId = parents.get(id);\n          if (parentId) {\n            matchAncestors.add(parentId);\n            collectAncestors([parentId]);\n          }\n        }\n      }\n      collectAncestors([...matchedIds]);\n\n      const matchDescendants: Set<O['id']> = new Set();\n      function collectDescendants(ids: O['id'][]) {\n        for (const id of ids) {\n          const childrenIds = children.get(id);\n          if (childrenIds) {\n            for (const child of childrenIds) {\n              matchDescendants.add(child);\n            }\n            collectDescendants(childrenIds);\n          }\n        }\n      }\n      collectDescendants([...matchedIds]);\n\n      /*\n        Next, we'll combine all the matched IDs with their direct ancestors and\n        descandants, and filter the original data set down to just these\n        options.\n      */\n      const filteredIds: Set<O['id']> = new Set([\n        ...matchedIds,\n        ...matchAncestors,\n        ...matchDescendants,\n      ]);\n\n      function filterOptions(options: Option<O>[]): Option<O>[] {\n        const filteredOptions: Option<O>[] = [];\n        for (const option of options) {\n          if (filteredIds.has(option.id)) {\n            filteredOptions.push({\n              ...option,\n              children: option.children?.length\n                ? filterOptions(option.children)\n                : undefined,\n            });\n          }\n        }\n        return filteredOptions;\n      }\n      const filteredOptions = filterOptions(getTopLevelOptions(data));\n\n      /*\n        At this point, we have an array of distinct trees (top-level options),\n        filtered down to only the options matching the search query. Note that\n        we don't care about section headers when searching since results should\n        be ordered by relevance. To calculate the order of these trees, we'll\n        take the total match scores for options found in the tree, divided by\n        the count of matches in the tree (the best average match score).\n      */\n\n      const scoreMap: Map<O['id'], number> = new Map(\n        matchedOptions.map(result => [result.item.id, result.score ?? 0]),\n      );\n      const ordered = sortBy(filteredOptions, (option: Option<O>): number => {\n        function calculateScore(option: Option<O>): number {\n          return (\n            (scoreMap.get(option.id) ?? 0) +\n            (option.children ?? []).reduce(\n              (score, child) => score + calculateScore(child),\n              0,\n            )\n          );\n        }\n        function calculateCount(option: Option<O>): number {\n          return (\n            1 +\n            (option.children ?? []).reduce(\n              (count, child) => count + calculateCount(child),\n              0,\n            )\n          );\n        }\n        const totalScore = calculateScore(option);\n        const totalCount = calculateCount(option);\n        return totalScore / totalCount;\n      });\n\n      /*\n        Finally, we'll add highlight indices to the matches so that they can be\n        displayed to the user.\n      */\n\n      type Highlights = {\n        titleHighlightIndices?: HighlightComponent.HighlightIndices[];\n        subtitleHighlightIndices?: HighlightComponent.HighlightIndices[];\n      };\n      const highlightMap: Map<O['id'], Highlights> = new Map(\n        matchedOptions.map(result => {\n          const highlights: Highlights = {};\n          for (const match of result.matches ?? []) {\n            // filter out inexact matches\n            if (exactMatch && match.value != null) {\n              match.indices = match.indices.filter(\n                isFuseMatchExact(match, query.search),\n              );\n            }\n            if (match.key === 'title') {\n              highlights.titleHighlightIndices = [...match.indices];\n            }\n            if (match.key === 'subtitle') {\n              highlights.subtitleHighlightIndices = [...match.indices];\n            }\n          }\n          return [result.item.id, highlights];\n        }),\n      );\n      function addHighlightsToOption(options: Option<O>[]): SourceOption<O>[] {\n        return options.map(option => ({\n          ...option,\n          ...highlightMap.get(option.id),\n          ...(option.children?.length\n            ? { children: addHighlightsToOption(option.children) }\n            : null),\n        }));\n      }\n\n      return [{ options: addHighlightsToOption(ordered) }];\n    };\n\n    return createManager(source, options);\n  }\n\n  export function isFuseMatchExact(\n    match: FuseResultMatch,\n    search: string,\n  ): (\n    value: RangeTuple,\n    index: number,\n    array: readonly RangeTuple[],\n  ) => boolean {\n    return matchedIndices => {\n      const matchedValue = match\n        .value!.slice(matchedIndices[0], matchedIndices[1] + 1)\n        .toLowerCase();\n      // fuse is weird with it's matches. For a text of \"planning\" and a search string of \"plan\"\n      // the matched value will be \"plann\" with the extra 'n' because of its fuzzy matching.\n      // so just make sure the matched value at least starts with the search string.\n      // it's extra weird because for a text of \"analytics\" and a search string of \"nalytics\",\n      // the matched value will be \"analytics\". So we just need to make sure the the matched value\n      // includes the search string because there might be extra stuff on the front or the end.\n      return matchedValue.includes(search.toLowerCase());\n    };\n  }\n\n  //////////////////////////////////\n  // State reducer (with helpers) //\n  //////////////////////////////////\n\n  function createSelectionSnapshotWithAncestors<O extends BaseOption>(\n    state: CoreState<O>,\n  ): OptionSet<O> {\n    const snapshot = new OptionSet(state.selection.selected);\n    const topLevelOptions = getTopLevelOptions(state.sourceOptionGroups);\n    const [parents] = getRelationshipMaps(topLevelOptions);\n\n    // For each selected option, add all its ancestors to the snapshot\n    for (const selectedOption of state.selection.selected) {\n      let currentId = selectedOption.id;\n      let parentId = parents.get(currentId);\n\n      while (parentId !== undefined) {\n        const parentOption = findOption(topLevelOptions, parentId);\n        if (parentOption) {\n          snapshot.add(parentOption);\n        }\n        currentId = parentId;\n        parentId = parents.get(currentId);\n      }\n    }\n\n    return snapshot;\n  }\n\n  function getDisplayLimitMessage<O extends BaseOption>(\n    displayedOptionCount: number,\n    totalOptionCount: number,\n    query: CoreState<O>['query'],\n  ): string | null {\n    if (displayedOptionCount === totalOptionCount) return null;\n    const rivNumber = new NumberPipe();\n    const displayed = rivNumber.transform(displayedOptionCount);\n    const total = rivNumber.transform(totalOptionCount);\n    const start = `Showing ${displayed} of ${total} options`;\n    return query.search ? `${start} matching \"${query.search}\"` : start;\n  }\n\n  function countVisibleOptions<O extends BaseOption>(\n    optionGroups: FullOptionGroup<O>[],\n    leafOnly: boolean,\n  ): number {\n    function count(options: FullOption<O>[]): number {\n      return options.reduce((acc, option) => {\n        if (option.expanded && option.children?.length) {\n          return acc + (leafOnly ? 0 : 1) + count(option.children);\n        }\n        return acc + 1;\n      }, 0);\n    }\n\n    return optionGroups.reduce(\n      (total, group) => total + count(group.options),\n      0,\n    );\n  }\n\n  function countAllOptions<O extends BaseOption>(\n    optionGroups: FullOptionGroup<O>[],\n  ): number {\n    function count(options: FullOption<O>[]): number {\n      return options.reduce((acc, option) => {\n        if (option.children?.length) {\n          return acc + 1 + count(option.children);\n        }\n        return acc + 1;\n      }, 0);\n    }\n\n    return optionGroups.reduce(\n      (total, group) => total + count(group.options),\n      0,\n    );\n  }\n\n  function applyDisplayLimit<O extends BaseOption>(\n    optionGroups: FullOptionGroup<O>[],\n    displayLimit?: number,\n  ): FullOptionGroup<O>[] {\n    if (displayLimit === undefined) return optionGroups;\n\n    type DisplayLimitOptions = [FullOption<O>[], number];\n    function filterWithLimit(\n      options: FullOption<O>[],\n      remaining: number,\n    ): DisplayLimitOptions {\n      let left = remaining;\n      const visibleOptions: FullOption<O>[] = [];\n      for (const option of options) {\n        if (left <= 0) break;\n\n        if (option.expanded && option.children?.length) {\n          const [childOptions, childRemaining] = filterWithLimit(\n            option.children,\n            left - 1,\n          );\n          visibleOptions.push({\n            ...option,\n            children: childOptions,\n          });\n          left = childRemaining;\n        } else {\n          visibleOptions.push(option);\n          left--;\n        }\n      }\n      return [visibleOptions, left];\n    }\n\n    type DisplayLimitGroups = [FullOptionGroup<O>[], number];\n    const startingValue: DisplayLimitGroups = [[], displayLimit];\n    const [resolvedGroups] = optionGroups.reduce<DisplayLimitGroups>(\n      ([groups, remaining], group) => {\n        const [options, leftAfter] = filterWithLimit(group.options, remaining);\n        if (options.length) {\n          return [[...groups, { ...group, options }], leftAfter];\n        } else {\n          return [groups, remaining];\n        }\n      },\n      startingValue,\n    );\n\n    return resolvedGroups;\n  }\n\n  /*\n    Sort options so that previously selected options (from prior sessions)\n    appear at the top of their peer/sibling lists.\n  */\n  function sortOptionsByPreviouslySelectedState<O extends BaseOption>(\n    optionGroups: FullOptionGroup<O>[],\n    selectionAtOpen: OptionSet<O>,\n  ): FullOptionGroup<O>[] {\n    function sortOptions(options: FullOption<O>[]): FullOption<O>[] {\n      return sortBy(options, option => !selectionAtOpen.has(option)).map(\n        option => {\n          if (option.children) {\n            return {\n              ...option,\n              children: sortOptions(option.children),\n            };\n          } else return option;\n        },\n      );\n    }\n\n    return optionGroups.map(group => ({\n      ...group,\n      options: sortOptions(group.options),\n    }));\n  }\n\n  /*\n    If we are restricting how many options are selected to a specific limit,\n      when we are at that limit, disable all options not currently selected.\n  */\n  function applySelectedOptionLimit<O extends BaseOption>(\n    state: CoreState<O>,\n    optionGroups: FullOptionGroup<O>[],\n    topLevelOptions: FullOption<O>[],\n    options?: ManagerOptions<O>,\n  ): FullOptionGroup<O>[] {\n    if (options?.selectedOptionLimit === undefined) {\n      return optionGroups;\n    }\n\n    const selectedOrIndeterminateTopOptions = topLevelOptions.filter(\n      option => option.selected != false,\n    );\n    const numSelectedOptions: number = options?.useTopLevelOptionsForDisplay\n      ? selectedOrIndeterminateTopOptions.length\n      : state.selection.selected.size;\n\n    const selectedOptionLimit: number = options.selectedOptionLimit;\n\n    // If we have less items selected than the limit, business as usual.\n    if (numSelectedOptions < selectedOptionLimit) {\n      return optionGroups;\n    }\n\n    // If we have equal items selected to the limit (or more), prevent users from selecting more options.\n    function disableUnselectedItems(\n      currentOptions: FullOption<O>[],\n      optionsAreChildrenOfSelectedGroup: boolean,\n    ): FullOption<O>[] {\n      const updatedItems: FullOption<O>[] = [];\n      for (const option of currentOptions) {\n        const isDisabledOrUnselected: boolean =\n          !!option.disabled || (option.selectable && option.selected == false);\n\n        const isCurrentOptionSelected: boolean =\n          option.selectable && option.selected != false;\n        const isCurrentOrParentOptionSelected: boolean =\n          isCurrentOptionSelected || optionsAreChildrenOfSelectedGroup;\n\n        const forceEnabledBasedOnParent: boolean =\n          !!options?.useTopLevelOptionsForDisplay &&\n          optionsAreChildrenOfSelectedGroup;\n        const markDisabled: boolean =\n          isDisabledOrUnselected && !forceEnabledBasedOnParent;\n\n        if (option.children?.length) {\n          const childOptions = disableUnselectedItems(\n            option.children,\n            isCurrentOrParentOptionSelected,\n          );\n          updatedItems.push({\n            ...option,\n            disabled: !!markDisabled,\n            children: childOptions,\n          });\n        } else {\n          updatedItems.push({\n            ...option,\n            disabled: !!markDisabled,\n          });\n        }\n      }\n      return updatedItems;\n    }\n\n    const groupsAfterLimit: FullOptionGroup<O>[] = [];\n    for (const currentGroup of optionGroups) {\n      groupsAfterLimit.push({\n        ...currentGroup,\n        options: disableUnselectedItems(currentGroup.options, false),\n      });\n    }\n\n    return groupsAfterLimit;\n  }\n\n  function getRelationshipMaps<O extends BaseOption>(\n    options: Option<O>[],\n  ): [Map<O['id'], O['id']>, Map<O['id'], O['id'][]>] {\n    const parents = new Map();\n    function buildParentsMap(options: Option<O>[], parent?: Option<O>): void {\n      for (const option of options) {\n        if (parent) {\n          parents.set(option.id, parent.id);\n        }\n        if (option.children?.length) {\n          buildParentsMap(option.children, option);\n        }\n      }\n    }\n    buildParentsMap(options);\n\n    const children = new Map();\n    function buildChildrenMap(options: Option<O>[]): void {\n      for (const option of options) {\n        if (option.children?.length) {\n          children.set(\n            option.id,\n            option.children.map(({ id }) => id),\n          );\n          buildChildrenMap(option.children);\n        }\n      }\n    }\n    buildChildrenMap(options);\n\n    return [parents, children];\n  }\n\n  function getTopLevelOptions<O extends BaseOption>(\n    optionGroups: FullOptionGroup<O>[],\n  ): FullOption<O>[];\n  function getTopLevelOptions<O extends BaseOption>(\n    optionGroups: SourceOptionGroup<O>[],\n  ): SourceOption<O>[];\n  function getTopLevelOptions<O extends BaseOption>(\n    optionGroups: OptionGroup<O>[],\n  ): Option<O>[];\n  function getTopLevelOptions<\n    O extends BaseOption,\n    G extends { options: readonly T[] },\n    T = G extends FullOptionGroup<O>\n      ? FullOption<O>\n      : G extends SourceOptionGroup<O>\n      ? SourceOption<O>\n      : Option<O>,\n  >(optionGroups: G[]): T[] {\n    return optionGroups.reduce<T[]>(\n      (options, group) => [...options, ...group.options],\n      [],\n    );\n  }\n\n  function getParentMultiSelectionState<O extends BaseOption>(\n    children: FullOption<O>[],\n  ): MultiSelectionState {\n    if (children.every(child => child.selected === true)) return true;\n    if (children.every(child => child.selected === false)) return false;\n    return 'indeterminate';\n  }\n\n  function augmentOptionToFullOption<O extends BaseOption>(\n    state: CoreState<O>,\n    option: SourceOption<O>,\n  ): FullOption<O> {\n    if (option.children?.length) {\n      const augmentedChildren = option.children.map(child =>\n        augmentOptionToFullOption(state, child),\n      );\n      return {\n        ...option,\n        children: augmentedChildren,\n        selected: getParentMultiSelectionState(augmentedChildren),\n        expanded: state.query.search\n          ? true\n          : state.display.expandedOptions.has(option.id),\n        selectable: !state.query.search,\n        expandable: !state.query.search,\n      };\n    }\n    return {\n      ...option,\n      children: undefined,\n      selected: state.selection.selected.has(option),\n      expanded: false,\n      selectable: true,\n      expandable: false,\n    };\n  }\n\n  function getFormattedOptionsForDisplay<O extends BaseOption>(\n    state: CoreState<O>,\n    topLevelOptions: FullOption<O>[],\n    options?: ManagerOptions<O>,\n  ): string {\n    // If we have a custom display function, use it\n    if (options?.getCustomOptionDisplay) {\n      return options.getCustomOptionDisplay([...state.selection.selected]);\n    }\n    if (options?.useTopLevelOptionsForDisplay) {\n      return getTopLevelFormattedOptionsForDisplay(topLevelOptions);\n    }\n    // Otherwise, use the default display for options - titles separated by commas.\n    return [...state.selection.selected].map(({ title }) => title).join(', ');\n  }\n\n  function getTopLevelFormattedOptionsForDisplay<O extends BaseOption>(\n    topLevelOptions: FullOption<O>[],\n  ): string {\n    if (!topLevelOptions || topLevelOptions.length == 0) {\n      return '';\n    }\n    const selectedOrIndeterminateTopOptions = topLevelOptions.filter(\n      option => option.selected != false,\n    );\n    return selectedOrIndeterminateTopOptions\n      .map(({ title }) => title)\n      .join(', ');\n  }\n\n  function getPillCountForDisplay<O extends BaseOption>(\n    state: CoreState<O>,\n    topLevelOptions: FullOption<O>[],\n    options?: ManagerOptions<O>,\n  ): number {\n    if (options?.useTopLevelOptionsForDisplay) {\n      const selectedOrIndeterminateTopOptions = topLevelOptions.filter(\n        option => option.selected != false,\n      );\n      return selectedOrIndeterminateTopOptions.length;\n    }\n    return state.selection.selected.size;\n  }\n\n  function getZeroStateMessage<O extends BaseOption>(\n    state: CoreState<O>,\n  ): string | null {\n    if (state.sourceOptionGroups.every(group => group.options.length === 0)) {\n      if (state.query.search) return 'No results found.';\n      return 'No options.';\n    }\n    return null;\n  }\n\n  function findOption<O extends BaseOption>(\n    options: SourceOption<O>[],\n    id: O['id'],\n  ): SourceOption<O> | null {\n    for (const option of options) {\n      if (option.id === id) return option;\n      if (option.children?.length) {\n        const child = findOption(option.children, id);\n        if (child) return child;\n      }\n    }\n    return null;\n  }\n\n  function flattenOptions<O extends BaseOption>(\n    options: Option<O>[],\n    leafOnly: boolean,\n  ): O[] {\n    return flattenDeep(\n      options.map(option => {\n        if (option.children?.length) {\n          const descendants = option.children.map(child =>\n            flattenOptions([child], leafOnly),\n          );\n          return leafOnly ? descendants : [option, ...descendants];\n        } else {\n          return [option];\n        }\n      }),\n    );\n  }\n\n  function toggleSelected<O extends BaseOption>(\n    state: CoreState<O>,\n    id: O['id'],\n  ): CoreState<O> {\n    const topLevelOptions = getTopLevelOptions(state.sourceOptionGroups);\n    const option = findOption(topLevelOptions, id);\n    if (!option) return state;\n\n    const newSelection = new OptionSet(state.selection.selected);\n\n    const newValue = !(\n      augmentOptionToFullOption(state, option).selected === true\n    );\n    const leaves = flattenOptions([option], true);\n    for (const leaf of leaves) {\n      if (newValue) {\n        newSelection.add(leaf);\n      } else {\n        newSelection.delete(leaf);\n      }\n    }\n\n    return {\n      ...state,\n      selection: {\n        selected: newSelection,\n      },\n    };\n  }\n\n  function setSelectedOption<O extends BaseOption>(\n    state: CoreState<O>,\n    id: O['id'],\n  ): CoreState<O> {\n    const topLevelOptions = getTopLevelOptions(state.sourceOptionGroups);\n    const option = findOption(topLevelOptions, id);\n    if (!option) return state;\n\n    const newSelection = new OptionSet<O>();\n    newSelection.add(option);\n\n    return {\n      ...state,\n      selection: {\n        selected: newSelection,\n      },\n    };\n  }\n\n  function toggleVisibleSelected<O extends BaseOption>(\n    state: CoreState<O>,\n  ): CoreState<O> {\n    const leaves = flattenOptions(\n      getTopLevelOptions(state.sourceOptionGroups),\n      true,\n    );\n    const isAllSelected = leaves.every(leaf =>\n      [...state.selection.selected].map(({ id }) => id).includes(leaf.id),\n    );\n    const newSelection = new OptionSet(state.selection.selected);\n\n    for (const leaf of leaves) {\n      if (isAllSelected) newSelection.delete(leaf);\n      else newSelection.add(leaf);\n    }\n\n    return {\n      ...state,\n      selection: {\n        ...state.selection,\n        selected: newSelection,\n      },\n    };\n  }\n\n  function toggleOptionExpanded<O extends BaseOption>(\n    state: CoreState<O>,\n    id: O['id'],\n  ): CoreState<O> {\n    const newValue = !state.display.expandedOptions.has(id);\n    const newExpandedOptions = new Set(state.display.expandedOptions);\n    if (newValue) newExpandedOptions.add(id);\n    else newExpandedOptions.delete(id);\n    return {\n      ...state,\n      display: {\n        ...state.display,\n        expandedOptions: newExpandedOptions,\n      },\n    };\n  }\n\n  function sideEffects<O extends BaseOption>(\n    state: CoreState<O>,\n    action: Action<O> | InternalAction<O>,\n    source: Source<O>,\n    internalActions: Subject<InternalAction<O>>,\n  ): CoreState<O> {\n    if (\n      action.type === 'load' ||\n      action.type === 'searchChange' ||\n      action.type === 'orderChange' ||\n      (action.type === 'openChange' && action.open)\n    ) {\n      source(state.query, action)\n        .then(data => {\n          internalActions.next({ type: 'loadComplete', data });\n        })\n        .catch(error => {\n          console.error(error);\n          internalActions.next({ type: 'loadError', error });\n        });\n      return {\n        ...state,\n        load: {\n          loading: true,\n          error: null,\n        },\n      };\n    }\n    return state;\n  }\n\n  function reduce<O extends BaseOption>(\n    state: CoreState<O>,\n    action: Action<O> | InternalAction<O>,\n  ): CoreState<O> {\n    switch (action.type) {\n      case 'load':\n        return state;\n      case 'loadComplete':\n        return {\n          ...state,\n          load: {\n            loading: false,\n            error: null,\n          },\n          sourceOptionGroups: action.data,\n        };\n      case 'loadError':\n        return {\n          ...state,\n          load: {\n            loading: false,\n            error: action.error,\n          },\n        };\n      case 'openChange':\n        return {\n          ...state,\n          query: {\n            ...state.query,\n            search: '',\n          },\n          display: {\n            ...state.display,\n            open: action.open,\n          },\n        };\n      case 'searchChange':\n        return {\n          ...state,\n          query: {\n            ...state.query,\n            search: action.payload,\n          },\n        };\n      case 'orderChange':\n        return {\n          ...state,\n          query: {\n            ...state.query,\n            order: action.payload,\n          },\n        };\n      case 'selectionChange':\n        return {\n          ...state,\n          selection: action.payload,\n        };\n      case 'toggleOptionSelected':\n        return toggleSelected(state, action.id);\n      case 'setSelectedOption':\n        return setSelectedOption(state, action.id);\n      case 'visibleSelectedChange':\n        return toggleVisibleSelected(state);\n      case 'toggleOptionExpanded':\n        return toggleOptionExpanded(state, action.id);\n    }\n  }\n}\n"]}
|
|
@@ -1960,14 +1960,26 @@ var RivSelect;
|
|
|
1960
1960
|
const defaultedInitialState = defaultsDeep({}, options === null || options === void 0 ? void 0 : options.initialState, defaultState);
|
|
1961
1961
|
const actions = new Subject();
|
|
1962
1962
|
const internalActions = new Subject();
|
|
1963
|
-
const
|
|
1964
|
-
|
|
1963
|
+
const coreStateWithSelectionSnapshot = merge(actions, internalActions).pipe(scan(([state, snapshot], action) => {
|
|
1964
|
+
const newState = sideEffects(reduce(state, action), action, source, internalActions);
|
|
1965
|
+
const newSelectionSnapshot = action.type === 'openChange' && action.open
|
|
1966
|
+
? createSelectionSnapshotWithAncestors(newState)
|
|
1967
|
+
: snapshot;
|
|
1968
|
+
return [newState, newSelectionSnapshot];
|
|
1969
|
+
}, [defaultedInitialState, new OptionSet()]), startWith([
|
|
1970
|
+
defaultedInitialState,
|
|
1971
|
+
new OptionSet(),
|
|
1972
|
+
]));
|
|
1973
|
+
const state = connectable(coreStateWithSelectionSnapshot.pipe(map(([s, selectionAtOpen]) => {
|
|
1965
1974
|
var _a, _b, _c, _d, _e;
|
|
1966
1975
|
const allOptionGroups = s.sourceOptionGroups.map(optionGroup => {
|
|
1967
1976
|
return Object.assign(Object.assign({}, optionGroup), { options: optionGroup.options.map(option => augmentOptionToFullOption(s, option)) });
|
|
1968
1977
|
});
|
|
1969
1978
|
const topLevelOptions = getTopLevelOptions(allOptionGroups);
|
|
1970
|
-
const
|
|
1979
|
+
const sortedOptionGroups = (options === null || options === void 0 ? void 0 : options.allowMultiSelect)
|
|
1980
|
+
? sortOptionsByPreviouslySelectedState(allOptionGroups, selectionAtOpen)
|
|
1981
|
+
: allOptionGroups;
|
|
1982
|
+
const displayLimitedOptionGroups = applyDisplayLimit(sortedOptionGroups, options === null || options === void 0 ? void 0 : options.displayLimit);
|
|
1971
1983
|
const fullOptionGroups = applySelectedOptionLimit(s, displayLimitedOptionGroups, topLevelOptions, options);
|
|
1972
1984
|
return Object.assign(Object.assign({}, s), { query: Object.assign(Object.assign({}, s.query), { showSearch: !!(options === null || options === void 0 ? void 0 : options.allowSearch) &&
|
|
1973
1985
|
(!!s.query.search ||
|
|
@@ -2183,6 +2195,25 @@ var RivSelect;
|
|
|
2183
2195
|
//////////////////////////////////
|
|
2184
2196
|
// State reducer (with helpers) //
|
|
2185
2197
|
//////////////////////////////////
|
|
2198
|
+
function createSelectionSnapshotWithAncestors(state) {
|
|
2199
|
+
const snapshot = new OptionSet(state.selection.selected);
|
|
2200
|
+
const topLevelOptions = getTopLevelOptions(state.sourceOptionGroups);
|
|
2201
|
+
const [parents] = getRelationshipMaps(topLevelOptions);
|
|
2202
|
+
// For each selected option, add all its ancestors to the snapshot
|
|
2203
|
+
for (const selectedOption of state.selection.selected) {
|
|
2204
|
+
let currentId = selectedOption.id;
|
|
2205
|
+
let parentId = parents.get(currentId);
|
|
2206
|
+
while (parentId !== undefined) {
|
|
2207
|
+
const parentOption = findOption(topLevelOptions, parentId);
|
|
2208
|
+
if (parentOption) {
|
|
2209
|
+
snapshot.add(parentOption);
|
|
2210
|
+
}
|
|
2211
|
+
currentId = parentId;
|
|
2212
|
+
parentId = parents.get(currentId);
|
|
2213
|
+
}
|
|
2214
|
+
}
|
|
2215
|
+
return snapshot;
|
|
2216
|
+
}
|
|
2186
2217
|
function getDisplayLimitMessage(displayedOptionCount, totalOptionCount, query) {
|
|
2187
2218
|
if (displayedOptionCount === totalOptionCount)
|
|
2188
2219
|
return null;
|
|
@@ -2250,6 +2281,22 @@ var RivSelect;
|
|
|
2250
2281
|
}, startingValue);
|
|
2251
2282
|
return resolvedGroups;
|
|
2252
2283
|
}
|
|
2284
|
+
/*
|
|
2285
|
+
Sort options so that previously selected options (from prior sessions)
|
|
2286
|
+
appear at the top of their peer/sibling lists.
|
|
2287
|
+
*/
|
|
2288
|
+
function sortOptionsByPreviouslySelectedState(optionGroups, selectionAtOpen) {
|
|
2289
|
+
function sortOptions(options) {
|
|
2290
|
+
return sortBy(options, option => !selectionAtOpen.has(option)).map(option => {
|
|
2291
|
+
if (option.children) {
|
|
2292
|
+
return Object.assign(Object.assign({}, option), { children: sortOptions(option.children) });
|
|
2293
|
+
}
|
|
2294
|
+
else
|
|
2295
|
+
return option;
|
|
2296
|
+
});
|
|
2297
|
+
}
|
|
2298
|
+
return optionGroups.map(group => (Object.assign(Object.assign({}, group), { options: sortOptions(group.options) })));
|
|
2299
|
+
}
|
|
2253
2300
|
/*
|
|
2254
2301
|
If we are restricting how many options are selected to a specific limit,
|
|
2255
2302
|
when we are at that limit, disable all options not currently selected.
|