@rivet-health/design-system 32.1.0 → 32.2.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.
|
@@ -164,4 +164,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
164
164
|
(function (SelectComponent) {
|
|
165
165
|
SelectComponent.Sizes = ['small', 'medium', 'large'];
|
|
166
166
|
})(SelectComponent || (SelectComponent = {}));
|
|
167
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../../projects/riv/src/lib/input/select/select/select.component.ts","../../../../../../../projects/riv/src/lib/input/select/select/select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  ElementRef,\n  Input,\n  OnDestroy,\n  OnInit,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport { debounce } from 'lodash';\nimport { distinctUntilChanged, map, skip, Subscription } from 'rxjs';\nimport { CalloutComponent } from '../../../overlay/callout/callout.component';\nimport { InputLabelComponent } from '../../input-label/input-label.component';\nimport { RivSelect } from '../state';\n\n@Component({\n  selector: 'riv-select',\n  templateUrl: './select.component.html',\n  styleUrls: ['./select.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SelectComponent<O extends RivSelect.BaseOption>\n  extends InputLabelComponent\n  implements OnInit, OnDestroy\n{\n  @Input()\n  manager?: RivSelect.Manager<O>;\n\n  @Input()\n  size: SelectComponent.Size = 'medium';\n\n  @Input()\n  disabled: boolean = false;\n\n  @Input()\n  locked: boolean = false;\n\n  @Input()\n  allowedCalloutPositions: CalloutComponent.AnchoredPosition[] = [\n    'top-left',\n    'top-center',\n    'top-right',\n    'bottom-right',\n    'bottom-center',\n    'bottom-left',\n  ];\n\n  @Input()\n  preferredCalloutPosition: CalloutComponent.AnchoredPosition = 'bottom-right';\n\n  @ContentChild('trigger')\n  triggerTemplate?: TemplateRef<{ state: RivSelect.FullState<O> }>;\n\n  @ContentChild('customSelectedOptions')\n  customSelectedOptionsTemplate?: TemplateRef<{\n    selected: RivSelect.OptionSet<O>;\n  }>;\n\n  @ContentChild('option')\n  optionTemplate?: TemplateRef<{ node: RivSelect.FullOption<O> }>;\n\n  @ContentChild('header')\n  headerTemplate?: TemplateRef<{ state: RivSelect.FullState<O> }>;\n\n  @ContentChild('footer')\n  footerTemplate?: TemplateRef<{ state: RivSelect.FullState<O> }>;\n\n  @ViewChild('customTriggerButton')\n  customTriggerButton?: ElementRef;\n\n  @ViewChild('standardTriggerButton')\n  standardTriggerButton?: ElementRef;\n\n  orderByManager?: RivSelect.Manager<SelectComponent.OrderByOption>;\n  private orderBySubscription?: Subscription;\n\n  ngOnInit(): void {\n    this.orderByManager = RivSelect.createInMemoryManager(\n      () => this.orderByOptionGroups,\n      {\n        showSingleSelected: true,\n        initialState: {\n          selection: {\n            selected: new RivSelect.OptionSet([\n              this.orderByOptionGroups[0].options.find(\n                ({ id }) => id === 'title',\n              )!,\n            ]),\n          },\n        },\n      },\n    );\n\n    this.orderBySubscription = this.orderByManager.state\n      .pipe(\n        map(s => [...s.selection.selected][0]?.id ?? null),\n        distinctUntilChanged((prev, current) => prev === current),\n        skip(1),\n      )\n      .subscribe(order => {\n        this.manager?.actions.next({\n          type: 'orderChange',\n          payload: order,\n        });\n      });\n  }\n\n  ngOnDestroy(): void {\n    this.orderBySubscription?.unsubscribe();\n  }\n\n  getTrigger(): Element | null {\n    return (\n      this.customTriggerButton?.nativeElement ??\n      this.standardTriggerButton?.nativeElement\n    );\n  }\n\n  allowedOpen(): void {\n    if (!this.disabled && !this.locked) {\n      this.manager?.actions.next({\n        type: 'openChange',\n        open: true,\n      });\n    }\n  }\n\n  selectChange(multi: boolean, id: O['id']) {\n    if (multi) {\n      this.manager?.actions.next({\n        type: 'toggleOptionSelected',\n        id,\n      });\n    } else {\n      this.manager?.actions.next({\n        type: 'setSelectedOption',\n        id,\n      });\n      this.manager?.actions.next({\n        type: 'openChange',\n        open: false,\n      });\n    }\n  }\n\n  readonly orderByOptionGroups: RivSelect.OptionGroup<SelectComponent.OrderByOption>[] =\n    [\n      {\n        options: [\n          {\n            id: 'title',\n            title: 'A-Z',\n            help: 'Sorts values in alphanumeric order (A-Z, 0-9)',\n          },\n          {\n            id: 'count',\n            title: 'Volume',\n            help: 'Sorts values by count (highest to lowest)',\n          },\n        ],\n      },\n    ];\n\n  getSelectedOrderByOption(\n    state: RivSelect.FullState<O>,\n  ): SelectComponent.OrderByOption | null {\n    return (\n      this.orderByOptionGroups[0].options.find(\n        ({ id }) => id === state.query.order,\n      ) ?? null\n    );\n  }\n\n  searchChange = debounce((query: string) => {\n    this.manager?.actions?.next({ type: 'searchChange', payload: query });\n  }, 500);\n\n  // trackBySymbol for our option groups that don't have a good identity.\n  // this lazily attaches a Javascript symbol to any value and returns it.\n  // Symbols are guaranteed unique and they do not exist in JSON, so they\n  // do not interfere with any types or serialization for API calls. The\n  // only purpose they serve is to tell ngFor which objects are still in\n  // the array. Note: this is only safe on an array of objects.\n  trackBySymbol(_: number, value: any) {\n    if (!value._trackingSymbol) {\n      value._trackingSymbol = Symbol();\n    }\n    return value._trackingSymbol;\n  }\n\n  trackByOption(_: number, option: RivSelect.FullOption<O>): string | number {\n    return option.id;\n  }\n}\n\nexport namespace SelectComponent {\n  export type OrderByOption = {\n    id: RivSelect.OrderBy;\n    title: string;\n    help: string;\n  };\n\n  export const Sizes = ['small', 'medium', 'large'] as const;\n  export type Size = (typeof Sizes)[number];\n}\n","<ng-container *ngIf=\"manager?.state | async; let s\">\n  <ng-template #content>\n    <riv-loading-cover [loading]=\"s.load.loading\">\n      <div\n        class=\"content-body\"\n        [class.inline]=\"s.display.inline\"\n        [ngStyle]=\"{\n          'max-height': s.display.maxHeight,\n          'max-width': s.display.maxWidth,\n          'min-height': s.display.minHeight,\n          'min-width': s.display.minWidth\n        }\"\n      >\n        <header *ngIf=\"headerTemplate\">\n          <ng-container\n            *ngTemplateOutlet=\"headerTemplate; context: { state: s }\"\n          ></ng-container>\n        </header>\n        <riv-search\n          *ngIf=\"s.query.showSearch\"\n          [value]=\"s.query.search\"\n          [placeholder]=\"s.query.searchPlaceholder\"\n          [autoFocus]=\"true\"\n          (valueChange)=\"searchChange($event)\"\n        ></riv-search>\n        <div *ngIf=\"s.query.showOrder\">\n          <span class=\"order-by\">Sort by:</span>\n          <riv-select [manager]=\"orderByManager\">\n            <ng-template #trigger let-state=\"state\">\n              <button\n                rivButton\n                [variant]=\"'ghost'\"\n                [size]=\"'small'\"\n                [icon]=\"state.display.open ? 'ChevronUp' : 'ChevronDown'\"\n                [iconPosition]=\"'last'\"\n              >\n                {{ getSelectedOrderByOption(s)?.title }}\n              </button>\n            </ng-template>\n          </riv-select>\n        </div>\n        <div class=\"options\">\n          <riv-select-node\n            *ngIf=\"\n              s.selection.allowMultiSelect &&\n              s.selection.allowSelectAll &&\n              !s.display.zeroStateMessage\n            \"\n            [mode]=\"'multi'\"\n            [node]=\"{\n              id: '__NOOP__',\n              title: s.query.search ? 'Select all matching' : 'Select all',\n              selected: s.selection.visibleSelectionState,\n              selectable: true,\n              expandable: false,\n              expanded: false\n            }\"\n            (selectChange)=\"\n              manager?.actions?.next({ type: 'visibleSelectedChange' })\n            \"\n          ></riv-select-node>\n          <div\n            *ngFor=\"let group of s.fullOptionGroups; trackBy: trackBySymbol\"\n            class=\"group\"\n            [class.divider]=\"s.display.dividers\"\n          >\n            <span *ngIf=\"group.header; let header\" class=\"header\">\n              {{ header }}\n            </span>\n            <ng-container\n              *ngFor=\"let option of group.options; trackBy: trackByOption\"\n            >\n              <ng-container *ngIf=\"optionTemplate; else standardTemplate\">\n                <ng-container\n                  [ngTemplateOutlet]=\"optionTemplate\"\n                  [ngTemplateOutletContext]=\"{ node: option }\"\n                ></ng-container>\n              </ng-container>\n              <ng-template #standardTemplate>\n                <riv-select-node\n                  [mode]=\"s.selection.allowMultiSelect ? 'multi' : 'single'\"\n                  [node]=\"option\"\n                  [showSingleSelected]=\"s.display.showSingleSelected\"\n                  (selectChange)=\"\n                    selectChange(s.selection.allowMultiSelect, $event)\n                  \"\n                  (expandChange)=\"\n                    manager?.actions?.next({\n                      type: 'toggleOptionExpanded',\n                      id: $event\n                    })\n                  \"\n                ></riv-select-node>\n              </ng-template>\n            </ng-container>\n          </div>\n          <span\n            *ngIf=\"s.display.displayLimitMessage; let message\"\n            class=\"display-limit\"\n          >\n            {{ message }}\n          </span>\n          <riv-zero-state\n            *ngIf=\"s.display.zeroStateMessage; let message\"\n            [message]=\"message\"\n          ></riv-zero-state>\n        </div>\n        <footer *ngIf=\"footerTemplate\" class=\"custom-footer\">\n          <ng-container\n            *ngTemplateOutlet=\"footerTemplate; context: { state: s }\"\n          ></ng-container>\n        </footer>\n      </div>\n    </riv-loading-cover>\n  </ng-template>\n\n  <ng-container *ngIf=\"!s.display.inline; else content\">\n    <ng-container *ngIf=\"triggerTemplate; else standardTrigger\">\n      <button\n        #customTriggerButton\n        (click)=\"allowedOpen()\"\n        [disabled]=\"disabled || locked\"\n        type=\"button\"\n        class=\"custom-trigger-button\"\n      >\n        <ng-container\n          [ngTemplateOutlet]=\"triggerTemplate\"\n          [ngTemplateOutletContext]=\"{ state: s }\"\n        ></ng-container>\n      </button>\n    </ng-container>\n    <ng-template #standardTrigger>\n      <riv-input-label\n        [label]=\"label\"\n        [help]=\"help\"\n        [required]=\"required\"\n        [state]=\"state\"\n        [errorMessage]=\"errorMessage\"\n        [labelActionText]=\"labelActionText\"\n        (labelAction)=\"labelAction.emit($event)\"\n      >\n        <button\n          #standardTriggerButton\n          class=\"trigger\"\n          [class.small]=\"size === 'small'\"\n          [class.large]=\"size === 'large'\"\n          [class.warning]=\"state === 'warning'\"\n          [class.error]=\"state === 'error'\"\n          (click)=\"allowedOpen()\"\n          [disabled]=\"disabled || locked\"\n          type=\"button\"\n        >\n          <ng-container\n            *ngIf=\"s.selection.selected.size; else placeholderValue\"\n          >\n            <ng-container\n              *ngIf=\"\n                customSelectedOptionsTemplate;\n                else standardSelectedOptionsTemplate\n              \"\n            >\n              <span class=\"value\">\n                <ng-container\n                  [ngTemplateOutlet]=\"customSelectedOptionsTemplate\"\n                  [ngTemplateOutletContext]=\"{ selected: s.selection.selected }\"\n                ></ng-container>\n              </span>\n            </ng-container>\n            <ng-template #standardSelectedOptionsTemplate>\n              <span class=\"value\">{{\n                s.display.formattedSelectedOptions\n              }}</span>\n              <span *ngIf=\"s.display.pillCount > 1\" class=\"selected-count\">\n                {{ s.display.pillCount | rivNumber }}\n              </span>\n            </ng-template>\n          </ng-container>\n          <ng-template #placeholderValue>\n            <span class=\"value placeholder\">{{ s.display.placeholder }}</span>\n          </ng-template>\n          <span class=\"chevron\">\n            <riv-icon\n              *ngIf=\"!locked\"\n              [name]=\"s.display.open ? 'ChevronUp' : 'ChevronDown'\"\n              [size]=\"20\"\n            ></riv-icon>\n            <riv-icon *ngIf=\"locked\" [name]=\"'Lock'\" [size]=\"20\"></riv-icon>\n          </span>\n        </button>\n      </riv-input-label>\n    </ng-template>\n\n    <ng-container *ngIf=\"s.display.open\">\n      <riv-callout\n        *riv-overlay\n        [anchor]=\"getTrigger()\"\n        [theme]=\"'light'\"\n        [showCaret]=\"false\"\n        [allowedPositions]=\"allowedCalloutPositions\"\n        [preferredPosition]=\"preferredCalloutPosition\"\n        (close)=\"manager?.actions?.next({ type: 'openChange', open: false })\"\n      >\n        <ng-container [ngTemplateOutlet]=\"content\"></ng-container>\n      </riv-callout>\n    </ng-container>\n  </ng-container>\n</ng-container>\n"]}
|
|
167
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../../projects/riv/src/lib/input/select/select/select.component.ts","../../../../../../../projects/riv/src/lib/input/select/select/select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  ElementRef,\n  Input,\n  OnDestroy,\n  OnInit,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport { debounce } from 'lodash';\nimport { distinctUntilChanged, map, skip, Subscription } from 'rxjs';\nimport { InputLabelComponent } from '../../input-label/input-label.component';\nimport { RivSelect } from '../state';\nimport { CalloutComponent } from '../../../overlay/callout/callout.component';\n\n@Component({\n  selector: 'riv-select',\n  templateUrl: './select.component.html',\n  styleUrls: ['./select.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SelectComponent<O extends RivSelect.BaseOption>\n  extends InputLabelComponent\n  implements OnInit, OnDestroy\n{\n  @Input()\n  manager?: RivSelect.Manager<O>;\n\n  @Input()\n  size: SelectComponent.Size = 'medium';\n\n  @Input()\n  disabled: boolean = false;\n\n  @Input()\n  locked: boolean = false;\n\n  @Input()\n  allowedCalloutPositions: CalloutComponent.AnchoredPosition[] = [\n    'top-left',\n    'top-center',\n    'top-right',\n    'bottom-right',\n    'bottom-center',\n    'bottom-left',\n  ];\n\n  @Input()\n  preferredCalloutPosition: CalloutComponent.AnchoredPosition = 'bottom-right';\n\n  @ContentChild('trigger')\n  triggerTemplate?: TemplateRef<{ state: RivSelect.FullState<O> }>;\n\n  @ContentChild('customSelectedOptions')\n  customSelectedOptionsTemplate?: TemplateRef<{\n    selected: RivSelect.OptionSet<O>;\n  }>;\n\n  @ContentChild('option')\n  optionTemplate?: TemplateRef<{ node: RivSelect.FullOption<O> }>;\n\n  @ContentChild('header')\n  headerTemplate?: TemplateRef<{ state: RivSelect.FullState<O> }>;\n\n  @ContentChild('footer')\n  footerTemplate?: TemplateRef<{ state: RivSelect.FullState<O> }>;\n\n  @ViewChild('customTriggerButton')\n  customTriggerButton?: ElementRef;\n\n  @ViewChild('standardTriggerButton')\n  standardTriggerButton?: ElementRef;\n\n  orderByManager?: RivSelect.Manager<SelectComponent.OrderByOption>;\n  private orderBySubscription?: Subscription;\n\n  ngOnInit(): void {\n    this.orderByManager = RivSelect.createInMemoryManager(\n      () => this.orderByOptionGroups,\n      {\n        showSingleSelected: true,\n        initialState: {\n          selection: {\n            selected: new RivSelect.OptionSet([\n              this.orderByOptionGroups[0].options.find(\n                ({ id }) => id === 'title',\n              )!,\n            ]),\n          },\n        },\n      },\n    );\n\n    this.orderBySubscription = this.orderByManager.state\n      .pipe(\n        map(s => [...s.selection.selected][0]?.id ?? null),\n        distinctUntilChanged((prev, current) => prev === current),\n        skip(1),\n      )\n      .subscribe(order => {\n        this.manager?.actions.next({\n          type: 'orderChange',\n          payload: order,\n        });\n      });\n  }\n\n  ngOnDestroy(): void {\n    this.orderBySubscription?.unsubscribe();\n  }\n\n  getTrigger(): Element | null {\n    return (\n      this.customTriggerButton?.nativeElement ??\n      this.standardTriggerButton?.nativeElement\n    );\n  }\n\n  allowedOpen(): void {\n    if (!this.disabled && !this.locked) {\n      this.manager?.actions.next({\n        type: 'openChange',\n        open: true,\n      });\n    }\n  }\n\n  selectChange(multi: boolean, id: O['id']) {\n    if (multi) {\n      this.manager?.actions.next({\n        type: 'toggleOptionSelected',\n        id,\n      });\n    } else {\n      this.manager?.actions.next({\n        type: 'setSelectedOption',\n        id,\n      });\n      this.manager?.actions.next({\n        type: 'openChange',\n        open: false,\n      });\n    }\n  }\n\n  readonly orderByOptionGroups: RivSelect.OptionGroup<SelectComponent.OrderByOption>[] =\n    [\n      {\n        options: [\n          {\n            id: 'title',\n            title: 'A-Z',\n            help: 'Sorts values in alphanumeric order (A-Z, 0-9)',\n          },\n          {\n            id: 'count',\n            title: 'Volume',\n            help: 'Sorts values by count (highest to lowest)',\n          },\n        ],\n      },\n    ];\n\n  getSelectedOrderByOption(\n    state: RivSelect.FullState<O>,\n  ): SelectComponent.OrderByOption | null {\n    return (\n      this.orderByOptionGroups[0].options.find(\n        ({ id }) => id === state.query.order,\n      ) ?? null\n    );\n  }\n\n  searchChange = debounce((query: string) => {\n    this.manager?.actions?.next({ type: 'searchChange', payload: query });\n  }, 500);\n\n  // trackBySymbol for our option groups that don't have a good identity.\n  // this lazily attaches a Javascript symbol to any value and returns it.\n  // Symbols are guaranteed unique and they do not exist in JSON, so they\n  // do not interfere with any types or serialization for API calls. The\n  // only purpose they serve is to tell ngFor which objects are still in\n  // the array. Note: this is only safe on an array of objects.\n  trackBySymbol(_: number, value: any) {\n    if (!value._trackingSymbol) {\n      value._trackingSymbol = Symbol();\n    }\n    return value._trackingSymbol;\n  }\n\n  trackByOption(_: number, option: RivSelect.FullOption<O>): string | number {\n    return option.id;\n  }\n}\n\nexport namespace SelectComponent {\n  export type OrderByOption = {\n    id: RivSelect.OrderBy;\n    title: string;\n    help: string;\n  };\n\n  export const Sizes = ['small', 'medium', 'large'] as const;\n  export type Size = (typeof Sizes)[number];\n}\n","<ng-container *ngIf=\"manager?.state | async; let s\">\n  <ng-template #content>\n    <riv-loading-cover [loading]=\"s.load.loading\">\n      <div\n        class=\"content-body\"\n        [class.inline]=\"s.display.inline\"\n        [ngStyle]=\"{\n          'max-height': s.display.maxHeight,\n          'max-width': s.display.maxWidth,\n          'min-height': s.display.minHeight,\n          'min-width': s.display.minWidth\n        }\"\n      >\n        <header *ngIf=\"headerTemplate\">\n          <ng-container\n            *ngTemplateOutlet=\"headerTemplate; context: { state: s }\"\n          ></ng-container>\n        </header>\n        <riv-search\n          *ngIf=\"s.query.showSearch\"\n          [value]=\"s.query.search\"\n          [placeholder]=\"s.query.searchPlaceholder\"\n          [autoFocus]=\"true\"\n          (valueChange)=\"searchChange($event)\"\n        ></riv-search>\n        <div *ngIf=\"s.query.showOrder\">\n          <span class=\"order-by\">Sort by:</span>\n          <riv-select [manager]=\"orderByManager\">\n            <ng-template #trigger let-state=\"state\">\n              <button\n                rivButton\n                [variant]=\"'ghost'\"\n                [size]=\"'small'\"\n                [icon]=\"state.display.open ? 'ChevronUp' : 'ChevronDown'\"\n                [iconPosition]=\"'last'\"\n              >\n                {{ getSelectedOrderByOption(s)?.title }}\n              </button>\n            </ng-template>\n          </riv-select>\n        </div>\n        <div class=\"options\">\n          <riv-select-node\n            *ngIf=\"\n              s.selection.allowMultiSelect &&\n              s.selection.allowSelectAll &&\n              !s.display.zeroStateMessage\n            \"\n            [mode]=\"'multi'\"\n            [node]=\"{\n              id: '__NOOP__',\n              title: s.query.search ? 'Select all matching' : 'Select all',\n              selected: s.selection.visibleSelectionState,\n              selectable: true,\n              expandable: false,\n              expanded: false\n            }\"\n            (selectChange)=\"\n              manager?.actions?.next({ type: 'visibleSelectedChange' })\n            \"\n          ></riv-select-node>\n          <div\n            *ngFor=\"let group of s.fullOptionGroups; trackBy: trackBySymbol\"\n            class=\"group\"\n            [class.divider]=\"s.display.dividers\"\n          >\n            <span *ngIf=\"group.header; let header\" class=\"header\">\n              {{ header }}\n            </span>\n            <ng-container\n              *ngFor=\"let option of group.options; trackBy: trackByOption\"\n            >\n              <ng-container *ngIf=\"optionTemplate; else standardTemplate\">\n                <ng-container\n                  [ngTemplateOutlet]=\"optionTemplate\"\n                  [ngTemplateOutletContext]=\"{ node: option }\"\n                ></ng-container>\n              </ng-container>\n              <ng-template #standardTemplate>\n                <riv-select-node\n                  [mode]=\"s.selection.allowMultiSelect ? 'multi' : 'single'\"\n                  [node]=\"option\"\n                  [showSingleSelected]=\"s.display.showSingleSelected\"\n                  (selectChange)=\"\n                    selectChange(s.selection.allowMultiSelect, $event)\n                  \"\n                  (expandChange)=\"\n                    manager?.actions?.next({\n                      type: 'toggleOptionExpanded',\n                      id: $event\n                    })\n                  \"\n                ></riv-select-node>\n              </ng-template>\n            </ng-container>\n          </div>\n          <span\n            *ngIf=\"s.display.displayLimitMessage; let message\"\n            class=\"display-limit\"\n          >\n            {{ message }}\n          </span>\n          <riv-zero-state\n            *ngIf=\"s.display.zeroStateMessage; let message\"\n            [message]=\"message\"\n          ></riv-zero-state>\n        </div>\n        <footer *ngIf=\"footerTemplate\" class=\"custom-footer\">\n          <ng-container\n            *ngTemplateOutlet=\"footerTemplate; context: { state: s }\"\n          ></ng-container>\n        </footer>\n      </div>\n    </riv-loading-cover>\n  </ng-template>\n\n  <ng-container *ngIf=\"!s.display.inline; else content\">\n    <ng-container *ngIf=\"triggerTemplate; else standardTrigger\">\n      <button\n        #customTriggerButton\n        (click)=\"allowedOpen()\"\n        [disabled]=\"disabled || locked\"\n        type=\"button\"\n        class=\"custom-trigger-button\"\n      >\n        <ng-container\n          [ngTemplateOutlet]=\"triggerTemplate\"\n          [ngTemplateOutletContext]=\"{ state: s }\"\n        ></ng-container>\n      </button>\n    </ng-container>\n    <ng-template #standardTrigger>\n      <riv-input-label\n        [label]=\"label\"\n        [help]=\"help\"\n        [required]=\"required\"\n        [state]=\"state\"\n        [errorMessage]=\"errorMessage\"\n        [labelActionText]=\"labelActionText\"\n        (labelAction)=\"labelAction.emit($event)\"\n      >\n        <button\n          #standardTriggerButton\n          class=\"trigger\"\n          [class.small]=\"size === 'small'\"\n          [class.large]=\"size === 'large'\"\n          [class.warning]=\"state === 'warning'\"\n          [class.error]=\"state === 'error'\"\n          (click)=\"allowedOpen()\"\n          [disabled]=\"disabled || locked\"\n          type=\"button\"\n        >\n          <ng-container\n            *ngIf=\"s.selection.selected.size; else placeholderValue\"\n          >\n            <ng-container\n              *ngIf=\"\n                customSelectedOptionsTemplate;\n                else standardSelectedOptionsTemplate\n              \"\n            >\n              <span class=\"value\">\n                <ng-container\n                  [ngTemplateOutlet]=\"customSelectedOptionsTemplate\"\n                  [ngTemplateOutletContext]=\"{ selected: s.selection.selected }\"\n                ></ng-container>\n              </span>\n            </ng-container>\n            <ng-template #standardSelectedOptionsTemplate>\n              <span class=\"value\">{{\n                s.display.formattedSelectedOptions\n              }}</span>\n              <span *ngIf=\"s.display.pillCount > 1\" class=\"selected-count\">\n                {{ s.display.pillCount | rivNumber }}\n              </span>\n            </ng-template>\n          </ng-container>\n          <ng-template #placeholderValue>\n            <span class=\"value placeholder\">{{ s.display.placeholder }}</span>\n          </ng-template>\n          <span class=\"chevron\">\n            <riv-icon\n              *ngIf=\"!locked\"\n              [name]=\"s.display.open ? 'ChevronUp' : 'ChevronDown'\"\n              [size]=\"20\"\n            ></riv-icon>\n            <riv-icon *ngIf=\"locked\" [name]=\"'Lock'\" [size]=\"20\"></riv-icon>\n          </span>\n        </button>\n      </riv-input-label>\n    </ng-template>\n\n    <ng-container *ngIf=\"s.display.open\">\n      <riv-callout\n        *riv-overlay\n        [anchor]=\"getTrigger()\"\n        [theme]=\"'light'\"\n        [showCaret]=\"false\"\n        [allowedPositions]=\"allowedCalloutPositions\"\n        [preferredPosition]=\"preferredCalloutPosition\"\n        (close)=\"manager?.actions?.next({ type: 'openChange', open: false })\"\n      >\n        <ng-container [ngTemplateOutlet]=\"content\"></ng-container>\n      </riv-callout>\n    </ng-container>\n  </ng-container>\n</ng-container>\n"]}
|