@dhutaryan/ngx-mat-timepicker 13.0.0 → 13.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -12,6 +12,7 @@ The timepicker module using Angular material.
12
12
  | mat-timepicker | Angular |
13
13
  | -------------- | ------------------- |
14
14
  | 12.x.x | >=12.0.0 && <15.0.0 |
15
+ | 13.x.x | >=13.0.0 && <15.0.0 |
15
16
 
16
17
  ## Documentation
17
18
 
@@ -55,7 +55,9 @@ export class MatTimepickerBase {
55
55
  }
56
56
  /** Whether the timepicker pop-up should be disabled. */
57
57
  get disabled() {
58
- return this._disabled;
58
+ return this._disabled === undefined && this.timepickerInput
59
+ ? this.timepickerInput.disabled
60
+ : !!this._disabled;
59
61
  }
60
62
  set disabled(value) {
61
63
  const newValue = coerceBooleanProperty(value);
@@ -390,4 +392,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
390
392
  type: Output,
391
393
  args: ['closed']
392
394
  }] } });
393
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timepicker-base.js","sourceRoot":"","sources":["../../../../projects/mat-timepicker/src/lib/timepicker-base.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Input,\n  ComponentRef,\n  ViewContainerRef,\n  Directive,\n  NgZone,\n  Inject,\n  Output,\n  EventEmitter,\n  OnChanges,\n  SimpleChanges,\n  ElementRef,\n  InjectionToken,\n  Optional,\n} from '@angular/core';\nimport { ThemePalette } from '@angular/material/core';\nimport {\n  BooleanInput,\n  coerceBooleanProperty,\n  coerceNumberProperty,\n} from '@angular/cdk/coercion';\nimport {\n  FlexibleConnectedPositionStrategy,\n  Overlay,\n  OverlayConfig,\n  OverlayRef,\n  ScrollStrategy,\n} from '@angular/cdk/overlay';\nimport {\n  ComponentPortal,\n  ComponentType,\n  TemplatePortal,\n} from '@angular/cdk/portal';\nimport {\n  DOWN_ARROW,\n  ESCAPE,\n  hasModifierKey,\n  LEFT_ARROW,\n  PAGE_DOWN,\n  PAGE_UP,\n  RIGHT_ARROW,\n  UP_ARROW,\n} from '@angular/cdk/keycodes';\nimport { filter, first, merge, Observable } from 'rxjs';\n\nimport { MatTimepickerContent } from './timepicker-content';\nimport { MAT_TIMEPICKER_SCROLL_STRATEGY } from './timepicker-scroll-strategy';\nimport {\n  ExtractTimeTypeFromSelection,\n  MatTimeSelectionModel,\n} from './time-selection-model';\nimport { MAT_DEFAULT_ACITONS } from './timepicker-actions-default';\nimport { TimepickerOrientation } from './orientation';\n\n/** Possible options for the timepicker to open. */\nexport type TimepickerOpenAs = 'dialog' | 'popup';\n\n/** Possible positions for the timepicker dropdown along the X axis. */\nexport type TimepickerDropdownPositionX = 'start' | 'end';\n\n/** Possible positions for the timepicker dropdown along the Y axis. */\nexport type TimepickerDropdownPositionY = 'above' | 'below';\n\n/** Possible options for the timepicker to display. */\nexport type TimepickerMode = 'input' | 'dial';\n\n/** Possible options for the timepicker period format. */\nexport type TimepickerFormat = '12h' | '24h';\n\n/** Form control that can be associated with a timepicker. */\nexport interface MatTimepickerControl<T> {\n  disabled: boolean;\n  min: T | null;\n  max: T | null;\n  getThemePalette(): ThemePalette;\n  getConnectedOverlayOrigin(): ElementRef;\n  getOverlayLabelId(): string | null;\n}\n\n/** A timepicker that can be attached to a {@link MatTimepickerControl}. */\nexport interface MatTimepickerPanel<\n  C extends MatTimepickerControl<T>,\n  S,\n  T = ExtractTimeTypeFromSelection<S>\n> {\n  /** Register an input with the timeepicker. */\n  registerInput(input: C): MatTimeSelectionModel<S, T>;\n}\n\n/**\n * Represents the default options for the form field that can be configured\n * using the `MAT_TIMEPICKER_DEFAULT_OPTIONS` injection token.\n */\nexport interface MatTimepickerDefaultOptions {\n  /** Default color of the timepicker. */\n  color?: ThemePalette;\n  /** Default timepicker mode. */\n  mode: TimepickerMode;\n  /** Defines how timepicker will be appeared. */\n  openAs: TimepickerOpenAs;\n  /** Default timepicker format. */\n  format: TimepickerFormat;\n  /** Should toggle face button be visible. */\n  showToggleModeButton: boolean;\n  /** Step for minutes. */\n  minuteInterval: number;\n  /** Orientation for dial mode. */\n  orientation: TimepickerOrientation;\n}\n\n/**\n * Injection token that can be used to configure the\n * default options for all timepickers within an app.\n */\nexport const MAT_TIMEPICKER_DEFAULT_OPTIONS =\n  new InjectionToken<MatTimepickerDefaultOptions>(\n    'MAT_TIMEPICKER_DEFAULT_OPTIONS'\n  );\n\n/** Default open as used by the timepicker. */\nconst DEFAULT_OPEN_AS: TimepickerOpenAs = 'popup';\n\n/** Default mode used by the timepicker. */\nconst DEFAULT_MODE: TimepickerMode = 'dial';\n\n/** Default format used by the timepicker. */\nconst DEFAULT_FORMAT: TimepickerFormat = '12h';\n\n/** Used to generate a unique ID for each timepicker instance. */\nlet timepickerUid = 0;\n\n@Directive()\nexport abstract class MatTimepickerBase<\n  C extends MatTimepickerControl<T>,\n  S,\n  T = ExtractTimeTypeFromSelection<S>\n> implements OnChanges\n{\n  /** Whether the timepicker pop-up should be disabled. */\n  @Input()\n  get disabled(): boolean {\n    return this._disabled;\n  }\n  set disabled(value: BooleanInput) {\n    const newValue = coerceBooleanProperty(value);\n\n    if (newValue !== this._disabled) {\n      this._disabled = newValue;\n    }\n  }\n  private _disabled: boolean;\n\n  /** Whether the timepicker is open. */\n  @Input()\n  get opened(): boolean {\n    return this._opened;\n  }\n  set opened(value: BooleanInput) {\n    coerceBooleanProperty(value) ? this.open() : this.close();\n  }\n  private _opened = false;\n\n  /** Whether the timepicker mode which determines what the timepicker will be opened as. */\n  @Input()\n  get openAs(): TimepickerOpenAs {\n    return this._openAs || this._defaults?.openAs || DEFAULT_OPEN_AS;\n  }\n  set openAs(value: TimepickerOpenAs) {\n    this._openAs = value;\n  }\n  private _openAs: TimepickerOpenAs;\n\n  /** Color palette to use on the timepicker's content. */\n  @Input()\n  get color(): ThemePalette {\n    return (\n      this._color ||\n      this._defaults?.color ||\n      (this.timepickerInput\n        ? this.timepickerInput.getThemePalette()\n        : undefined)\n    );\n  }\n  set color(value: ThemePalette) {\n    this._color = value;\n  }\n  private _color: ThemePalette;\n\n  /** Timepicker display mode. */\n  @Input()\n  get mode(): TimepickerMode {\n    return this._mode || this._defaults?.mode || DEFAULT_MODE;\n  }\n  set mode(value: TimepickerMode) {\n    this._mode = value;\n  }\n  private _mode: TimepickerMode;\n\n  /** Timepicker period format. */\n  @Input()\n  get format(): TimepickerFormat {\n    return this._format || this._defaults?.format || DEFAULT_FORMAT;\n  }\n  set format(value: TimepickerFormat) {\n    this._format = value;\n  }\n  private _format: TimepickerFormat;\n\n  /** Show or hide toggle button between dial and input. */\n  @Input()\n  get showToggleModeButton(): boolean {\n    return this._showToggleModeButton;\n  }\n  set showToggleModeButton(value: boolean) {\n    this._showToggleModeButton = value;\n  }\n  private _showToggleModeButton: boolean = true;\n\n  /** Step for minutes. */\n  @Input()\n  get minuteInterval(): number {\n    return this._minuteInterval || this._defaults?.minuteInterval || 1;\n  }\n  set minuteInterval(value: number) {\n    this._minuteInterval = coerceNumberProperty(value);\n  }\n  private _minuteInterval: number;\n\n  /** Orientation for dial mode. */\n  @Input()\n  get orientation(): TimepickerOrientation {\n    return this._orientation || this._defaults?.orientation || 'vertical';\n  }\n  set orientation(value: TimepickerOrientation) {\n    this._orientation = value;\n  }\n  private _orientation: TimepickerOrientation;\n\n  /** Preferred position of the timepicker in the X axis. */\n  @Input()\n  xPosition: TimepickerDropdownPositionX = 'start';\n\n  /** Preferred position of the timepicker in the Y axis. */\n  @Input()\n  yPosition: TimepickerDropdownPositionY = 'below';\n\n  /** Emits when the timepicker has been closed. */\n  @Output('closed') readonly closedStream = new EventEmitter<void>();\n\n  /** The id for the timepicker. */\n  id: string = `mat-timepicker-${timepickerUid++}`;\n\n  /** The input element this timepicker is associated with. */\n  timepickerInput!: C;\n\n  /** Portal with projected action buttons. */\n  _actionsPortal: TemplatePortal | null = null;\n\n  /** A reference to the overlay into which we've rendered the timepicker. */\n  private _overlayRef: OverlayRef | null;\n\n  /** Reference to the component instance rendered in the overlay. */\n  private _componentRef!: ComponentRef<MatTimepickerContent<S, T>> | null;\n\n  /** Unique class that will be added to the backdrop so that the test harnesses can look it up. */\n  private _backdropHarnessClass = `${this.id}-backdrop`;\n\n  /** Scroll strategy. */\n  private _scrollStrategy: () => ScrollStrategy;\n\n  /** The minimum selectable time. */\n  _getMinTime(): T | null {\n    return this.timepickerInput && this.timepickerInput.min;\n  }\n\n  /** The maximum selectable time. */\n  _getMaxTime(): T | null {\n    return this.timepickerInput && this.timepickerInput.max;\n  }\n\n  constructor(\n    private _viewContainerRef: ViewContainerRef,\n    private _overlay: Overlay,\n    private _ngZone: NgZone,\n    @Inject(MAT_TIMEPICKER_SCROLL_STRATEGY) scrollStrategy: any,\n    @Inject(MAT_DEFAULT_ACITONS)\n    private _defaultActionsComponent: ComponentType<any>,\n    private _model: MatTimeSelectionModel<S, T>,\n    @Optional()\n    @Inject(MAT_TIMEPICKER_DEFAULT_OPTIONS)\n    private _defaults?: MatTimepickerDefaultOptions\n  ) {\n    this._scrollStrategy = scrollStrategy;\n\n    if (_defaults) {\n      this.showToggleModeButton =\n        _defaults.showToggleModeButton !== undefined\n          ? _defaults.showToggleModeButton\n          : true;\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    const positionChange = changes['xPosition'] || changes['yPosition'];\n\n    if (positionChange && !positionChange.firstChange && this._overlayRef) {\n      const positionStrategy = this._overlayRef.getConfig().positionStrategy;\n\n      if (positionStrategy instanceof FlexibleConnectedPositionStrategy) {\n        this._setConnectedPositions(positionStrategy);\n\n        if (this.opened) {\n          this._overlayRef.updatePosition();\n        }\n      }\n    }\n  }\n\n  ngOnDestroy() {\n    this._destroyOverlay();\n    this.close();\n  }\n\n  /** Opens the timepicker. */\n  open(): void {\n    if (this._opened || this.disabled) {\n      return;\n    }\n\n    if (!this.timepickerInput) {\n      throw Error(\n        'Attempted to open an MatTimepicker with no associated input.'\n      );\n    }\n\n    this._openOverlay();\n    this._opened = true;\n  }\n\n  /** Closes the timepicker. */\n  close(): void {\n    if (!this._opened) {\n      return;\n    }\n\n    if (this._componentRef) {\n      const instance = this._componentRef.instance;\n      instance.startExitAnimation();\n      instance._animationDone\n        .pipe(first())\n        .subscribe(() => this._destroyOverlay());\n    }\n\n    // The `_opened` could've been reset already if\n    // we got two events in quick succession.\n    if (this._opened) {\n      this._opened = false;\n      this.closedStream.emit();\n    }\n  }\n\n  /**\n   * Register an input with this timepicker.\n   * @param input The timepicker input to register with this timepicker.\n   * @returns Selection model that the input should hook itself up to.\n   */\n  registerInput(input: C): MatTimeSelectionModel<S, T> {\n    if (this.timepickerInput) {\n      throw Error(\n        'A MatTimepicker can only be associated with a single input.'\n      );\n    }\n\n    this.timepickerInput = input;\n    return this._model;\n  }\n\n  /**\n   * Registers a portal containing action buttons with the timepicker.\n   * @param portal Portal to be registered.\n   */\n  registerActions(portal: TemplatePortal): void {\n    if (this._actionsPortal) {\n      throw Error(\n        'A MatTimepicker can only be associated with a single actions row.'\n      );\n    }\n    this._actionsPortal = portal;\n    this._componentRef?.instance._assignActions(portal, true);\n  }\n\n  /**\n   * Removes a portal containing action buttons from the timepicker.\n   * @param portal Portal to be removed.\n   */\n  removeActions(portal: TemplatePortal): void {\n    if (portal === this._actionsPortal) {\n      this._actionsPortal = null;\n      this._componentRef?.instance._assignActions(null, true);\n    }\n  }\n\n  /** Applies the current pending selection on the overlay to the model. */\n  _applyPendingSelection() {\n    this._componentRef?.instance?._applyPendingSelection();\n  }\n\n  /** Forwards relevant values from the timepicker to the timepicker content inside the overlay. */\n  protected _forwardContentValues(instance: MatTimepickerContent<S, T>): void {\n    const defaultPortal = new ComponentPortal(this._defaultActionsComponent);\n\n    instance.timepicker = this;\n    instance.color = this.color;\n    instance.mode = this.mode;\n    instance.isMeridiem = this.format === '12h';\n    instance.showToggleModeButton = this.showToggleModeButton;\n    instance.minuteInterval = this.minuteInterval;\n    instance.orientation = this.orientation;\n    instance._dialogLabelId = this.timepickerInput.getOverlayLabelId();\n    instance._assignActions(this._actionsPortal || defaultPortal, false);\n  }\n\n  /** Opens the overlay with the timepicker. */\n  private _openOverlay(): void {\n    this._destroyOverlay();\n\n    const isDialog = this.openAs === 'dialog';\n    const portal = new ComponentPortal<MatTimepickerContent<S, T>>(\n      MatTimepickerContent,\n      this._viewContainerRef\n    );\n\n    const overlayRef = (this._overlayRef = this._overlay.create(\n      new OverlayConfig({\n        positionStrategy: isDialog\n          ? this._getDialogStrategy()\n          : this._getDropdownStrategy(),\n        hasBackdrop: true,\n        backdropClass: [\n          isDialog\n            ? 'cdk-overlay-dark-backdrop'\n            : 'mat-overlay-transparent-backdrop',\n          this._backdropHarnessClass,\n        ],\n        direction: 'ltr',\n        scrollStrategy: isDialog\n          ? this._overlay.scrollStrategies.block()\n          : this._scrollStrategy(),\n        panelClass: `mat-timepicker-${this.openAs}`,\n      })\n    ));\n\n    this._getCloseStream(overlayRef).subscribe((event) => {\n      if (event) {\n        event.preventDefault();\n      }\n      this.close();\n    });\n\n    // The `preventDefault` call happens inside the timepicker as well, however focus moves into\n    // it inside a timeout which can give browsers a chance to fire off a keyboard event in-between\n    // that can scroll the page. Always block default actions of arrow keys for the\n    // entire overlay so the page doesn't get scrolled by accident.\n    overlayRef.keydownEvents().subscribe((event) => {\n      const keyCode = event.keyCode;\n\n      if (\n        keyCode === UP_ARROW ||\n        keyCode === DOWN_ARROW ||\n        keyCode === LEFT_ARROW ||\n        keyCode === RIGHT_ARROW ||\n        keyCode === PAGE_UP ||\n        keyCode === PAGE_DOWN\n      ) {\n        event.preventDefault();\n      }\n    });\n\n    this._componentRef = overlayRef.attach(portal);\n    this._forwardContentValues(this._componentRef.instance);\n\n    // Update the position once the timepicker has rendered. Only relevant in dropdown mode.\n    if (!isDialog) {\n      this._ngZone.onStable\n        .pipe(first())\n        .subscribe(() => overlayRef.updatePosition());\n    }\n  }\n\n  /** Destroys the current overlay. */\n  private _destroyOverlay(): void {\n    if (this._overlayRef) {\n      this._overlayRef.dispose();\n      this._overlayRef = this._componentRef = null;\n    }\n  }\n\n  /** Gets a position strategy that will open the timepicker as a dropdown. */\n  private _getDialogStrategy() {\n    return this._overlay\n      .position()\n      .global()\n      .centerHorizontally()\n      .centerVertically();\n  }\n\n  /** Gets a position strategy that will open the timepicker as a dropdown. */\n  private _getDropdownStrategy() {\n    const strategy = this._overlay\n      .position()\n      .flexibleConnectedTo(this.timepickerInput.getConnectedOverlayOrigin())\n      .withTransformOriginOn('.mat-timepicker-content')\n      .withFlexibleDimensions(false)\n      .withViewportMargin(8)\n      .withLockedPosition();\n\n    return this._setConnectedPositions(strategy);\n  }\n\n  /** Sets the positions of the timepicker in dropdown mode based on the current configuration. */\n  private _setConnectedPositions(\n    strategy: FlexibleConnectedPositionStrategy\n  ): FlexibleConnectedPositionStrategy {\n    const primaryX = this.xPosition === 'end' ? 'end' : 'start';\n    const secondaryX = primaryX === 'start' ? 'end' : 'start';\n    const primaryY = this.yPosition === 'above' ? 'bottom' : 'top';\n    const secondaryY = primaryY === 'top' ? 'bottom' : 'top';\n\n    return strategy.withPositions([\n      {\n        originX: primaryX,\n        originY: secondaryY,\n        overlayX: primaryX,\n        overlayY: primaryY,\n      },\n      {\n        originX: primaryX,\n        originY: primaryY,\n        overlayX: primaryX,\n        overlayY: secondaryY,\n      },\n      {\n        originX: secondaryX,\n        originY: secondaryY,\n        overlayX: secondaryX,\n        overlayY: primaryY,\n      },\n      {\n        originX: secondaryX,\n        originY: primaryY,\n        overlayX: secondaryX,\n        overlayY: secondaryY,\n      },\n    ]);\n  }\n\n  /** Gets an observable that will emit when the overlay is supposed to be closed. */\n  private _getCloseStream(\n    overlayRef: OverlayRef\n  ): Observable<void | KeyboardEvent | MouseEvent> {\n    return merge(\n      overlayRef.backdropClick(),\n      overlayRef.detachments(),\n      overlayRef.keydownEvents().pipe(\n        filter((event) => {\n          // Closing on alt + up is only valid when there's an input associated with the timepicker.\n          return (\n            (event.keyCode === ESCAPE && !hasModifierKey(event)) ||\n            (this.timepickerInput &&\n              hasModifierKey(event, 'altKey') &&\n              event.keyCode === UP_ARROW)\n          );\n        })\n      )\n    );\n  }\n}\n"]}
395
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timepicker-base.js","sourceRoot":"","sources":["../../../../projects/mat-timepicker/src/lib/timepicker-base.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Input,\n  ComponentRef,\n  ViewContainerRef,\n  Directive,\n  NgZone,\n  Inject,\n  Output,\n  EventEmitter,\n  OnChanges,\n  SimpleChanges,\n  ElementRef,\n  InjectionToken,\n  Optional,\n} from '@angular/core';\nimport { ThemePalette } from '@angular/material/core';\nimport {\n  BooleanInput,\n  coerceBooleanProperty,\n  coerceNumberProperty,\n} from '@angular/cdk/coercion';\nimport {\n  FlexibleConnectedPositionStrategy,\n  Overlay,\n  OverlayConfig,\n  OverlayRef,\n  ScrollStrategy,\n} from '@angular/cdk/overlay';\nimport {\n  ComponentPortal,\n  ComponentType,\n  TemplatePortal,\n} from '@angular/cdk/portal';\nimport {\n  DOWN_ARROW,\n  ESCAPE,\n  hasModifierKey,\n  LEFT_ARROW,\n  PAGE_DOWN,\n  PAGE_UP,\n  RIGHT_ARROW,\n  UP_ARROW,\n} from '@angular/cdk/keycodes';\nimport { filter, first, merge, Observable } from 'rxjs';\n\nimport { MatTimepickerContent } from './timepicker-content';\nimport { MAT_TIMEPICKER_SCROLL_STRATEGY } from './timepicker-scroll-strategy';\nimport {\n  ExtractTimeTypeFromSelection,\n  MatTimeSelectionModel,\n} from './time-selection-model';\nimport { MAT_DEFAULT_ACITONS } from './timepicker-actions-default';\nimport { TimepickerOrientation } from './orientation';\n\n/** Possible options for the timepicker to open. */\nexport type TimepickerOpenAs = 'dialog' | 'popup';\n\n/** Possible positions for the timepicker dropdown along the X axis. */\nexport type TimepickerDropdownPositionX = 'start' | 'end';\n\n/** Possible positions for the timepicker dropdown along the Y axis. */\nexport type TimepickerDropdownPositionY = 'above' | 'below';\n\n/** Possible options for the timepicker to display. */\nexport type TimepickerMode = 'input' | 'dial';\n\n/** Possible options for the timepicker period format. */\nexport type TimepickerFormat = '12h' | '24h';\n\n/** Form control that can be associated with a timepicker. */\nexport interface MatTimepickerControl<T> {\n  disabled: boolean;\n  min: T | null;\n  max: T | null;\n  getThemePalette(): ThemePalette;\n  getConnectedOverlayOrigin(): ElementRef;\n  getOverlayLabelId(): string | null;\n}\n\n/** A timepicker that can be attached to a {@link MatTimepickerControl}. */\nexport interface MatTimepickerPanel<\n  C extends MatTimepickerControl<T>,\n  S,\n  T = ExtractTimeTypeFromSelection<S>\n> {\n  /** Register an input with the timeepicker. */\n  registerInput(input: C): MatTimeSelectionModel<S, T>;\n}\n\n/**\n * Represents the default options for the form field that can be configured\n * using the `MAT_TIMEPICKER_DEFAULT_OPTIONS` injection token.\n */\nexport interface MatTimepickerDefaultOptions {\n  /** Default color of the timepicker. */\n  color?: ThemePalette;\n  /** Default timepicker mode. */\n  mode: TimepickerMode;\n  /** Defines how timepicker will be appeared. */\n  openAs: TimepickerOpenAs;\n  /** Default timepicker format. */\n  format: TimepickerFormat;\n  /** Should toggle face button be visible. */\n  showToggleModeButton: boolean;\n  /** Step for minutes. */\n  minuteInterval: number;\n  /** Orientation for dial mode. */\n  orientation: TimepickerOrientation;\n}\n\n/**\n * Injection token that can be used to configure the\n * default options for all timepickers within an app.\n */\nexport const MAT_TIMEPICKER_DEFAULT_OPTIONS =\n  new InjectionToken<MatTimepickerDefaultOptions>(\n    'MAT_TIMEPICKER_DEFAULT_OPTIONS'\n  );\n\n/** Default open as used by the timepicker. */\nconst DEFAULT_OPEN_AS: TimepickerOpenAs = 'popup';\n\n/** Default mode used by the timepicker. */\nconst DEFAULT_MODE: TimepickerMode = 'dial';\n\n/** Default format used by the timepicker. */\nconst DEFAULT_FORMAT: TimepickerFormat = '12h';\n\n/** Used to generate a unique ID for each timepicker instance. */\nlet timepickerUid = 0;\n\n@Directive()\nexport abstract class MatTimepickerBase<\n  C extends MatTimepickerControl<T>,\n  S,\n  T = ExtractTimeTypeFromSelection<S>\n> implements OnChanges\n{\n  /** Whether the timepicker pop-up should be disabled. */\n  @Input()\n  get disabled(): boolean {\n    return this._disabled === undefined && this.timepickerInput\n      ? this.timepickerInput.disabled\n      : !!this._disabled;\n  }\n  set disabled(value: BooleanInput) {\n    const newValue = coerceBooleanProperty(value);\n\n    if (newValue !== this._disabled) {\n      this._disabled = newValue;\n    }\n  }\n  private _disabled: boolean;\n\n  /** Whether the timepicker is open. */\n  @Input()\n  get opened(): boolean {\n    return this._opened;\n  }\n  set opened(value: BooleanInput) {\n    coerceBooleanProperty(value) ? this.open() : this.close();\n  }\n  private _opened = false;\n\n  /** Whether the timepicker mode which determines what the timepicker will be opened as. */\n  @Input()\n  get openAs(): TimepickerOpenAs {\n    return this._openAs || this._defaults?.openAs || DEFAULT_OPEN_AS;\n  }\n  set openAs(value: TimepickerOpenAs) {\n    this._openAs = value;\n  }\n  private _openAs: TimepickerOpenAs;\n\n  /** Color palette to use on the timepicker's content. */\n  @Input()\n  get color(): ThemePalette {\n    return (\n      this._color ||\n      this._defaults?.color ||\n      (this.timepickerInput\n        ? this.timepickerInput.getThemePalette()\n        : undefined)\n    );\n  }\n  set color(value: ThemePalette) {\n    this._color = value;\n  }\n  private _color: ThemePalette;\n\n  /** Timepicker display mode. */\n  @Input()\n  get mode(): TimepickerMode {\n    return this._mode || this._defaults?.mode || DEFAULT_MODE;\n  }\n  set mode(value: TimepickerMode) {\n    this._mode = value;\n  }\n  private _mode: TimepickerMode;\n\n  /** Timepicker period format. */\n  @Input()\n  get format(): TimepickerFormat {\n    return this._format || this._defaults?.format || DEFAULT_FORMAT;\n  }\n  set format(value: TimepickerFormat) {\n    this._format = value;\n  }\n  private _format: TimepickerFormat;\n\n  /** Show or hide toggle button between dial and input. */\n  @Input()\n  get showToggleModeButton(): boolean {\n    return this._showToggleModeButton;\n  }\n  set showToggleModeButton(value: boolean) {\n    this._showToggleModeButton = value;\n  }\n  private _showToggleModeButton: boolean = true;\n\n  /** Step for minutes. */\n  @Input()\n  get minuteInterval(): number {\n    return this._minuteInterval || this._defaults?.minuteInterval || 1;\n  }\n  set minuteInterval(value: number) {\n    this._minuteInterval = coerceNumberProperty(value);\n  }\n  private _minuteInterval: number;\n\n  /** Orientation for dial mode. */\n  @Input()\n  get orientation(): TimepickerOrientation {\n    return this._orientation || this._defaults?.orientation || 'vertical';\n  }\n  set orientation(value: TimepickerOrientation) {\n    this._orientation = value;\n  }\n  private _orientation: TimepickerOrientation;\n\n  /** Preferred position of the timepicker in the X axis. */\n  @Input()\n  xPosition: TimepickerDropdownPositionX = 'start';\n\n  /** Preferred position of the timepicker in the Y axis. */\n  @Input()\n  yPosition: TimepickerDropdownPositionY = 'below';\n\n  /** Emits when the timepicker has been closed. */\n  @Output('closed') readonly closedStream = new EventEmitter<void>();\n\n  /** The id for the timepicker. */\n  id: string = `mat-timepicker-${timepickerUid++}`;\n\n  /** The input element this timepicker is associated with. */\n  timepickerInput!: C;\n\n  /** Portal with projected action buttons. */\n  _actionsPortal: TemplatePortal | null = null;\n\n  /** A reference to the overlay into which we've rendered the timepicker. */\n  private _overlayRef: OverlayRef | null;\n\n  /** Reference to the component instance rendered in the overlay. */\n  private _componentRef!: ComponentRef<MatTimepickerContent<S, T>> | null;\n\n  /** Unique class that will be added to the backdrop so that the test harnesses can look it up. */\n  private _backdropHarnessClass = `${this.id}-backdrop`;\n\n  /** Scroll strategy. */\n  private _scrollStrategy: () => ScrollStrategy;\n\n  /** The minimum selectable time. */\n  _getMinTime(): T | null {\n    return this.timepickerInput && this.timepickerInput.min;\n  }\n\n  /** The maximum selectable time. */\n  _getMaxTime(): T | null {\n    return this.timepickerInput && this.timepickerInput.max;\n  }\n\n  constructor(\n    private _viewContainerRef: ViewContainerRef,\n    private _overlay: Overlay,\n    private _ngZone: NgZone,\n    @Inject(MAT_TIMEPICKER_SCROLL_STRATEGY) scrollStrategy: any,\n    @Inject(MAT_DEFAULT_ACITONS)\n    private _defaultActionsComponent: ComponentType<any>,\n    private _model: MatTimeSelectionModel<S, T>,\n    @Optional()\n    @Inject(MAT_TIMEPICKER_DEFAULT_OPTIONS)\n    private _defaults?: MatTimepickerDefaultOptions\n  ) {\n    this._scrollStrategy = scrollStrategy;\n\n    if (_defaults) {\n      this.showToggleModeButton =\n        _defaults.showToggleModeButton !== undefined\n          ? _defaults.showToggleModeButton\n          : true;\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    const positionChange = changes['xPosition'] || changes['yPosition'];\n\n    if (positionChange && !positionChange.firstChange && this._overlayRef) {\n      const positionStrategy = this._overlayRef.getConfig().positionStrategy;\n\n      if (positionStrategy instanceof FlexibleConnectedPositionStrategy) {\n        this._setConnectedPositions(positionStrategy);\n\n        if (this.opened) {\n          this._overlayRef.updatePosition();\n        }\n      }\n    }\n  }\n\n  ngOnDestroy() {\n    this._destroyOverlay();\n    this.close();\n  }\n\n  /** Opens the timepicker. */\n  open(): void {\n    if (this._opened || this.disabled) {\n      return;\n    }\n\n    if (!this.timepickerInput) {\n      throw Error(\n        'Attempted to open an MatTimepicker with no associated input.'\n      );\n    }\n\n    this._openOverlay();\n    this._opened = true;\n  }\n\n  /** Closes the timepicker. */\n  close(): void {\n    if (!this._opened) {\n      return;\n    }\n\n    if (this._componentRef) {\n      const instance = this._componentRef.instance;\n      instance.startExitAnimation();\n      instance._animationDone\n        .pipe(first())\n        .subscribe(() => this._destroyOverlay());\n    }\n\n    // The `_opened` could've been reset already if\n    // we got two events in quick succession.\n    if (this._opened) {\n      this._opened = false;\n      this.closedStream.emit();\n    }\n  }\n\n  /**\n   * Register an input with this timepicker.\n   * @param input The timepicker input to register with this timepicker.\n   * @returns Selection model that the input should hook itself up to.\n   */\n  registerInput(input: C): MatTimeSelectionModel<S, T> {\n    if (this.timepickerInput) {\n      throw Error(\n        'A MatTimepicker can only be associated with a single input.'\n      );\n    }\n\n    this.timepickerInput = input;\n    return this._model;\n  }\n\n  /**\n   * Registers a portal containing action buttons with the timepicker.\n   * @param portal Portal to be registered.\n   */\n  registerActions(portal: TemplatePortal): void {\n    if (this._actionsPortal) {\n      throw Error(\n        'A MatTimepicker can only be associated with a single actions row.'\n      );\n    }\n    this._actionsPortal = portal;\n    this._componentRef?.instance._assignActions(portal, true);\n  }\n\n  /**\n   * Removes a portal containing action buttons from the timepicker.\n   * @param portal Portal to be removed.\n   */\n  removeActions(portal: TemplatePortal): void {\n    if (portal === this._actionsPortal) {\n      this._actionsPortal = null;\n      this._componentRef?.instance._assignActions(null, true);\n    }\n  }\n\n  /** Applies the current pending selection on the overlay to the model. */\n  _applyPendingSelection() {\n    this._componentRef?.instance?._applyPendingSelection();\n  }\n\n  /** Forwards relevant values from the timepicker to the timepicker content inside the overlay. */\n  protected _forwardContentValues(instance: MatTimepickerContent<S, T>): void {\n    const defaultPortal = new ComponentPortal(this._defaultActionsComponent);\n\n    instance.timepicker = this;\n    instance.color = this.color;\n    instance.mode = this.mode;\n    instance.isMeridiem = this.format === '12h';\n    instance.showToggleModeButton = this.showToggleModeButton;\n    instance.minuteInterval = this.minuteInterval;\n    instance.orientation = this.orientation;\n    instance._dialogLabelId = this.timepickerInput.getOverlayLabelId();\n    instance._assignActions(this._actionsPortal || defaultPortal, false);\n  }\n\n  /** Opens the overlay with the timepicker. */\n  private _openOverlay(): void {\n    this._destroyOverlay();\n\n    const isDialog = this.openAs === 'dialog';\n    const portal = new ComponentPortal<MatTimepickerContent<S, T>>(\n      MatTimepickerContent,\n      this._viewContainerRef\n    );\n\n    const overlayRef = (this._overlayRef = this._overlay.create(\n      new OverlayConfig({\n        positionStrategy: isDialog\n          ? this._getDialogStrategy()\n          : this._getDropdownStrategy(),\n        hasBackdrop: true,\n        backdropClass: [\n          isDialog\n            ? 'cdk-overlay-dark-backdrop'\n            : 'mat-overlay-transparent-backdrop',\n          this._backdropHarnessClass,\n        ],\n        direction: 'ltr',\n        scrollStrategy: isDialog\n          ? this._overlay.scrollStrategies.block()\n          : this._scrollStrategy(),\n        panelClass: `mat-timepicker-${this.openAs}`,\n      })\n    ));\n\n    this._getCloseStream(overlayRef).subscribe((event) => {\n      if (event) {\n        event.preventDefault();\n      }\n      this.close();\n    });\n\n    // The `preventDefault` call happens inside the timepicker as well, however focus moves into\n    // it inside a timeout which can give browsers a chance to fire off a keyboard event in-between\n    // that can scroll the page. Always block default actions of arrow keys for the\n    // entire overlay so the page doesn't get scrolled by accident.\n    overlayRef.keydownEvents().subscribe((event) => {\n      const keyCode = event.keyCode;\n\n      if (\n        keyCode === UP_ARROW ||\n        keyCode === DOWN_ARROW ||\n        keyCode === LEFT_ARROW ||\n        keyCode === RIGHT_ARROW ||\n        keyCode === PAGE_UP ||\n        keyCode === PAGE_DOWN\n      ) {\n        event.preventDefault();\n      }\n    });\n\n    this._componentRef = overlayRef.attach(portal);\n    this._forwardContentValues(this._componentRef.instance);\n\n    // Update the position once the timepicker has rendered. Only relevant in dropdown mode.\n    if (!isDialog) {\n      this._ngZone.onStable\n        .pipe(first())\n        .subscribe(() => overlayRef.updatePosition());\n    }\n  }\n\n  /** Destroys the current overlay. */\n  private _destroyOverlay(): void {\n    if (this._overlayRef) {\n      this._overlayRef.dispose();\n      this._overlayRef = this._componentRef = null;\n    }\n  }\n\n  /** Gets a position strategy that will open the timepicker as a dropdown. */\n  private _getDialogStrategy() {\n    return this._overlay\n      .position()\n      .global()\n      .centerHorizontally()\n      .centerVertically();\n  }\n\n  /** Gets a position strategy that will open the timepicker as a dropdown. */\n  private _getDropdownStrategy() {\n    const strategy = this._overlay\n      .position()\n      .flexibleConnectedTo(this.timepickerInput.getConnectedOverlayOrigin())\n      .withTransformOriginOn('.mat-timepicker-content')\n      .withFlexibleDimensions(false)\n      .withViewportMargin(8)\n      .withLockedPosition();\n\n    return this._setConnectedPositions(strategy);\n  }\n\n  /** Sets the positions of the timepicker in dropdown mode based on the current configuration. */\n  private _setConnectedPositions(\n    strategy: FlexibleConnectedPositionStrategy\n  ): FlexibleConnectedPositionStrategy {\n    const primaryX = this.xPosition === 'end' ? 'end' : 'start';\n    const secondaryX = primaryX === 'start' ? 'end' : 'start';\n    const primaryY = this.yPosition === 'above' ? 'bottom' : 'top';\n    const secondaryY = primaryY === 'top' ? 'bottom' : 'top';\n\n    return strategy.withPositions([\n      {\n        originX: primaryX,\n        originY: secondaryY,\n        overlayX: primaryX,\n        overlayY: primaryY,\n      },\n      {\n        originX: primaryX,\n        originY: primaryY,\n        overlayX: primaryX,\n        overlayY: secondaryY,\n      },\n      {\n        originX: secondaryX,\n        originY: secondaryY,\n        overlayX: secondaryX,\n        overlayY: primaryY,\n      },\n      {\n        originX: secondaryX,\n        originY: primaryY,\n        overlayX: secondaryX,\n        overlayY: secondaryY,\n      },\n    ]);\n  }\n\n  /** Gets an observable that will emit when the overlay is supposed to be closed. */\n  private _getCloseStream(\n    overlayRef: OverlayRef\n  ): Observable<void | KeyboardEvent | MouseEvent> {\n    return merge(\n      overlayRef.backdropClick(),\n      overlayRef.detachments(),\n      overlayRef.keydownEvents().pipe(\n        filter((event) => {\n          // Closing on alt + up is only valid when there's an input associated with the timepicker.\n          return (\n            (event.keyCode === ESCAPE && !hasModifierKey(event)) ||\n            (this.timepickerInput &&\n              hasModifierKey(event, 'altKey') &&\n              event.keyCode === UP_ARROW)\n          );\n        })\n      )\n    );\n  }\n}\n"]}
@@ -77,7 +77,7 @@ export class MatTimepickerContent extends _MatTimepickerContentBase {
77
77
  }
78
78
  }
79
79
  MatTimepickerContent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: MatTimepickerContent, deps: [{ token: i0.ElementRef }, { token: i1.MatTimepickerIntl }, { token: i2.MatTimeSelectionModel }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
80
- MatTimepickerContent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: MatTimepickerContent, selector: "mat-timepicker-content", host: { listeners: { "@transformPanel.done": "_animationDone.next()" }, properties: { "@transformPanel": "_animationState" }, classAttribute: "mat-timepicker-content" }, viewQueries: [{ propertyName: "_dials", first: true, predicate: MatClockDials, descendants: true }, { propertyName: "_inputs", first: true, predicate: MatTimeInputs, descendants: true }], exportAs: ["matTimepickerContent"], usesInheritance: true, ngImport: i0, template: "<div\n cdkTrapFocus\n role=\"dialog\"\n class=\"mat-timepicker-content-container\"\n [attr.aria-modal]=\"true\"\n [attr.aria-labelledby]=\"_dialogLabelId ?? undefined\"\n>\n <ng-container [ngSwitch]=\"mode\">\n <ng-template ngSwitchCase=\"input\">\n <mat-time-inputs\n [id]=\"timepicker.id\"\n [color]=\"color\"\n [isMeridiem]=\"isMeridiem\"\n [selected]=\"_getSelected()\"\n [minTime]=\"timepicker._getMinTime()\"\n [maxTime]=\"timepicker._getMaxTime()\"\n [minuteInterval]=\"minuteInterval\"\n (_userSelection)=\"_handleUserSelection($event)\"\n ></mat-time-inputs>\n\n <div class=\"mat-timepicker-content-actions\">\n <button\n class=\"mat-time-toggle-mode-button\"\n mat-icon-button\n *ngIf=\"showToggleModeButton\"\n (click)=\"onToggleMode('dial')\"\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n height=\"24\"\n width=\"24\"\n viewBox=\"0 0 24 24\"\n >\n <path\n d=\"m15.175 16.625 1.475-1.45-3.6-3.6V7.1h-2.075v5.3ZM12 21.95q-2.075 0-3.887-.787-1.813-.788-3.15-2.125-1.338-1.338-2.125-3.151Q2.05 14.075 2.05 12t.788-3.887q.787-1.813 2.125-3.15Q6.3 3.625 8.113 2.837 9.925 2.05 12 2.05t3.887.787q1.813.788 3.151 2.126 1.337 1.337 2.125 3.15.787 1.812.787 3.887t-.787 3.887q-.788 1.813-2.125 3.151-1.338 1.337-3.151 2.125-1.812.787-3.887.787ZM12 12Zm0 7.8q3.225 0 5.513-2.275Q19.8 15.25 19.8 12q0-3.25-2.287-5.525Q15.225 4.2 12 4.2T6.488 6.475Q4.2 8.75 4.2 12q0 3.25 2.288 5.525Q8.775 19.8 12 19.8Z\"\n />\n </svg>\n </button>\n\n <ng-template [cdkPortalOutlet]=\"_actionsPortal\"></ng-template>\n </div>\n </ng-template>\n <ng-template ngSwitchCase=\"dial\">\n <mat-clock-dials\n [id]=\"timepicker.id\"\n [color]=\"color\"\n [isMeridiem]=\"isMeridiem\"\n [selected]=\"_getSelected()\"\n [minTime]=\"timepicker._getMinTime()\"\n [maxTime]=\"timepicker._getMaxTime()\"\n [minuteInterval]=\"minuteInterval\"\n [orientation]=\"orientation\"\n (_userSelection)=\"_handleUserSelection($event)\"\n ></mat-clock-dials>\n\n <div class=\"mat-timepicker-content-actions\">\n <button\n class=\"mat-time-toggle-mode-button\"\n mat-icon-button\n *ngIf=\"showToggleModeButton\"\n (click)=\"onToggleMode('input')\"\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n height=\"24\"\n width=\"24\"\n viewBox=\"0 0 24 24\"\n >\n <path\n d=\"M4 19q-.825 0-1.412-.587Q2 17.825 2 17V7q0-.825.588-1.412Q3.175 5 4 5h16q.825 0 1.413.588Q22 6.175 22 7v10q0 .825-.587 1.413Q20.825 19 20 19Zm0-2h16V7H4v10Zm4-1h8v-2H8Zm-3-3h2v-2H5Zm3 0h2v-2H8Zm3 0h2v-2h-2Zm3 0h2v-2h-2Zm3 0h2v-2h-2ZM5 10h2V8H5Zm3 0h2V8H8Zm3 0h2V8h-2Zm3 0h2V8h-2Zm3 0h2V8h-2ZM4 17V7v10Z\"\n />\n </svg>\n </button>\n\n <ng-template [cdkPortalOutlet]=\"_actionsPortal\"></ng-template>\n </div>\n </ng-template>\n </ng-container>\n\n <!-- Invisible close button for screen reader users. -->\n <button\n type=\"button\"\n mat-raised-button\n [color]=\"color || 'primary'\"\n class=\"mat-timepicker-close-button\"\n [class.cdk-visually-hidden]=\"!_closeButtonFocused\"\n (focus)=\"_closeButtonFocused = true\"\n (blur)=\"_closeButtonFocused = false\"\n (click)=\"timepicker.close()\"\n >\n {{ _closeButtonText }}\n </button>\n</div>\n", styles: [".mat-timepicker-content{display:block;border-radius:4px}.mat-timepicker-content-container{position:relative;display:flex;flex-direction:column;padding:.5rem 1.5rem}.mat-timepicker-content-actions{display:flex;justify-content:space-between;margin-right:-1rem;margin-top:1.5rem}.mat-time-toggle-mode-button{width:3.25rem;height:3.25rem;margin-left:-.75rem;margin-bottom:-.25rem;line-height:3.25rem}.mat-timepicker-close-button{position:absolute;top:100%;left:0;margin-top:.5rem}.ng-animating .mat-timepicker-close-button{display:none}\n"], components: [{ type: i3.MatTimeInputs, selector: "mat-time-inputs" }, { type: i4.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i5.MatClockDials, selector: "mat-clock-dials", inputs: ["orientation"], exportAs: ["matClockDials"] }], directives: [{ type: i6.CdkTrapFocus, selector: "[cdkTrapFocus]", inputs: ["cdkTrapFocus", "cdkTrapFocusAutoCapture"], exportAs: ["cdkTrapFocus"] }, { type: i7.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i7.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i8.CdkPortalOutlet, selector: "[cdkPortalOutlet]", inputs: ["cdkPortalOutlet"], outputs: ["attached"], exportAs: ["cdkPortalOutlet"] }], animations: [
80
+ MatTimepickerContent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: MatTimepickerContent, selector: "mat-timepicker-content", host: { listeners: { "@transformPanel.done": "_animationDone.next()" }, properties: { "@transformPanel": "_animationState" }, classAttribute: "mat-timepicker-content" }, viewQueries: [{ propertyName: "_dials", first: true, predicate: MatClockDials, descendants: true }, { propertyName: "_inputs", first: true, predicate: MatTimeInputs, descendants: true }], exportAs: ["matTimepickerContent"], usesInheritance: true, ngImport: i0, template: "<div\n cdkTrapFocus\n role=\"dialog\"\n class=\"mat-timepicker-content-container\"\n [attr.aria-modal]=\"true\"\n [attr.aria-labelledby]=\"_dialogLabelId ?? undefined\"\n>\n <ng-container [ngSwitch]=\"mode\">\n <ng-template ngSwitchCase=\"input\">\n <mat-time-inputs\n [id]=\"timepicker.id\"\n [color]=\"color\"\n [isMeridiem]=\"isMeridiem\"\n [selected]=\"_getSelected()\"\n [minTime]=\"timepicker._getMinTime()\"\n [maxTime]=\"timepicker._getMaxTime()\"\n [minuteInterval]=\"minuteInterval\"\n (_userSelection)=\"_handleUserSelection($event)\"\n ></mat-time-inputs>\n\n <div class=\"mat-timepicker-content-actions\">\n <button\n class=\"mat-time-toggle-mode-button\"\n mat-icon-button\n *ngIf=\"showToggleModeButton\"\n (click)=\"onToggleMode('dial')\"\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n height=\"24\"\n width=\"24\"\n viewBox=\"0 0 24 24\"\n >\n <path\n d=\"m15.175 16.625 1.475-1.45-3.6-3.6V7.1h-2.075v5.3ZM12 21.95q-2.075 0-3.887-.787-1.813-.788-3.15-2.125-1.338-1.338-2.125-3.151Q2.05 14.075 2.05 12t.788-3.887q.787-1.813 2.125-3.15Q6.3 3.625 8.113 2.837 9.925 2.05 12 2.05t3.887.787q1.813.788 3.151 2.126 1.337 1.337 2.125 3.15.787 1.812.787 3.887t-.787 3.887q-.788 1.813-2.125 3.151-1.338 1.337-3.151 2.125-1.812.787-3.887.787ZM12 12Zm0 7.8q3.225 0 5.513-2.275Q19.8 15.25 19.8 12q0-3.25-2.287-5.525Q15.225 4.2 12 4.2T6.488 6.475Q4.2 8.75 4.2 12q0 3.25 2.288 5.525Q8.775 19.8 12 19.8Z\"\n />\n </svg>\n </button>\n\n <ng-template [cdkPortalOutlet]=\"_actionsPortal\"></ng-template>\n </div>\n </ng-template>\n <ng-template ngSwitchCase=\"dial\">\n <mat-clock-dials\n [id]=\"timepicker.id\"\n [color]=\"color\"\n [isMeridiem]=\"isMeridiem\"\n [selected]=\"_getSelected()\"\n [minTime]=\"timepicker._getMinTime()\"\n [maxTime]=\"timepicker._getMaxTime()\"\n [minuteInterval]=\"minuteInterval\"\n [orientation]=\"orientation\"\n (_userSelection)=\"_handleUserSelection($event)\"\n ></mat-clock-dials>\n\n <div class=\"mat-timepicker-content-actions\">\n <button\n class=\"mat-time-toggle-mode-button\"\n mat-icon-button\n *ngIf=\"showToggleModeButton\"\n (click)=\"onToggleMode('input')\"\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n height=\"24\"\n width=\"24\"\n viewBox=\"0 0 24 24\"\n >\n <path\n d=\"M4 19q-.825 0-1.412-.587Q2 17.825 2 17V7q0-.825.588-1.412Q3.175 5 4 5h16q.825 0 1.413.588Q22 6.175 22 7v10q0 .825-.587 1.413Q20.825 19 20 19Zm0-2h16V7H4v10Zm4-1h8v-2H8Zm-3-3h2v-2H5Zm3 0h2v-2H8Zm3 0h2v-2h-2Zm3 0h2v-2h-2Zm3 0h2v-2h-2ZM5 10h2V8H5Zm3 0h2V8H8Zm3 0h2V8h-2Zm3 0h2V8h-2Zm3 0h2V8h-2ZM4 17V7v10Z\"\n />\n </svg>\n </button>\n\n <ng-template [cdkPortalOutlet]=\"_actionsPortal\"></ng-template>\n </div>\n </ng-template>\n </ng-container>\n\n <!-- Invisible close button for screen reader users. -->\n <button\n type=\"button\"\n class=\"mat-timepicker-close-button\"\n mat-raised-button\n [color]=\"color || 'primary'\"\n [class.cdk-visually-hidden]=\"!_closeButtonFocused\"\n (focus)=\"_closeButtonFocused = true\"\n (blur)=\"_closeButtonFocused = false\"\n (click)=\"timepicker.close()\"\n >\n {{ _closeButtonText }}\n </button>\n</div>\n", styles: [".mat-timepicker-content{display:block;border-radius:4px}.mat-timepicker-content-container{position:relative;display:flex;flex-direction:column;padding:.5rem 1.5rem}.mat-timepicker-content-actions{display:flex;justify-content:space-between;margin-right:-1rem;margin-top:1.5rem}.mat-time-toggle-mode-button{width:3.25rem;height:3.25rem;margin-left:-.75rem;margin-bottom:-.25rem;line-height:3.25rem}button.mat-timepicker-close-button{position:absolute;top:100%;left:0;margin-top:.5rem}.ng-animating button.mat-timepicker-close-button{display:none}\n"], components: [{ type: i3.MatTimeInputs, selector: "mat-time-inputs" }, { type: i4.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i5.MatClockDials, selector: "mat-clock-dials", inputs: ["orientation"], exportAs: ["matClockDials"] }], directives: [{ type: i6.CdkTrapFocus, selector: "[cdkTrapFocus]", inputs: ["cdkTrapFocus", "cdkTrapFocusAutoCapture"], exportAs: ["cdkTrapFocus"] }, { type: i7.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i7.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i8.CdkPortalOutlet, selector: "[cdkPortalOutlet]", inputs: ["cdkPortalOutlet"], outputs: ["attached"], exportAs: ["cdkPortalOutlet"] }], animations: [
81
81
  matTimepickerAnimations.transformPanel,
82
82
  matTimepickerAnimations.fadeInTimepicker,
83
83
  ], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
@@ -90,7 +90,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
90
90
  }, animations: [
91
91
  matTimepickerAnimations.transformPanel,
92
92
  matTimepickerAnimations.fadeInTimepicker,
93
- ], template: "<div\n cdkTrapFocus\n role=\"dialog\"\n class=\"mat-timepicker-content-container\"\n [attr.aria-modal]=\"true\"\n [attr.aria-labelledby]=\"_dialogLabelId ?? undefined\"\n>\n <ng-container [ngSwitch]=\"mode\">\n <ng-template ngSwitchCase=\"input\">\n <mat-time-inputs\n [id]=\"timepicker.id\"\n [color]=\"color\"\n [isMeridiem]=\"isMeridiem\"\n [selected]=\"_getSelected()\"\n [minTime]=\"timepicker._getMinTime()\"\n [maxTime]=\"timepicker._getMaxTime()\"\n [minuteInterval]=\"minuteInterval\"\n (_userSelection)=\"_handleUserSelection($event)\"\n ></mat-time-inputs>\n\n <div class=\"mat-timepicker-content-actions\">\n <button\n class=\"mat-time-toggle-mode-button\"\n mat-icon-button\n *ngIf=\"showToggleModeButton\"\n (click)=\"onToggleMode('dial')\"\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n height=\"24\"\n width=\"24\"\n viewBox=\"0 0 24 24\"\n >\n <path\n d=\"m15.175 16.625 1.475-1.45-3.6-3.6V7.1h-2.075v5.3ZM12 21.95q-2.075 0-3.887-.787-1.813-.788-3.15-2.125-1.338-1.338-2.125-3.151Q2.05 14.075 2.05 12t.788-3.887q.787-1.813 2.125-3.15Q6.3 3.625 8.113 2.837 9.925 2.05 12 2.05t3.887.787q1.813.788 3.151 2.126 1.337 1.337 2.125 3.15.787 1.812.787 3.887t-.787 3.887q-.788 1.813-2.125 3.151-1.338 1.337-3.151 2.125-1.812.787-3.887.787ZM12 12Zm0 7.8q3.225 0 5.513-2.275Q19.8 15.25 19.8 12q0-3.25-2.287-5.525Q15.225 4.2 12 4.2T6.488 6.475Q4.2 8.75 4.2 12q0 3.25 2.288 5.525Q8.775 19.8 12 19.8Z\"\n />\n </svg>\n </button>\n\n <ng-template [cdkPortalOutlet]=\"_actionsPortal\"></ng-template>\n </div>\n </ng-template>\n <ng-template ngSwitchCase=\"dial\">\n <mat-clock-dials\n [id]=\"timepicker.id\"\n [color]=\"color\"\n [isMeridiem]=\"isMeridiem\"\n [selected]=\"_getSelected()\"\n [minTime]=\"timepicker._getMinTime()\"\n [maxTime]=\"timepicker._getMaxTime()\"\n [minuteInterval]=\"minuteInterval\"\n [orientation]=\"orientation\"\n (_userSelection)=\"_handleUserSelection($event)\"\n ></mat-clock-dials>\n\n <div class=\"mat-timepicker-content-actions\">\n <button\n class=\"mat-time-toggle-mode-button\"\n mat-icon-button\n *ngIf=\"showToggleModeButton\"\n (click)=\"onToggleMode('input')\"\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n height=\"24\"\n width=\"24\"\n viewBox=\"0 0 24 24\"\n >\n <path\n d=\"M4 19q-.825 0-1.412-.587Q2 17.825 2 17V7q0-.825.588-1.412Q3.175 5 4 5h16q.825 0 1.413.588Q22 6.175 22 7v10q0 .825-.587 1.413Q20.825 19 20 19Zm0-2h16V7H4v10Zm4-1h8v-2H8Zm-3-3h2v-2H5Zm3 0h2v-2H8Zm3 0h2v-2h-2Zm3 0h2v-2h-2Zm3 0h2v-2h-2ZM5 10h2V8H5Zm3 0h2V8H8Zm3 0h2V8h-2Zm3 0h2V8h-2Zm3 0h2V8h-2ZM4 17V7v10Z\"\n />\n </svg>\n </button>\n\n <ng-template [cdkPortalOutlet]=\"_actionsPortal\"></ng-template>\n </div>\n </ng-template>\n </ng-container>\n\n <!-- Invisible close button for screen reader users. -->\n <button\n type=\"button\"\n mat-raised-button\n [color]=\"color || 'primary'\"\n class=\"mat-timepicker-close-button\"\n [class.cdk-visually-hidden]=\"!_closeButtonFocused\"\n (focus)=\"_closeButtonFocused = true\"\n (blur)=\"_closeButtonFocused = false\"\n (click)=\"timepicker.close()\"\n >\n {{ _closeButtonText }}\n </button>\n</div>\n", styles: [".mat-timepicker-content{display:block;border-radius:4px}.mat-timepicker-content-container{position:relative;display:flex;flex-direction:column;padding:.5rem 1.5rem}.mat-timepicker-content-actions{display:flex;justify-content:space-between;margin-right:-1rem;margin-top:1.5rem}.mat-time-toggle-mode-button{width:3.25rem;height:3.25rem;margin-left:-.75rem;margin-bottom:-.25rem;line-height:3.25rem}.mat-timepicker-close-button{position:absolute;top:100%;left:0;margin-top:.5rem}.ng-animating .mat-timepicker-close-button{display:none}\n"] }]
93
+ ], template: "<div\n cdkTrapFocus\n role=\"dialog\"\n class=\"mat-timepicker-content-container\"\n [attr.aria-modal]=\"true\"\n [attr.aria-labelledby]=\"_dialogLabelId ?? undefined\"\n>\n <ng-container [ngSwitch]=\"mode\">\n <ng-template ngSwitchCase=\"input\">\n <mat-time-inputs\n [id]=\"timepicker.id\"\n [color]=\"color\"\n [isMeridiem]=\"isMeridiem\"\n [selected]=\"_getSelected()\"\n [minTime]=\"timepicker._getMinTime()\"\n [maxTime]=\"timepicker._getMaxTime()\"\n [minuteInterval]=\"minuteInterval\"\n (_userSelection)=\"_handleUserSelection($event)\"\n ></mat-time-inputs>\n\n <div class=\"mat-timepicker-content-actions\">\n <button\n class=\"mat-time-toggle-mode-button\"\n mat-icon-button\n *ngIf=\"showToggleModeButton\"\n (click)=\"onToggleMode('dial')\"\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n height=\"24\"\n width=\"24\"\n viewBox=\"0 0 24 24\"\n >\n <path\n d=\"m15.175 16.625 1.475-1.45-3.6-3.6V7.1h-2.075v5.3ZM12 21.95q-2.075 0-3.887-.787-1.813-.788-3.15-2.125-1.338-1.338-2.125-3.151Q2.05 14.075 2.05 12t.788-3.887q.787-1.813 2.125-3.15Q6.3 3.625 8.113 2.837 9.925 2.05 12 2.05t3.887.787q1.813.788 3.151 2.126 1.337 1.337 2.125 3.15.787 1.812.787 3.887t-.787 3.887q-.788 1.813-2.125 3.151-1.338 1.337-3.151 2.125-1.812.787-3.887.787ZM12 12Zm0 7.8q3.225 0 5.513-2.275Q19.8 15.25 19.8 12q0-3.25-2.287-5.525Q15.225 4.2 12 4.2T6.488 6.475Q4.2 8.75 4.2 12q0 3.25 2.288 5.525Q8.775 19.8 12 19.8Z\"\n />\n </svg>\n </button>\n\n <ng-template [cdkPortalOutlet]=\"_actionsPortal\"></ng-template>\n </div>\n </ng-template>\n <ng-template ngSwitchCase=\"dial\">\n <mat-clock-dials\n [id]=\"timepicker.id\"\n [color]=\"color\"\n [isMeridiem]=\"isMeridiem\"\n [selected]=\"_getSelected()\"\n [minTime]=\"timepicker._getMinTime()\"\n [maxTime]=\"timepicker._getMaxTime()\"\n [minuteInterval]=\"minuteInterval\"\n [orientation]=\"orientation\"\n (_userSelection)=\"_handleUserSelection($event)\"\n ></mat-clock-dials>\n\n <div class=\"mat-timepicker-content-actions\">\n <button\n class=\"mat-time-toggle-mode-button\"\n mat-icon-button\n *ngIf=\"showToggleModeButton\"\n (click)=\"onToggleMode('input')\"\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n height=\"24\"\n width=\"24\"\n viewBox=\"0 0 24 24\"\n >\n <path\n d=\"M4 19q-.825 0-1.412-.587Q2 17.825 2 17V7q0-.825.588-1.412Q3.175 5 4 5h16q.825 0 1.413.588Q22 6.175 22 7v10q0 .825-.587 1.413Q20.825 19 20 19Zm0-2h16V7H4v10Zm4-1h8v-2H8Zm-3-3h2v-2H5Zm3 0h2v-2H8Zm3 0h2v-2h-2Zm3 0h2v-2h-2Zm3 0h2v-2h-2ZM5 10h2V8H5Zm3 0h2V8H8Zm3 0h2V8h-2Zm3 0h2V8h-2Zm3 0h2V8h-2ZM4 17V7v10Z\"\n />\n </svg>\n </button>\n\n <ng-template [cdkPortalOutlet]=\"_actionsPortal\"></ng-template>\n </div>\n </ng-template>\n </ng-container>\n\n <!-- Invisible close button for screen reader users. -->\n <button\n type=\"button\"\n class=\"mat-timepicker-close-button\"\n mat-raised-button\n [color]=\"color || 'primary'\"\n [class.cdk-visually-hidden]=\"!_closeButtonFocused\"\n (focus)=\"_closeButtonFocused = true\"\n (blur)=\"_closeButtonFocused = false\"\n (click)=\"timepicker.close()\"\n >\n {{ _closeButtonText }}\n </button>\n</div>\n", styles: [".mat-timepicker-content{display:block;border-radius:4px}.mat-timepicker-content-container{position:relative;display:flex;flex-direction:column;padding:.5rem 1.5rem}.mat-timepicker-content-actions{display:flex;justify-content:space-between;margin-right:-1rem;margin-top:1.5rem}.mat-time-toggle-mode-button{width:3.25rem;height:3.25rem;margin-left:-.75rem;margin-bottom:-.25rem;line-height:3.25rem}button.mat-timepicker-close-button{position:absolute;top:100%;left:0;margin-top:.5rem}.ng-animating button.mat-timepicker-close-button{display:none}\n"] }]
94
94
  }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.MatTimepickerIntl }, { type: i2.MatTimeSelectionModel }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { _dials: [{
95
95
  type: ViewChild,
96
96
  args: [MatClockDials]
@@ -98,4 +98,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
98
98
  type: ViewChild,
99
99
  args: [MatTimeInputs]
100
100
  }] } });
101
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timepicker-content.js","sourceRoot":"","sources":["../../../../projects/mat-timepicker/src/lib/timepicker-content.ts","../../../../projects/mat-timepicker/src/lib/timepicker-content.html"],"names":[],"mappings":"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","sourcesContent":["import { ComponentPortal, TemplatePortal } from '@angular/cdk/portal';\nimport {\n  Component,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  ViewEncapsulation,\n  ElementRef,\n  OnInit,\n  AfterViewInit,\n  ViewChild,\n} from '@angular/core';\nimport { mixinColor } from '@angular/material/core';\nimport { Subject } from 'rxjs';\n\nimport {\n  ExtractTimeTypeFromSelection,\n  MatTimeSelectionModel,\n} from './time-selection-model';\nimport { matTimepickerAnimations } from './timepicker-animations';\nimport { MatTimepickerBase, TimepickerMode } from './timepicker-base';\nimport { MatTimepickerIntl } from './timepicker-intl';\nimport { MatClockDials } from './clock-dials';\nimport { MatTimeInputs } from './time-inputs';\nimport { TimepickerOrientation } from './orientation';\n\n// Boilerplate for applying mixins to MatTimepickerContent.\nconst _MatTimepickerContentBase = mixinColor(\n  class {\n    constructor(public _elementRef: ElementRef) {}\n  }\n);\n\n@Component({\n  selector: 'mat-timepicker-content',\n  templateUrl: './timepicker-content.html',\n  styleUrls: ['./timepicker-content.scss'],\n  exportAs: 'matTimepickerContent',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  host: {\n    class: 'mat-timepicker-content',\n    '[@transformPanel]': '_animationState',\n    '(@transformPanel.done)': '_animationDone.next()',\n  },\n  animations: [\n    matTimepickerAnimations.transformPanel,\n    matTimepickerAnimations.fadeInTimepicker,\n  ],\n})\nexport class MatTimepickerContent<S, T = ExtractTimeTypeFromSelection<S>>\n  extends _MatTimepickerContentBase\n  implements OnInit, AfterViewInit\n{\n  /** Reference to the internal clock dials component. */\n  @ViewChild(MatClockDials) _dials: MatClockDials<T> | undefined;\n\n  /** Reference to the internal time inputs component. */\n  @ViewChild(MatTimeInputs) _inputs: MatTimeInputs<T> | undefined;\n\n  /** Reference to the timepicker that created the overlay. */\n  timepicker: MatTimepickerBase<any, S, T>;\n\n  /** Display mode. */\n  mode: TimepickerMode;\n\n  /** Current state of the animation. */\n  _animationState: 'enter-dropdown' | 'enter-dialog' | 'void';\n\n  /** Whether the clock uses 12 hour format. */\n  isMeridiem: boolean;\n\n  /** Whether should toggle face button be shown. */\n  showToggleModeButton: boolean;\n\n  /** Step for minutes. */\n  minuteInterval: number;\n\n  /** Orientation for dial mode. */\n  orientation: TimepickerOrientation;\n\n  /** Portal with projected action buttons. */\n  _actionsPortal: TemplatePortal | ComponentPortal<any> | null = null;\n\n  /** Id of the label for the `role=\"dialog\"` element. */\n  _dialogLabelId: string | null;\n\n  /** Text for the close button. */\n  _closeButtonText: string;\n\n  /** Whether the close button currently has focus. */\n  _closeButtonFocused: boolean;\n\n  /** Emits when an animation has finished. */\n  readonly _animationDone = new Subject<void>();\n\n  private _model: MatTimeSelectionModel<S, T>;\n\n  constructor(\n    elementRef: ElementRef,\n    intl: MatTimepickerIntl,\n    private _globalModel: MatTimeSelectionModel<S, T>,\n    private _changeDetectorRef: ChangeDetectorRef\n  ) {\n    super(elementRef);\n    this._closeButtonText = intl.closeTimepickerLabel;\n  }\n\n  ngOnInit() {\n    this._animationState =\n      this.timepicker.openAs === 'dialog' ? 'enter-dialog' : 'enter-dropdown';\n  }\n\n  ngAfterViewInit() {\n    (this._dials || this._inputs)?.focusActiveCell();\n  }\n\n  /** Changes animation state while closing timepicker content. */\n  startExitAnimation() {\n    this._animationState = 'void';\n    this._changeDetectorRef.markForCheck();\n  }\n\n  onToggleMode(mode: TimepickerMode): void {\n    this.mode = mode;\n  }\n\n  _getSelected() {\n    return this._model?.selection as unknown as T | null;\n  }\n\n  /** Applies the current pending selection to the global model. */\n  _applyPendingSelection() {\n    if (this._model !== this._globalModel) {\n      this._globalModel.updateSelection(this._model.selection, this);\n    }\n  }\n\n  /**\n   * Assigns a new portal containing the timepicker actions.\n   * @param portal Portal with the actions to be assigned.\n   * @param forceRerender Whether a re-render of the portal should be triggered. This isn't\n   * necessary if the portal is assigned during initialization, but it may be required if it's\n   * added at a later point.\n   */\n  _assignActions(\n    portal: TemplatePortal<any> | ComponentPortal<any> | null,\n    forceRerender: boolean\n  ) {\n    // As we have actions, clone the model so that we have the ability to cancel the selection.\n    // Note that we want to assign this as soon as possible,\n    // but `_actionsPortal` isn't available in the constructor so we do it in `ngOnInit`.\n    this._model = this._globalModel.clone();\n\n    this._actionsPortal = portal;\n\n    if (forceRerender) {\n      this._changeDetectorRef.detectChanges();\n    }\n  }\n\n  _handleUserSelection(event: T) {\n    const value = event;\n    this._model.add(value);\n  }\n}\n","<div\n  cdkTrapFocus\n  role=\"dialog\"\n  class=\"mat-timepicker-content-container\"\n  [attr.aria-modal]=\"true\"\n  [attr.aria-labelledby]=\"_dialogLabelId ?? undefined\"\n>\n  <ng-container [ngSwitch]=\"mode\">\n    <ng-template ngSwitchCase=\"input\">\n      <mat-time-inputs\n        [id]=\"timepicker.id\"\n        [color]=\"color\"\n        [isMeridiem]=\"isMeridiem\"\n        [selected]=\"_getSelected()\"\n        [minTime]=\"timepicker._getMinTime()\"\n        [maxTime]=\"timepicker._getMaxTime()\"\n        [minuteInterval]=\"minuteInterval\"\n        (_userSelection)=\"_handleUserSelection($event)\"\n      ></mat-time-inputs>\n\n      <div class=\"mat-timepicker-content-actions\">\n        <button\n          class=\"mat-time-toggle-mode-button\"\n          mat-icon-button\n          *ngIf=\"showToggleModeButton\"\n          (click)=\"onToggleMode('dial')\"\n        >\n          <svg\n            xmlns=\"http://www.w3.org/2000/svg\"\n            height=\"24\"\n            width=\"24\"\n            viewBox=\"0 0 24 24\"\n          >\n            <path\n              d=\"m15.175 16.625 1.475-1.45-3.6-3.6V7.1h-2.075v5.3ZM12 21.95q-2.075 0-3.887-.787-1.813-.788-3.15-2.125-1.338-1.338-2.125-3.151Q2.05 14.075 2.05 12t.788-3.887q.787-1.813 2.125-3.15Q6.3 3.625 8.113 2.837 9.925 2.05 12 2.05t3.887.787q1.813.788 3.151 2.126 1.337 1.337 2.125 3.15.787 1.812.787 3.887t-.787 3.887q-.788 1.813-2.125 3.151-1.338 1.337-3.151 2.125-1.812.787-3.887.787ZM12 12Zm0 7.8q3.225 0 5.513-2.275Q19.8 15.25 19.8 12q0-3.25-2.287-5.525Q15.225 4.2 12 4.2T6.488 6.475Q4.2 8.75 4.2 12q0 3.25 2.288 5.525Q8.775 19.8 12 19.8Z\"\n            />\n          </svg>\n        </button>\n\n        <ng-template [cdkPortalOutlet]=\"_actionsPortal\"></ng-template>\n      </div>\n    </ng-template>\n    <ng-template ngSwitchCase=\"dial\">\n      <mat-clock-dials\n        [id]=\"timepicker.id\"\n        [color]=\"color\"\n        [isMeridiem]=\"isMeridiem\"\n        [selected]=\"_getSelected()\"\n        [minTime]=\"timepicker._getMinTime()\"\n        [maxTime]=\"timepicker._getMaxTime()\"\n        [minuteInterval]=\"minuteInterval\"\n        [orientation]=\"orientation\"\n        (_userSelection)=\"_handleUserSelection($event)\"\n      ></mat-clock-dials>\n\n      <div class=\"mat-timepicker-content-actions\">\n        <button\n          class=\"mat-time-toggle-mode-button\"\n          mat-icon-button\n          *ngIf=\"showToggleModeButton\"\n          (click)=\"onToggleMode('input')\"\n        >\n          <svg\n            xmlns=\"http://www.w3.org/2000/svg\"\n            height=\"24\"\n            width=\"24\"\n            viewBox=\"0 0 24 24\"\n          >\n            <path\n              d=\"M4 19q-.825 0-1.412-.587Q2 17.825 2 17V7q0-.825.588-1.412Q3.175 5 4 5h16q.825 0 1.413.588Q22 6.175 22 7v10q0 .825-.587 1.413Q20.825 19 20 19Zm0-2h16V7H4v10Zm4-1h8v-2H8Zm-3-3h2v-2H5Zm3 0h2v-2H8Zm3 0h2v-2h-2Zm3 0h2v-2h-2Zm3 0h2v-2h-2ZM5 10h2V8H5Zm3 0h2V8H8Zm3 0h2V8h-2Zm3 0h2V8h-2Zm3 0h2V8h-2ZM4 17V7v10Z\"\n            />\n          </svg>\n        </button>\n\n        <ng-template [cdkPortalOutlet]=\"_actionsPortal\"></ng-template>\n      </div>\n    </ng-template>\n  </ng-container>\n\n  <!-- Invisible close button for screen reader users. -->\n  <button\n    type=\"button\"\n    mat-raised-button\n    [color]=\"color || 'primary'\"\n    class=\"mat-timepicker-close-button\"\n    [class.cdk-visually-hidden]=\"!_closeButtonFocused\"\n    (focus)=\"_closeButtonFocused = true\"\n    (blur)=\"_closeButtonFocused = false\"\n    (click)=\"timepicker.close()\"\n  >\n    {{ _closeButtonText }}\n  </button>\n</div>\n"]}
101
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timepicker-content.js","sourceRoot":"","sources":["../../../../projects/mat-timepicker/src/lib/timepicker-content.ts","../../../../projects/mat-timepicker/src/lib/timepicker-content.html"],"names":[],"mappings":"AACA,OAAO,EACL,SAAS,EACT,uBAAuB,EAEvB,iBAAiB,EAIjB,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AACpD,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAM/B,OAAO,EAAE,uBAAuB,EAAE,MAAM,yBAAyB,CAAC;AAGlE,OAAO,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAC9C,OAAO,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;;;;;;;;;;AAG9C,2DAA2D;AAC3D,MAAM,yBAAyB,GAAG,UAAU,CAC1C;IACE,YAAmB,WAAuB;QAAvB,gBAAW,GAAX,WAAW,CAAY;IAAG,CAAC;CAC/C,CACF,CAAC;AAmBF,MAAM,OAAO,oBACX,SAAQ,yBAAyB;IA+CjC,YACE,UAAsB,EACtB,IAAuB,EACf,YAAyC,EACzC,kBAAqC;QAE7C,KAAK,CAAC,UAAU,CAAC,CAAC;QAHV,iBAAY,GAAZ,YAAY,CAA6B;QACzC,uBAAkB,GAAlB,kBAAkB,CAAmB;QArB/C,4CAA4C;QAC5C,mBAAc,GAAiD,IAAI,CAAC;QAWpE,4CAA4C;QACnC,mBAAc,GAAG,IAAI,OAAO,EAAQ,CAAC;QAW5C,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,oBAAoB,CAAC;IACpD,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,eAAe;YAClB,IAAI,CAAC,UAAU,CAAC,MAAM,KAAK,QAAQ,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,gBAAgB,CAAC;IAC5E,CAAC;IAED,eAAe;QACb,CAAC,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,OAAO,CAAC,EAAE,eAAe,EAAE,CAAC;IACnD,CAAC;IAED,gEAAgE;IAChE,kBAAkB;QAChB,IAAI,CAAC,eAAe,GAAG,MAAM,CAAC;QAC9B,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;IACzC,CAAC;IAED,YAAY,CAAC,IAAoB;QAC/B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;IACnB,CAAC;IAED,YAAY;QACV,OAAO,IAAI,CAAC,MAAM,EAAE,SAAgC,CAAC;IACvD,CAAC;IAED,iEAAiE;IACjE,sBAAsB;QACpB,IAAI,IAAI,CAAC,MAAM,KAAK,IAAI,CAAC,YAAY,EAAE;YACrC,IAAI,CAAC,YAAY,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;SAChE;IACH,CAAC;IAED;;;;;;OAMG;IACH,cAAc,CACZ,MAAyD,EACzD,aAAsB;QAEtB,2FAA2F;QAC3F,wDAAwD;QACxD,qFAAqF;QACrF,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,CAAC;QAExC,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC;QAE7B,IAAI,aAAa,EAAE;YACjB,IAAI,CAAC,kBAAkB,CAAC,aAAa,EAAE,CAAC;SACzC;IACH,CAAC;IAED,oBAAoB,CAAC,KAAQ;QAC3B,MAAM,KAAK,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IACzB,CAAC;;iHAlHU,oBAAoB;qGAApB,oBAAoB,gRAKpB,aAAa,0EAGb,aAAa,2GCzD1B,8iHA6FA,0iDDjDc;QACV,uBAAuB,CAAC,cAAc;QACtC,uBAAuB,CAAC,gBAAgB;KACzC;2FAEU,oBAAoB;kBAjBhC,SAAS;+BACE,wBAAwB,YAGxB,sBAAsB,mBACf,uBAAuB,CAAC,MAAM,iBAChC,iBAAiB,CAAC,IAAI,QAC/B;wBACJ,KAAK,EAAE,wBAAwB;wBAC/B,mBAAmB,EAAE,iBAAiB;wBACtC,wBAAwB,EAAE,uBAAuB;qBAClD,cACW;wBACV,uBAAuB,CAAC,cAAc;wBACtC,uBAAuB,CAAC,gBAAgB;qBACzC;qMAOyB,MAAM;sBAA/B,SAAS;uBAAC,aAAa;gBAGE,OAAO;sBAAhC,SAAS;uBAAC,aAAa","sourcesContent":["import { ComponentPortal, TemplatePortal } from '@angular/cdk/portal';\nimport {\n  Component,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  ViewEncapsulation,\n  ElementRef,\n  OnInit,\n  AfterViewInit,\n  ViewChild,\n} from '@angular/core';\nimport { mixinColor } from '@angular/material/core';\nimport { Subject } from 'rxjs';\n\nimport {\n  ExtractTimeTypeFromSelection,\n  MatTimeSelectionModel,\n} from './time-selection-model';\nimport { matTimepickerAnimations } from './timepicker-animations';\nimport { MatTimepickerBase, TimepickerMode } from './timepicker-base';\nimport { MatTimepickerIntl } from './timepicker-intl';\nimport { MatClockDials } from './clock-dials';\nimport { MatTimeInputs } from './time-inputs';\nimport { TimepickerOrientation } from './orientation';\n\n// Boilerplate for applying mixins to MatTimepickerContent.\nconst _MatTimepickerContentBase = mixinColor(\n  class {\n    constructor(public _elementRef: ElementRef) {}\n  }\n);\n\n@Component({\n  selector: 'mat-timepicker-content',\n  templateUrl: './timepicker-content.html',\n  styleUrls: ['./timepicker-content.scss'],\n  exportAs: 'matTimepickerContent',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  host: {\n    class: 'mat-timepicker-content',\n    '[@transformPanel]': '_animationState',\n    '(@transformPanel.done)': '_animationDone.next()',\n  },\n  animations: [\n    matTimepickerAnimations.transformPanel,\n    matTimepickerAnimations.fadeInTimepicker,\n  ],\n})\nexport class MatTimepickerContent<S, T = ExtractTimeTypeFromSelection<S>>\n  extends _MatTimepickerContentBase\n  implements OnInit, AfterViewInit\n{\n  /** Reference to the internal clock dials component. */\n  @ViewChild(MatClockDials) _dials: MatClockDials<T> | undefined;\n\n  /** Reference to the internal time inputs component. */\n  @ViewChild(MatTimeInputs) _inputs: MatTimeInputs<T> | undefined;\n\n  /** Reference to the timepicker that created the overlay. */\n  timepicker: MatTimepickerBase<any, S, T>;\n\n  /** Display mode. */\n  mode: TimepickerMode;\n\n  /** Current state of the animation. */\n  _animationState: 'enter-dropdown' | 'enter-dialog' | 'void';\n\n  /** Whether the clock uses 12 hour format. */\n  isMeridiem: boolean;\n\n  /** Whether should toggle face button be shown. */\n  showToggleModeButton: boolean;\n\n  /** Step for minutes. */\n  minuteInterval: number;\n\n  /** Orientation for dial mode. */\n  orientation: TimepickerOrientation;\n\n  /** Portal with projected action buttons. */\n  _actionsPortal: TemplatePortal | ComponentPortal<any> | null = null;\n\n  /** Id of the label for the `role=\"dialog\"` element. */\n  _dialogLabelId: string | null;\n\n  /** Text for the close button. */\n  _closeButtonText: string;\n\n  /** Whether the close button currently has focus. */\n  _closeButtonFocused: boolean;\n\n  /** Emits when an animation has finished. */\n  readonly _animationDone = new Subject<void>();\n\n  private _model: MatTimeSelectionModel<S, T>;\n\n  constructor(\n    elementRef: ElementRef,\n    intl: MatTimepickerIntl,\n    private _globalModel: MatTimeSelectionModel<S, T>,\n    private _changeDetectorRef: ChangeDetectorRef\n  ) {\n    super(elementRef);\n    this._closeButtonText = intl.closeTimepickerLabel;\n  }\n\n  ngOnInit() {\n    this._animationState =\n      this.timepicker.openAs === 'dialog' ? 'enter-dialog' : 'enter-dropdown';\n  }\n\n  ngAfterViewInit() {\n    (this._dials || this._inputs)?.focusActiveCell();\n  }\n\n  /** Changes animation state while closing timepicker content. */\n  startExitAnimation() {\n    this._animationState = 'void';\n    this._changeDetectorRef.markForCheck();\n  }\n\n  onToggleMode(mode: TimepickerMode): void {\n    this.mode = mode;\n  }\n\n  _getSelected() {\n    return this._model?.selection as unknown as T | null;\n  }\n\n  /** Applies the current pending selection to the global model. */\n  _applyPendingSelection() {\n    if (this._model !== this._globalModel) {\n      this._globalModel.updateSelection(this._model.selection, this);\n    }\n  }\n\n  /**\n   * Assigns a new portal containing the timepicker actions.\n   * @param portal Portal with the actions to be assigned.\n   * @param forceRerender Whether a re-render of the portal should be triggered. This isn't\n   * necessary if the portal is assigned during initialization, but it may be required if it's\n   * added at a later point.\n   */\n  _assignActions(\n    portal: TemplatePortal<any> | ComponentPortal<any> | null,\n    forceRerender: boolean\n  ) {\n    // As we have actions, clone the model so that we have the ability to cancel the selection.\n    // Note that we want to assign this as soon as possible,\n    // but `_actionsPortal` isn't available in the constructor so we do it in `ngOnInit`.\n    this._model = this._globalModel.clone();\n\n    this._actionsPortal = portal;\n\n    if (forceRerender) {\n      this._changeDetectorRef.detectChanges();\n    }\n  }\n\n  _handleUserSelection(event: T) {\n    const value = event;\n    this._model.add(value);\n  }\n}\n","<div\n  cdkTrapFocus\n  role=\"dialog\"\n  class=\"mat-timepicker-content-container\"\n  [attr.aria-modal]=\"true\"\n  [attr.aria-labelledby]=\"_dialogLabelId ?? undefined\"\n>\n  <ng-container [ngSwitch]=\"mode\">\n    <ng-template ngSwitchCase=\"input\">\n      <mat-time-inputs\n        [id]=\"timepicker.id\"\n        [color]=\"color\"\n        [isMeridiem]=\"isMeridiem\"\n        [selected]=\"_getSelected()\"\n        [minTime]=\"timepicker._getMinTime()\"\n        [maxTime]=\"timepicker._getMaxTime()\"\n        [minuteInterval]=\"minuteInterval\"\n        (_userSelection)=\"_handleUserSelection($event)\"\n      ></mat-time-inputs>\n\n      <div class=\"mat-timepicker-content-actions\">\n        <button\n          class=\"mat-time-toggle-mode-button\"\n          mat-icon-button\n          *ngIf=\"showToggleModeButton\"\n          (click)=\"onToggleMode('dial')\"\n        >\n          <svg\n            xmlns=\"http://www.w3.org/2000/svg\"\n            height=\"24\"\n            width=\"24\"\n            viewBox=\"0 0 24 24\"\n          >\n            <path\n              d=\"m15.175 16.625 1.475-1.45-3.6-3.6V7.1h-2.075v5.3ZM12 21.95q-2.075 0-3.887-.787-1.813-.788-3.15-2.125-1.338-1.338-2.125-3.151Q2.05 14.075 2.05 12t.788-3.887q.787-1.813 2.125-3.15Q6.3 3.625 8.113 2.837 9.925 2.05 12 2.05t3.887.787q1.813.788 3.151 2.126 1.337 1.337 2.125 3.15.787 1.812.787 3.887t-.787 3.887q-.788 1.813-2.125 3.151-1.338 1.337-3.151 2.125-1.812.787-3.887.787ZM12 12Zm0 7.8q3.225 0 5.513-2.275Q19.8 15.25 19.8 12q0-3.25-2.287-5.525Q15.225 4.2 12 4.2T6.488 6.475Q4.2 8.75 4.2 12q0 3.25 2.288 5.525Q8.775 19.8 12 19.8Z\"\n            />\n          </svg>\n        </button>\n\n        <ng-template [cdkPortalOutlet]=\"_actionsPortal\"></ng-template>\n      </div>\n    </ng-template>\n    <ng-template ngSwitchCase=\"dial\">\n      <mat-clock-dials\n        [id]=\"timepicker.id\"\n        [color]=\"color\"\n        [isMeridiem]=\"isMeridiem\"\n        [selected]=\"_getSelected()\"\n        [minTime]=\"timepicker._getMinTime()\"\n        [maxTime]=\"timepicker._getMaxTime()\"\n        [minuteInterval]=\"minuteInterval\"\n        [orientation]=\"orientation\"\n        (_userSelection)=\"_handleUserSelection($event)\"\n      ></mat-clock-dials>\n\n      <div class=\"mat-timepicker-content-actions\">\n        <button\n          class=\"mat-time-toggle-mode-button\"\n          mat-icon-button\n          *ngIf=\"showToggleModeButton\"\n          (click)=\"onToggleMode('input')\"\n        >\n          <svg\n            xmlns=\"http://www.w3.org/2000/svg\"\n            height=\"24\"\n            width=\"24\"\n            viewBox=\"0 0 24 24\"\n          >\n            <path\n              d=\"M4 19q-.825 0-1.412-.587Q2 17.825 2 17V7q0-.825.588-1.412Q3.175 5 4 5h16q.825 0 1.413.588Q22 6.175 22 7v10q0 .825-.587 1.413Q20.825 19 20 19Zm0-2h16V7H4v10Zm4-1h8v-2H8Zm-3-3h2v-2H5Zm3 0h2v-2H8Zm3 0h2v-2h-2Zm3 0h2v-2h-2Zm3 0h2v-2h-2ZM5 10h2V8H5Zm3 0h2V8H8Zm3 0h2V8h-2Zm3 0h2V8h-2Zm3 0h2V8h-2ZM4 17V7v10Z\"\n            />\n          </svg>\n        </button>\n\n        <ng-template [cdkPortalOutlet]=\"_actionsPortal\"></ng-template>\n      </div>\n    </ng-template>\n  </ng-container>\n\n  <!-- Invisible close button for screen reader users. -->\n  <button\n    type=\"button\"\n    class=\"mat-timepicker-close-button\"\n    mat-raised-button\n    [color]=\"color || 'primary'\"\n    [class.cdk-visually-hidden]=\"!_closeButtonFocused\"\n    (focus)=\"_closeButtonFocused = true\"\n    (blur)=\"_closeButtonFocused = false\"\n    (click)=\"timepicker.close()\"\n  >\n    {{ _closeButtonText }}\n  </button>\n</div>\n"]}
@@ -93,7 +93,7 @@ export class MatTimepickerInput extends MatTimepickerInputBase {
93
93
  }
94
94
  }
95
95
  MatTimepickerInput.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: MatTimepickerInput, deps: [{ token: i0.ElementRef }, { token: i1.TimeAdapter, optional: true }, { token: MAT_FORM_FIELD, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
96
- MatTimepickerInput.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.4.0", type: MatTimepickerInput, selector: "input[matTimepicker]", inputs: { matTimepicker: "matTimepicker", min: "min", max: "max" }, host: { listeners: { "input": "_onInput($event.target.value)", "change": "_onChange()", "blur": "_onBlur()" }, properties: { "attr.aria-haspopup": "_timepicker ? \"dialog\" : null", "attr.aria-owns": "(_timepicker?.opened && _timepicker.id) || null", "disabled": "disabled" }, classAttribute: "mat-timepicker-input" }, providers: [
96
+ MatTimepickerInput.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.4.0", type: MatTimepickerInput, selector: "input[matTimepicker]", inputs: { matTimepicker: "matTimepicker", min: "min", max: "max" }, host: { listeners: { "input": "_onInput($event.target.value)", "change": "_onChange()", "blur": "_onBlur()" }, properties: { "attr.aria-haspopup": "_timepicker ? \"dialog\" : null", "attr.aria-owns": "(_timepicker?.opened && _timepicker.id) || null", "attr.min": "min || null", "attr.max": "max || null", "disabled": "disabled" }, classAttribute: "mat-timepicker-input" }, providers: [
97
97
  MAT_TIMEPICKER_VALUE_ACCESSOR,
98
98
  MAT_TIMEPICKER_VALIDATORS,
99
99
  { provide: MAT_INPUT_VALUE_ACCESSOR, useExisting: MatTimepickerInput },
@@ -112,6 +112,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
112
112
  class: 'mat-timepicker-input',
113
113
  '[attr.aria-haspopup]': '_timepicker ? "dialog" : null',
114
114
  '[attr.aria-owns]': '(_timepicker?.opened && _timepicker.id) || null',
115
+ '[attr.min]': 'min || null',
116
+ '[attr.max]': 'max || null',
115
117
  '[disabled]': 'disabled',
116
118
  '(input)': '_onInput($event.target.value)',
117
119
  '(change)': '_onChange()',
@@ -132,4 +134,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
132
134
  }], max: [{
133
135
  type: Input
134
136
  }] } });
135
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timepicker-input.js","sourceRoot":"","sources":["../../../../projects/mat-timepicker/src/lib/timepicker-input.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  forwardRef,\n  Inject,\n  Input,\n  Optional,\n} from '@angular/core';\nimport {\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n  ValidatorFn,\n  Validators,\n} from '@angular/forms';\nimport { ThemePalette } from '@angular/material/core';\nimport { MatFormField, MAT_FORM_FIELD } from '@angular/material/form-field';\nimport { MAT_INPUT_VALUE_ACCESSOR } from '@angular/material/input';\n\nimport { MatTimepicker } from './timepicker';\nimport { TimeAdapter } from './adapter/time-adapter';\nimport { MatTimepickerInputBase } from './timepicker-input-base';\nimport { TimeSelectionModelChange } from './time-selection-model';\nimport { MatTimepickerControl, MatTimepickerPanel } from './timepicker-base';\n\nexport const MAT_TIMEPICKER_VALUE_ACCESSOR: any = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => MatTimepickerInput),\n  multi: true,\n};\n\nexport const MAT_TIMEPICKER_VALIDATORS: any = {\n  provide: NG_VALIDATORS,\n  useExisting: forwardRef(() => MatTimepickerInput),\n  multi: true,\n};\n\n/** Directive used to connect an input to a MatTimepicker. */\n@Directive({\n  selector: 'input[matTimepicker]',\n  exportAs: 'matTimepickerInput',\n  providers: [\n    MAT_TIMEPICKER_VALUE_ACCESSOR,\n    MAT_TIMEPICKER_VALIDATORS,\n    { provide: MAT_INPUT_VALUE_ACCESSOR, useExisting: MatTimepickerInput },\n  ],\n  host: {\n    class: 'mat-timepicker-input',\n    '[attr.aria-haspopup]': '_timepicker ? \"dialog\" : null',\n    '[attr.aria-owns]': '(_timepicker?.opened && _timepicker.id) || null',\n    '[disabled]': 'disabled',\n    '(input)': '_onInput($event.target.value)',\n    '(change)': '_onChange()',\n    '(blur)': '_onBlur()',\n  },\n})\nexport class MatTimepickerInput<T>\n  extends MatTimepickerInputBase<T | null, T>\n  implements MatTimepickerControl<T | null>\n{\n  /** The timepicker that this input is associated with. */\n  @Input()\n  set matTimepicker(\n    timepicker: MatTimepickerPanel<MatTimepickerControl<T>, T | null, T>\n  ) {\n    if (timepicker) {\n      this._timepicker = timepicker;\n      this._registerModel(timepicker.registerInput(this));\n    }\n  }\n  _timepicker: MatTimepickerPanel<MatTimepickerControl<T>, T | null, T>;\n\n  /** The combined form control validator for this input. */\n  protected _validator: ValidatorFn | null;\n\n  /** The minimum valid date. */\n  @Input()\n  get min(): T | null {\n    return this._min;\n  }\n  set min(value: T | null) {\n    const validValue = this._timeAdapter.getValidTimeOrNull(\n      this._timeAdapter.deserialize(value)\n    );\n\n    if (!this._timeAdapter.sameTime(validValue, this._min)) {\n      this._min = validValue;\n      this._validatorOnChange();\n    }\n  }\n  private _min: T | null;\n\n  /** The maximum valid date. */\n  @Input()\n  get max(): T | null {\n    return this._max;\n  }\n  set max(value: T | null) {\n    const validValue = this._timeAdapter.getValidTimeOrNull(\n      this._timeAdapter.deserialize(value)\n    );\n\n    if (!this._timeAdapter.sameTime(validValue, this._max)) {\n      this._max = validValue;\n      this._validatorOnChange();\n    }\n  }\n  private _max: T | null;\n\n  constructor(\n    elementRef: ElementRef<HTMLInputElement>,\n    @Optional() timeAdapter: TimeAdapter<T>,\n    @Optional() @Inject(MAT_FORM_FIELD) private _formField?: MatFormField\n  ) {\n    super(elementRef, timeAdapter);\n    this._validator = Validators.compose(super._getValidators());\n  }\n\n  /**\n   * Gets the element that the timepicker popup should be connected to.\n   * @return The element to connect the popup to.\n   */\n  getConnectedOverlayOrigin(): ElementRef {\n    return this._formField\n      ? this._formField.getConnectedOverlayOrigin()\n      : this._elementRef;\n  }\n\n  /** Returns the palette used by the input's form field, if any. */\n  getThemePalette(): ThemePalette {\n    return this._formField ? this._formField.color : undefined;\n  }\n\n  /** Gets the ID of an element that should be used a description for the timepicker overlay. */\n  getOverlayLabelId(): string | null {\n    if (this._formField) {\n      return this._formField.getLabelId();\n    }\n\n    return this._elementRef.nativeElement.getAttribute('aria-labelledby');\n  }\n\n  /** Gets the input's minimum time. */\n  _getMinTime() {\n    return this._min;\n  }\n\n  /** Gets the input's maximum time. */\n  _getMaxTime() {\n    return this._max;\n  }\n\n  protected _assignValueToModel(value: T | null): void {\n    if (this._model) {\n      this._model.updateSelection(value, this);\n    }\n  }\n\n  protected _getValueFromModel(modelValue: T | null): T | null {\n    return modelValue;\n  }\n\n  protected _shouldHandleChangeEvent(event: TimeSelectionModelChange<T>) {\n    return event.source !== this;\n  }\n}\n"]}
137
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timepicker-input.js","sourceRoot":"","sources":["../../../../projects/mat-timepicker/src/lib/timepicker-input.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  forwardRef,\n  Inject,\n  Input,\n  Optional,\n} from '@angular/core';\nimport {\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n  ValidatorFn,\n  Validators,\n} from '@angular/forms';\nimport { ThemePalette } from '@angular/material/core';\nimport { MatFormField, MAT_FORM_FIELD } from '@angular/material/form-field';\nimport { MAT_INPUT_VALUE_ACCESSOR } from '@angular/material/input';\n\nimport { MatTimepicker } from './timepicker';\nimport { TimeAdapter } from './adapter/time-adapter';\nimport { MatTimepickerInputBase } from './timepicker-input-base';\nimport { TimeSelectionModelChange } from './time-selection-model';\nimport { MatTimepickerControl, MatTimepickerPanel } from './timepicker-base';\n\nexport const MAT_TIMEPICKER_VALUE_ACCESSOR: any = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => MatTimepickerInput),\n  multi: true,\n};\n\nexport const MAT_TIMEPICKER_VALIDATORS: any = {\n  provide: NG_VALIDATORS,\n  useExisting: forwardRef(() => MatTimepickerInput),\n  multi: true,\n};\n\n/** Directive used to connect an input to a MatTimepicker. */\n@Directive({\n  selector: 'input[matTimepicker]',\n  exportAs: 'matTimepickerInput',\n  providers: [\n    MAT_TIMEPICKER_VALUE_ACCESSOR,\n    MAT_TIMEPICKER_VALIDATORS,\n    { provide: MAT_INPUT_VALUE_ACCESSOR, useExisting: MatTimepickerInput },\n  ],\n  host: {\n    class: 'mat-timepicker-input',\n    '[attr.aria-haspopup]': '_timepicker ? \"dialog\" : null',\n    '[attr.aria-owns]': '(_timepicker?.opened && _timepicker.id) || null',\n    '[attr.min]': 'min || null',\n    '[attr.max]': 'max || null',\n    '[disabled]': 'disabled',\n    '(input)': '_onInput($event.target.value)',\n    '(change)': '_onChange()',\n    '(blur)': '_onBlur()',\n  },\n})\nexport class MatTimepickerInput<T>\n  extends MatTimepickerInputBase<T | null, T>\n  implements MatTimepickerControl<T | null>\n{\n  /** The timepicker that this input is associated with. */\n  @Input()\n  set matTimepicker(\n    timepicker: MatTimepickerPanel<MatTimepickerControl<T>, T | null, T>\n  ) {\n    if (timepicker) {\n      this._timepicker = timepicker;\n      this._registerModel(timepicker.registerInput(this));\n    }\n  }\n  _timepicker: MatTimepickerPanel<MatTimepickerControl<T>, T | null, T>;\n\n  /** The combined form control validator for this input. */\n  protected _validator: ValidatorFn | null;\n\n  /** The minimum valid date. */\n  @Input()\n  get min(): T | null {\n    return this._min;\n  }\n  set min(value: T | null) {\n    const validValue = this._timeAdapter.getValidTimeOrNull(\n      this._timeAdapter.deserialize(value)\n    );\n\n    if (!this._timeAdapter.sameTime(validValue, this._min)) {\n      this._min = validValue;\n      this._validatorOnChange();\n    }\n  }\n  private _min: T | null;\n\n  /** The maximum valid date. */\n  @Input()\n  get max(): T | null {\n    return this._max;\n  }\n  set max(value: T | null) {\n    const validValue = this._timeAdapter.getValidTimeOrNull(\n      this._timeAdapter.deserialize(value)\n    );\n\n    if (!this._timeAdapter.sameTime(validValue, this._max)) {\n      this._max = validValue;\n      this._validatorOnChange();\n    }\n  }\n  private _max: T | null;\n\n  constructor(\n    elementRef: ElementRef<HTMLInputElement>,\n    @Optional() timeAdapter: TimeAdapter<T>,\n    @Optional() @Inject(MAT_FORM_FIELD) private _formField?: MatFormField\n  ) {\n    super(elementRef, timeAdapter);\n    this._validator = Validators.compose(super._getValidators());\n  }\n\n  /**\n   * Gets the element that the timepicker popup should be connected to.\n   * @return The element to connect the popup to.\n   */\n  getConnectedOverlayOrigin(): ElementRef {\n    return this._formField\n      ? this._formField.getConnectedOverlayOrigin()\n      : this._elementRef;\n  }\n\n  /** Returns the palette used by the input's form field, if any. */\n  getThemePalette(): ThemePalette {\n    return this._formField ? this._formField.color : undefined;\n  }\n\n  /** Gets the ID of an element that should be used a description for the timepicker overlay. */\n  getOverlayLabelId(): string | null {\n    if (this._formField) {\n      return this._formField.getLabelId();\n    }\n\n    return this._elementRef.nativeElement.getAttribute('aria-labelledby');\n  }\n\n  /** Gets the input's minimum time. */\n  _getMinTime() {\n    return this._min;\n  }\n\n  /** Gets the input's maximum time. */\n  _getMaxTime() {\n    return this._max;\n  }\n\n  protected _assignValueToModel(value: T | null): void {\n    if (this._model) {\n      this._model.updateSelection(value, this);\n    }\n  }\n\n  protected _getValueFromModel(modelValue: T | null): T | null {\n    return modelValue;\n  }\n\n  protected _shouldHandleChangeEvent(event: TimeSelectionModelChange<T>) {\n    return event.source !== this;\n  }\n}\n"]}
@@ -8,6 +8,7 @@ export * from './lib/timepicker-toggle';
8
8
  export * from './lib/timepicker-content';
9
9
  export * from './lib/timepicker-content-layout';
10
10
  export * from './lib/timepicker-input';
11
+ export * from './lib/timepicker-input-base';
11
12
  export * from './lib/hours-clock-dial';
12
13
  export * from './lib/minutes-clock-dial';
13
14
  export * from './lib/time-inputs';
@@ -19,4 +20,4 @@ export * from './lib/adapter';
19
20
  export * from './lib/timepicker-scroll-strategy';
20
21
  export * from './lib/timepicker-intl';
21
22
  export * from './lib/orientation';
22
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL21hdC10aW1lcGlja2VyL3NyYy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLGtDQUFrQyxDQUFDO0FBQ2pELGNBQWMsZUFBZSxDQUFDO0FBQzlCLGNBQWMsa0NBQWtDLENBQUM7QUFDakQsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLG1CQUFtQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBtYXQtdGltZXBpY2tlclxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL3RpbWVwaWNrZXIubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RpbWVwaWNrZXInO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGltZXBpY2tlci1iYXNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RpbWVwaWNrZXItdG9nZ2xlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RpbWVwaWNrZXItY29udGVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90aW1lcGlja2VyLWNvbnRlbnQtbGF5b3V0JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RpbWVwaWNrZXItaW5wdXQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvaG91cnMtY2xvY2stZGlhbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9taW51dGVzLWNsb2NrLWRpYWwnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGltZS1pbnB1dHMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY2xvY2stZGlhbHMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGltZS1wZXJpb2QnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGltZXBpY2tlci1hY3Rpb25zJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RpbWVwaWNrZXItYWN0aW9ucy1kZWZhdWx0JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2FkYXB0ZXInO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGltZXBpY2tlci1zY3JvbGwtc3RyYXRlZ3knO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGltZXBpY2tlci1pbnRsJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL29yaWVudGF0aW9uJztcbiJdfQ==
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL21hdC10aW1lcGlja2VyL3NyYy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsa0NBQWtDLENBQUM7QUFDakQsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxrQ0FBa0MsQ0FBQztBQUNqRCxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsbUJBQW1CLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIG1hdC10aW1lcGlja2VyXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9saWIvdGltZXBpY2tlci5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGltZXBpY2tlcic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90aW1lcGlja2VyLWJhc2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGltZXBpY2tlci10b2dnbGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGltZXBpY2tlci1jb250ZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RpbWVwaWNrZXItY29udGVudC1sYXlvdXQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGltZXBpY2tlci1pbnB1dCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90aW1lcGlja2VyLWlucHV0LWJhc2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvaG91cnMtY2xvY2stZGlhbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9taW51dGVzLWNsb2NrLWRpYWwnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGltZS1pbnB1dHMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY2xvY2stZGlhbHMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGltZS1wZXJpb2QnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGltZXBpY2tlci1hY3Rpb25zJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RpbWVwaWNrZXItYWN0aW9ucy1kZWZhdWx0JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2FkYXB0ZXInO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGltZXBpY2tlci1zY3JvbGwtc3RyYXRlZ3knO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGltZXBpY2tlci1pbnRsJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL29yaWVudGF0aW9uJztcbiJdfQ==
@@ -1542,7 +1542,7 @@ class MatTimepickerContent extends _MatTimepickerContentBase {
1542
1542
  }
1543
1543
  }
1544
1544
  MatTimepickerContent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: MatTimepickerContent, deps: [{ token: i0.ElementRef }, { token: MatTimepickerIntl }, { token: MatTimeSelectionModel }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
1545
- MatTimepickerContent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: MatTimepickerContent, selector: "mat-timepicker-content", host: { listeners: { "@transformPanel.done": "_animationDone.next()" }, properties: { "@transformPanel": "_animationState" }, classAttribute: "mat-timepicker-content" }, viewQueries: [{ propertyName: "_dials", first: true, predicate: MatClockDials, descendants: true }, { propertyName: "_inputs", first: true, predicate: MatTimeInputs, descendants: true }], exportAs: ["matTimepickerContent"], usesInheritance: true, ngImport: i0, template: "<div\n cdkTrapFocus\n role=\"dialog\"\n class=\"mat-timepicker-content-container\"\n [attr.aria-modal]=\"true\"\n [attr.aria-labelledby]=\"_dialogLabelId ?? undefined\"\n>\n <ng-container [ngSwitch]=\"mode\">\n <ng-template ngSwitchCase=\"input\">\n <mat-time-inputs\n [id]=\"timepicker.id\"\n [color]=\"color\"\n [isMeridiem]=\"isMeridiem\"\n [selected]=\"_getSelected()\"\n [minTime]=\"timepicker._getMinTime()\"\n [maxTime]=\"timepicker._getMaxTime()\"\n [minuteInterval]=\"minuteInterval\"\n (_userSelection)=\"_handleUserSelection($event)\"\n ></mat-time-inputs>\n\n <div class=\"mat-timepicker-content-actions\">\n <button\n class=\"mat-time-toggle-mode-button\"\n mat-icon-button\n *ngIf=\"showToggleModeButton\"\n (click)=\"onToggleMode('dial')\"\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n height=\"24\"\n width=\"24\"\n viewBox=\"0 0 24 24\"\n >\n <path\n d=\"m15.175 16.625 1.475-1.45-3.6-3.6V7.1h-2.075v5.3ZM12 21.95q-2.075 0-3.887-.787-1.813-.788-3.15-2.125-1.338-1.338-2.125-3.151Q2.05 14.075 2.05 12t.788-3.887q.787-1.813 2.125-3.15Q6.3 3.625 8.113 2.837 9.925 2.05 12 2.05t3.887.787q1.813.788 3.151 2.126 1.337 1.337 2.125 3.15.787 1.812.787 3.887t-.787 3.887q-.788 1.813-2.125 3.151-1.338 1.337-3.151 2.125-1.812.787-3.887.787ZM12 12Zm0 7.8q3.225 0 5.513-2.275Q19.8 15.25 19.8 12q0-3.25-2.287-5.525Q15.225 4.2 12 4.2T6.488 6.475Q4.2 8.75 4.2 12q0 3.25 2.288 5.525Q8.775 19.8 12 19.8Z\"\n />\n </svg>\n </button>\n\n <ng-template [cdkPortalOutlet]=\"_actionsPortal\"></ng-template>\n </div>\n </ng-template>\n <ng-template ngSwitchCase=\"dial\">\n <mat-clock-dials\n [id]=\"timepicker.id\"\n [color]=\"color\"\n [isMeridiem]=\"isMeridiem\"\n [selected]=\"_getSelected()\"\n [minTime]=\"timepicker._getMinTime()\"\n [maxTime]=\"timepicker._getMaxTime()\"\n [minuteInterval]=\"minuteInterval\"\n [orientation]=\"orientation\"\n (_userSelection)=\"_handleUserSelection($event)\"\n ></mat-clock-dials>\n\n <div class=\"mat-timepicker-content-actions\">\n <button\n class=\"mat-time-toggle-mode-button\"\n mat-icon-button\n *ngIf=\"showToggleModeButton\"\n (click)=\"onToggleMode('input')\"\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n height=\"24\"\n width=\"24\"\n viewBox=\"0 0 24 24\"\n >\n <path\n d=\"M4 19q-.825 0-1.412-.587Q2 17.825 2 17V7q0-.825.588-1.412Q3.175 5 4 5h16q.825 0 1.413.588Q22 6.175 22 7v10q0 .825-.587 1.413Q20.825 19 20 19Zm0-2h16V7H4v10Zm4-1h8v-2H8Zm-3-3h2v-2H5Zm3 0h2v-2H8Zm3 0h2v-2h-2Zm3 0h2v-2h-2Zm3 0h2v-2h-2ZM5 10h2V8H5Zm3 0h2V8H8Zm3 0h2V8h-2Zm3 0h2V8h-2Zm3 0h2V8h-2ZM4 17V7v10Z\"\n />\n </svg>\n </button>\n\n <ng-template [cdkPortalOutlet]=\"_actionsPortal\"></ng-template>\n </div>\n </ng-template>\n </ng-container>\n\n <!-- Invisible close button for screen reader users. -->\n <button\n type=\"button\"\n mat-raised-button\n [color]=\"color || 'primary'\"\n class=\"mat-timepicker-close-button\"\n [class.cdk-visually-hidden]=\"!_closeButtonFocused\"\n (focus)=\"_closeButtonFocused = true\"\n (blur)=\"_closeButtonFocused = false\"\n (click)=\"timepicker.close()\"\n >\n {{ _closeButtonText }}\n </button>\n</div>\n", styles: [".mat-timepicker-content{display:block;border-radius:4px}.mat-timepicker-content-container{position:relative;display:flex;flex-direction:column;padding:.5rem 1.5rem}.mat-timepicker-content-actions{display:flex;justify-content:space-between;margin-right:-1rem;margin-top:1.5rem}.mat-time-toggle-mode-button{width:3.25rem;height:3.25rem;margin-left:-.75rem;margin-bottom:-.25rem;line-height:3.25rem}.mat-timepicker-close-button{position:absolute;top:100%;left:0;margin-top:.5rem}.ng-animating .mat-timepicker-close-button{display:none}\n"], components: [{ type: MatTimeInputs, selector: "mat-time-inputs" }, { type: i1.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: MatClockDials, selector: "mat-clock-dials", inputs: ["orientation"], exportAs: ["matClockDials"] }], directives: [{ type: i6$1.CdkTrapFocus, selector: "[cdkTrapFocus]", inputs: ["cdkTrapFocus", "cdkTrapFocusAutoCapture"], exportAs: ["cdkTrapFocus"] }, { type: i7.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i7.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i8.CdkPortalOutlet, selector: "[cdkPortalOutlet]", inputs: ["cdkPortalOutlet"], outputs: ["attached"], exportAs: ["cdkPortalOutlet"] }], animations: [
1545
+ MatTimepickerContent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: MatTimepickerContent, selector: "mat-timepicker-content", host: { listeners: { "@transformPanel.done": "_animationDone.next()" }, properties: { "@transformPanel": "_animationState" }, classAttribute: "mat-timepicker-content" }, viewQueries: [{ propertyName: "_dials", first: true, predicate: MatClockDials, descendants: true }, { propertyName: "_inputs", first: true, predicate: MatTimeInputs, descendants: true }], exportAs: ["matTimepickerContent"], usesInheritance: true, ngImport: i0, template: "<div\n cdkTrapFocus\n role=\"dialog\"\n class=\"mat-timepicker-content-container\"\n [attr.aria-modal]=\"true\"\n [attr.aria-labelledby]=\"_dialogLabelId ?? undefined\"\n>\n <ng-container [ngSwitch]=\"mode\">\n <ng-template ngSwitchCase=\"input\">\n <mat-time-inputs\n [id]=\"timepicker.id\"\n [color]=\"color\"\n [isMeridiem]=\"isMeridiem\"\n [selected]=\"_getSelected()\"\n [minTime]=\"timepicker._getMinTime()\"\n [maxTime]=\"timepicker._getMaxTime()\"\n [minuteInterval]=\"minuteInterval\"\n (_userSelection)=\"_handleUserSelection($event)\"\n ></mat-time-inputs>\n\n <div class=\"mat-timepicker-content-actions\">\n <button\n class=\"mat-time-toggle-mode-button\"\n mat-icon-button\n *ngIf=\"showToggleModeButton\"\n (click)=\"onToggleMode('dial')\"\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n height=\"24\"\n width=\"24\"\n viewBox=\"0 0 24 24\"\n >\n <path\n d=\"m15.175 16.625 1.475-1.45-3.6-3.6V7.1h-2.075v5.3ZM12 21.95q-2.075 0-3.887-.787-1.813-.788-3.15-2.125-1.338-1.338-2.125-3.151Q2.05 14.075 2.05 12t.788-3.887q.787-1.813 2.125-3.15Q6.3 3.625 8.113 2.837 9.925 2.05 12 2.05t3.887.787q1.813.788 3.151 2.126 1.337 1.337 2.125 3.15.787 1.812.787 3.887t-.787 3.887q-.788 1.813-2.125 3.151-1.338 1.337-3.151 2.125-1.812.787-3.887.787ZM12 12Zm0 7.8q3.225 0 5.513-2.275Q19.8 15.25 19.8 12q0-3.25-2.287-5.525Q15.225 4.2 12 4.2T6.488 6.475Q4.2 8.75 4.2 12q0 3.25 2.288 5.525Q8.775 19.8 12 19.8Z\"\n />\n </svg>\n </button>\n\n <ng-template [cdkPortalOutlet]=\"_actionsPortal\"></ng-template>\n </div>\n </ng-template>\n <ng-template ngSwitchCase=\"dial\">\n <mat-clock-dials\n [id]=\"timepicker.id\"\n [color]=\"color\"\n [isMeridiem]=\"isMeridiem\"\n [selected]=\"_getSelected()\"\n [minTime]=\"timepicker._getMinTime()\"\n [maxTime]=\"timepicker._getMaxTime()\"\n [minuteInterval]=\"minuteInterval\"\n [orientation]=\"orientation\"\n (_userSelection)=\"_handleUserSelection($event)\"\n ></mat-clock-dials>\n\n <div class=\"mat-timepicker-content-actions\">\n <button\n class=\"mat-time-toggle-mode-button\"\n mat-icon-button\n *ngIf=\"showToggleModeButton\"\n (click)=\"onToggleMode('input')\"\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n height=\"24\"\n width=\"24\"\n viewBox=\"0 0 24 24\"\n >\n <path\n d=\"M4 19q-.825 0-1.412-.587Q2 17.825 2 17V7q0-.825.588-1.412Q3.175 5 4 5h16q.825 0 1.413.588Q22 6.175 22 7v10q0 .825-.587 1.413Q20.825 19 20 19Zm0-2h16V7H4v10Zm4-1h8v-2H8Zm-3-3h2v-2H5Zm3 0h2v-2H8Zm3 0h2v-2h-2Zm3 0h2v-2h-2Zm3 0h2v-2h-2ZM5 10h2V8H5Zm3 0h2V8H8Zm3 0h2V8h-2Zm3 0h2V8h-2Zm3 0h2V8h-2ZM4 17V7v10Z\"\n />\n </svg>\n </button>\n\n <ng-template [cdkPortalOutlet]=\"_actionsPortal\"></ng-template>\n </div>\n </ng-template>\n </ng-container>\n\n <!-- Invisible close button for screen reader users. -->\n <button\n type=\"button\"\n class=\"mat-timepicker-close-button\"\n mat-raised-button\n [color]=\"color || 'primary'\"\n [class.cdk-visually-hidden]=\"!_closeButtonFocused\"\n (focus)=\"_closeButtonFocused = true\"\n (blur)=\"_closeButtonFocused = false\"\n (click)=\"timepicker.close()\"\n >\n {{ _closeButtonText }}\n </button>\n</div>\n", styles: [".mat-timepicker-content{display:block;border-radius:4px}.mat-timepicker-content-container{position:relative;display:flex;flex-direction:column;padding:.5rem 1.5rem}.mat-timepicker-content-actions{display:flex;justify-content:space-between;margin-right:-1rem;margin-top:1.5rem}.mat-time-toggle-mode-button{width:3.25rem;height:3.25rem;margin-left:-.75rem;margin-bottom:-.25rem;line-height:3.25rem}button.mat-timepicker-close-button{position:absolute;top:100%;left:0;margin-top:.5rem}.ng-animating button.mat-timepicker-close-button{display:none}\n"], components: [{ type: MatTimeInputs, selector: "mat-time-inputs" }, { type: i1.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: MatClockDials, selector: "mat-clock-dials", inputs: ["orientation"], exportAs: ["matClockDials"] }], directives: [{ type: i6$1.CdkTrapFocus, selector: "[cdkTrapFocus]", inputs: ["cdkTrapFocus", "cdkTrapFocusAutoCapture"], exportAs: ["cdkTrapFocus"] }, { type: i7.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i7.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i8.CdkPortalOutlet, selector: "[cdkPortalOutlet]", inputs: ["cdkPortalOutlet"], outputs: ["attached"], exportAs: ["cdkPortalOutlet"] }], animations: [
1546
1546
  matTimepickerAnimations.transformPanel,
1547
1547
  matTimepickerAnimations.fadeInTimepicker,
1548
1548
  ], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
@@ -1555,7 +1555,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
1555
1555
  }, animations: [
1556
1556
  matTimepickerAnimations.transformPanel,
1557
1557
  matTimepickerAnimations.fadeInTimepicker,
1558
- ], template: "<div\n cdkTrapFocus\n role=\"dialog\"\n class=\"mat-timepicker-content-container\"\n [attr.aria-modal]=\"true\"\n [attr.aria-labelledby]=\"_dialogLabelId ?? undefined\"\n>\n <ng-container [ngSwitch]=\"mode\">\n <ng-template ngSwitchCase=\"input\">\n <mat-time-inputs\n [id]=\"timepicker.id\"\n [color]=\"color\"\n [isMeridiem]=\"isMeridiem\"\n [selected]=\"_getSelected()\"\n [minTime]=\"timepicker._getMinTime()\"\n [maxTime]=\"timepicker._getMaxTime()\"\n [minuteInterval]=\"minuteInterval\"\n (_userSelection)=\"_handleUserSelection($event)\"\n ></mat-time-inputs>\n\n <div class=\"mat-timepicker-content-actions\">\n <button\n class=\"mat-time-toggle-mode-button\"\n mat-icon-button\n *ngIf=\"showToggleModeButton\"\n (click)=\"onToggleMode('dial')\"\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n height=\"24\"\n width=\"24\"\n viewBox=\"0 0 24 24\"\n >\n <path\n d=\"m15.175 16.625 1.475-1.45-3.6-3.6V7.1h-2.075v5.3ZM12 21.95q-2.075 0-3.887-.787-1.813-.788-3.15-2.125-1.338-1.338-2.125-3.151Q2.05 14.075 2.05 12t.788-3.887q.787-1.813 2.125-3.15Q6.3 3.625 8.113 2.837 9.925 2.05 12 2.05t3.887.787q1.813.788 3.151 2.126 1.337 1.337 2.125 3.15.787 1.812.787 3.887t-.787 3.887q-.788 1.813-2.125 3.151-1.338 1.337-3.151 2.125-1.812.787-3.887.787ZM12 12Zm0 7.8q3.225 0 5.513-2.275Q19.8 15.25 19.8 12q0-3.25-2.287-5.525Q15.225 4.2 12 4.2T6.488 6.475Q4.2 8.75 4.2 12q0 3.25 2.288 5.525Q8.775 19.8 12 19.8Z\"\n />\n </svg>\n </button>\n\n <ng-template [cdkPortalOutlet]=\"_actionsPortal\"></ng-template>\n </div>\n </ng-template>\n <ng-template ngSwitchCase=\"dial\">\n <mat-clock-dials\n [id]=\"timepicker.id\"\n [color]=\"color\"\n [isMeridiem]=\"isMeridiem\"\n [selected]=\"_getSelected()\"\n [minTime]=\"timepicker._getMinTime()\"\n [maxTime]=\"timepicker._getMaxTime()\"\n [minuteInterval]=\"minuteInterval\"\n [orientation]=\"orientation\"\n (_userSelection)=\"_handleUserSelection($event)\"\n ></mat-clock-dials>\n\n <div class=\"mat-timepicker-content-actions\">\n <button\n class=\"mat-time-toggle-mode-button\"\n mat-icon-button\n *ngIf=\"showToggleModeButton\"\n (click)=\"onToggleMode('input')\"\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n height=\"24\"\n width=\"24\"\n viewBox=\"0 0 24 24\"\n >\n <path\n d=\"M4 19q-.825 0-1.412-.587Q2 17.825 2 17V7q0-.825.588-1.412Q3.175 5 4 5h16q.825 0 1.413.588Q22 6.175 22 7v10q0 .825-.587 1.413Q20.825 19 20 19Zm0-2h16V7H4v10Zm4-1h8v-2H8Zm-3-3h2v-2H5Zm3 0h2v-2H8Zm3 0h2v-2h-2Zm3 0h2v-2h-2Zm3 0h2v-2h-2ZM5 10h2V8H5Zm3 0h2V8H8Zm3 0h2V8h-2Zm3 0h2V8h-2Zm3 0h2V8h-2ZM4 17V7v10Z\"\n />\n </svg>\n </button>\n\n <ng-template [cdkPortalOutlet]=\"_actionsPortal\"></ng-template>\n </div>\n </ng-template>\n </ng-container>\n\n <!-- Invisible close button for screen reader users. -->\n <button\n type=\"button\"\n mat-raised-button\n [color]=\"color || 'primary'\"\n class=\"mat-timepicker-close-button\"\n [class.cdk-visually-hidden]=\"!_closeButtonFocused\"\n (focus)=\"_closeButtonFocused = true\"\n (blur)=\"_closeButtonFocused = false\"\n (click)=\"timepicker.close()\"\n >\n {{ _closeButtonText }}\n </button>\n</div>\n", styles: [".mat-timepicker-content{display:block;border-radius:4px}.mat-timepicker-content-container{position:relative;display:flex;flex-direction:column;padding:.5rem 1.5rem}.mat-timepicker-content-actions{display:flex;justify-content:space-between;margin-right:-1rem;margin-top:1.5rem}.mat-time-toggle-mode-button{width:3.25rem;height:3.25rem;margin-left:-.75rem;margin-bottom:-.25rem;line-height:3.25rem}.mat-timepicker-close-button{position:absolute;top:100%;left:0;margin-top:.5rem}.ng-animating .mat-timepicker-close-button{display:none}\n"] }]
1558
+ ], template: "<div\n cdkTrapFocus\n role=\"dialog\"\n class=\"mat-timepicker-content-container\"\n [attr.aria-modal]=\"true\"\n [attr.aria-labelledby]=\"_dialogLabelId ?? undefined\"\n>\n <ng-container [ngSwitch]=\"mode\">\n <ng-template ngSwitchCase=\"input\">\n <mat-time-inputs\n [id]=\"timepicker.id\"\n [color]=\"color\"\n [isMeridiem]=\"isMeridiem\"\n [selected]=\"_getSelected()\"\n [minTime]=\"timepicker._getMinTime()\"\n [maxTime]=\"timepicker._getMaxTime()\"\n [minuteInterval]=\"minuteInterval\"\n (_userSelection)=\"_handleUserSelection($event)\"\n ></mat-time-inputs>\n\n <div class=\"mat-timepicker-content-actions\">\n <button\n class=\"mat-time-toggle-mode-button\"\n mat-icon-button\n *ngIf=\"showToggleModeButton\"\n (click)=\"onToggleMode('dial')\"\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n height=\"24\"\n width=\"24\"\n viewBox=\"0 0 24 24\"\n >\n <path\n d=\"m15.175 16.625 1.475-1.45-3.6-3.6V7.1h-2.075v5.3ZM12 21.95q-2.075 0-3.887-.787-1.813-.788-3.15-2.125-1.338-1.338-2.125-3.151Q2.05 14.075 2.05 12t.788-3.887q.787-1.813 2.125-3.15Q6.3 3.625 8.113 2.837 9.925 2.05 12 2.05t3.887.787q1.813.788 3.151 2.126 1.337 1.337 2.125 3.15.787 1.812.787 3.887t-.787 3.887q-.788 1.813-2.125 3.151-1.338 1.337-3.151 2.125-1.812.787-3.887.787ZM12 12Zm0 7.8q3.225 0 5.513-2.275Q19.8 15.25 19.8 12q0-3.25-2.287-5.525Q15.225 4.2 12 4.2T6.488 6.475Q4.2 8.75 4.2 12q0 3.25 2.288 5.525Q8.775 19.8 12 19.8Z\"\n />\n </svg>\n </button>\n\n <ng-template [cdkPortalOutlet]=\"_actionsPortal\"></ng-template>\n </div>\n </ng-template>\n <ng-template ngSwitchCase=\"dial\">\n <mat-clock-dials\n [id]=\"timepicker.id\"\n [color]=\"color\"\n [isMeridiem]=\"isMeridiem\"\n [selected]=\"_getSelected()\"\n [minTime]=\"timepicker._getMinTime()\"\n [maxTime]=\"timepicker._getMaxTime()\"\n [minuteInterval]=\"minuteInterval\"\n [orientation]=\"orientation\"\n (_userSelection)=\"_handleUserSelection($event)\"\n ></mat-clock-dials>\n\n <div class=\"mat-timepicker-content-actions\">\n <button\n class=\"mat-time-toggle-mode-button\"\n mat-icon-button\n *ngIf=\"showToggleModeButton\"\n (click)=\"onToggleMode('input')\"\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n height=\"24\"\n width=\"24\"\n viewBox=\"0 0 24 24\"\n >\n <path\n d=\"M4 19q-.825 0-1.412-.587Q2 17.825 2 17V7q0-.825.588-1.412Q3.175 5 4 5h16q.825 0 1.413.588Q22 6.175 22 7v10q0 .825-.587 1.413Q20.825 19 20 19Zm0-2h16V7H4v10Zm4-1h8v-2H8Zm-3-3h2v-2H5Zm3 0h2v-2H8Zm3 0h2v-2h-2Zm3 0h2v-2h-2Zm3 0h2v-2h-2ZM5 10h2V8H5Zm3 0h2V8H8Zm3 0h2V8h-2Zm3 0h2V8h-2Zm3 0h2V8h-2ZM4 17V7v10Z\"\n />\n </svg>\n </button>\n\n <ng-template [cdkPortalOutlet]=\"_actionsPortal\"></ng-template>\n </div>\n </ng-template>\n </ng-container>\n\n <!-- Invisible close button for screen reader users. -->\n <button\n type=\"button\"\n class=\"mat-timepicker-close-button\"\n mat-raised-button\n [color]=\"color || 'primary'\"\n [class.cdk-visually-hidden]=\"!_closeButtonFocused\"\n (focus)=\"_closeButtonFocused = true\"\n (blur)=\"_closeButtonFocused = false\"\n (click)=\"timepicker.close()\"\n >\n {{ _closeButtonText }}\n </button>\n</div>\n", styles: [".mat-timepicker-content{display:block;border-radius:4px}.mat-timepicker-content-container{position:relative;display:flex;flex-direction:column;padding:.5rem 1.5rem}.mat-timepicker-content-actions{display:flex;justify-content:space-between;margin-right:-1rem;margin-top:1.5rem}.mat-time-toggle-mode-button{width:3.25rem;height:3.25rem;margin-left:-.75rem;margin-bottom:-.25rem;line-height:3.25rem}button.mat-timepicker-close-button{position:absolute;top:100%;left:0;margin-top:.5rem}.ng-animating button.mat-timepicker-close-button{display:none}\n"] }]
1559
1559
  }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: MatTimepickerIntl }, { type: MatTimeSelectionModel }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { _dials: [{
1560
1560
  type: ViewChild,
1561
1561
  args: [MatClockDials]
@@ -1611,7 +1611,9 @@ class MatTimepickerBase {
1611
1611
  }
1612
1612
  /** Whether the timepicker pop-up should be disabled. */
1613
1613
  get disabled() {
1614
- return this._disabled;
1614
+ return this._disabled === undefined && this.timepickerInput
1615
+ ? this.timepickerInput.disabled
1616
+ : !!this._disabled;
1615
1617
  }
1616
1618
  set disabled(value) {
1617
1619
  const newValue = coerceBooleanProperty(value);
@@ -2293,7 +2295,7 @@ class MatTimepickerInput extends MatTimepickerInputBase {
2293
2295
  }
2294
2296
  }
2295
2297
  MatTimepickerInput.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: MatTimepickerInput, deps: [{ token: i0.ElementRef }, { token: TimeAdapter, optional: true }, { token: MAT_FORM_FIELD, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
2296
- MatTimepickerInput.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.4.0", type: MatTimepickerInput, selector: "input[matTimepicker]", inputs: { matTimepicker: "matTimepicker", min: "min", max: "max" }, host: { listeners: { "input": "_onInput($event.target.value)", "change": "_onChange()", "blur": "_onBlur()" }, properties: { "attr.aria-haspopup": "_timepicker ? \"dialog\" : null", "attr.aria-owns": "(_timepicker?.opened && _timepicker.id) || null", "disabled": "disabled" }, classAttribute: "mat-timepicker-input" }, providers: [
2298
+ MatTimepickerInput.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.4.0", type: MatTimepickerInput, selector: "input[matTimepicker]", inputs: { matTimepicker: "matTimepicker", min: "min", max: "max" }, host: { listeners: { "input": "_onInput($event.target.value)", "change": "_onChange()", "blur": "_onBlur()" }, properties: { "attr.aria-haspopup": "_timepicker ? \"dialog\" : null", "attr.aria-owns": "(_timepicker?.opened && _timepicker.id) || null", "attr.min": "min || null", "attr.max": "max || null", "disabled": "disabled" }, classAttribute: "mat-timepicker-input" }, providers: [
2297
2299
  MAT_TIMEPICKER_VALUE_ACCESSOR,
2298
2300
  MAT_TIMEPICKER_VALIDATORS,
2299
2301
  { provide: MAT_INPUT_VALUE_ACCESSOR, useExisting: MatTimepickerInput },
@@ -2312,6 +2314,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
2312
2314
  class: 'mat-timepicker-input',
2313
2315
  '[attr.aria-haspopup]': '_timepicker ? "dialog" : null',
2314
2316
  '[attr.aria-owns]': '(_timepicker?.opened && _timepicker.id) || null',
2317
+ '[attr.min]': 'min || null',
2318
+ '[attr.max]': 'max || null',
2315
2319
  '[disabled]': 'disabled',
2316
2320
  '(input)': '_onInput($event.target.value)',
2317
2321
  '(change)': '_onChange()',
@@ -2592,5 +2596,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
2592
2596
  * Generated bundle index. Do not edit.
2593
2597
  */
2594
2598
 
2595
- export { ALL_HOURS, ALL_MINUTES, MAT_DEFAULT_ACITONS, MAT_TIMEPICKER_DEFAULT_OPTIONS, MAT_TIMEPICKER_SCROLL_STRATEGY, MAT_TIMEPICKER_SCROLL_STRATEGY_FACTORY, MAT_TIMEPICKER_SCROLL_STRATEGY_FACTORY_PROVIDER, MAT_TIMEPICKER_VALIDATORS, MAT_TIMEPICKER_VALUE_ACCESSOR, MAT_TIME_LOCALE, MAT_TIME_LOCALE_PROVIDER, MatClockDials, MatHourInput, MatHoursClockDial, MatMinuteInput, MatMinutesClockDial, MatNativeDateTimeModule, MatTimeInputs, MatTimePeriod, MatTimepicker, MatTimepickerActions, MatTimepickerApply, MatTimepickerBase, MatTimepickerCancel, MatTimepickerContent, MatTimepickerContentLayout, MatTimepickerDefaultActions, MatTimepickerInput, MatTimepickerIntl, MatTimepickerModule, MatTimepickerToggle, MatTimepickerToggleIcon, NativeDateTimeAdapter, TimeAdapter };
2599
+ export { ALL_HOURS, ALL_MINUTES, MAT_DEFAULT_ACITONS, MAT_TIMEPICKER_DEFAULT_OPTIONS, MAT_TIMEPICKER_SCROLL_STRATEGY, MAT_TIMEPICKER_SCROLL_STRATEGY_FACTORY, MAT_TIMEPICKER_SCROLL_STRATEGY_FACTORY_PROVIDER, MAT_TIMEPICKER_VALIDATORS, MAT_TIMEPICKER_VALUE_ACCESSOR, MAT_TIME_LOCALE, MAT_TIME_LOCALE_PROVIDER, MatClockDials, MatHourInput, MatHoursClockDial, MatMinuteInput, MatMinutesClockDial, MatNativeDateTimeModule, MatTimeInputs, MatTimePeriod, MatTimepicker, MatTimepickerActions, MatTimepickerApply, MatTimepickerBase, MatTimepickerCancel, MatTimepickerContent, MatTimepickerContentLayout, MatTimepickerDefaultActions, MatTimepickerInput, MatTimepickerInputBase, MatTimepickerInputEvent, MatTimepickerIntl, MatTimepickerModule, MatTimepickerToggle, MatTimepickerToggleIcon, NativeDateTimeAdapter, TimeAdapter };
2596
2600
  //# sourceMappingURL=dhutaryan-ngx-mat-timepicker.mjs.map