@danske/sapphire-angular 1.19.1 → 1.19.3

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.
@@ -144,7 +144,7 @@ export class CheckboxComponent extends _CheckboxMixinBase {
144
144
  }
145
145
  _onInputClick($event) {
146
146
  $event.stopPropagation();
147
- if (!this.disabled && !this.readonly && !this.indeterminate) {
147
+ if (!this.disabled && !this.readonly) {
148
148
  this._selected = !this._selected;
149
149
  // Emit our custom change event if the native input emitted one.
150
150
  // It is important to only emit it, if the native input triggered one, because
@@ -261,4 +261,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImpor
261
261
  }], indeterminate: [{
262
262
  type: Input
263
263
  }] } });
264
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox.component.js","sourceRoot":"","sources":["../../../../../src/lib/checkbox/src/checkbox.component.ts","../../../../../src/lib/checkbox/src/checkbox.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Attribute,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  HostBinding,\n  Input,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport { FocusableOption } from '@angular/cdk/a11y';\nimport { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { HasTabIndex, mixinTabIndex } from '../../common/tabindex';\nimport { CanDisable, mixinDisabled } from '../../common/disabled';\nimport { ThemeCheckDirective } from '../../theme/src/theme-check.directive';\nimport { CoerceBoolean } from '../../common/coerce-boolean.decorator';\nimport { AutoId } from '../../common/auto-id.decorator';\n\n/** Change event object emitted by checkbox. */\nexport class CheckboxChange {\n  constructor(\n    /** The new `selected` value of the checkbox. */\n    public readonly selected: boolean,\n    /** The source checkbox of the event. */\n    public readonly source: CheckboxComponent\n  ) {}\n}\n\nconst _CheckboxMixinBase = mixinTabIndex(\n  mixinDisabled(\n    class {\n      constructor(public _elementRef: ElementRef) {}\n    }\n  )\n);\n\n@Component({\n  selector: 'sp-checkbox',\n  templateUrl: './checkbox.component.html',\n  styleUrls: ['./checkbox.component.scss'],\n  exportAs: 'spCheckbox',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => CheckboxComponent),\n      multi: true,\n    },\n  ],\n  host: {\n    '[attr.tabindex]': 'null',\n    '[attr.aria-label]': 'null',\n    '[attr.aria-labelledby]': 'null',\n  },\n  hostDirectives: [ThemeCheckDirective],\n})\nexport class CheckboxComponent\n  extends _CheckboxMixinBase\n  implements\n    AfterViewInit,\n    ControlValueAccessor,\n    CanDisable,\n    HasTabIndex,\n    FocusableOption\n{\n  /**\n   * Attached to the aria-label attribute of the host element. In most cases,\n   * aria-labelledby will take precedence so this may be omitted.\n   */\n  @Input('aria-label') ariaLabel: string = '';\n\n  /**\n   * Users can specify the `aria-labelledby` attribute which will be forwarded\n   * to the input element\n   */\n  @Input('aria-labelledby') ariaLabelledby: string | null = null;\n\n  /** The 'aria-describedby' attribute is read after the element's label and field type. */\n  @Input('aria-describedby') ariaDescribedby: string = '';\n\n  /** A unique id for the checkbox input. If none is supplied, it will be auto-generated. */\n\n  @HostBinding()\n  @Input()\n  @AutoId()\n  id = '';\n\n  /** Returns the unique id for the visual hidden input. */\n  get _inputId(): string {\n    return `${this.id}-input`;\n  }\n\n  /** Whether the checkbox is required. */\n  @Input()\n  @CoerceBoolean\n  required: BooleanInput = false;\n\n  /**\n   * Whether the checkbox is readonly.\n   */\n  @Input()\n  @CoerceBoolean\n  readonly: BooleanInput = false;\n\n  /** Name value will be applied to the input element if present */\n  @Input() name: string | null = null;\n\n  @Input() size?: 'large' | 'medium' = 'large';\n\n  /** Event emitted when the checkbox's `selected` value changes. */\n  @Output() readonly change: EventEmitter<CheckboxChange> =\n    new EventEmitter<CheckboxChange>();\n\n  /** The value attribute of the native input element */\n  @Input() value: string | undefined;\n\n  /** The native `<input type=\"checkbox\">` element */\n  @ViewChild('input') _inputElement!: ElementRef<HTMLInputElement>;\n\n  /**\n   * Called when the checkbox is blurred. Needed to properly implement\n   * ControlValueAccessor.\n   * @docs-private\n   */\n  private onTouched: () => any = () => {};\n  private controlValueAccessorChangeFn: (value: any) => void = () => {};\n\n  constructor(\n    elementRef: ElementRef<HTMLElement>,\n    private changeDetectorRef: ChangeDetectorRef,\n    @Attribute('tabindex') tabIndex: string\n  ) {\n    super(elementRef);\n    this.tabIndex = parseInt(tabIndex) || 0;\n  }\n  ngAfterViewInit() {\n    this.syncIndeterminate(this._indeterminate);\n  }\n\n  /** Whether the checkbox is selected. */\n  @Input()\n  get selected(): boolean {\n    return this._selected;\n  }\n  set selected(value: BooleanInput) {\n    const selected = coerceBooleanProperty(value);\n\n    if (selected != this.selected) {\n      this._selected = selected;\n      this.changeDetectorRef.markForCheck();\n    }\n  }\n  private _selected: boolean = false;\n\n  /**\n   * Whether the checkbox is disabled. This fully overrides the implementation\n   * provided by mixinDisabled, but the mixin is still required because\n   * mixinTabIndex requires it.\n   */\n  @Input()\n  override get disabled(): boolean {\n    return this._disabled;\n  }\n  override set disabled(value: BooleanInput) {\n    const newValue = coerceBooleanProperty(value);\n\n    if (newValue !== this.disabled) {\n      this._disabled = newValue;\n      this.changeDetectorRef.markForCheck();\n    }\n  }\n  private _disabled: boolean = false;\n\n  /**\n   * Whether the checkbox is indeterminate. This is also known as \"mixed\" mode\n   * and can be used to represent a checkbox with three states, e.g. a checkbox\n   * that represents a nested list of checkable items.\n   */\n  @Input()\n  get indeterminate(): boolean {\n    return this._indeterminate;\n  }\n  set indeterminate(value: BooleanInput) {\n    this._indeterminate = coerceBooleanProperty(value);\n    this.syncIndeterminate(this._indeterminate);\n  }\n  private _indeterminate: boolean = false;\n\n  // Implemented as part of ControlValueAccessor.\n  writeValue(value: any) {\n    this.selected = !!value;\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  registerOnChange(fn: (value: any) => void) {\n    this.controlValueAccessorChangeFn = fn;\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  registerOnTouched(fn: any) {\n    this.onTouched = fn;\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  setDisabledState(disabled: boolean) {\n    this.disabled = disabled;\n  }\n\n  /** Toggles the `selected` state of the checkbox. */\n  toggle(): void {\n    this.selected = !this.selected;\n    this.controlValueAccessorChangeFn(this.selected);\n  }\n\n  focus() {\n    this._inputElement.nativeElement.focus();\n  }\n\n  _getAriaChecked(): 'true' | 'false' | 'mixed' {\n    if (this.selected) {\n      return 'true';\n    }\n\n    return this.indeterminate ? 'mixed' : 'false';\n  }\n\n  _onInputClick($event: Event) {\n    $event.stopPropagation();\n    if (!this.disabled && !this.readonly && !this.indeterminate) {\n      this._selected = !this._selected;\n      // Emit our custom change event if the native input emitted one.\n      // It is important to only emit it, if the native input triggered one, because\n      // we don't want to trigger a change event, when the `checked` variable changes for example.\n      this.emitChangeEvent();\n    }\n  }\n\n  _onInteractionEvent(event: Event) {\n    // We always have to stop propagation on the change event.\n    // Otherwise, the change event, from the input element, will bubble up and\n    // emit its event object to the `change` output.\n    event.stopPropagation();\n  }\n\n  _onBlur() {\n    // When a focused element becomes disabled, the browser *immediately* fires a blur event.\n    // Angular does not expect events to be raised during change detection, so any state change\n    // (such as a form control's 'ng-touched') will cause a changed-after-checked error.\n    // See https://github.com/angular/angular/issues/17793. To work around this, we defer\n    // telling the form control it has been touched until the next tick.\n    Promise.resolve().then(() => {\n      this.onTouched();\n      this.changeDetectorRef.markForCheck();\n    });\n  }\n  private emitChangeEvent() {\n    this.controlValueAccessorChangeFn(this.selected);\n    this.change.emit(new CheckboxChange(this.selected, this));\n\n    // Assigning the value again here is redundant, but we have to do it in case it was\n    // changed inside the `change` listener which will cause the input to be out of sync.\n    if (this._inputElement) {\n      this._inputElement.nativeElement.checked = this.selected;\n    }\n  }\n\n  /**\n   * Syncs the indeterminate value with the checkbox DOM node.\n   *\n   * We sync `indeterminate` directly on the DOM node, because in Ivy the check\n   * for whether a property is supported on an element boils down to `if\n   * (propName in element)`. Domino's HTMLInputElement doesn't have an\n   * `indeterminate` property so Ivy will warn during server-side rendering.\n   */\n  private syncIndeterminate(value: boolean) {\n    const nativeCheckbox = this._inputElement;\n\n    if (nativeCheckbox) {\n      nativeCheckbox.nativeElement.indeterminate = value;\n    }\n  }\n}\n","<label\n  [for]=\"_inputId\"\n  class=\"sapphire-checkbox\"\n  [class.sapphire-checkbox--checked]=\"selected\"\n  [class.sapphire-checkbox--indeterminate]=\"indeterminate\"\n  [class.sapphire-checkbox--medium]=\"size === 'medium'\"\n>\n  <input\n    #input\n    type=\"checkbox\"\n    class=\"sapphire-checkbox__input\"\n    [attr.aria-checked]=\"_getAriaChecked()\"\n    [attr.aria-label]=\"ariaLabel || null\"\n    [attr.aria-labelledby]=\"ariaLabelledby\"\n    [attr.aria-describedby]=\"ariaDescribedby\"\n    [attr.name]=\"name\"\n    [attr.value]=\"value\"\n    [checked]=\"selected\"\n    [disabled]=\"disabled\"\n    [readonly]=\"readonly\"\n    [id]=\"_inputId\"\n    [required]=\"required\"\n    [tabIndex]=\"tabIndex\"\n    (blur)=\"_onBlur()\"\n    (click)=\"_onInputClick($event)\"\n    (change)=\"_onInteractionEvent($event)\"\n  />\n  <span class=\"sapphire-checkbox__box\">\n    <svg\n      *ngIf=\"indeterminate\"\n      class=\"sapphire-checkbox__box-icon\"\n      xmlns=\"http://www.w3.org/2000/svg\"\n      viewBox=\"0 0 24 24\"\n      aria-hidden=\"true\"\n    >\n      <g fill=\"none\" fill-rule=\"evenodd\">\n        <path\n          stroke=\"currentColor\"\n          stroke-width=\"2\"\n          stroke-linecap=\"square\"\n          d=\"M7 12h10\"\n        />\n        <path fill=\"currentColor\" fill-rule=\"nonzero\" d=\"M18 11v2H6v-2z\" />\n      </g>\n    </svg>\n    <svg\n      *ngIf=\"selected && !indeterminate\"\n      class=\"sapphire-checkbox__box-icon\"\n      xmlns=\"http://www.w3.org/2000/svg\"\n      viewBox=\"0 0 24 24\"\n      aria-hidden=\"true\"\n    >\n      <path\n        d=\"M17.782 6.918l.753.659a.5.5 0 01.047.705L10.9 17.061a.5.5 0 01-.73.024l-4.232-4.231a.5.5 0 010-.708l.707-.707a.5.5 0 01.708 0l3.097 3.097 6.626-7.57a.5.5 0 01.705-.048z\"\n        fill=\"currentColor\"\n        fill-rule=\"nonzero\"\n      />\n    </svg>\n  </span>\n  <span class=\"sapphire-checkbox__label\"><ng-content></ng-content></span>\n</label>\n"]}
264
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox.component.js","sourceRoot":"","sources":["../../../../../src/lib/checkbox/src/checkbox.component.ts","../../../../../src/lib/checkbox/src/checkbox.component.html"],"names":[],"mappings":";AAAA,OAAO,EAEL,SAAS,EACT,uBAAuB,EAEvB,SAAS,EAET,YAAY,EACZ,UAAU,EACV,WAAW,EACX,KAAK,EACL,MAAM,EACN,SAAS,GACV,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAgB,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AAC5E,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAEzE,OAAO,EAAe,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACnE,OAAO,EAAc,aAAa,EAAE,MAAM,uBAAuB,CAAC;AAClE,OAAO,EAAE,mBAAmB,EAAE,MAAM,uCAAuC,CAAC;AAC5E,OAAO,EAAE,aAAa,EAAE,MAAM,uCAAuC,CAAC;AACtE,OAAO,EAAE,MAAM,EAAE,MAAM,gCAAgC,CAAC;;;;AAExD,+CAA+C;AAC/C,MAAM,OAAO,cAAc;IACzB;IACE,gDAAgD;IAChC,QAAiB;IACjC,wCAAwC;IACxB,MAAyB;QAFzB,aAAQ,GAAR,QAAQ,CAAS;QAEjB,WAAM,GAAN,MAAM,CAAmB;IACxC,CAAC;CACL;AAED,MAAM,kBAAkB,GAAG,aAAa,CACtC,aAAa,CACX;IACE,YAAmB,WAAuB;QAAvB,gBAAW,GAAX,WAAW,CAAY;IAAG,CAAC;CAC/C,CACF,CACF,CAAC;AAsBF,MAAM,OAAO,iBACX,SAAQ,kBAAkB;IA8B1B,yDAAyD;IACzD,IAAI,QAAQ;QACV,OAAO,GAAG,IAAI,CAAC,EAAE,QAAQ,CAAC;IAC5B,CAAC;IAqCD,YACE,UAAmC,EAC3B,iBAAoC,EACrB,QAAgB;QAEvC,KAAK,CAAC,UAAU,CAAC,CAAC;QAHV,sBAAiB,GAAjB,iBAAiB,CAAmB;QAhE9C;;;WAGG;QACkB,cAAS,GAAW,EAAE,CAAC;QAE5C;;;WAGG;QACuB,mBAAc,GAAkB,IAAI,CAAC;QAE/D,yFAAyF;QAC9D,oBAAe,GAAW,EAAE,CAAC;QAExD,0FAA0F;QAK1F,OAAE,GAAG,EAAE,CAAC;QAOR,wCAAwC;QAGxC,aAAQ,GAAiB,KAAK,CAAC;QAE/B;;WAEG;QAGH,aAAQ,GAAiB,KAAK,CAAC;QAE/B,iEAAiE;QACxD,SAAI,GAAkB,IAAI,CAAC;QAE3B,SAAI,GAAwB,OAAO,CAAC;QAE7C,kEAAkE;QAC/C,WAAM,GACvB,IAAI,YAAY,EAAkB,CAAC;QAQrC;;;;WAIG;QACK,cAAS,GAAc,GAAG,EAAE,GAAE,CAAC,CAAC;QAChC,iCAA4B,GAAyB,GAAG,EAAE,GAAE,CAAC,CAAC;QA2B9D,cAAS,GAAY,KAAK,CAAC;QAmB3B,cAAS,GAAY,KAAK,CAAC;QAe3B,mBAAc,GAAY,KAAK,CAAC;QArDtC,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;IAC1C,CAAC;IACD,eAAe;QACb,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;IAC9C,CAAC;IAED,wCAAwC;IACxC,IACI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IACD,IAAI,QAAQ,CAAC,KAAmB;QAC9B,MAAM,QAAQ,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;QAE9C,IAAI,QAAQ,IAAI,IAAI,CAAC,QAAQ,EAAE;YAC7B,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;YAC1B,IAAI,CAAC,iBAAiB,CAAC,YAAY,EAAE,CAAC;SACvC;IACH,CAAC;IAGD;;;;OAIG;IACH,IACa,QAAQ;QACnB,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IACD,IAAa,QAAQ,CAAC,KAAmB;QACvC,MAAM,QAAQ,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;QAE9C,IAAI,QAAQ,KAAK,IAAI,CAAC,QAAQ,EAAE;YAC9B,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;YAC1B,IAAI,CAAC,iBAAiB,CAAC,YAAY,EAAE,CAAC;SACvC;IACH,CAAC;IAGD;;;;OAIG;IACH,IACI,aAAa;QACf,OAAO,IAAI,CAAC,cAAc,CAAC;IAC7B,CAAC;IACD,IAAI,aAAa,CAAC,KAAmB;QACnC,IAAI,CAAC,cAAc,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;QACnD,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;IAC9C,CAAC;IAGD,+CAA+C;IAC/C,UAAU,CAAC,KAAU;QACnB,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC,KAAK,CAAC;IAC1B,CAAC;IAED,+CAA+C;IAC/C,gBAAgB,CAAC,EAAwB;QACvC,IAAI,CAAC,4BAA4B,GAAG,EAAE,CAAC;IACzC,CAAC;IAED,+CAA+C;IAC/C,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAED,+CAA+C;IAC/C,gBAAgB,CAAC,QAAiB;QAChC,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;IAC3B,CAAC;IAED,oDAAoD;IACpD,MAAM;QACJ,IAAI,CAAC,QAAQ,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC;QAC/B,IAAI,CAAC,4BAA4B,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACnD,CAAC;IAED,KAAK;QACH,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IAC3C,CAAC;IAED,eAAe;QACb,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,OAAO,MAAM,CAAC;SACf;QAED,OAAO,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC;IAChD,CAAC;IAED,aAAa,CAAC,MAAa;QACzB,MAAM,CAAC,eAAe,EAAE,CAAC;QACzB,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YACpC,IAAI,CAAC,SAAS,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC;YACjC,gEAAgE;YAChE,8EAA8E;YAC9E,4FAA4F;YAC5F,IAAI,CAAC,eAAe,EAAE,CAAC;SACxB;IACH,CAAC;IAED,mBAAmB,CAAC,KAAY;QAC9B,0DAA0D;QAC1D,0EAA0E;QAC1E,gDAAgD;QAChD,KAAK,CAAC,eAAe,EAAE,CAAC;IAC1B,CAAC;IAED,OAAO;QACL,yFAAyF;QACzF,2FAA2F;QAC3F,oFAAoF;QACpF,qFAAqF;QACrF,oEAAoE;QACpE,OAAO,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;YAC1B,IAAI,CAAC,SAAS,EAAE,CAAC;YACjB,IAAI,CAAC,iBAAiB,CAAC,YAAY,EAAE,CAAC;QACxC,CAAC,CAAC,CAAC;IACL,CAAC;IACO,eAAe;QACrB,IAAI,CAAC,4BAA4B,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACjD,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,cAAc,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC,CAAC;QAE1D,mFAAmF;QACnF,qFAAqF;QACrF,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC;SAC1D;IACH,CAAC;IAED;;;;;;;OAOG;IACK,iBAAiB,CAAC,KAAc;QACtC,MAAM,cAAc,GAAG,IAAI,CAAC,aAAa,CAAC;QAE1C,IAAI,cAAc,EAAE;YAClB,cAAc,CAAC,aAAa,CAAC,aAAa,GAAG,KAAK,CAAC;SACpD;IACH,CAAC;;8GAhOU,iBAAiB,6EA0Ef,UAAU;kGA1EZ,iBAAiB,uhBAdjB;QACT;YACE,OAAO,EAAE,iBAAiB;YAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC;YAChD,KAAK,EAAE,IAAI;SACZ;KACF,4OCtDH,67DA6DA;AD8BE;IADC,MAAM,EAAE;6CACD;AAUR;IADC,aAAa;mDACiB;AAO/B;IADC,aAAa;mDACiB;2FA9CpB,iBAAiB;kBApB7B,SAAS;+BACE,aAAa,YAGb,YAAY,mBACL,uBAAuB,CAAC,MAAM,aACpC;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,kBAAkB,CAAC;4BAChD,KAAK,EAAE,IAAI;yBACZ;qBACF,QACK;wBACJ,iBAAiB,EAAE,MAAM;wBACzB,mBAAmB,EAAE,MAAM;wBAC3B,wBAAwB,EAAE,MAAM;qBACjC,kBACe,CAAC,mBAAmB,CAAC;;0BA4ElC,SAAS;2BAAC,UAAU;4CA7DF,SAAS;sBAA7B,KAAK;uBAAC,YAAY;gBAMO,cAAc;sBAAvC,KAAK;uBAAC,iBAAiB;gBAGG,eAAe;sBAAzC,KAAK;uBAAC,kBAAkB;gBAOzB,EAAE;sBAHD,WAAW;;sBACX,KAAK;gBAYN,QAAQ;sBAFP,KAAK;gBASN,QAAQ;sBAFP,KAAK;gBAKG,IAAI;sBAAZ,KAAK;gBAEG,IAAI;sBAAZ,KAAK;gBAGa,MAAM;sBAAxB,MAAM;gBAIE,KAAK;sBAAb,KAAK;gBAGc,aAAa;sBAAhC,SAAS;uBAAC,OAAO;gBAwBd,QAAQ;sBADX,KAAK;gBAoBO,QAAQ;sBADpB,KAAK;gBAoBF,aAAa;sBADhB,KAAK","sourcesContent":["import {\n  AfterViewInit,\n  Attribute,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  HostBinding,\n  Input,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport { FocusableOption } from '@angular/cdk/a11y';\nimport { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { HasTabIndex, mixinTabIndex } from '../../common/tabindex';\nimport { CanDisable, mixinDisabled } from '../../common/disabled';\nimport { ThemeCheckDirective } from '../../theme/src/theme-check.directive';\nimport { CoerceBoolean } from '../../common/coerce-boolean.decorator';\nimport { AutoId } from '../../common/auto-id.decorator';\n\n/** Change event object emitted by checkbox. */\nexport class CheckboxChange {\n  constructor(\n    /** The new `selected` value of the checkbox. */\n    public readonly selected: boolean,\n    /** The source checkbox of the event. */\n    public readonly source: CheckboxComponent\n  ) {}\n}\n\nconst _CheckboxMixinBase = mixinTabIndex(\n  mixinDisabled(\n    class {\n      constructor(public _elementRef: ElementRef) {}\n    }\n  )\n);\n\n@Component({\n  selector: 'sp-checkbox',\n  templateUrl: './checkbox.component.html',\n  styleUrls: ['./checkbox.component.scss'],\n  exportAs: 'spCheckbox',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => CheckboxComponent),\n      multi: true,\n    },\n  ],\n  host: {\n    '[attr.tabindex]': 'null',\n    '[attr.aria-label]': 'null',\n    '[attr.aria-labelledby]': 'null',\n  },\n  hostDirectives: [ThemeCheckDirective],\n})\nexport class CheckboxComponent\n  extends _CheckboxMixinBase\n  implements\n    AfterViewInit,\n    ControlValueAccessor,\n    CanDisable,\n    HasTabIndex,\n    FocusableOption\n{\n  /**\n   * Attached to the aria-label attribute of the host element. In most cases,\n   * aria-labelledby will take precedence so this may be omitted.\n   */\n  @Input('aria-label') ariaLabel: string = '';\n\n  /**\n   * Users can specify the `aria-labelledby` attribute which will be forwarded\n   * to the input element\n   */\n  @Input('aria-labelledby') ariaLabelledby: string | null = null;\n\n  /** The 'aria-describedby' attribute is read after the element's label and field type. */\n  @Input('aria-describedby') ariaDescribedby: string = '';\n\n  /** A unique id for the checkbox input. If none is supplied, it will be auto-generated. */\n\n  @HostBinding()\n  @Input()\n  @AutoId()\n  id = '';\n\n  /** Returns the unique id for the visual hidden input. */\n  get _inputId(): string {\n    return `${this.id}-input`;\n  }\n\n  /** Whether the checkbox is required. */\n  @Input()\n  @CoerceBoolean\n  required: BooleanInput = false;\n\n  /**\n   * Whether the checkbox is readonly.\n   */\n  @Input()\n  @CoerceBoolean\n  readonly: BooleanInput = false;\n\n  /** Name value will be applied to the input element if present */\n  @Input() name: string | null = null;\n\n  @Input() size?: 'large' | 'medium' = 'large';\n\n  /** Event emitted when the checkbox's `selected` value changes. */\n  @Output() readonly change: EventEmitter<CheckboxChange> =\n    new EventEmitter<CheckboxChange>();\n\n  /** The value attribute of the native input element */\n  @Input() value: string | undefined;\n\n  /** The native `<input type=\"checkbox\">` element */\n  @ViewChild('input') _inputElement!: ElementRef<HTMLInputElement>;\n\n  /**\n   * Called when the checkbox is blurred. Needed to properly implement\n   * ControlValueAccessor.\n   * @docs-private\n   */\n  private onTouched: () => any = () => {};\n  private controlValueAccessorChangeFn: (value: any) => void = () => {};\n\n  constructor(\n    elementRef: ElementRef<HTMLElement>,\n    private changeDetectorRef: ChangeDetectorRef,\n    @Attribute('tabindex') tabIndex: string\n  ) {\n    super(elementRef);\n    this.tabIndex = parseInt(tabIndex) || 0;\n  }\n  ngAfterViewInit() {\n    this.syncIndeterminate(this._indeterminate);\n  }\n\n  /** Whether the checkbox is selected. */\n  @Input()\n  get selected(): boolean {\n    return this._selected;\n  }\n  set selected(value: BooleanInput) {\n    const selected = coerceBooleanProperty(value);\n\n    if (selected != this.selected) {\n      this._selected = selected;\n      this.changeDetectorRef.markForCheck();\n    }\n  }\n  private _selected: boolean = false;\n\n  /**\n   * Whether the checkbox is disabled. This fully overrides the implementation\n   * provided by mixinDisabled, but the mixin is still required because\n   * mixinTabIndex requires it.\n   */\n  @Input()\n  override get disabled(): boolean {\n    return this._disabled;\n  }\n  override set disabled(value: BooleanInput) {\n    const newValue = coerceBooleanProperty(value);\n\n    if (newValue !== this.disabled) {\n      this._disabled = newValue;\n      this.changeDetectorRef.markForCheck();\n    }\n  }\n  private _disabled: boolean = false;\n\n  /**\n   * Whether the checkbox is indeterminate. This is also known as \"mixed\" mode\n   * and can be used to represent a checkbox with three states, e.g. a checkbox\n   * that represents a nested list of checkable items.\n   */\n  @Input()\n  get indeterminate(): boolean {\n    return this._indeterminate;\n  }\n  set indeterminate(value: BooleanInput) {\n    this._indeterminate = coerceBooleanProperty(value);\n    this.syncIndeterminate(this._indeterminate);\n  }\n  private _indeterminate: boolean = false;\n\n  // Implemented as part of ControlValueAccessor.\n  writeValue(value: any) {\n    this.selected = !!value;\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  registerOnChange(fn: (value: any) => void) {\n    this.controlValueAccessorChangeFn = fn;\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  registerOnTouched(fn: any) {\n    this.onTouched = fn;\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  setDisabledState(disabled: boolean) {\n    this.disabled = disabled;\n  }\n\n  /** Toggles the `selected` state of the checkbox. */\n  toggle(): void {\n    this.selected = !this.selected;\n    this.controlValueAccessorChangeFn(this.selected);\n  }\n\n  focus() {\n    this._inputElement.nativeElement.focus();\n  }\n\n  _getAriaChecked(): 'true' | 'false' | 'mixed' {\n    if (this.selected) {\n      return 'true';\n    }\n\n    return this.indeterminate ? 'mixed' : 'false';\n  }\n\n  _onInputClick($event: Event) {\n    $event.stopPropagation();\n    if (!this.disabled && !this.readonly) {\n      this._selected = !this._selected;\n      // Emit our custom change event if the native input emitted one.\n      // It is important to only emit it, if the native input triggered one, because\n      // we don't want to trigger a change event, when the `checked` variable changes for example.\n      this.emitChangeEvent();\n    }\n  }\n\n  _onInteractionEvent(event: Event) {\n    // We always have to stop propagation on the change event.\n    // Otherwise, the change event, from the input element, will bubble up and\n    // emit its event object to the `change` output.\n    event.stopPropagation();\n  }\n\n  _onBlur() {\n    // When a focused element becomes disabled, the browser *immediately* fires a blur event.\n    // Angular does not expect events to be raised during change detection, so any state change\n    // (such as a form control's 'ng-touched') will cause a changed-after-checked error.\n    // See https://github.com/angular/angular/issues/17793. To work around this, we defer\n    // telling the form control it has been touched until the next tick.\n    Promise.resolve().then(() => {\n      this.onTouched();\n      this.changeDetectorRef.markForCheck();\n    });\n  }\n  private emitChangeEvent() {\n    this.controlValueAccessorChangeFn(this.selected);\n    this.change.emit(new CheckboxChange(this.selected, this));\n\n    // Assigning the value again here is redundant, but we have to do it in case it was\n    // changed inside the `change` listener which will cause the input to be out of sync.\n    if (this._inputElement) {\n      this._inputElement.nativeElement.checked = this.selected;\n    }\n  }\n\n  /**\n   * Syncs the indeterminate value with the checkbox DOM node.\n   *\n   * We sync `indeterminate` directly on the DOM node, because in Ivy the check\n   * for whether a property is supported on an element boils down to `if\n   * (propName in element)`. Domino's HTMLInputElement doesn't have an\n   * `indeterminate` property so Ivy will warn during server-side rendering.\n   */\n  private syncIndeterminate(value: boolean) {\n    const nativeCheckbox = this._inputElement;\n\n    if (nativeCheckbox) {\n      nativeCheckbox.nativeElement.indeterminate = value;\n    }\n  }\n}\n","<label\n  [for]=\"_inputId\"\n  class=\"sapphire-checkbox\"\n  [class.sapphire-checkbox--checked]=\"selected\"\n  [class.sapphire-checkbox--indeterminate]=\"indeterminate\"\n  [class.sapphire-checkbox--medium]=\"size === 'medium'\"\n>\n  <input\n    #input\n    type=\"checkbox\"\n    class=\"sapphire-checkbox__input\"\n    [attr.aria-checked]=\"_getAriaChecked()\"\n    [attr.aria-label]=\"ariaLabel || null\"\n    [attr.aria-labelledby]=\"ariaLabelledby\"\n    [attr.aria-describedby]=\"ariaDescribedby\"\n    [attr.name]=\"name\"\n    [attr.value]=\"value\"\n    [checked]=\"selected\"\n    [disabled]=\"disabled\"\n    [readonly]=\"readonly\"\n    [id]=\"_inputId\"\n    [required]=\"required\"\n    [tabIndex]=\"tabIndex\"\n    (blur)=\"_onBlur()\"\n    (click)=\"_onInputClick($event)\"\n    (change)=\"_onInteractionEvent($event)\"\n  />\n  <span class=\"sapphire-checkbox__box\">\n    <svg\n      *ngIf=\"indeterminate\"\n      class=\"sapphire-checkbox__box-icon\"\n      xmlns=\"http://www.w3.org/2000/svg\"\n      viewBox=\"0 0 24 24\"\n      aria-hidden=\"true\"\n    >\n      <g fill=\"none\" fill-rule=\"evenodd\">\n        <path\n          stroke=\"currentColor\"\n          stroke-width=\"2\"\n          stroke-linecap=\"square\"\n          d=\"M7 12h10\"\n        />\n        <path fill=\"currentColor\" fill-rule=\"nonzero\" d=\"M18 11v2H6v-2z\" />\n      </g>\n    </svg>\n    <svg\n      *ngIf=\"selected && !indeterminate\"\n      class=\"sapphire-checkbox__box-icon\"\n      xmlns=\"http://www.w3.org/2000/svg\"\n      viewBox=\"0 0 24 24\"\n      aria-hidden=\"true\"\n    >\n      <path\n        d=\"M17.782 6.918l.753.659a.5.5 0 01.047.705L10.9 17.061a.5.5 0 01-.73.024l-4.232-4.231a.5.5 0 010-.708l.707-.707a.5.5 0 01.708 0l3.097 3.097 6.626-7.57a.5.5 0 01.705-.048z\"\n        fill=\"currentColor\"\n        fill-rule=\"nonzero\"\n      />\n    </svg>\n  </span>\n  <span class=\"sapphire-checkbox__label\"><ng-content></ng-content></span>\n</label>\n"]}
@@ -11,10 +11,9 @@ export class DialogTriggerDirective extends ModalTriggerDirective {
11
11
  this.modalService = modalService;
12
12
  }
13
13
  open() {
14
- if (!this.templateRef) {
15
- throw new Error('Template referenced by modal trigger not found.');
14
+ if (this.templateRef) {
15
+ this.dialogRef = this.modalService.openDialog(this.templateRef, this);
16
16
  }
17
- this.dialogRef = this.modalService.openDialog(this.templateRef, this);
18
17
  }
19
18
  }
20
19
  DialogTriggerDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: DialogTriggerDirective, deps: [{ token: i1.ModalService }], target: i0.ɵɵFactoryTarget.Directive });
@@ -34,4 +33,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImpor
34
33
  type: HostListener,
35
34
  args: ['click']
36
35
  }] } });
37
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLXRyaWdnZXIuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9tb2RhbC9zcmMvZGlhbG9nL2RpYWxvZy10cmlnZ2VyLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN4RCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQzs7O0FBR25FOztHQUVHO0FBVUgsTUFBTSxPQUFPLHNCQUF1QixTQUFRLHFCQUFxQjtJQUMvRCxZQUFzQixZQUEwQjtRQUM5QyxLQUFLLENBQUMsWUFBWSxDQUFDLENBQUM7UUFEQSxpQkFBWSxHQUFaLFlBQVksQ0FBYztJQUVoRCxDQUFDO0lBR0QsSUFBSTtRQUNGLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFO1lBQ3JCLE1BQU0sSUFBSSxLQUFLLENBQUMsaURBQWlELENBQUMsQ0FBQztTQUNwRTtRQUNELElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxJQUFJLENBQUMsQ0FBQztJQUN4RSxDQUFDOzttSEFYVSxzQkFBc0I7dUdBQXRCLHNCQUFzQjsyRkFBdEIsc0JBQXNCO2tCQVRsQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxzQkFBc0I7b0JBQ2hDLE1BQU0sRUFBRTt3QkFDTixrQ0FBa0M7d0JBQ2xDLDZEQUE2RDt3QkFDN0QsaUNBQWlDO3FCQUNsQztvQkFDRCxRQUFRLEVBQUUsaUJBQWlCO2lCQUM1QjttR0FPQyxJQUFJO3NCQURILFlBQVk7dUJBQUMsT0FBTyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgSG9zdExpc3RlbmVyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBNb2RhbFRyaWdnZXJEaXJlY3RpdmUgfSBmcm9tICcuLi9tb2RhbC10cmlnZ2VyLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBNb2RhbFNlcnZpY2UgfSBmcm9tICcuLi9tb2RhbC5zZXJ2aWNlJztcblxuLyoqXG4gKiBNYWtlcyBhIGNsaWNrYWJsZSBlbGVtZW50IGEgdHJpZ2dlciBmb3IgYSBkaWFsb2cuXG4gKi9cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1tzcERpYWxvZ1RyaWdnZXJGb3JdJyxcbiAgaW5wdXRzOiBbXG4gICAgJ2Rpc21pc3NhYmxlOiBzcERpYWxvZ0Rpc21pc3NhYmxlJyxcbiAgICAna2V5Ym9hcmREaXNtaXNzRGlzYWJsZWQ6IHNwRGlhbG9nRGlzYWJsZUtleWJvYXJkRGlzbWlzc2FibGUnLFxuICAgICd0ZW1wbGF0ZVJlZjogc3BEaWFsb2dUcmlnZ2VyRm9yJyxcbiAgXSxcbiAgZXhwb3J0QXM6ICdzcERpYWxvZ1RyaWdnZXInLFxufSlcbmV4cG9ydCBjbGFzcyBEaWFsb2dUcmlnZ2VyRGlyZWN0aXZlIGV4dGVuZHMgTW9kYWxUcmlnZ2VyRGlyZWN0aXZlIHtcbiAgY29uc3RydWN0b3IocHJvdGVjdGVkIG1vZGFsU2VydmljZTogTW9kYWxTZXJ2aWNlKSB7XG4gICAgc3VwZXIobW9kYWxTZXJ2aWNlKTtcbiAgfVxuXG4gIEBIb3N0TGlzdGVuZXIoJ2NsaWNrJylcbiAgb3BlbigpIHtcbiAgICBpZiAoIXRoaXMudGVtcGxhdGVSZWYpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignVGVtcGxhdGUgcmVmZXJlbmNlZCBieSBtb2RhbCB0cmlnZ2VyIG5vdCBmb3VuZC4nKTtcbiAgICB9XG4gICAgdGhpcy5kaWFsb2dSZWYgPSB0aGlzLm1vZGFsU2VydmljZS5vcGVuRGlhbG9nKHRoaXMudGVtcGxhdGVSZWYsIHRoaXMpO1xuICB9XG59XG4iXX0=
36
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLXRyaWdnZXIuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9tb2RhbC9zcmMvZGlhbG9nL2RpYWxvZy10cmlnZ2VyLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN4RCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQzs7O0FBR25FOztHQUVHO0FBVUgsTUFBTSxPQUFPLHNCQUF1QixTQUFRLHFCQUFxQjtJQUMvRCxZQUFzQixZQUEwQjtRQUM5QyxLQUFLLENBQUMsWUFBWSxDQUFDLENBQUM7UUFEQSxpQkFBWSxHQUFaLFlBQVksQ0FBYztJQUVoRCxDQUFDO0lBR0QsSUFBSTtRQUNGLElBQUksSUFBSSxDQUFDLFdBQVcsRUFBRTtZQUNwQixJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxXQUFXLEVBQUUsSUFBSSxDQUFDLENBQUM7U0FDdkU7SUFDSCxDQUFDOzttSEFWVSxzQkFBc0I7dUdBQXRCLHNCQUFzQjsyRkFBdEIsc0JBQXNCO2tCQVRsQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxzQkFBc0I7b0JBQ2hDLE1BQU0sRUFBRTt3QkFDTixrQ0FBa0M7d0JBQ2xDLDZEQUE2RDt3QkFDN0QsaUNBQWlDO3FCQUNsQztvQkFDRCxRQUFRLEVBQUUsaUJBQWlCO2lCQUM1QjttR0FPQyxJQUFJO3NCQURILFlBQVk7dUJBQUMsT0FBTyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgSG9zdExpc3RlbmVyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBNb2RhbFRyaWdnZXJEaXJlY3RpdmUgfSBmcm9tICcuLi9tb2RhbC10cmlnZ2VyLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBNb2RhbFNlcnZpY2UgfSBmcm9tICcuLi9tb2RhbC5zZXJ2aWNlJztcblxuLyoqXG4gKiBNYWtlcyBhIGNsaWNrYWJsZSBlbGVtZW50IGEgdHJpZ2dlciBmb3IgYSBkaWFsb2cuXG4gKi9cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1tzcERpYWxvZ1RyaWdnZXJGb3JdJyxcbiAgaW5wdXRzOiBbXG4gICAgJ2Rpc21pc3NhYmxlOiBzcERpYWxvZ0Rpc21pc3NhYmxlJyxcbiAgICAna2V5Ym9hcmREaXNtaXNzRGlzYWJsZWQ6IHNwRGlhbG9nRGlzYWJsZUtleWJvYXJkRGlzbWlzc2FibGUnLFxuICAgICd0ZW1wbGF0ZVJlZjogc3BEaWFsb2dUcmlnZ2VyRm9yJyxcbiAgXSxcbiAgZXhwb3J0QXM6ICdzcERpYWxvZ1RyaWdnZXInLFxufSlcbmV4cG9ydCBjbGFzcyBEaWFsb2dUcmlnZ2VyRGlyZWN0aXZlIGV4dGVuZHMgTW9kYWxUcmlnZ2VyRGlyZWN0aXZlIHtcbiAgY29uc3RydWN0b3IocHJvdGVjdGVkIG1vZGFsU2VydmljZTogTW9kYWxTZXJ2aWNlKSB7XG4gICAgc3VwZXIobW9kYWxTZXJ2aWNlKTtcbiAgfVxuXG4gIEBIb3N0TGlzdGVuZXIoJ2NsaWNrJylcbiAgb3BlbigpIHtcbiAgICBpZiAodGhpcy50ZW1wbGF0ZVJlZikge1xuICAgICAgdGhpcy5kaWFsb2dSZWYgPSB0aGlzLm1vZGFsU2VydmljZS5vcGVuRGlhbG9nKHRoaXMudGVtcGxhdGVSZWYsIHRoaXMpO1xuICAgIH1cbiAgfVxufVxuIl19
@@ -1,8 +1,10 @@
1
+ import { __decorate } from "tslib";
1
2
  import { Directive, forwardRef, HostBinding, Inject, Input, } from '@angular/core';
2
3
  import { TableRowDirective } from './table-row.directive';
3
4
  import { TableComponent } from './table.component';
4
5
  import { TruncatedWithTooltipDirective } from '../../tooltip/public_api';
5
6
  import { UseComponentStyles } from '../../common/sapphire-view-encapsulation';
7
+ import { CoerceBoolean } from '../../common/coerce-boolean.decorator';
6
8
  import * as i0 from "@angular/core";
7
9
  import * as i1 from "../../tooltip/public_api";
8
10
  import * as i2 from "../../tooltip/src/truncated-with-tooltip.directive";
@@ -37,6 +39,11 @@ export class TableCellDirective {
37
39
  this.table = table;
38
40
  this.truncatedWithTooltipDirective = truncatedWithTooltipDirective;
39
41
  this.tableRow = tableRow;
42
+ /**
43
+ * Applies the styles for selection cell.
44
+ * A selection cell is the first cell in a row, containing a checkbox.
45
+ */
46
+ this.selectionCell = false;
40
47
  this.isFirstCellInRow = false;
41
48
  }
42
49
  ngAfterContentChecked() {
@@ -47,7 +54,10 @@ export class TableCellDirective {
47
54
  }
48
55
  }
49
56
  TableCellDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: TableCellDirective, deps: [{ token: forwardRef(() => TableComponent) }, { token: i1.TruncatedWithTooltipDirective }, { token: forwardRef(() => TableRowDirective) }], target: i0.ɵɵFactoryTarget.Directive });
50
- TableCellDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.0", type: TableCellDirective, selector: "td[sp-table-td]", inputs: { align: "align" }, host: { properties: { "class.sapphire-table__cell--alignLeft": "align === 'left'", "class.sapphire-table__cell--alignCenter": "align === 'center'", "class.sapphire-table__cell--alignRight": "align === 'right'", "attr.role": "this.role", "attr.align": "this.align", "style.width": "this.width", "style.min-width": "this.minWidth", "style.max-width": "this.maxWidth" }, classAttribute: "sapphire-table__cell" }, hostDirectives: [{ directive: i2.TruncatedWithTooltipDirective }, { directive: i3.UseComponentStyles }], ngImport: i0 });
57
+ TableCellDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.0", type: TableCellDirective, selector: "td[sp-table-td]", inputs: { align: "align", selectionCell: "selectionCell" }, host: { properties: { "class.sapphire-table__cell--alignLeft": "align === 'left'", "class.sapphire-table__cell--alignCenter": "align === 'center'", "class.sapphire-table__cell--alignRight": "align === 'right'", "class.sapphire-table__selectionCell": "selectionCell", "attr.role": "this.role", "attr.align": "this.align", "style.width": "this.width", "style.min-width": "this.minWidth", "style.max-width": "this.maxWidth" }, classAttribute: "sapphire-table__cell" }, hostDirectives: [{ directive: i2.TruncatedWithTooltipDirective }, { directive: i3.UseComponentStyles }], ngImport: i0 });
58
+ __decorate([
59
+ CoerceBoolean
60
+ ], TableCellDirective.prototype, "selectionCell", void 0);
51
61
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: TableCellDirective, decorators: [{
52
62
  type: Directive,
53
63
  args: [{
@@ -58,6 +68,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImpor
58
68
  '[class.sapphire-table__cell--alignLeft]': "align === 'left'",
59
69
  '[class.sapphire-table__cell--alignCenter]': "align === 'center'",
60
70
  '[class.sapphire-table__cell--alignRight]': "align === 'right'",
71
+ '[class.sapphire-table__selectionCell]': 'selectionCell',
61
72
  },
62
73
  }]
63
74
  }], ctorParameters: function () { return [{ type: i4.TableComponent, decorators: [{
@@ -74,6 +85,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImpor
74
85
  args: ['attr.align']
75
86
  }, {
76
87
  type: Input
88
+ }], selectionCell: [{
89
+ type: Input
77
90
  }], width: [{
78
91
  type: HostBinding,
79
92
  args: ['style.width']
@@ -84,4 +97,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImpor
84
97
  type: HostBinding,
85
98
  args: ['style.max-width']
86
99
  }] } });
87
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtY2VsbC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbGliL3RhYmxlL3NyYy90YWJsZS1jZWxsLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBRUwsU0FBUyxFQUNULFVBQVUsRUFDVixXQUFXLEVBQ1gsTUFBTSxFQUNOLEtBQUssR0FDTixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDbkQsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDekUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sMENBQTBDLENBQUM7Ozs7Ozs7QUFlOUUsTUFBTSxPQUFPLGtCQUFrQjtJQUM3QixJQUNJLElBQUk7UUFDTixPQUFPLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUM7SUFDdEQsQ0FBQztJQUNEOzs7O09BSUc7SUFDSCxJQUVJLEtBQUs7UUFDUCxPQUFPLElBQUksQ0FBQyxNQUFNLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRSxLQUFLLENBQUM7SUFDN0MsQ0FBQztJQUVELElBQUksS0FBSyxDQUFDLEtBQWdDO1FBQ3hDLElBQUksQ0FBQyxNQUFNLEdBQUcsS0FBSyxDQUFDO0lBQ3RCLENBQUM7SUFFRCxJQUNJLEtBQUs7UUFDUCxPQUFPLElBQUksQ0FBQyxRQUFRLEVBQUUsS0FBSyxDQUFDO0lBQzlCLENBQUM7SUFFRCxJQUNJLFFBQVE7UUFDVixPQUFPLElBQUksQ0FBQyxRQUFRLEVBQUUsUUFBUSxDQUFDO0lBQ2pDLENBQUM7SUFFRCxJQUNJLFFBQVE7UUFDVixPQUFPLElBQUksQ0FBQyxRQUFRLEVBQUUsUUFBUSxDQUFDO0lBQ2pDLENBQUM7SUFLRCxZQUVVLEtBQXFCLEVBQ3JCLDZCQUE0RCxFQUU1RCxRQUEyQjtRQUgzQixVQUFLLEdBQUwsS0FBSyxDQUFnQjtRQUNyQixrQ0FBNkIsR0FBN0IsNkJBQTZCLENBQStCO1FBRTVELGFBQVEsR0FBUixRQUFRLENBQW1CO1FBUDdCLHFCQUFnQixHQUFHLEtBQUssQ0FBQztJQVE5QixDQUFDO0lBRUoscUJBQXFCO1FBQ25CLElBQUksQ0FBQyw2QkFBNkIsQ0FBQyxPQUFPO1lBQ3hDLElBQUksQ0FBQyxLQUFLLENBQUMsWUFBWSxLQUFLLFVBQVUsQ0FBQztRQUN6QyxJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDdEQsSUFBSSxDQUFDLGdCQUFnQixHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLE9BQU8sRUFBRSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDNUUsQ0FBQzs7K0dBbkRVLGtCQUFrQixrQkF1Q25CLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxjQUFjLENBQUMsMERBR2hDLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQzttR0ExQ2xDLGtCQUFrQjsyRkFBbEIsa0JBQWtCO2tCQVY5QixTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxpQkFBaUI7b0JBQzNCLGNBQWMsRUFBRSxDQUFDLDZCQUE2QixFQUFFLGtCQUFrQixDQUFDO29CQUNuRSxJQUFJLEVBQUU7d0JBQ0osS0FBSyxFQUFFLHNCQUFzQjt3QkFDN0IseUNBQXlDLEVBQUUsa0JBQWtCO3dCQUM3RCwyQ0FBMkMsRUFBRSxvQkFBb0I7d0JBQ2pFLDBDQUEwQyxFQUFFLG1CQUFtQjtxQkFDaEU7aUJBQ0Y7OzBCQXdDSSxNQUFNOzJCQUFDLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxjQUFjLENBQUM7OzBCQUd2QyxNQUFNOzJCQUFDLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQzs0Q0F4Q3pDLElBQUk7c0JBRFAsV0FBVzt1QkFBQyxXQUFXO2dCQVdwQixLQUFLO3NCQUZSLFdBQVc7dUJBQUMsWUFBWTs7c0JBQ3hCLEtBQUs7Z0JBVUYsS0FBSztzQkFEUixXQUFXO3VCQUFDLGFBQWE7Z0JBTXRCLFFBQVE7c0JBRFgsV0FBVzt1QkFBQyxpQkFBaUI7Z0JBTTFCLFFBQVE7c0JBRFgsV0FBVzt1QkFBQyxpQkFBaUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBBZnRlckNvbnRlbnRDaGVja2VkLFxuICBEaXJlY3RpdmUsXG4gIGZvcndhcmRSZWYsXG4gIEhvc3RCaW5kaW5nLFxuICBJbmplY3QsXG4gIElucHV0LFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFRhYmxlUm93RGlyZWN0aXZlIH0gZnJvbSAnLi90YWJsZS1yb3cuZGlyZWN0aXZlJztcbmltcG9ydCB7IFRhYmxlQ29tcG9uZW50IH0gZnJvbSAnLi90YWJsZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgVHJ1bmNhdGVkV2l0aFRvb2x0aXBEaXJlY3RpdmUgfSBmcm9tICcuLi8uLi90b29sdGlwL3B1YmxpY19hcGknO1xuaW1wb3J0IHsgVXNlQ29tcG9uZW50U3R5bGVzIH0gZnJvbSAnLi4vLi4vY29tbW9uL3NhcHBoaXJlLXZpZXctZW5jYXBzdWxhdGlvbic7XG5pbXBvcnQgeyBUYWJsZUhlYWRDZWxsQ29tcG9uZW50IH0gZnJvbSAnLi90YWJsZS1oZWFkLWNlbGwuY29tcG9uZW50JztcblxudHlwZSBDZWxsQWxpZ25tZW50ID0gJ2xlZnQnIHwgJ2NlbnRlcicgfCAncmlnaHQnO1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICd0ZFtzcC10YWJsZS10ZF0nLFxuICBob3N0RGlyZWN0aXZlczogW1RydW5jYXRlZFdpdGhUb29sdGlwRGlyZWN0aXZlLCBVc2VDb21wb25lbnRTdHlsZXNdLFxuICBob3N0OiB7XG4gICAgY2xhc3M6ICdzYXBwaGlyZS10YWJsZV9fY2VsbCcsXG4gICAgJ1tjbGFzcy5zYXBwaGlyZS10YWJsZV9fY2VsbC0tYWxpZ25MZWZ0XSc6IFwiYWxpZ24gPT09ICdsZWZ0J1wiLFxuICAgICdbY2xhc3Muc2FwcGhpcmUtdGFibGVfX2NlbGwtLWFsaWduQ2VudGVyXSc6IFwiYWxpZ24gPT09ICdjZW50ZXInXCIsXG4gICAgJ1tjbGFzcy5zYXBwaGlyZS10YWJsZV9fY2VsbC0tYWxpZ25SaWdodF0nOiBcImFsaWduID09PSAncmlnaHQnXCIsXG4gIH0sXG59KVxuZXhwb3J0IGNsYXNzIFRhYmxlQ2VsbERpcmVjdGl2ZSBpbXBsZW1lbnRzIEFmdGVyQ29udGVudENoZWNrZWQge1xuICBASG9zdEJpbmRpbmcoJ2F0dHIucm9sZScpXG4gIGdldCByb2xlKCkge1xuICAgIHJldHVybiB0aGlzLmlzRmlyc3RDZWxsSW5Sb3cgPyAncm93aGVhZGVyJyA6ICdjZWxsJztcbiAgfVxuICAvKipcbiAgICogSG9yaXpvbnRhbCBhbGlnbm1lbnQgb2YgY29udGVudCBpbiB0aGUgY2VsbC5cbiAgICpcbiAgICogQGRlZmF1bHQgJ2xlZnQnXG4gICAqL1xuICBASG9zdEJpbmRpbmcoJ2F0dHIuYWxpZ24nKVxuICBASW5wdXQoKVxuICBnZXQgYWxpZ24oKTogQ2VsbEFsaWdubWVudCB8IHVuZGVmaW5lZCB7XG4gICAgcmV0dXJuIHRoaXMuX2FsaWduIHx8IHRoaXMuaGVhZENlbGw/LmFsaWduO1xuICB9XG5cbiAgc2V0IGFsaWduKHZhbHVlOiBDZWxsQWxpZ25tZW50IHwgdW5kZWZpbmVkKSB7XG4gICAgdGhpcy5fYWxpZ24gPSB2YWx1ZTtcbiAgfVxuICBwcml2YXRlIF9hbGlnbjogQ2VsbEFsaWdubWVudCB8IHVuZGVmaW5lZDtcbiAgQEhvc3RCaW5kaW5nKCdzdHlsZS53aWR0aCcpXG4gIGdldCB3aWR0aCgpIHtcbiAgICByZXR1cm4gdGhpcy5oZWFkQ2VsbD8ud2lkdGg7XG4gIH1cblxuICBASG9zdEJpbmRpbmcoJ3N0eWxlLm1pbi13aWR0aCcpXG4gIGdldCBtaW5XaWR0aCgpIHtcbiAgICByZXR1cm4gdGhpcy5oZWFkQ2VsbD8ubWluV2lkdGg7XG4gIH1cblxuICBASG9zdEJpbmRpbmcoJ3N0eWxlLm1heC13aWR0aCcpXG4gIGdldCBtYXhXaWR0aCgpIHtcbiAgICByZXR1cm4gdGhpcy5oZWFkQ2VsbD8ubWF4V2lkdGg7XG4gIH1cblxuICBwcml2YXRlIGhlYWRDZWxsPzogVGFibGVIZWFkQ2VsbENvbXBvbmVudDtcbiAgcHJpdmF0ZSBpc0ZpcnN0Q2VsbEluUm93ID0gZmFsc2U7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgQEluamVjdChmb3J3YXJkUmVmKCgpID0+IFRhYmxlQ29tcG9uZW50KSlcbiAgICBwcml2YXRlIHRhYmxlOiBUYWJsZUNvbXBvbmVudCxcbiAgICBwcml2YXRlIHRydW5jYXRlZFdpdGhUb29sdGlwRGlyZWN0aXZlOiBUcnVuY2F0ZWRXaXRoVG9vbHRpcERpcmVjdGl2ZSxcbiAgICBASW5qZWN0KGZvcndhcmRSZWYoKCkgPT4gVGFibGVSb3dEaXJlY3RpdmUpKVxuICAgIHByaXZhdGUgdGFibGVSb3c6IFRhYmxlUm93RGlyZWN0aXZlXG4gICkge31cblxuICBuZ0FmdGVyQ29udGVudENoZWNrZWQoKTogdm9pZCB7XG4gICAgdGhpcy50cnVuY2F0ZWRXaXRoVG9vbHRpcERpcmVjdGl2ZS5lbmFibGVkID1cbiAgICAgIHRoaXMudGFibGUuY2VsbE92ZXJmbG93ID09PSAndHJ1bmNhdGUnO1xuICAgIHRoaXMuaGVhZENlbGwgPSB0aGlzLnRhYmxlUm93LmdldENvbHVtbkhlYWRDZWxsKHRoaXMpO1xuICAgIHRoaXMuaXNGaXJzdENlbGxJblJvdyA9IHRoaXMudGFibGVSb3cuY2VsbHMudG9BcnJheSgpLmluZGV4T2YodGhpcykgPT09IDA7XG4gIH1cbn1cbiJdfQ==
100
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtY2VsbC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbGliL3RhYmxlL3NyYy90YWJsZS1jZWxsLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUVMLFNBQVMsRUFDVCxVQUFVLEVBQ1YsV0FBVyxFQUNYLE1BQU0sRUFDTixLQUFLLEdBQ04sTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDMUQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ25ELE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQ3pFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBRTlFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQzs7Ozs7OztBQWdCdEUsTUFBTSxPQUFPLGtCQUFrQjtJQUM3QixJQUNJLElBQUk7UUFDTixPQUFPLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUM7SUFDdEQsQ0FBQztJQUNEOzs7O09BSUc7SUFDSCxJQUVJLEtBQUs7UUFDUCxPQUFPLElBQUksQ0FBQyxNQUFNLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRSxLQUFLLENBQUM7SUFDN0MsQ0FBQztJQVVELElBQUksS0FBSyxDQUFDLEtBQWdDO1FBQ3hDLElBQUksQ0FBQyxNQUFNLEdBQUcsS0FBSyxDQUFDO0lBQ3RCLENBQUM7SUFFRCxJQUNJLEtBQUs7UUFDUCxPQUFPLElBQUksQ0FBQyxRQUFRLEVBQUUsS0FBSyxDQUFDO0lBQzlCLENBQUM7SUFFRCxJQUNJLFFBQVE7UUFDVixPQUFPLElBQUksQ0FBQyxRQUFRLEVBQUUsUUFBUSxDQUFDO0lBQ2pDLENBQUM7SUFFRCxJQUNJLFFBQVE7UUFDVixPQUFPLElBQUksQ0FBQyxRQUFRLEVBQUUsUUFBUSxDQUFDO0lBQ2pDLENBQUM7SUFLRCxZQUVVLEtBQXFCLEVBQ3JCLDZCQUE0RCxFQUU1RCxRQUEyQjtRQUgzQixVQUFLLEdBQUwsS0FBSyxDQUFnQjtRQUNyQixrQ0FBNkIsR0FBN0IsNkJBQTZCLENBQStCO1FBRTVELGFBQVEsR0FBUixRQUFRLENBQW1CO1FBbkNyQzs7O1dBR0c7UUFHSCxrQkFBYSxHQUFpQixLQUFLLENBQUM7UUFzQjVCLHFCQUFnQixHQUFHLEtBQUssQ0FBQztJQVE5QixDQUFDO0lBRUoscUJBQXFCO1FBQ25CLElBQUksQ0FBQyw2QkFBNkIsQ0FBQyxPQUFPO1lBQ3hDLElBQUksQ0FBQyxLQUFLLENBQUMsWUFBWSxLQUFLLFVBQVUsQ0FBQztRQUN6QyxJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDdEQsSUFBSSxDQUFDLGdCQUFnQixHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLE9BQU8sRUFBRSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDNUUsQ0FBQzs7K0dBM0RVLGtCQUFrQixrQkErQ25CLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxjQUFjLENBQUMsMERBR2hDLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQzttR0FsRGxDLGtCQUFrQjtBQXNCN0I7SUFEQyxhQUFhO3lEQUNzQjsyRkF0QnpCLGtCQUFrQjtrQkFYOUIsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsaUJBQWlCO29CQUMzQixjQUFjLEVBQUUsQ0FBQyw2QkFBNkIsRUFBRSxrQkFBa0IsQ0FBQztvQkFDbkUsSUFBSSxFQUFFO3dCQUNKLEtBQUssRUFBRSxzQkFBc0I7d0JBQzdCLHlDQUF5QyxFQUFFLGtCQUFrQjt3QkFDN0QsMkNBQTJDLEVBQUUsb0JBQW9CO3dCQUNqRSwwQ0FBMEMsRUFBRSxtQkFBbUI7d0JBQy9ELHVDQUF1QyxFQUFFLGVBQWU7cUJBQ3pEO2lCQUNGOzswQkFnREksTUFBTTsyQkFBQyxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsY0FBYyxDQUFDOzswQkFHdkMsTUFBTTsyQkFBQyxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsaUJBQWlCLENBQUM7NENBaER6QyxJQUFJO3NCQURQLFdBQVc7dUJBQUMsV0FBVztnQkFXcEIsS0FBSztzQkFGUixXQUFXO3VCQUFDLFlBQVk7O3NCQUN4QixLQUFLO2dCQVdOLGFBQWE7c0JBRlosS0FBSztnQkFTRixLQUFLO3NCQURSLFdBQVc7dUJBQUMsYUFBYTtnQkFNdEIsUUFBUTtzQkFEWCxXQUFXO3VCQUFDLGlCQUFpQjtnQkFNMUIsUUFBUTtzQkFEWCxXQUFXO3VCQUFDLGlCQUFpQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIEFmdGVyQ29udGVudENoZWNrZWQsXG4gIERpcmVjdGl2ZSxcbiAgZm9yd2FyZFJlZixcbiAgSG9zdEJpbmRpbmcsXG4gIEluamVjdCxcbiAgSW5wdXQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVGFibGVSb3dEaXJlY3RpdmUgfSBmcm9tICcuL3RhYmxlLXJvdy5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgVGFibGVDb21wb25lbnQgfSBmcm9tICcuL3RhYmxlLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBUcnVuY2F0ZWRXaXRoVG9vbHRpcERpcmVjdGl2ZSB9IGZyb20gJy4uLy4uL3Rvb2x0aXAvcHVibGljX2FwaSc7XG5pbXBvcnQgeyBVc2VDb21wb25lbnRTdHlsZXMgfSBmcm9tICcuLi8uLi9jb21tb24vc2FwcGhpcmUtdmlldy1lbmNhcHN1bGF0aW9uJztcbmltcG9ydCB7IFRhYmxlSGVhZENlbGxDb21wb25lbnQgfSBmcm9tICcuL3RhYmxlLWhlYWQtY2VsbC5jb21wb25lbnQnO1xuaW1wb3J0IHsgQ29lcmNlQm9vbGVhbiB9IGZyb20gJy4uLy4uL2NvbW1vbi9jb2VyY2UtYm9vbGVhbi5kZWNvcmF0b3InO1xuaW1wb3J0IHsgQm9vbGVhbklucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2NvZXJjaW9uJztcblxudHlwZSBDZWxsQWxpZ25tZW50ID0gJ2xlZnQnIHwgJ2NlbnRlcicgfCAncmlnaHQnO1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICd0ZFtzcC10YWJsZS10ZF0nLFxuICBob3N0RGlyZWN0aXZlczogW1RydW5jYXRlZFdpdGhUb29sdGlwRGlyZWN0aXZlLCBVc2VDb21wb25lbnRTdHlsZXNdLFxuICBob3N0OiB7XG4gICAgY2xhc3M6ICdzYXBwaGlyZS10YWJsZV9fY2VsbCcsXG4gICAgJ1tjbGFzcy5zYXBwaGlyZS10YWJsZV9fY2VsbC0tYWxpZ25MZWZ0XSc6IFwiYWxpZ24gPT09ICdsZWZ0J1wiLFxuICAgICdbY2xhc3Muc2FwcGhpcmUtdGFibGVfX2NlbGwtLWFsaWduQ2VudGVyXSc6IFwiYWxpZ24gPT09ICdjZW50ZXInXCIsXG4gICAgJ1tjbGFzcy5zYXBwaGlyZS10YWJsZV9fY2VsbC0tYWxpZ25SaWdodF0nOiBcImFsaWduID09PSAncmlnaHQnXCIsXG4gICAgJ1tjbGFzcy5zYXBwaGlyZS10YWJsZV9fc2VsZWN0aW9uQ2VsbF0nOiAnc2VsZWN0aW9uQ2VsbCcsXG4gIH0sXG59KVxuZXhwb3J0IGNsYXNzIFRhYmxlQ2VsbERpcmVjdGl2ZSBpbXBsZW1lbnRzIEFmdGVyQ29udGVudENoZWNrZWQge1xuICBASG9zdEJpbmRpbmcoJ2F0dHIucm9sZScpXG4gIGdldCByb2xlKCkge1xuICAgIHJldHVybiB0aGlzLmlzRmlyc3RDZWxsSW5Sb3cgPyAncm93aGVhZGVyJyA6ICdjZWxsJztcbiAgfVxuICAvKipcbiAgICogSG9yaXpvbnRhbCBhbGlnbm1lbnQgb2YgY29udGVudCBpbiB0aGUgY2VsbC5cbiAgICpcbiAgICogQGRlZmF1bHQgJ2xlZnQnXG4gICAqL1xuICBASG9zdEJpbmRpbmcoJ2F0dHIuYWxpZ24nKVxuICBASW5wdXQoKVxuICBnZXQgYWxpZ24oKTogQ2VsbEFsaWdubWVudCB8IHVuZGVmaW5lZCB7XG4gICAgcmV0dXJuIHRoaXMuX2FsaWduIHx8IHRoaXMuaGVhZENlbGw/LmFsaWduO1xuICB9XG5cbiAgLyoqXG4gICAqIEFwcGxpZXMgdGhlIHN0eWxlcyBmb3Igc2VsZWN0aW9uIGNlbGwuXG4gICAqIEEgc2VsZWN0aW9uIGNlbGwgaXMgdGhlIGZpcnN0IGNlbGwgaW4gYSByb3csIGNvbnRhaW5pbmcgYSBjaGVja2JveC5cbiAgICovXG4gIEBJbnB1dCgpXG4gIEBDb2VyY2VCb29sZWFuXG4gIHNlbGVjdGlvbkNlbGw6IEJvb2xlYW5JbnB1dCA9IGZhbHNlO1xuXG4gIHNldCBhbGlnbih2YWx1ZTogQ2VsbEFsaWdubWVudCB8IHVuZGVmaW5lZCkge1xuICAgIHRoaXMuX2FsaWduID0gdmFsdWU7XG4gIH1cbiAgcHJpdmF0ZSBfYWxpZ246IENlbGxBbGlnbm1lbnQgfCB1bmRlZmluZWQ7XG4gIEBIb3N0QmluZGluZygnc3R5bGUud2lkdGgnKVxuICBnZXQgd2lkdGgoKSB7XG4gICAgcmV0dXJuIHRoaXMuaGVhZENlbGw/LndpZHRoO1xuICB9XG5cbiAgQEhvc3RCaW5kaW5nKCdzdHlsZS5taW4td2lkdGgnKVxuICBnZXQgbWluV2lkdGgoKSB7XG4gICAgcmV0dXJuIHRoaXMuaGVhZENlbGw/Lm1pbldpZHRoO1xuICB9XG5cbiAgQEhvc3RCaW5kaW5nKCdzdHlsZS5tYXgtd2lkdGgnKVxuICBnZXQgbWF4V2lkdGgoKSB7XG4gICAgcmV0dXJuIHRoaXMuaGVhZENlbGw/Lm1heFdpZHRoO1xuICB9XG5cbiAgcHJpdmF0ZSBoZWFkQ2VsbD86IFRhYmxlSGVhZENlbGxDb21wb25lbnQ7XG4gIHByaXZhdGUgaXNGaXJzdENlbGxJblJvdyA9IGZhbHNlO1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIEBJbmplY3QoZm9yd2FyZFJlZigoKSA9PiBUYWJsZUNvbXBvbmVudCkpXG4gICAgcHJpdmF0ZSB0YWJsZTogVGFibGVDb21wb25lbnQsXG4gICAgcHJpdmF0ZSB0cnVuY2F0ZWRXaXRoVG9vbHRpcERpcmVjdGl2ZTogVHJ1bmNhdGVkV2l0aFRvb2x0aXBEaXJlY3RpdmUsXG4gICAgQEluamVjdChmb3J3YXJkUmVmKCgpID0+IFRhYmxlUm93RGlyZWN0aXZlKSlcbiAgICBwcml2YXRlIHRhYmxlUm93OiBUYWJsZVJvd0RpcmVjdGl2ZVxuICApIHt9XG5cbiAgbmdBZnRlckNvbnRlbnRDaGVja2VkKCk6IHZvaWQge1xuICAgIHRoaXMudHJ1bmNhdGVkV2l0aFRvb2x0aXBEaXJlY3RpdmUuZW5hYmxlZCA9XG4gICAgICB0aGlzLnRhYmxlLmNlbGxPdmVyZmxvdyA9PT0gJ3RydW5jYXRlJztcbiAgICB0aGlzLmhlYWRDZWxsID0gdGhpcy50YWJsZVJvdy5nZXRDb2x1bW5IZWFkQ2VsbCh0aGlzKTtcbiAgICB0aGlzLmlzRmlyc3RDZWxsSW5Sb3cgPSB0aGlzLnRhYmxlUm93LmNlbGxzLnRvQXJyYXkoKS5pbmRleE9mKHRoaXMpID09PSAwO1xuICB9XG59XG4iXX0=
@@ -1,6 +1,8 @@
1
+ import { __decorate } from "tslib";
1
2
  import { Component, forwardRef, HostBinding, Inject, Input, Optional, } from '@angular/core';
2
3
  import { TableComponent } from './table.component';
3
4
  import { UseComponentStyles } from '../../common/sapphire-view-encapsulation';
5
+ import { CoerceBoolean } from '../../common/coerce-boolean.decorator';
4
6
  import * as i0 from "@angular/core";
5
7
  import * as i1 from "./table-sort-header.directive";
6
8
  import * as i2 from "../../common/sapphire-view-encapsulation";
@@ -19,18 +21,28 @@ export class TableHeadCellComponent {
19
21
  * Horizontal alignment of content in the cell.
20
22
  */
21
23
  this.align = 'left';
24
+ /**
25
+ * Applies the styles for selection cell. A selection cell is the first cell in a row, containing
26
+ * a checkbox.
27
+ */
28
+ this.selectionCell = false;
22
29
  }
23
30
  }
24
31
  TableHeadCellComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: TableHeadCellComponent, deps: [{ token: forwardRef(() => TableComponent) }, { token: i1.TableSortHeaderDirective, optional: true }], target: i0.ɵɵFactoryTarget.Component });
25
- TableHeadCellComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.0", type: TableHeadCellComponent, selector: "th[sp-table-th]", inputs: { align: "align", width: "width", minWidth: "minWidth", maxWidth: "maxWidth" }, host: { properties: { "class.sapphire-table__cell--alignLeft": "align === 'left'", "class.sapphire-table__cell--alignCenter": "align === 'center'", "class.sapphire-table__cell--alignRight": "align === 'right'", "style.width": "this.width", "style.min-width": "this.minWidth", "style.max-width": "this.maxWidth" }, classAttribute: "sapphire-table__headCell" }, hostDirectives: [{ directive: i2.UseComponentStyles }], ngImport: i0, template: "<div class=\"sapphire-table__headCell_container\" _spUseComponentStyles>\n <span *ngIf=\"tableSortHeader && align === 'right'\">\n <ng-container *ngTemplateOutlet=\"sortIcon\"></ng-container>\n </span>\n <span [spTruncatedWithTooltip]=\"cellOverflow === 'truncate'\">\n <ng-content></ng-content>\n </span>\n <span *ngIf=\"tableSortHeader && align !== 'right'\">\n <ng-container *ngTemplateOutlet=\"sortIcon\"></ng-container>\n </span>\n</div>\n\n<ng-template #sortIcon>\n <span\n *ngIf=\"tableSortHeader\"\n aria-hidden=\"true\"\n [class.sapphire-table-sortableIcon]=\"\n tableSortHeader.tableSort.sortDescriptor.column !==\n tableSortHeader.sortHeader\n \"\n [class.sapphire-table-sortedIcon]=\"\n tableSortHeader.tableSort.sortDescriptor.column ===\n tableSortHeader.sortHeader\n \"\n _spUseComponentStyles\n >\n <sp-icon\n [name]=\"\n tableSortHeader.tableSort.sortDescriptor.column ===\n tableSortHeader.sortHeader &&\n tableSortHeader.tableSort.sortDescriptor.direction === 'descending'\n ? 'caretDownMedium'\n : 'caretUpMedium'\n \"\n ></sp-icon>\n </span>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i4.IconComponent, selector: "sp-icon", inputs: ["name", "size"] }, { kind: "directive", type: i5.TruncatedWithTooltipDirective, selector: "[spTruncatedWithTooltip]", inputs: ["spTruncatedWithTooltip"] }, { kind: "directive", type: i2.UseComponentStyles, selector: "[_spUseComponentStyles]" }] });
32
+ TableHeadCellComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.0", type: TableHeadCellComponent, selector: "th[sp-table-th]", inputs: { align: "align", width: "width", minWidth: "minWidth", maxWidth: "maxWidth", selectionCell: "selectionCell" }, host: { properties: { "class.sapphire-table__headCell": "!selectionCell", "class.sapphire-table__cell": "selectionCell", "class.sapphire-table__cell--alignLeft": "align === 'left'", "class.sapphire-table__cell--alignCenter": "align === 'center'", "class.sapphire-table__cell--alignRight": "align === 'right'", "class.sapphire-table__selectionCell": "selectionCell", "style.width": "this.width", "style.min-width": "this.minWidth", "style.max-width": "this.maxWidth" } }, hostDirectives: [{ directive: i2.UseComponentStyles }], ngImport: i0, template: "<div\n *ngIf=\"!selectionCell\"\n class=\"sapphire-table__headCell_container\"\n _spUseComponentStyles\n>\n <span *ngIf=\"tableSortHeader && align === 'right'\">\n <ng-container *ngTemplateOutlet=\"sortIcon\"></ng-container>\n </span>\n <span [spTruncatedWithTooltip]=\"cellOverflow === 'truncate'\">\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </span>\n <span *ngIf=\"tableSortHeader && align !== 'right'\">\n <ng-container *ngTemplateOutlet=\"sortIcon\"></ng-container>\n </span>\n</div>\n<ng-container *ngIf=\"selectionCell\"\n ><ng-container *ngTemplateOutlet=\"content\"></ng-container\n></ng-container>\n\n<ng-template #content><ng-content></ng-content></ng-template>\n\n<ng-template #sortIcon>\n <span\n *ngIf=\"tableSortHeader\"\n aria-hidden=\"true\"\n [class.sapphire-table-sortableIcon]=\"\n tableSortHeader.tableSort.sortDescriptor.column !==\n tableSortHeader.sortHeader\n \"\n [class.sapphire-table-sortedIcon]=\"\n tableSortHeader.tableSort.sortDescriptor.column ===\n tableSortHeader.sortHeader\n \"\n _spUseComponentStyles\n >\n <sp-icon\n [name]=\"\n tableSortHeader.tableSort.sortDescriptor.column ===\n tableSortHeader.sortHeader &&\n tableSortHeader.tableSort.sortDescriptor.direction === 'descending'\n ? 'caretDownMedium'\n : 'caretUpMedium'\n \"\n ></sp-icon>\n </span>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i4.IconComponent, selector: "sp-icon", inputs: ["name", "size"] }, { kind: "directive", type: i5.TruncatedWithTooltipDirective, selector: "[spTruncatedWithTooltip]", inputs: ["spTruncatedWithTooltip"] }, { kind: "directive", type: i2.UseComponentStyles, selector: "[_spUseComponentStyles]" }] });
33
+ __decorate([
34
+ CoerceBoolean
35
+ ], TableHeadCellComponent.prototype, "selectionCell", void 0);
26
36
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: TableHeadCellComponent, decorators: [{
27
37
  type: Component,
28
38
  args: [{ selector: 'th[sp-table-th]', host: {
29
- class: 'sapphire-table__headCell',
39
+ '[class.sapphire-table__headCell]': '!selectionCell',
40
+ '[class.sapphire-table__cell]': 'selectionCell',
30
41
  '[class.sapphire-table__cell--alignLeft]': "align === 'left'",
31
42
  '[class.sapphire-table__cell--alignCenter]': "align === 'center'",
32
43
  '[class.sapphire-table__cell--alignRight]': "align === 'right'",
33
- }, hostDirectives: [UseComponentStyles], template: "<div class=\"sapphire-table__headCell_container\" _spUseComponentStyles>\n <span *ngIf=\"tableSortHeader && align === 'right'\">\n <ng-container *ngTemplateOutlet=\"sortIcon\"></ng-container>\n </span>\n <span [spTruncatedWithTooltip]=\"cellOverflow === 'truncate'\">\n <ng-content></ng-content>\n </span>\n <span *ngIf=\"tableSortHeader && align !== 'right'\">\n <ng-container *ngTemplateOutlet=\"sortIcon\"></ng-container>\n </span>\n</div>\n\n<ng-template #sortIcon>\n <span\n *ngIf=\"tableSortHeader\"\n aria-hidden=\"true\"\n [class.sapphire-table-sortableIcon]=\"\n tableSortHeader.tableSort.sortDescriptor.column !==\n tableSortHeader.sortHeader\n \"\n [class.sapphire-table-sortedIcon]=\"\n tableSortHeader.tableSort.sortDescriptor.column ===\n tableSortHeader.sortHeader\n \"\n _spUseComponentStyles\n >\n <sp-icon\n [name]=\"\n tableSortHeader.tableSort.sortDescriptor.column ===\n tableSortHeader.sortHeader &&\n tableSortHeader.tableSort.sortDescriptor.direction === 'descending'\n ? 'caretDownMedium'\n : 'caretUpMedium'\n \"\n ></sp-icon>\n </span>\n</ng-template>\n" }]
44
+ '[class.sapphire-table__selectionCell]': 'selectionCell',
45
+ }, hostDirectives: [UseComponentStyles], template: "<div\n *ngIf=\"!selectionCell\"\n class=\"sapphire-table__headCell_container\"\n _spUseComponentStyles\n>\n <span *ngIf=\"tableSortHeader && align === 'right'\">\n <ng-container *ngTemplateOutlet=\"sortIcon\"></ng-container>\n </span>\n <span [spTruncatedWithTooltip]=\"cellOverflow === 'truncate'\">\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </span>\n <span *ngIf=\"tableSortHeader && align !== 'right'\">\n <ng-container *ngTemplateOutlet=\"sortIcon\"></ng-container>\n </span>\n</div>\n<ng-container *ngIf=\"selectionCell\"\n ><ng-container *ngTemplateOutlet=\"content\"></ng-container\n></ng-container>\n\n<ng-template #content><ng-content></ng-content></ng-template>\n\n<ng-template #sortIcon>\n <span\n *ngIf=\"tableSortHeader\"\n aria-hidden=\"true\"\n [class.sapphire-table-sortableIcon]=\"\n tableSortHeader.tableSort.sortDescriptor.column !==\n tableSortHeader.sortHeader\n \"\n [class.sapphire-table-sortedIcon]=\"\n tableSortHeader.tableSort.sortDescriptor.column ===\n tableSortHeader.sortHeader\n \"\n _spUseComponentStyles\n >\n <sp-icon\n [name]=\"\n tableSortHeader.tableSort.sortDescriptor.column ===\n tableSortHeader.sortHeader &&\n tableSortHeader.tableSort.sortDescriptor.direction === 'descending'\n ? 'caretDownMedium'\n : 'caretUpMedium'\n \"\n ></sp-icon>\n </span>\n</ng-template>\n" }]
34
46
  }], ctorParameters: function () { return [{ type: i6.TableComponent, decorators: [{
35
47
  type: Inject,
36
48
  args: [forwardRef(() => TableComponent)]
@@ -53,5 +65,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImpor
53
65
  args: ['style.max-width']
54
66
  }, {
55
67
  type: Input
68
+ }], selectionCell: [{
69
+ type: Input
56
70
  }] } });
57
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtaGVhZC1jZWxsLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9saWIvdGFibGUvc3JjL3RhYmxlLWhlYWQtY2VsbC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9zcmMvbGliL3RhYmxlL3NyYy90YWJsZS1oZWFkZXItY2VsbC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsU0FBUyxFQUNULFVBQVUsRUFDVixXQUFXLEVBQ1gsTUFBTSxFQUNOLEtBQUssRUFDTCxRQUFRLEdBQ1QsTUFBTSxlQUFlLENBQUM7QUFFdkIsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ25ELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDBDQUEwQyxDQUFDOzs7Ozs7OztBQWE5RSxNQUFNLE9BQU8sc0JBQXNCO0lBbUJqQyxJQUFJLFlBQVk7UUFDZCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsWUFBWSxDQUFDO0lBQ2pDLENBQUM7SUFFRCxZQUVVLEtBQXFCLEVBQ1YsZUFBMEM7UUFEckQsVUFBSyxHQUFMLEtBQUssQ0FBZ0I7UUFDVixvQkFBZSxHQUFmLGVBQWUsQ0FBMkI7UUF6Qi9EOztXQUVHO1FBRUgsVUFBSyxHQUFpQyxNQUFNLENBQUM7SUFzQjFDLENBQUM7O21IQTNCTyxzQkFBc0Isa0JBd0J2QixVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsY0FBYyxDQUFDO3VHQXhCL0Isc0JBQXNCLCtpQkN2Qm5DLDhxQ0FxQ0E7MkZEZGEsc0JBQXNCO2tCQVhsQyxTQUFTOytCQUNFLGlCQUFpQixRQUVyQjt3QkFDSixLQUFLLEVBQUUsMEJBQTBCO3dCQUNqQyx5Q0FBeUMsRUFBRSxrQkFBa0I7d0JBQzdELDJDQUEyQyxFQUFFLG9CQUFvQjt3QkFDakUsMENBQTBDLEVBQUUsbUJBQW1CO3FCQUNoRSxrQkFDZSxDQUFDLGtCQUFrQixDQUFDOzswQkEwQmpDLE1BQU07MkJBQUMsVUFBVSxDQUFDLEdBQUcsRUFBRSxDQUFDLGNBQWMsQ0FBQzs7MEJBRXZDLFFBQVE7NENBckJYLEtBQUs7c0JBREosS0FBSztnQkFLTixLQUFLO3NCQUZKLFdBQVc7dUJBQUMsYUFBYTs7c0JBQ3pCLEtBQUs7Z0JBS04sUUFBUTtzQkFGUCxXQUFXO3VCQUFDLGlCQUFpQjs7c0JBQzdCLEtBQUs7Z0JBS04sUUFBUTtzQkFGUCxXQUFXO3VCQUFDLGlCQUFpQjs7c0JBQzdCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDb21wb25lbnQsXG4gIGZvcndhcmRSZWYsXG4gIEhvc3RCaW5kaW5nLFxuICBJbmplY3QsXG4gIElucHV0LFxuICBPcHRpb25hbCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUYWJsZVNvcnRIZWFkZXJEaXJlY3RpdmUgfSBmcm9tICcuL3RhYmxlLXNvcnQtaGVhZGVyLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBUYWJsZUNvbXBvbmVudCB9IGZyb20gJy4vdGFibGUuY29tcG9uZW50JztcbmltcG9ydCB7IFVzZUNvbXBvbmVudFN0eWxlcyB9IGZyb20gJy4uLy4uL2NvbW1vbi9zYXBwaGlyZS12aWV3LWVuY2Fwc3VsYXRpb24nO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd0aFtzcC10YWJsZS10aF0nLFxuICB0ZW1wbGF0ZVVybDogJy4vdGFibGUtaGVhZGVyLWNlbGwuY29tcG9uZW50Lmh0bWwnLFxuICBob3N0OiB7XG4gICAgY2xhc3M6ICdzYXBwaGlyZS10YWJsZV9faGVhZENlbGwnLFxuICAgICdbY2xhc3Muc2FwcGhpcmUtdGFibGVfX2NlbGwtLWFsaWduTGVmdF0nOiBcImFsaWduID09PSAnbGVmdCdcIixcbiAgICAnW2NsYXNzLnNhcHBoaXJlLXRhYmxlX19jZWxsLS1hbGlnbkNlbnRlcl0nOiBcImFsaWduID09PSAnY2VudGVyJ1wiLFxuICAgICdbY2xhc3Muc2FwcGhpcmUtdGFibGVfX2NlbGwtLWFsaWduUmlnaHRdJzogXCJhbGlnbiA9PT0gJ3JpZ2h0J1wiLFxuICB9LFxuICBob3N0RGlyZWN0aXZlczogW1VzZUNvbXBvbmVudFN0eWxlc10sXG59KVxuZXhwb3J0IGNsYXNzIFRhYmxlSGVhZENlbGxDb21wb25lbnQge1xuICAvKipcbiAgICogSG9yaXpvbnRhbCBhbGlnbm1lbnQgb2YgY29udGVudCBpbiB0aGUgY2VsbC5cbiAgICovXG4gIEBJbnB1dCgpXG4gIGFsaWduPzogJ2xlZnQnIHwgJ2NlbnRlcicgfCAncmlnaHQnID0gJ2xlZnQnO1xuXG4gIEBIb3N0QmluZGluZygnc3R5bGUud2lkdGgnKVxuICBASW5wdXQoKVxuICB3aWR0aD86IHN0cmluZztcblxuICBASG9zdEJpbmRpbmcoJ3N0eWxlLm1pbi13aWR0aCcpXG4gIEBJbnB1dCgpXG4gIG1pbldpZHRoPzogc3RyaW5nO1xuXG4gIEBIb3N0QmluZGluZygnc3R5bGUubWF4LXdpZHRoJylcbiAgQElucHV0KClcbiAgbWF4V2lkdGg/OiBzdHJpbmc7XG5cbiAgZ2V0IGNlbGxPdmVyZmxvdygpIHtcbiAgICByZXR1cm4gdGhpcy50YWJsZS5jZWxsT3ZlcmZsb3c7XG4gIH1cblxuICBjb25zdHJ1Y3RvcihcbiAgICBASW5qZWN0KGZvcndhcmRSZWYoKCkgPT4gVGFibGVDb21wb25lbnQpKVxuICAgIHByaXZhdGUgdGFibGU6IFRhYmxlQ29tcG9uZW50LFxuICAgIEBPcHRpb25hbCgpIHB1YmxpYyB0YWJsZVNvcnRIZWFkZXI/OiBUYWJsZVNvcnRIZWFkZXJEaXJlY3RpdmVcbiAgKSB7fVxufVxuIiwiPGRpdiBjbGFzcz1cInNhcHBoaXJlLXRhYmxlX19oZWFkQ2VsbF9jb250YWluZXJcIiBfc3BVc2VDb21wb25lbnRTdHlsZXM+XG4gIDxzcGFuICpuZ0lmPVwidGFibGVTb3J0SGVhZGVyICYmIGFsaWduID09PSAncmlnaHQnXCI+XG4gICAgPG5nLWNvbnRhaW5lciAqbmdUZW1wbGF0ZU91dGxldD1cInNvcnRJY29uXCI+PC9uZy1jb250YWluZXI+XG4gIDwvc3Bhbj5cbiAgPHNwYW4gW3NwVHJ1bmNhdGVkV2l0aFRvb2x0aXBdPVwiY2VsbE92ZXJmbG93ID09PSAndHJ1bmNhdGUnXCI+XG4gICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICA8L3NwYW4+XG4gIDxzcGFuICpuZ0lmPVwidGFibGVTb3J0SGVhZGVyICYmIGFsaWduICE9PSAncmlnaHQnXCI+XG4gICAgPG5nLWNvbnRhaW5lciAqbmdUZW1wbGF0ZU91dGxldD1cInNvcnRJY29uXCI+PC9uZy1jb250YWluZXI+XG4gIDwvc3Bhbj5cbjwvZGl2PlxuXG48bmctdGVtcGxhdGUgI3NvcnRJY29uPlxuICA8c3BhblxuICAgICpuZ0lmPVwidGFibGVTb3J0SGVhZGVyXCJcbiAgICBhcmlhLWhpZGRlbj1cInRydWVcIlxuICAgIFtjbGFzcy5zYXBwaGlyZS10YWJsZS1zb3J0YWJsZUljb25dPVwiXG4gICAgICB0YWJsZVNvcnRIZWFkZXIudGFibGVTb3J0LnNvcnREZXNjcmlwdG9yLmNvbHVtbiAhPT1cbiAgICAgIHRhYmxlU29ydEhlYWRlci5zb3J0SGVhZGVyXG4gICAgXCJcbiAgICBbY2xhc3Muc2FwcGhpcmUtdGFibGUtc29ydGVkSWNvbl09XCJcbiAgICAgIHRhYmxlU29ydEhlYWRlci50YWJsZVNvcnQuc29ydERlc2NyaXB0b3IuY29sdW1uID09PVxuICAgICAgdGFibGVTb3J0SGVhZGVyLnNvcnRIZWFkZXJcbiAgICBcIlxuICAgIF9zcFVzZUNvbXBvbmVudFN0eWxlc1xuICA+XG4gICAgPHNwLWljb25cbiAgICAgIFtuYW1lXT1cIlxuICAgICAgICB0YWJsZVNvcnRIZWFkZXIudGFibGVTb3J0LnNvcnREZXNjcmlwdG9yLmNvbHVtbiA9PT1cbiAgICAgICAgICB0YWJsZVNvcnRIZWFkZXIuc29ydEhlYWRlciAmJlxuICAgICAgICB0YWJsZVNvcnRIZWFkZXIudGFibGVTb3J0LnNvcnREZXNjcmlwdG9yLmRpcmVjdGlvbiA9PT0gJ2Rlc2NlbmRpbmcnXG4gICAgICAgICAgPyAnY2FyZXREb3duTWVkaXVtJ1xuICAgICAgICAgIDogJ2NhcmV0VXBNZWRpdW0nXG4gICAgICBcIlxuICAgID48L3NwLWljb24+XG4gIDwvc3Bhbj5cbjwvbmctdGVtcGxhdGU+XG4iXX0=
71
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtaGVhZC1jZWxsLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9saWIvdGFibGUvc3JjL3RhYmxlLWhlYWQtY2VsbC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9zcmMvbGliL3RhYmxlL3NyYy90YWJsZS1oZWFkZXItY2VsbC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUNMLFNBQVMsRUFDVCxVQUFVLEVBQ1YsV0FBVyxFQUNYLE1BQU0sRUFDTixLQUFLLEVBQ0wsUUFBUSxHQUNULE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUNuRCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSwwQ0FBMEMsQ0FBQztBQUM5RSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sdUNBQXVDLENBQUM7Ozs7Ozs7O0FBZ0J0RSxNQUFNLE9BQU8sc0JBQXNCO0lBMkJqQyxJQUFJLFlBQVk7UUFDZCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsWUFBWSxDQUFDO0lBQ2pDLENBQUM7SUFFRCxZQUVVLEtBQXFCLEVBQ1YsZUFBMEM7UUFEckQsVUFBSyxHQUFMLEtBQUssQ0FBZ0I7UUFDVixvQkFBZSxHQUFmLGVBQWUsQ0FBMkI7UUFqQy9EOztXQUVHO1FBRUgsVUFBSyxHQUFpQyxNQUFNLENBQUM7UUFjN0M7OztXQUdHO1FBR0gsa0JBQWEsR0FBaUIsS0FBSyxDQUFDO0lBVWpDLENBQUM7O21IQW5DTyxzQkFBc0Isa0JBZ0N2QixVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsY0FBYyxDQUFDO3VHQWhDL0Isc0JBQXNCLDhyQkMzQm5DLDY2Q0E4Q0E7QURNRTtJQURDLGFBQWE7NkRBQ3NCOzJGQXpCekIsc0JBQXNCO2tCQWJsQyxTQUFTOytCQUNFLGlCQUFpQixRQUVyQjt3QkFDSixrQ0FBa0MsRUFBRSxnQkFBZ0I7d0JBQ3BELDhCQUE4QixFQUFFLGVBQWU7d0JBQy9DLHlDQUF5QyxFQUFFLGtCQUFrQjt3QkFDN0QsMkNBQTJDLEVBQUUsb0JBQW9CO3dCQUNqRSwwQ0FBMEMsRUFBRSxtQkFBbUI7d0JBQy9ELHVDQUF1QyxFQUFFLGVBQWU7cUJBQ3pELGtCQUNlLENBQUMsa0JBQWtCLENBQUM7OzBCQWtDakMsTUFBTTsyQkFBQyxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsY0FBYyxDQUFDOzswQkFFdkMsUUFBUTs0Q0E3QlgsS0FBSztzQkFESixLQUFLO2dCQUtOLEtBQUs7c0JBRkosV0FBVzt1QkFBQyxhQUFhOztzQkFDekIsS0FBSztnQkFLTixRQUFRO3NCQUZQLFdBQVc7dUJBQUMsaUJBQWlCOztzQkFDN0IsS0FBSztnQkFLTixRQUFRO3NCQUZQLFdBQVc7dUJBQUMsaUJBQWlCOztzQkFDN0IsS0FBSztnQkFTTixhQUFhO3NCQUZaLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDb21wb25lbnQsXG4gIGZvcndhcmRSZWYsXG4gIEhvc3RCaW5kaW5nLFxuICBJbmplY3QsXG4gIElucHV0LFxuICBPcHRpb25hbCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUYWJsZVNvcnRIZWFkZXJEaXJlY3RpdmUgfSBmcm9tICcuL3RhYmxlLXNvcnQtaGVhZGVyLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBUYWJsZUNvbXBvbmVudCB9IGZyb20gJy4vdGFibGUuY29tcG9uZW50JztcbmltcG9ydCB7IFVzZUNvbXBvbmVudFN0eWxlcyB9IGZyb20gJy4uLy4uL2NvbW1vbi9zYXBwaGlyZS12aWV3LWVuY2Fwc3VsYXRpb24nO1xuaW1wb3J0IHsgQ29lcmNlQm9vbGVhbiB9IGZyb20gJy4uLy4uL2NvbW1vbi9jb2VyY2UtYm9vbGVhbi5kZWNvcmF0b3InO1xuaW1wb3J0IHsgQm9vbGVhbklucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2NvZXJjaW9uJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndGhbc3AtdGFibGUtdGhdJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3RhYmxlLWhlYWRlci1jZWxsLmNvbXBvbmVudC5odG1sJyxcbiAgaG9zdDoge1xuICAgICdbY2xhc3Muc2FwcGhpcmUtdGFibGVfX2hlYWRDZWxsXSc6ICchc2VsZWN0aW9uQ2VsbCcsXG4gICAgJ1tjbGFzcy5zYXBwaGlyZS10YWJsZV9fY2VsbF0nOiAnc2VsZWN0aW9uQ2VsbCcsXG4gICAgJ1tjbGFzcy5zYXBwaGlyZS10YWJsZV9fY2VsbC0tYWxpZ25MZWZ0XSc6IFwiYWxpZ24gPT09ICdsZWZ0J1wiLFxuICAgICdbY2xhc3Muc2FwcGhpcmUtdGFibGVfX2NlbGwtLWFsaWduQ2VudGVyXSc6IFwiYWxpZ24gPT09ICdjZW50ZXInXCIsXG4gICAgJ1tjbGFzcy5zYXBwaGlyZS10YWJsZV9fY2VsbC0tYWxpZ25SaWdodF0nOiBcImFsaWduID09PSAncmlnaHQnXCIsXG4gICAgJ1tjbGFzcy5zYXBwaGlyZS10YWJsZV9fc2VsZWN0aW9uQ2VsbF0nOiAnc2VsZWN0aW9uQ2VsbCcsXG4gIH0sXG4gIGhvc3REaXJlY3RpdmVzOiBbVXNlQ29tcG9uZW50U3R5bGVzXSxcbn0pXG5leHBvcnQgY2xhc3MgVGFibGVIZWFkQ2VsbENvbXBvbmVudCB7XG4gIC8qKlxuICAgKiBIb3Jpem9udGFsIGFsaWdubWVudCBvZiBjb250ZW50IGluIHRoZSBjZWxsLlxuICAgKi9cbiAgQElucHV0KClcbiAgYWxpZ24/OiAnbGVmdCcgfCAnY2VudGVyJyB8ICdyaWdodCcgPSAnbGVmdCc7XG5cbiAgQEhvc3RCaW5kaW5nKCdzdHlsZS53aWR0aCcpXG4gIEBJbnB1dCgpXG4gIHdpZHRoPzogc3RyaW5nO1xuXG4gIEBIb3N0QmluZGluZygnc3R5bGUubWluLXdpZHRoJylcbiAgQElucHV0KClcbiAgbWluV2lkdGg/OiBzdHJpbmc7XG5cbiAgQEhvc3RCaW5kaW5nKCdzdHlsZS5tYXgtd2lkdGgnKVxuICBASW5wdXQoKVxuICBtYXhXaWR0aD86IHN0cmluZztcblxuICAvKipcbiAgICogQXBwbGllcyB0aGUgc3R5bGVzIGZvciBzZWxlY3Rpb24gY2VsbC4gQSBzZWxlY3Rpb24gY2VsbCBpcyB0aGUgZmlyc3QgY2VsbCBpbiBhIHJvdywgY29udGFpbmluZ1xuICAgKiBhIGNoZWNrYm94LlxuICAgKi9cbiAgQElucHV0KClcbiAgQENvZXJjZUJvb2xlYW5cbiAgc2VsZWN0aW9uQ2VsbDogQm9vbGVhbklucHV0ID0gZmFsc2U7XG5cbiAgZ2V0IGNlbGxPdmVyZmxvdygpIHtcbiAgICByZXR1cm4gdGhpcy50YWJsZS5jZWxsT3ZlcmZsb3c7XG4gIH1cblxuICBjb25zdHJ1Y3RvcihcbiAgICBASW5qZWN0KGZvcndhcmRSZWYoKCkgPT4gVGFibGVDb21wb25lbnQpKVxuICAgIHByaXZhdGUgdGFibGU6IFRhYmxlQ29tcG9uZW50LFxuICAgIEBPcHRpb25hbCgpIHB1YmxpYyB0YWJsZVNvcnRIZWFkZXI/OiBUYWJsZVNvcnRIZWFkZXJEaXJlY3RpdmVcbiAgKSB7fVxufVxuIiwiPGRpdlxuICAqbmdJZj1cIiFzZWxlY3Rpb25DZWxsXCJcbiAgY2xhc3M9XCJzYXBwaGlyZS10YWJsZV9faGVhZENlbGxfY29udGFpbmVyXCJcbiAgX3NwVXNlQ29tcG9uZW50U3R5bGVzXG4+XG4gIDxzcGFuICpuZ0lmPVwidGFibGVTb3J0SGVhZGVyICYmIGFsaWduID09PSAncmlnaHQnXCI+XG4gICAgPG5nLWNvbnRhaW5lciAqbmdUZW1wbGF0ZU91dGxldD1cInNvcnRJY29uXCI+PC9uZy1jb250YWluZXI+XG4gIDwvc3Bhbj5cbiAgPHNwYW4gW3NwVHJ1bmNhdGVkV2l0aFRvb2x0aXBdPVwiY2VsbE92ZXJmbG93ID09PSAndHJ1bmNhdGUnXCI+XG4gICAgPG5nLWNvbnRhaW5lciAqbmdUZW1wbGF0ZU91dGxldD1cImNvbnRlbnRcIj48L25nLWNvbnRhaW5lcj5cbiAgPC9zcGFuPlxuICA8c3BhbiAqbmdJZj1cInRhYmxlU29ydEhlYWRlciAmJiBhbGlnbiAhPT0gJ3JpZ2h0J1wiPlxuICAgIDxuZy1jb250YWluZXIgKm5nVGVtcGxhdGVPdXRsZXQ9XCJzb3J0SWNvblwiPjwvbmctY29udGFpbmVyPlxuICA8L3NwYW4+XG48L2Rpdj5cbjxuZy1jb250YWluZXIgKm5nSWY9XCJzZWxlY3Rpb25DZWxsXCJcbiAgPjxuZy1jb250YWluZXIgKm5nVGVtcGxhdGVPdXRsZXQ9XCJjb250ZW50XCI+PC9uZy1jb250YWluZXJcbj48L25nLWNvbnRhaW5lcj5cblxuPG5nLXRlbXBsYXRlICNjb250ZW50PjxuZy1jb250ZW50PjwvbmctY29udGVudD48L25nLXRlbXBsYXRlPlxuXG48bmctdGVtcGxhdGUgI3NvcnRJY29uPlxuICA8c3BhblxuICAgICpuZ0lmPVwidGFibGVTb3J0SGVhZGVyXCJcbiAgICBhcmlhLWhpZGRlbj1cInRydWVcIlxuICAgIFtjbGFzcy5zYXBwaGlyZS10YWJsZS1zb3J0YWJsZUljb25dPVwiXG4gICAgICB0YWJsZVNvcnRIZWFkZXIudGFibGVTb3J0LnNvcnREZXNjcmlwdG9yLmNvbHVtbiAhPT1cbiAgICAgIHRhYmxlU29ydEhlYWRlci5zb3J0SGVhZGVyXG4gICAgXCJcbiAgICBbY2xhc3Muc2FwcGhpcmUtdGFibGUtc29ydGVkSWNvbl09XCJcbiAgICAgIHRhYmxlU29ydEhlYWRlci50YWJsZVNvcnQuc29ydERlc2NyaXB0b3IuY29sdW1uID09PVxuICAgICAgdGFibGVTb3J0SGVhZGVyLnNvcnRIZWFkZXJcbiAgICBcIlxuICAgIF9zcFVzZUNvbXBvbmVudFN0eWxlc1xuICA+XG4gICAgPHNwLWljb25cbiAgICAgIFtuYW1lXT1cIlxuICAgICAgICB0YWJsZVNvcnRIZWFkZXIudGFibGVTb3J0LnNvcnREZXNjcmlwdG9yLmNvbHVtbiA9PT1cbiAgICAgICAgICB0YWJsZVNvcnRIZWFkZXIuc29ydEhlYWRlciAmJlxuICAgICAgICB0YWJsZVNvcnRIZWFkZXIudGFibGVTb3J0LnNvcnREZXNjcmlwdG9yLmRpcmVjdGlvbiA9PT0gJ2Rlc2NlbmRpbmcnXG4gICAgICAgICAgPyAnY2FyZXREb3duTWVkaXVtJ1xuICAgICAgICAgIDogJ2NhcmV0VXBNZWRpdW0nXG4gICAgICBcIlxuICAgID48L3NwLWljb24+XG4gIDwvc3Bhbj5cbjwvbmctdGVtcGxhdGU+XG4iXX0=
@@ -25,13 +25,20 @@ export class TableRowDirective {
25
25
  this.cells = new QueryList();
26
26
  this.rowData = null;
27
27
  this.disabled = false;
28
+ /**
29
+ * Applies selected row styles, and marks the row as selected for assistive technology.
30
+ */
31
+ this.selected = false;
28
32
  }
29
33
  }
30
34
  TableRowDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: TableRowDirective, deps: [{ token: forwardRef(() => TableComponent) }], target: i0.ɵɵFactoryTarget.Directive });
31
- TableRowDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.0", type: TableRowDirective, selector: "tr[sp-table-tr]", inputs: { rowData: "rowData", disabled: "disabled" }, host: { listeners: { "click": "onRowClick()" }, properties: { "class.js-hover": "disabled" }, classAttribute: "sapphire-table__row" }, queries: [{ propertyName: "cells", predicate: TableCellDirective }], hostDirectives: [{ directive: i1.UseComponentStyles }], ngImport: i0 });
35
+ TableRowDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.0", type: TableRowDirective, selector: "tr[sp-table-tr]", inputs: { rowData: "rowData", disabled: "disabled", selected: "selected" }, host: { listeners: { "click": "onRowClick()" }, properties: { "class.sapphire-table__row--selected": "selected", "attr.aria-selected": "selected || null", "class.js-hover": "disabled" }, classAttribute: "sapphire-table__row" }, queries: [{ propertyName: "cells", predicate: TableCellDirective }], hostDirectives: [{ directive: i1.UseComponentStyles }], ngImport: i0 });
32
36
  __decorate([
33
37
  CoerceBoolean
34
38
  ], TableRowDirective.prototype, "disabled", void 0);
39
+ __decorate([
40
+ CoerceBoolean
41
+ ], TableRowDirective.prototype, "selected", void 0);
35
42
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: TableRowDirective, decorators: [{
36
43
  type: Directive,
37
44
  args: [{
@@ -43,6 +50,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImpor
43
50
  * The "js-hover" class basically means that we're taking over the hover
44
51
  * styles from css.
45
52
  */
53
+ '[class.sapphire-table__row--selected]': 'selected',
54
+ '[attr.aria-selected]': 'selected || null',
46
55
  '[class.js-hover]': 'disabled',
47
56
  },
48
57
  hostDirectives: [UseComponentStyles],
@@ -57,8 +66,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImpor
57
66
  type: Input
58
67
  }], disabled: [{
59
68
  type: Input
69
+ }], selected: [{
70
+ type: Input
60
71
  }], onRowClick: [{
61
72
  type: HostListener,
62
73
  args: ['click']
63
74
  }] } });
64
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtcm93LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9saWIvdGFibGUvc3JjL3RhYmxlLXJvdy5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFDTCxlQUFlLEVBQ2YsU0FBUyxFQUNULFVBQVUsRUFDVixZQUFZLEVBQ1osTUFBTSxFQUNOLEtBQUssRUFDTCxTQUFTLEdBQ1YsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ25ELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBRTVELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBQzlFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQzs7OztBQWdCdEUsTUFBTSxPQUFPLGlCQUFpQjtJQVlwQixVQUFVO1FBQ2hCLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFO1lBQ2xCLElBQUksQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQztnQkFDeEIsS0FBSyxFQUNILElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxFQUFFLE9BQU8sRUFBRSxDQUFDLFNBQVMsQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFLENBQUMsR0FBRyxLQUFLLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztnQkFDbkUsT0FBTyxFQUFFLElBQUksQ0FBQyxPQUFPO2FBQ3RCLENBQUMsQ0FBQztTQUNKO0lBQ0gsQ0FBQztJQUVNLGlCQUFpQixDQUFDLElBQXdCO1FBQy9DLE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxFQUFFLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ2pELE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxTQUFTLEVBQUUsT0FBTyxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDaEQsQ0FBQztJQUVELFlBRVMsS0FBcUI7UUFBckIsVUFBSyxHQUFMLEtBQUssQ0FBZ0I7UUEzQjlCLFVBQUssR0FBa0MsSUFBSSxTQUFTLEVBQUUsQ0FBQztRQUd2RCxZQUFPLEdBQWEsSUFBSSxDQUFDO1FBSXpCLGFBQVEsR0FBaUIsS0FBSyxDQUFDO0lBcUI1QixDQUFDOzs4R0E5Qk8saUJBQWlCLGtCQTRCbEIsVUFBVSxDQUFDLEdBQUcsRUFBRSxDQUFDLGNBQWMsQ0FBQztrR0E1Qi9CLGlCQUFpQiwwUUFDWCxrQkFBa0I7QUFRbkM7SUFEQyxhQUFhO21EQUNpQjsyRkFUcEIsaUJBQWlCO2tCQWI3QixTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxpQkFBaUI7b0JBQzNCLElBQUksRUFBRTt3QkFDSixLQUFLLEVBQUUscUJBQXFCO3dCQUM1Qjs7OzsyQkFJRzt3QkFDSCxrQkFBa0IsRUFBRSxVQUFVO3FCQUMvQjtvQkFDRCxjQUFjLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQztpQkFDckM7OzBCQTZCSSxNQUFNOzJCQUFDLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxjQUFjLENBQUM7NENBMUIxQyxLQUFLO3NCQURKLGVBQWU7dUJBQUMsa0JBQWtCO2dCQUluQyxPQUFPO3NCQUROLEtBQUs7Z0JBS04sUUFBUTtzQkFGUCxLQUFLO2dCQUtFLFVBQVU7c0JBRGpCLFlBQVk7dUJBQUMsT0FBTyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENvbnRlbnRDaGlsZHJlbixcbiAgRGlyZWN0aXZlLFxuICBmb3J3YXJkUmVmLFxuICBIb3N0TGlzdGVuZXIsXG4gIEluamVjdCxcbiAgSW5wdXQsXG4gIFF1ZXJ5TGlzdCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUYWJsZUNvbXBvbmVudCB9IGZyb20gJy4vdGFibGUuY29tcG9uZW50JztcbmltcG9ydCB7IFRhYmxlQ2VsbERpcmVjdGl2ZSB9IGZyb20gJy4vdGFibGUtY2VsbC5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgVGFibGVIZWFkQ2VsbENvbXBvbmVudCB9IGZyb20gJy4vdGFibGUtaGVhZC1jZWxsLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBVc2VDb21wb25lbnRTdHlsZXMgfSBmcm9tICcuLi8uLi9jb21tb24vc2FwcGhpcmUtdmlldy1lbmNhcHN1bGF0aW9uJztcbmltcG9ydCB7IENvZXJjZUJvb2xlYW4gfSBmcm9tICcuLi8uLi9jb21tb24vY29lcmNlLWJvb2xlYW4uZGVjb3JhdG9yJztcbmltcG9ydCB7IEJvb2xlYW5JbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9jb2VyY2lvbic7XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ3RyW3NwLXRhYmxlLXRyXScsXG4gIGhvc3Q6IHtcbiAgICBjbGFzczogJ3NhcHBoaXJlLXRhYmxlX19yb3cnLFxuICAgIC8qKlxuICAgICAqIFdlIHdhbnQgdGhlIGNzcyBob3ZlciBzdHlsZXMgdG8gbm90IGJlIGFwcGxpZWQgZm9yIHRoZSBkaXNhYmxlZCByb3dzLlxuICAgICAqIFRoZSBcImpzLWhvdmVyXCIgY2xhc3MgYmFzaWNhbGx5IG1lYW5zIHRoYXQgd2UncmUgdGFraW5nIG92ZXIgdGhlIGhvdmVyXG4gICAgICogc3R5bGVzIGZyb20gY3NzLlxuICAgICAqL1xuICAgICdbY2xhc3MuanMtaG92ZXJdJzogJ2Rpc2FibGVkJyxcbiAgfSxcbiAgaG9zdERpcmVjdGl2ZXM6IFtVc2VDb21wb25lbnRTdHlsZXNdLFxufSlcbmV4cG9ydCBjbGFzcyBUYWJsZVJvd0RpcmVjdGl2ZTxEID0gdW5rbm93bj4ge1xuICBAQ29udGVudENoaWxkcmVuKFRhYmxlQ2VsbERpcmVjdGl2ZSlcbiAgY2VsbHM6IFF1ZXJ5TGlzdDxUYWJsZUNlbGxEaXJlY3RpdmU+ID0gbmV3IFF1ZXJ5TGlzdCgpO1xuXG4gIEBJbnB1dCgpXG4gIHJvd0RhdGE6IEQgfCBudWxsID0gbnVsbDtcblxuICBASW5wdXQoKVxuICBAQ29lcmNlQm9vbGVhblxuICBkaXNhYmxlZDogQm9vbGVhbklucHV0ID0gZmFsc2U7XG5cbiAgQEhvc3RMaXN0ZW5lcignY2xpY2snKVxuICBwcml2YXRlIG9uUm93Q2xpY2soKSB7XG4gICAgaWYgKCF0aGlzLmRpc2FibGVkKSB7XG4gICAgICB0aGlzLnRhYmxlLnJvd0FjdGlvbi5lbWl0KHtcbiAgICAgICAgaW5kZXg6XG4gICAgICAgICAgdGhpcy50YWJsZS5yb3dzPy50b0FycmF5KCkuZmluZEluZGV4KChyb3cpID0+IHJvdyA9PT0gdGhpcykgPz8gLTEsXG4gICAgICAgIHJvd0RhdGE6IHRoaXMucm93RGF0YSxcbiAgICAgIH0pO1xuICAgIH1cbiAgfVxuXG4gIHB1YmxpYyBnZXRDb2x1bW5IZWFkQ2VsbChjZWxsOiBUYWJsZUNlbGxEaXJlY3RpdmUpIHtcbiAgICBjb25zdCBpbmRleCA9IHRoaXMuY2VsbHMudG9BcnJheSgpLmluZGV4T2YoY2VsbCk7XG4gICAgcmV0dXJuIHRoaXMudGFibGUuaGVhZENlbGxzPy50b0FycmF5KClbaW5kZXhdO1xuICB9XG5cbiAgY29uc3RydWN0b3IoXG4gICAgQEluamVjdChmb3J3YXJkUmVmKCgpID0+IFRhYmxlQ29tcG9uZW50KSlcbiAgICBwdWJsaWMgdGFibGU6IFRhYmxlQ29tcG9uZW50XG4gICkge31cbn1cbiJdfQ==
75
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtcm93LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9saWIvdGFibGUvc3JjL3RhYmxlLXJvdy5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFDTCxlQUFlLEVBQ2YsU0FBUyxFQUNULFVBQVUsRUFDVixZQUFZLEVBQ1osTUFBTSxFQUNOLEtBQUssRUFDTCxTQUFTLEdBQ1YsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ25ELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQzVELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBQzlFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQzs7OztBQWtCdEUsTUFBTSxPQUFPLGlCQUFpQjtJQW1CcEIsVUFBVTtRQUNoQixJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUNsQixJQUFJLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUM7Z0JBQ3hCLEtBQUssRUFDSCxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksRUFBRSxPQUFPLEVBQUUsQ0FBQyxTQUFTLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUFDLEdBQUcsS0FBSyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7Z0JBQ25FLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTzthQUN0QixDQUFDLENBQUM7U0FDSjtJQUNILENBQUM7SUFFTSxpQkFBaUIsQ0FBQyxJQUF3QjtRQUMvQyxNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sRUFBRSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNqRCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsU0FBUyxFQUFFLE9BQU8sRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2hELENBQUM7SUFFRCxZQUVTLEtBQXFCO1FBQXJCLFVBQUssR0FBTCxLQUFLLENBQWdCO1FBbEM5QixVQUFLLEdBQWtDLElBQUksU0FBUyxFQUFFLENBQUM7UUFHdkQsWUFBTyxHQUFhLElBQUksQ0FBQztRQUl6QixhQUFRLEdBQWlCLEtBQUssQ0FBQztRQUUvQjs7V0FFRztRQUdILGFBQVEsR0FBaUIsS0FBSyxDQUFDO0lBcUI1QixDQUFDOzs4R0FyQ08saUJBQWlCLGtCQW1DbEIsVUFBVSxDQUFDLEdBQUcsRUFBRSxDQUFDLGNBQWMsQ0FBQztrR0FuQy9CLGlCQUFpQiw2WEFDWCxrQkFBa0I7QUFRbkM7SUFEQyxhQUFhO21EQUNpQjtBQU8vQjtJQURDLGFBQWE7bURBQ2lCOzJGQWhCcEIsaUJBQWlCO2tCQWY3QixTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxpQkFBaUI7b0JBQzNCLElBQUksRUFBRTt3QkFDSixLQUFLLEVBQUUscUJBQXFCO3dCQUM1Qjs7OzsyQkFJRzt3QkFDSCx1Q0FBdUMsRUFBRSxVQUFVO3dCQUNuRCxzQkFBc0IsRUFBRSxrQkFBa0I7d0JBQzFDLGtCQUFrQixFQUFFLFVBQVU7cUJBQy9CO29CQUNELGNBQWMsRUFBRSxDQUFDLGtCQUFrQixDQUFDO2lCQUNyQzs7MEJBb0NJLE1BQU07MkJBQUMsVUFBVSxDQUFDLEdBQUcsRUFBRSxDQUFDLGNBQWMsQ0FBQzs0Q0FqQzFDLEtBQUs7c0JBREosZUFBZTt1QkFBQyxrQkFBa0I7Z0JBSW5DLE9BQU87c0JBRE4sS0FBSztnQkFLTixRQUFRO3NCQUZQLEtBQUs7Z0JBU04sUUFBUTtzQkFGUCxLQUFLO2dCQUtFLFVBQVU7c0JBRGpCLFlBQVk7dUJBQUMsT0FBTyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENvbnRlbnRDaGlsZHJlbixcbiAgRGlyZWN0aXZlLFxuICBmb3J3YXJkUmVmLFxuICBIb3N0TGlzdGVuZXIsXG4gIEluamVjdCxcbiAgSW5wdXQsXG4gIFF1ZXJ5TGlzdCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUYWJsZUNvbXBvbmVudCB9IGZyb20gJy4vdGFibGUuY29tcG9uZW50JztcbmltcG9ydCB7IFRhYmxlQ2VsbERpcmVjdGl2ZSB9IGZyb20gJy4vdGFibGUtY2VsbC5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgVXNlQ29tcG9uZW50U3R5bGVzIH0gZnJvbSAnLi4vLi4vY29tbW9uL3NhcHBoaXJlLXZpZXctZW5jYXBzdWxhdGlvbic7XG5pbXBvcnQgeyBDb2VyY2VCb29sZWFuIH0gZnJvbSAnLi4vLi4vY29tbW9uL2NvZXJjZS1ib29sZWFuLmRlY29yYXRvcic7XG5pbXBvcnQgeyBCb29sZWFuSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jZGsvY29lcmNpb24nO1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICd0cltzcC10YWJsZS10cl0nLFxuICBob3N0OiB7XG4gICAgY2xhc3M6ICdzYXBwaGlyZS10YWJsZV9fcm93JyxcbiAgICAvKipcbiAgICAgKiBXZSB3YW50IHRoZSBjc3MgaG92ZXIgc3R5bGVzIHRvIG5vdCBiZSBhcHBsaWVkIGZvciB0aGUgZGlzYWJsZWQgcm93cy5cbiAgICAgKiBUaGUgXCJqcy1ob3ZlclwiIGNsYXNzIGJhc2ljYWxseSBtZWFucyB0aGF0IHdlJ3JlIHRha2luZyBvdmVyIHRoZSBob3ZlclxuICAgICAqIHN0eWxlcyBmcm9tIGNzcy5cbiAgICAgKi9cbiAgICAnW2NsYXNzLnNhcHBoaXJlLXRhYmxlX19yb3ctLXNlbGVjdGVkXSc6ICdzZWxlY3RlZCcsXG4gICAgJ1thdHRyLmFyaWEtc2VsZWN0ZWRdJzogJ3NlbGVjdGVkIHx8IG51bGwnLFxuICAgICdbY2xhc3MuanMtaG92ZXJdJzogJ2Rpc2FibGVkJyxcbiAgfSxcbiAgaG9zdERpcmVjdGl2ZXM6IFtVc2VDb21wb25lbnRTdHlsZXNdLFxufSlcbmV4cG9ydCBjbGFzcyBUYWJsZVJvd0RpcmVjdGl2ZTxEID0gdW5rbm93bj4ge1xuICBAQ29udGVudENoaWxkcmVuKFRhYmxlQ2VsbERpcmVjdGl2ZSlcbiAgY2VsbHM6IFF1ZXJ5TGlzdDxUYWJsZUNlbGxEaXJlY3RpdmU+ID0gbmV3IFF1ZXJ5TGlzdCgpO1xuXG4gIEBJbnB1dCgpXG4gIHJvd0RhdGE6IEQgfCBudWxsID0gbnVsbDtcblxuICBASW5wdXQoKVxuICBAQ29lcmNlQm9vbGVhblxuICBkaXNhYmxlZDogQm9vbGVhbklucHV0ID0gZmFsc2U7XG5cbiAgLyoqXG4gICAqIEFwcGxpZXMgc2VsZWN0ZWQgcm93IHN0eWxlcywgYW5kIG1hcmtzIHRoZSByb3cgYXMgc2VsZWN0ZWQgZm9yIGFzc2lzdGl2ZSB0ZWNobm9sb2d5LlxuICAgKi9cbiAgQElucHV0KClcbiAgQENvZXJjZUJvb2xlYW5cbiAgc2VsZWN0ZWQ6IEJvb2xlYW5JbnB1dCA9IGZhbHNlO1xuXG4gIEBIb3N0TGlzdGVuZXIoJ2NsaWNrJylcbiAgcHJpdmF0ZSBvblJvd0NsaWNrKCkge1xuICAgIGlmICghdGhpcy5kaXNhYmxlZCkge1xuICAgICAgdGhpcy50YWJsZS5yb3dBY3Rpb24uZW1pdCh7XG4gICAgICAgIGluZGV4OlxuICAgICAgICAgIHRoaXMudGFibGUucm93cz8udG9BcnJheSgpLmZpbmRJbmRleCgocm93KSA9PiByb3cgPT09IHRoaXMpID8/IC0xLFxuICAgICAgICByb3dEYXRhOiB0aGlzLnJvd0RhdGEsXG4gICAgICB9KTtcbiAgICB9XG4gIH1cblxuICBwdWJsaWMgZ2V0Q29sdW1uSGVhZENlbGwoY2VsbDogVGFibGVDZWxsRGlyZWN0aXZlKSB7XG4gICAgY29uc3QgaW5kZXggPSB0aGlzLmNlbGxzLnRvQXJyYXkoKS5pbmRleE9mKGNlbGwpO1xuICAgIHJldHVybiB0aGlzLnRhYmxlLmhlYWRDZWxscz8udG9BcnJheSgpW2luZGV4XTtcbiAgfVxuXG4gIGNvbnN0cnVjdG9yKFxuICAgIEBJbmplY3QoZm9yd2FyZFJlZigoKSA9PiBUYWJsZUNvbXBvbmVudCkpXG4gICAgcHVibGljIHRhYmxlOiBUYWJsZUNvbXBvbmVudFxuICApIHt9XG59XG4iXX0=
@@ -1,17 +1,19 @@
1
- import { Directive } from '@angular/core';
1
+ import { Directive, Optional, SkipSelf } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
- import * as i1 from "./theme-base.directive";
3
+ import * as i1 from "./top-level-theme-ref.service";
4
+ import * as i2 from "./theme-base.directive";
4
5
  /**
5
6
  * Applies the current theme style on an element which is not under the rendered
6
7
  * sp-theme, in DOM tree. Useful for non-Sapphire portal components that render things in body.
7
8
  *
8
9
  */
9
10
  export class ThemeRootDirective {
10
- constructor(elementRef, theme) {
11
+ constructor(elementRef, themeRef, parentTheme) {
12
+ const theme = parentTheme || themeRef.theme;
11
13
  theme.applyOnDomNode(elementRef.nativeElement);
12
14
  }
13
15
  }
14
- ThemeRootDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: ThemeRootDirective, deps: [{ token: i0.ElementRef }, { token: i1.ThemeBaseDirective }], target: i0.ɵɵFactoryTarget.Directive });
16
+ ThemeRootDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: ThemeRootDirective, deps: [{ token: i0.ElementRef }, { token: i1.TopLevelThemeRef }, { token: i2.ThemeBaseDirective, optional: true, skipSelf: true }], target: i0.ɵɵFactoryTarget.Directive });
15
17
  ThemeRootDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.0", type: ThemeRootDirective, isStandalone: true, selector: "[sp-theme-root]", ngImport: i0 });
16
18
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: ThemeRootDirective, decorators: [{
17
19
  type: Directive,
@@ -19,5 +21,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImpor
19
21
  selector: '[sp-theme-root]',
20
22
  standalone: true,
21
23
  }]
22
- }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.ThemeBaseDirective }]; } });
23
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGhlbWUtcm9vdC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbGliL3RoZW1lL3NyYy90aGVtZS1yb290LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFjLE1BQU0sZUFBZSxDQUFDOzs7QUFHdEQ7Ozs7R0FJRztBQUtILE1BQU0sT0FBTyxrQkFBa0I7SUFDN0IsWUFBWSxVQUFzQixFQUFFLEtBQXlCO1FBQzNELEtBQUssQ0FBQyxjQUFjLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQyxDQUFDO0lBQ2pELENBQUM7OytHQUhVLGtCQUFrQjttR0FBbEIsa0JBQWtCOzJGQUFsQixrQkFBa0I7a0JBSjlCLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGlCQUFpQjtvQkFDM0IsVUFBVSxFQUFFLElBQUk7aUJBQ2pCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUaGVtZUJhc2VEaXJlY3RpdmUgfSBmcm9tICcuL3RoZW1lLWJhc2UuZGlyZWN0aXZlJztcblxuLyoqXG4gKiBBcHBsaWVzIHRoZSBjdXJyZW50IHRoZW1lIHN0eWxlIG9uIGFuIGVsZW1lbnQgd2hpY2ggaXMgbm90IHVuZGVyIHRoZSByZW5kZXJlZFxuICogc3AtdGhlbWUsIGluIERPTSB0cmVlLiBVc2VmdWwgZm9yIG5vbi1TYXBwaGlyZSBwb3J0YWwgY29tcG9uZW50cyB0aGF0IHJlbmRlciB0aGluZ3MgaW4gYm9keS5cbiAqXG4gKi9cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1tzcC10aGVtZS1yb290XScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG59KVxuZXhwb3J0IGNsYXNzIFRoZW1lUm9vdERpcmVjdGl2ZSB7XG4gIGNvbnN0cnVjdG9yKGVsZW1lbnRSZWY6IEVsZW1lbnRSZWYsIHRoZW1lOiBUaGVtZUJhc2VEaXJlY3RpdmUpIHtcbiAgICB0aGVtZS5hcHBseU9uRG9tTm9kZShlbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQpO1xuICB9XG59XG4iXX0=
24
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.TopLevelThemeRef }, { type: i2.ThemeBaseDirective, decorators: [{
25
+ type: Optional
26
+ }, {
27
+ type: SkipSelf
28
+ }] }]; } });
29
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGhlbWUtcm9vdC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbGliL3RoZW1lL3NyYy90aGVtZS1yb290LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFjLFFBQVEsRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7QUFJMUU7Ozs7R0FJRztBQUtILE1BQU0sT0FBTyxrQkFBa0I7SUFDN0IsWUFDRSxVQUFzQixFQUN0QixRQUEwQixFQUNGLFdBQStCO1FBRXZELE1BQU0sS0FBSyxHQUFHLFdBQVcsSUFBSSxRQUFRLENBQUMsS0FBSyxDQUFDO1FBQzVDLEtBQUssQ0FBQyxjQUFjLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQyxDQUFDO0lBQ2pELENBQUM7OytHQVJVLGtCQUFrQjttR0FBbEIsa0JBQWtCOzJGQUFsQixrQkFBa0I7a0JBSjlCLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGlCQUFpQjtvQkFDM0IsVUFBVSxFQUFFLElBQUk7aUJBQ2pCOzswQkFLSSxRQUFROzswQkFBSSxRQUFRIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBPcHRpb25hbCwgU2tpcFNlbGYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFRoZW1lQmFzZURpcmVjdGl2ZSB9IGZyb20gJy4vdGhlbWUtYmFzZS5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgVG9wTGV2ZWxUaGVtZVJlZiB9IGZyb20gJy4vdG9wLWxldmVsLXRoZW1lLXJlZi5zZXJ2aWNlJztcblxuLyoqXG4gKiBBcHBsaWVzIHRoZSBjdXJyZW50IHRoZW1lIHN0eWxlIG9uIGFuIGVsZW1lbnQgd2hpY2ggaXMgbm90IHVuZGVyIHRoZSByZW5kZXJlZFxuICogc3AtdGhlbWUsIGluIERPTSB0cmVlLiBVc2VmdWwgZm9yIG5vbi1TYXBwaGlyZSBwb3J0YWwgY29tcG9uZW50cyB0aGF0IHJlbmRlciB0aGluZ3MgaW4gYm9keS5cbiAqXG4gKi9cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1tzcC10aGVtZS1yb290XScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG59KVxuZXhwb3J0IGNsYXNzIFRoZW1lUm9vdERpcmVjdGl2ZSB7XG4gIGNvbnN0cnVjdG9yKFxuICAgIGVsZW1lbnRSZWY6IEVsZW1lbnRSZWYsXG4gICAgdGhlbWVSZWY6IFRvcExldmVsVGhlbWVSZWYsXG4gICAgQE9wdGlvbmFsKCkgQFNraXBTZWxmKCkgcGFyZW50VGhlbWU6IFRoZW1lQmFzZURpcmVjdGl2ZVxuICApIHtcbiAgICBjb25zdCB0aGVtZSA9IHBhcmVudFRoZW1lIHx8IHRoZW1lUmVmLnRoZW1lO1xuICAgIHRoZW1lLmFwcGx5T25Eb21Ob2RlKGVsZW1lbnRSZWYubmF0aXZlRWxlbWVudCk7XG4gIH1cbn1cbiJdfQ==