[6a3a178] | 1 | /**
|
---|
| 2 | * @license
|
---|
| 3 | * Copyright Google LLC All Rights Reserved.
|
---|
| 4 | *
|
---|
| 5 | * Use of this source code is governed by an MIT-style license that can be
|
---|
| 6 | * found in the LICENSE file at https://angular.io/license
|
---|
| 7 | */
|
---|
| 8 | import { Directionality } from '@angular/cdk/bidi';
|
---|
| 9 | import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
---|
| 10 | import { ESCAPE, hasModifierKey } from '@angular/cdk/keycodes';
|
---|
| 11 | import { TemplatePortal } from '@angular/cdk/portal';
|
---|
| 12 | import { Directive, ElementRef, EventEmitter, Inject, InjectionToken, Input, Optional, Output, TemplateRef, ViewContainerRef, } from '@angular/core';
|
---|
| 13 | import { Subscription } from 'rxjs';
|
---|
| 14 | import { takeWhile } from 'rxjs/operators';
|
---|
| 15 | import { Overlay } from './overlay';
|
---|
| 16 | import { OverlayConfig } from './overlay-config';
|
---|
| 17 | import { FlexibleConnectedPositionStrategy, } from './position/flexible-connected-position-strategy';
|
---|
| 18 | /** Default set of positions for the overlay. Follows the behavior of a dropdown. */
|
---|
| 19 | const defaultPositionList = [
|
---|
| 20 | {
|
---|
| 21 | originX: 'start',
|
---|
| 22 | originY: 'bottom',
|
---|
| 23 | overlayX: 'start',
|
---|
| 24 | overlayY: 'top'
|
---|
| 25 | },
|
---|
| 26 | {
|
---|
| 27 | originX: 'start',
|
---|
| 28 | originY: 'top',
|
---|
| 29 | overlayX: 'start',
|
---|
| 30 | overlayY: 'bottom'
|
---|
| 31 | },
|
---|
| 32 | {
|
---|
| 33 | originX: 'end',
|
---|
| 34 | originY: 'top',
|
---|
| 35 | overlayX: 'end',
|
---|
| 36 | overlayY: 'bottom'
|
---|
| 37 | },
|
---|
| 38 | {
|
---|
| 39 | originX: 'end',
|
---|
| 40 | originY: 'bottom',
|
---|
| 41 | overlayX: 'end',
|
---|
| 42 | overlayY: 'top'
|
---|
| 43 | }
|
---|
| 44 | ];
|
---|
| 45 | /** Injection token that determines the scroll handling while the connected overlay is open. */
|
---|
| 46 | export const CDK_CONNECTED_OVERLAY_SCROLL_STRATEGY = new InjectionToken('cdk-connected-overlay-scroll-strategy');
|
---|
| 47 | /**
|
---|
| 48 | * Directive applied to an element to make it usable as an origin for an Overlay using a
|
---|
| 49 | * ConnectedPositionStrategy.
|
---|
| 50 | */
|
---|
| 51 | export class CdkOverlayOrigin {
|
---|
| 52 | constructor(
|
---|
| 53 | /** Reference to the element on which the directive is applied. */
|
---|
| 54 | elementRef) {
|
---|
| 55 | this.elementRef = elementRef;
|
---|
| 56 | }
|
---|
| 57 | }
|
---|
| 58 | CdkOverlayOrigin.decorators = [
|
---|
| 59 | { type: Directive, args: [{
|
---|
| 60 | selector: '[cdk-overlay-origin], [overlay-origin], [cdkOverlayOrigin]',
|
---|
| 61 | exportAs: 'cdkOverlayOrigin',
|
---|
| 62 | },] }
|
---|
| 63 | ];
|
---|
| 64 | CdkOverlayOrigin.ctorParameters = () => [
|
---|
| 65 | { type: ElementRef }
|
---|
| 66 | ];
|
---|
| 67 | /**
|
---|
| 68 | * Directive to facilitate declarative creation of an
|
---|
| 69 | * Overlay using a FlexibleConnectedPositionStrategy.
|
---|
| 70 | */
|
---|
| 71 | export class CdkConnectedOverlay {
|
---|
| 72 | // TODO(jelbourn): inputs for size, scroll behavior, animation, etc.
|
---|
| 73 | constructor(_overlay, templateRef, viewContainerRef, scrollStrategyFactory, _dir) {
|
---|
| 74 | this._overlay = _overlay;
|
---|
| 75 | this._dir = _dir;
|
---|
| 76 | this._hasBackdrop = false;
|
---|
| 77 | this._lockPosition = false;
|
---|
| 78 | this._growAfterOpen = false;
|
---|
| 79 | this._flexibleDimensions = false;
|
---|
| 80 | this._push = false;
|
---|
| 81 | this._backdropSubscription = Subscription.EMPTY;
|
---|
| 82 | this._attachSubscription = Subscription.EMPTY;
|
---|
| 83 | this._detachSubscription = Subscription.EMPTY;
|
---|
| 84 | this._positionSubscription = Subscription.EMPTY;
|
---|
| 85 | /** Margin between the overlay and the viewport edges. */
|
---|
| 86 | this.viewportMargin = 0;
|
---|
| 87 | /** Whether the overlay is open. */
|
---|
| 88 | this.open = false;
|
---|
| 89 | /** Whether the overlay can be closed by user interaction. */
|
---|
| 90 | this.disableClose = false;
|
---|
| 91 | /** Event emitted when the backdrop is clicked. */
|
---|
| 92 | this.backdropClick = new EventEmitter();
|
---|
| 93 | /** Event emitted when the position has changed. */
|
---|
| 94 | this.positionChange = new EventEmitter();
|
---|
| 95 | /** Event emitted when the overlay has been attached. */
|
---|
| 96 | this.attach = new EventEmitter();
|
---|
| 97 | /** Event emitted when the overlay has been detached. */
|
---|
| 98 | this.detach = new EventEmitter();
|
---|
| 99 | /** Emits when there are keyboard events that are targeted at the overlay. */
|
---|
| 100 | this.overlayKeydown = new EventEmitter();
|
---|
| 101 | /** Emits when there are mouse outside click events that are targeted at the overlay. */
|
---|
| 102 | this.overlayOutsideClick = new EventEmitter();
|
---|
| 103 | this._templatePortal = new TemplatePortal(templateRef, viewContainerRef);
|
---|
| 104 | this._scrollStrategyFactory = scrollStrategyFactory;
|
---|
| 105 | this.scrollStrategy = this._scrollStrategyFactory();
|
---|
| 106 | }
|
---|
| 107 | /** The offset in pixels for the overlay connection point on the x-axis */
|
---|
| 108 | get offsetX() { return this._offsetX; }
|
---|
| 109 | set offsetX(offsetX) {
|
---|
| 110 | this._offsetX = offsetX;
|
---|
| 111 | if (this._position) {
|
---|
| 112 | this._updatePositionStrategy(this._position);
|
---|
| 113 | }
|
---|
| 114 | }
|
---|
| 115 | /** The offset in pixels for the overlay connection point on the y-axis */
|
---|
| 116 | get offsetY() { return this._offsetY; }
|
---|
| 117 | set offsetY(offsetY) {
|
---|
| 118 | this._offsetY = offsetY;
|
---|
| 119 | if (this._position) {
|
---|
| 120 | this._updatePositionStrategy(this._position);
|
---|
| 121 | }
|
---|
| 122 | }
|
---|
| 123 | /** Whether or not the overlay should attach a backdrop. */
|
---|
| 124 | get hasBackdrop() { return this._hasBackdrop; }
|
---|
| 125 | set hasBackdrop(value) { this._hasBackdrop = coerceBooleanProperty(value); }
|
---|
| 126 | /** Whether or not the overlay should be locked when scrolling. */
|
---|
| 127 | get lockPosition() { return this._lockPosition; }
|
---|
| 128 | set lockPosition(value) { this._lockPosition = coerceBooleanProperty(value); }
|
---|
| 129 | /** Whether the overlay's width and height can be constrained to fit within the viewport. */
|
---|
| 130 | get flexibleDimensions() { return this._flexibleDimensions; }
|
---|
| 131 | set flexibleDimensions(value) {
|
---|
| 132 | this._flexibleDimensions = coerceBooleanProperty(value);
|
---|
| 133 | }
|
---|
| 134 | /** Whether the overlay can grow after the initial open when flexible positioning is turned on. */
|
---|
| 135 | get growAfterOpen() { return this._growAfterOpen; }
|
---|
| 136 | set growAfterOpen(value) { this._growAfterOpen = coerceBooleanProperty(value); }
|
---|
| 137 | /** Whether the overlay can be pushed on-screen if none of the provided positions fit. */
|
---|
| 138 | get push() { return this._push; }
|
---|
| 139 | set push(value) { this._push = coerceBooleanProperty(value); }
|
---|
| 140 | /** The associated overlay reference. */
|
---|
| 141 | get overlayRef() {
|
---|
| 142 | return this._overlayRef;
|
---|
| 143 | }
|
---|
| 144 | /** The element's layout direction. */
|
---|
| 145 | get dir() {
|
---|
| 146 | return this._dir ? this._dir.value : 'ltr';
|
---|
| 147 | }
|
---|
| 148 | ngOnDestroy() {
|
---|
| 149 | this._attachSubscription.unsubscribe();
|
---|
| 150 | this._detachSubscription.unsubscribe();
|
---|
| 151 | this._backdropSubscription.unsubscribe();
|
---|
| 152 | this._positionSubscription.unsubscribe();
|
---|
| 153 | if (this._overlayRef) {
|
---|
| 154 | this._overlayRef.dispose();
|
---|
| 155 | }
|
---|
| 156 | }
|
---|
| 157 | ngOnChanges(changes) {
|
---|
| 158 | if (this._position) {
|
---|
| 159 | this._updatePositionStrategy(this._position);
|
---|
| 160 | this._overlayRef.updateSize({
|
---|
| 161 | width: this.width,
|
---|
| 162 | minWidth: this.minWidth,
|
---|
| 163 | height: this.height,
|
---|
| 164 | minHeight: this.minHeight,
|
---|
| 165 | });
|
---|
| 166 | if (changes['origin'] && this.open) {
|
---|
| 167 | this._position.apply();
|
---|
| 168 | }
|
---|
| 169 | }
|
---|
| 170 | if (changes['open']) {
|
---|
| 171 | this.open ? this._attachOverlay() : this._detachOverlay();
|
---|
| 172 | }
|
---|
| 173 | }
|
---|
| 174 | /** Creates an overlay */
|
---|
| 175 | _createOverlay() {
|
---|
| 176 | if (!this.positions || !this.positions.length) {
|
---|
| 177 | this.positions = defaultPositionList;
|
---|
| 178 | }
|
---|
| 179 | const overlayRef = this._overlayRef = this._overlay.create(this._buildConfig());
|
---|
| 180 | this._attachSubscription = overlayRef.attachments().subscribe(() => this.attach.emit());
|
---|
| 181 | this._detachSubscription = overlayRef.detachments().subscribe(() => this.detach.emit());
|
---|
| 182 | overlayRef.keydownEvents().subscribe((event) => {
|
---|
| 183 | this.overlayKeydown.next(event);
|
---|
| 184 | if (event.keyCode === ESCAPE && !this.disableClose && !hasModifierKey(event)) {
|
---|
| 185 | event.preventDefault();
|
---|
| 186 | this._detachOverlay();
|
---|
| 187 | }
|
---|
| 188 | });
|
---|
| 189 | this._overlayRef.outsidePointerEvents().subscribe((event) => {
|
---|
| 190 | this.overlayOutsideClick.next(event);
|
---|
| 191 | });
|
---|
| 192 | }
|
---|
| 193 | /** Builds the overlay config based on the directive's inputs */
|
---|
| 194 | _buildConfig() {
|
---|
| 195 | const positionStrategy = this._position =
|
---|
| 196 | this.positionStrategy || this._createPositionStrategy();
|
---|
| 197 | const overlayConfig = new OverlayConfig({
|
---|
| 198 | direction: this._dir,
|
---|
| 199 | positionStrategy,
|
---|
| 200 | scrollStrategy: this.scrollStrategy,
|
---|
| 201 | hasBackdrop: this.hasBackdrop
|
---|
| 202 | });
|
---|
| 203 | if (this.width || this.width === 0) {
|
---|
| 204 | overlayConfig.width = this.width;
|
---|
| 205 | }
|
---|
| 206 | if (this.height || this.height === 0) {
|
---|
| 207 | overlayConfig.height = this.height;
|
---|
| 208 | }
|
---|
| 209 | if (this.minWidth || this.minWidth === 0) {
|
---|
| 210 | overlayConfig.minWidth = this.minWidth;
|
---|
| 211 | }
|
---|
| 212 | if (this.minHeight || this.minHeight === 0) {
|
---|
| 213 | overlayConfig.minHeight = this.minHeight;
|
---|
| 214 | }
|
---|
| 215 | if (this.backdropClass) {
|
---|
| 216 | overlayConfig.backdropClass = this.backdropClass;
|
---|
| 217 | }
|
---|
| 218 | if (this.panelClass) {
|
---|
| 219 | overlayConfig.panelClass = this.panelClass;
|
---|
| 220 | }
|
---|
| 221 | return overlayConfig;
|
---|
| 222 | }
|
---|
| 223 | /** Updates the state of a position strategy, based on the values of the directive inputs. */
|
---|
| 224 | _updatePositionStrategy(positionStrategy) {
|
---|
| 225 | const positions = this.positions.map(currentPosition => ({
|
---|
| 226 | originX: currentPosition.originX,
|
---|
| 227 | originY: currentPosition.originY,
|
---|
| 228 | overlayX: currentPosition.overlayX,
|
---|
| 229 | overlayY: currentPosition.overlayY,
|
---|
| 230 | offsetX: currentPosition.offsetX || this.offsetX,
|
---|
| 231 | offsetY: currentPosition.offsetY || this.offsetY,
|
---|
| 232 | panelClass: currentPosition.panelClass || undefined,
|
---|
| 233 | }));
|
---|
| 234 | return positionStrategy
|
---|
| 235 | .setOrigin(this.origin.elementRef)
|
---|
| 236 | .withPositions(positions)
|
---|
| 237 | .withFlexibleDimensions(this.flexibleDimensions)
|
---|
| 238 | .withPush(this.push)
|
---|
| 239 | .withGrowAfterOpen(this.growAfterOpen)
|
---|
| 240 | .withViewportMargin(this.viewportMargin)
|
---|
| 241 | .withLockedPosition(this.lockPosition)
|
---|
| 242 | .withTransformOriginOn(this.transformOriginSelector);
|
---|
| 243 | }
|
---|
| 244 | /** Returns the position strategy of the overlay to be set on the overlay config */
|
---|
| 245 | _createPositionStrategy() {
|
---|
| 246 | const strategy = this._overlay.position().flexibleConnectedTo(this.origin.elementRef);
|
---|
| 247 | this._updatePositionStrategy(strategy);
|
---|
| 248 | return strategy;
|
---|
| 249 | }
|
---|
| 250 | /** Attaches the overlay and subscribes to backdrop clicks if backdrop exists */
|
---|
| 251 | _attachOverlay() {
|
---|
| 252 | if (!this._overlayRef) {
|
---|
| 253 | this._createOverlay();
|
---|
| 254 | }
|
---|
| 255 | else {
|
---|
| 256 | // Update the overlay size, in case the directive's inputs have changed
|
---|
| 257 | this._overlayRef.getConfig().hasBackdrop = this.hasBackdrop;
|
---|
| 258 | }
|
---|
| 259 | if (!this._overlayRef.hasAttached()) {
|
---|
| 260 | this._overlayRef.attach(this._templatePortal);
|
---|
| 261 | }
|
---|
| 262 | if (this.hasBackdrop) {
|
---|
| 263 | this._backdropSubscription = this._overlayRef.backdropClick().subscribe(event => {
|
---|
| 264 | this.backdropClick.emit(event);
|
---|
| 265 | });
|
---|
| 266 | }
|
---|
| 267 | else {
|
---|
| 268 | this._backdropSubscription.unsubscribe();
|
---|
| 269 | }
|
---|
| 270 | this._positionSubscription.unsubscribe();
|
---|
| 271 | // Only subscribe to `positionChanges` if requested, because putting
|
---|
| 272 | // together all the information for it can be expensive.
|
---|
| 273 | if (this.positionChange.observers.length > 0) {
|
---|
| 274 | this._positionSubscription = this._position.positionChanges
|
---|
| 275 | .pipe(takeWhile(() => this.positionChange.observers.length > 0))
|
---|
| 276 | .subscribe(position => {
|
---|
| 277 | this.positionChange.emit(position);
|
---|
| 278 | if (this.positionChange.observers.length === 0) {
|
---|
| 279 | this._positionSubscription.unsubscribe();
|
---|
| 280 | }
|
---|
| 281 | });
|
---|
| 282 | }
|
---|
| 283 | }
|
---|
| 284 | /** Detaches the overlay and unsubscribes to backdrop clicks if backdrop exists */
|
---|
| 285 | _detachOverlay() {
|
---|
| 286 | if (this._overlayRef) {
|
---|
| 287 | this._overlayRef.detach();
|
---|
| 288 | }
|
---|
| 289 | this._backdropSubscription.unsubscribe();
|
---|
| 290 | this._positionSubscription.unsubscribe();
|
---|
| 291 | }
|
---|
| 292 | }
|
---|
| 293 | CdkConnectedOverlay.decorators = [
|
---|
| 294 | { type: Directive, args: [{
|
---|
| 295 | selector: '[cdk-connected-overlay], [connected-overlay], [cdkConnectedOverlay]',
|
---|
| 296 | exportAs: 'cdkConnectedOverlay'
|
---|
| 297 | },] }
|
---|
| 298 | ];
|
---|
| 299 | CdkConnectedOverlay.ctorParameters = () => [
|
---|
| 300 | { type: Overlay },
|
---|
| 301 | { type: TemplateRef },
|
---|
| 302 | { type: ViewContainerRef },
|
---|
| 303 | { type: undefined, decorators: [{ type: Inject, args: [CDK_CONNECTED_OVERLAY_SCROLL_STRATEGY,] }] },
|
---|
| 304 | { type: Directionality, decorators: [{ type: Optional }] }
|
---|
| 305 | ];
|
---|
| 306 | CdkConnectedOverlay.propDecorators = {
|
---|
| 307 | origin: [{ type: Input, args: ['cdkConnectedOverlayOrigin',] }],
|
---|
| 308 | positions: [{ type: Input, args: ['cdkConnectedOverlayPositions',] }],
|
---|
| 309 | positionStrategy: [{ type: Input, args: ['cdkConnectedOverlayPositionStrategy',] }],
|
---|
| 310 | offsetX: [{ type: Input, args: ['cdkConnectedOverlayOffsetX',] }],
|
---|
| 311 | offsetY: [{ type: Input, args: ['cdkConnectedOverlayOffsetY',] }],
|
---|
| 312 | width: [{ type: Input, args: ['cdkConnectedOverlayWidth',] }],
|
---|
| 313 | height: [{ type: Input, args: ['cdkConnectedOverlayHeight',] }],
|
---|
| 314 | minWidth: [{ type: Input, args: ['cdkConnectedOverlayMinWidth',] }],
|
---|
| 315 | minHeight: [{ type: Input, args: ['cdkConnectedOverlayMinHeight',] }],
|
---|
| 316 | backdropClass: [{ type: Input, args: ['cdkConnectedOverlayBackdropClass',] }],
|
---|
| 317 | panelClass: [{ type: Input, args: ['cdkConnectedOverlayPanelClass',] }],
|
---|
| 318 | viewportMargin: [{ type: Input, args: ['cdkConnectedOverlayViewportMargin',] }],
|
---|
| 319 | scrollStrategy: [{ type: Input, args: ['cdkConnectedOverlayScrollStrategy',] }],
|
---|
| 320 | open: [{ type: Input, args: ['cdkConnectedOverlayOpen',] }],
|
---|
| 321 | disableClose: [{ type: Input, args: ['cdkConnectedOverlayDisableClose',] }],
|
---|
| 322 | transformOriginSelector: [{ type: Input, args: ['cdkConnectedOverlayTransformOriginOn',] }],
|
---|
| 323 | hasBackdrop: [{ type: Input, args: ['cdkConnectedOverlayHasBackdrop',] }],
|
---|
| 324 | lockPosition: [{ type: Input, args: ['cdkConnectedOverlayLockPosition',] }],
|
---|
| 325 | flexibleDimensions: [{ type: Input, args: ['cdkConnectedOverlayFlexibleDimensions',] }],
|
---|
| 326 | growAfterOpen: [{ type: Input, args: ['cdkConnectedOverlayGrowAfterOpen',] }],
|
---|
| 327 | push: [{ type: Input, args: ['cdkConnectedOverlayPush',] }],
|
---|
| 328 | backdropClick: [{ type: Output }],
|
---|
| 329 | positionChange: [{ type: Output }],
|
---|
| 330 | attach: [{ type: Output }],
|
---|
| 331 | detach: [{ type: Output }],
|
---|
| 332 | overlayKeydown: [{ type: Output }],
|
---|
| 333 | overlayOutsideClick: [{ type: Output }]
|
---|
| 334 | };
|
---|
| 335 | /** @docs-private */
|
---|
| 336 | export function CDK_CONNECTED_OVERLAY_SCROLL_STRATEGY_PROVIDER_FACTORY(overlay) {
|
---|
| 337 | return () => overlay.scrollStrategies.reposition();
|
---|
| 338 | }
|
---|
| 339 | /** @docs-private */
|
---|
| 340 | export const CDK_CONNECTED_OVERLAY_SCROLL_STRATEGY_PROVIDER = {
|
---|
| 341 | provide: CDK_CONNECTED_OVERLAY_SCROLL_STRATEGY,
|
---|
| 342 | deps: [Overlay],
|
---|
| 343 | useFactory: CDK_CONNECTED_OVERLAY_SCROLL_STRATEGY_PROVIDER_FACTORY,
|
---|
| 344 | };
|
---|
| 345 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay-directives.js","sourceRoot":"","sources":["../../../../../../src/cdk/overlay/overlay-directives.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {Direction, Directionality} from '@angular/cdk/bidi';\nimport {BooleanInput, coerceBooleanProperty} from '@angular/cdk/coercion';\nimport {ESCAPE, hasModifierKey} from '@angular/cdk/keycodes';\nimport {TemplatePortal} from '@angular/cdk/portal';\nimport {\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  InjectionToken,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Optional,\n  Output,\n  SimpleChanges,\n  TemplateRef,\n  ViewContainerRef,\n} from '@angular/core';\nimport {Subscription} from 'rxjs';\nimport {takeWhile} from 'rxjs/operators';\nimport {Overlay} from './overlay';\nimport {OverlayConfig} from './overlay-config';\nimport {OverlayRef} from './overlay-ref';\nimport {ConnectedOverlayPositionChange} from './position/connected-position';\nimport {\n  ConnectedPosition,\n  FlexibleConnectedPositionStrategy,\n} from './position/flexible-connected-position-strategy';\nimport {\n  RepositionScrollStrategy,\n  ScrollStrategy,\n} from './scroll/index';\n\n\n/** Default set of positions for the overlay. Follows the behavior of a dropdown. */\nconst defaultPositionList: ConnectedPosition[] = [\n  {\n    originX: 'start',\n    originY: 'bottom',\n    overlayX: 'start',\n    overlayY: 'top'\n  },\n  {\n    originX: 'start',\n    originY: 'top',\n    overlayX: 'start',\n    overlayY: 'bottom'\n  },\n  {\n    originX: 'end',\n    originY: 'top',\n    overlayX: 'end',\n    overlayY: 'bottom'\n  },\n  {\n    originX: 'end',\n    originY: 'bottom',\n    overlayX: 'end',\n    overlayY: 'top'\n  }\n];\n\n/** Injection token that determines the scroll handling while the connected overlay is open. */\nexport const CDK_CONNECTED_OVERLAY_SCROLL_STRATEGY =\n    new InjectionToken<() => ScrollStrategy>('cdk-connected-overlay-scroll-strategy');\n\n/**\n * Directive applied to an element to make it usable as an origin for an Overlay using a\n * ConnectedPositionStrategy.\n */\n@Directive({\n  selector: '[cdk-overlay-origin], [overlay-origin], [cdkOverlayOrigin]',\n  exportAs: 'cdkOverlayOrigin',\n})\nexport class CdkOverlayOrigin {\n  constructor(\n      /** Reference to the element on which the directive is applied. */\n      public elementRef: ElementRef) { }\n}\n\n\n/**\n * Directive to facilitate declarative creation of an\n * Overlay using a FlexibleConnectedPositionStrategy.\n */\n@Directive({\n  selector: '[cdk-connected-overlay], [connected-overlay], [cdkConnectedOverlay]',\n  exportAs: 'cdkConnectedOverlay'\n})\nexport class CdkConnectedOverlay implements OnDestroy, OnChanges {\n  private _overlayRef: OverlayRef;\n  private _templatePortal: TemplatePortal;\n  private _hasBackdrop = false;\n  private _lockPosition = false;\n  private _growAfterOpen = false;\n  private _flexibleDimensions = false;\n  private _push = false;\n  private _backdropSubscription = Subscription.EMPTY;\n  private _attachSubscription = Subscription.EMPTY;\n  private _detachSubscription = Subscription.EMPTY;\n  private _positionSubscription = Subscription.EMPTY;\n  private _offsetX: number;\n  private _offsetY: number;\n  private _position: FlexibleConnectedPositionStrategy;\n  private _scrollStrategyFactory: () => ScrollStrategy;\n\n  /** Origin for the connected overlay. */\n  @Input('cdkConnectedOverlayOrigin') origin: CdkOverlayOrigin;\n\n  /** Registered connected position pairs. */\n  @Input('cdkConnectedOverlayPositions') positions: ConnectedPosition[];\n\n  /**\n   * This input overrides the positions input if specified. It lets users pass\n   * in arbitrary positioning strategies.\n   */\n  @Input('cdkConnectedOverlayPositionStrategy') positionStrategy: FlexibleConnectedPositionStrategy;\n\n  /** The offset in pixels for the overlay connection point on the x-axis */\n  @Input('cdkConnectedOverlayOffsetX')\n  get offsetX(): number { return this._offsetX; }\n  set offsetX(offsetX: number) {\n    this._offsetX = offsetX;\n\n    if (this._position) {\n      this._updatePositionStrategy(this._position);\n    }\n  }\n\n  /** The offset in pixels for the overlay connection point on the y-axis */\n  @Input('cdkConnectedOverlayOffsetY')\n  get offsetY() { return this._offsetY; }\n  set offsetY(offsetY: number) {\n    this._offsetY = offsetY;\n\n    if (this._position) {\n      this._updatePositionStrategy(this._position);\n    }\n  }\n\n  /** The width of the overlay panel. */\n  @Input('cdkConnectedOverlayWidth') width: number | string;\n\n  /** The height of the overlay panel. */\n  @Input('cdkConnectedOverlayHeight') height: number | string;\n\n  /** The min width of the overlay panel. */\n  @Input('cdkConnectedOverlayMinWidth') minWidth: number | string;\n\n  /** The min height of the overlay panel. */\n  @Input('cdkConnectedOverlayMinHeight') minHeight: number | string;\n\n  /** The custom class to be set on the backdrop element. */\n  @Input('cdkConnectedOverlayBackdropClass') backdropClass: string;\n\n  /** The custom class to add to the overlay pane element. */\n  @Input('cdkConnectedOverlayPanelClass') panelClass: string | string[];\n\n  /** Margin between the overlay and the viewport edges. */\n  @Input('cdkConnectedOverlayViewportMargin') viewportMargin: number = 0;\n\n  /** Strategy to be used when handling scroll events while the overlay is open. */\n  @Input('cdkConnectedOverlayScrollStrategy') scrollStrategy: ScrollStrategy;\n\n  /** Whether the overlay is open. */\n  @Input('cdkConnectedOverlayOpen') open: boolean = false;\n\n  /** Whether the overlay can be closed by user interaction. */\n  @Input('cdkConnectedOverlayDisableClose') disableClose: boolean = false;\n\n  /** CSS selector which to set the transform origin. */\n  @Input('cdkConnectedOverlayTransformOriginOn') transformOriginSelector: string;\n\n  /** Whether or not the overlay should attach a backdrop. */\n  @Input('cdkConnectedOverlayHasBackdrop')\n  get hasBackdrop() { return this._hasBackdrop; }\n  set hasBackdrop(value: any) { this._hasBackdrop = coerceBooleanProperty(value); }\n\n  /** Whether or not the overlay should be locked when scrolling. */\n  @Input('cdkConnectedOverlayLockPosition')\n  get lockPosition() { return this._lockPosition; }\n  set lockPosition(value: any) { this._lockPosition = coerceBooleanProperty(value); }\n\n  /** Whether the overlay's width and height can be constrained to fit within the viewport. */\n  @Input('cdkConnectedOverlayFlexibleDimensions')\n  get flexibleDimensions() { return this._flexibleDimensions; }\n  set flexibleDimensions(value: boolean) {\n    this._flexibleDimensions = coerceBooleanProperty(value);\n  }\n\n  /** Whether the overlay can grow after the initial open when flexible positioning is turned on. */\n  @Input('cdkConnectedOverlayGrowAfterOpen')\n  get growAfterOpen() { return this._growAfterOpen; }\n  set growAfterOpen(value: boolean) { this._growAfterOpen = coerceBooleanProperty(value); }\n\n  /** Whether the overlay can be pushed on-screen if none of the provided positions fit. */\n  @Input('cdkConnectedOverlayPush')\n  get push() { return this._push; }\n  set push(value: boolean) { this._push = coerceBooleanProperty(value); }\n\n  /** Event emitted when the backdrop is clicked. */\n  @Output() readonly backdropClick = new EventEmitter<MouseEvent>();\n\n  /** Event emitted when the position has changed. */\n  @Output() readonly positionChange = new EventEmitter<ConnectedOverlayPositionChange>();\n\n  /** Event emitted when the overlay has been attached. */\n  @Output() readonly attach = new EventEmitter<void>();\n\n  /** Event emitted when the overlay has been detached. */\n  @Output() readonly detach = new EventEmitter<void>();\n\n  /** Emits when there are keyboard events that are targeted at the overlay. */\n  @Output() readonly overlayKeydown = new EventEmitter<KeyboardEvent>();\n\n  /** Emits when there are mouse outside click events that are targeted at the overlay. */\n  @Output() readonly overlayOutsideClick = new EventEmitter<MouseEvent>();\n\n  // TODO(jelbourn): inputs for size, scroll behavior, animation, etc.\n\n  constructor(\n      private _overlay: Overlay,\n      templateRef: TemplateRef<any>,\n      viewContainerRef: ViewContainerRef,\n      @Inject(CDK_CONNECTED_OVERLAY_SCROLL_STRATEGY) scrollStrategyFactory: any,\n      @Optional() private _dir: Directionality) {\n    this._templatePortal = new TemplatePortal(templateRef, viewContainerRef);\n    this._scrollStrategyFactory = scrollStrategyFactory;\n    this.scrollStrategy = this._scrollStrategyFactory();\n  }\n\n  /** The associated overlay reference. */\n  get overlayRef(): OverlayRef {\n    return this._overlayRef;\n  }\n\n  /** The element's layout direction. */\n  get dir(): Direction {\n    return this._dir ? this._dir.value : 'ltr';\n  }\n\n  ngOnDestroy() {\n    this._attachSubscription.unsubscribe();\n    this._detachSubscription.unsubscribe();\n    this._backdropSubscription.unsubscribe();\n    this._positionSubscription.unsubscribe();\n\n    if (this._overlayRef) {\n      this._overlayRef.dispose();\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (this._position) {\n      this._updatePositionStrategy(this._position);\n      this._overlayRef.updateSize({\n        width: this.width,\n        minWidth: this.minWidth,\n        height: this.height,\n        minHeight: this.minHeight,\n      });\n\n      if (changes['origin'] && this.open) {\n        this._position.apply();\n      }\n    }\n\n    if (changes['open']) {\n      this.open ? this._attachOverlay() : this._detachOverlay();\n    }\n  }\n\n  /** Creates an overlay */\n  private _createOverlay() {\n    if (!this.positions || !this.positions.length) {\n      this.positions = defaultPositionList;\n    }\n\n    const overlayRef = this._overlayRef = this._overlay.create(this._buildConfig());\n    this._attachSubscription = overlayRef.attachments().subscribe(() => this.attach.emit());\n    this._detachSubscription = overlayRef.detachments().subscribe(() => this.detach.emit());\n    overlayRef.keydownEvents().subscribe((event: KeyboardEvent) => {\n      this.overlayKeydown.next(event);\n\n      if (event.keyCode === ESCAPE && !this.disableClose && !hasModifierKey(event)) {\n        event.preventDefault();\n        this._detachOverlay();\n      }\n    });\n\n    this._overlayRef.outsidePointerEvents().subscribe((event: MouseEvent) => {\n      this.overlayOutsideClick.next(event);\n    });\n  }\n\n  /** Builds the overlay config based on the directive's inputs */\n  private _buildConfig(): OverlayConfig {\n    const positionStrategy = this._position =\n      this.positionStrategy || this._createPositionStrategy();\n    const overlayConfig = new OverlayConfig({\n      direction: this._dir,\n      positionStrategy,\n      scrollStrategy: this.scrollStrategy,\n      hasBackdrop: this.hasBackdrop\n    });\n\n    if (this.width || this.width === 0) {\n      overlayConfig.width = this.width;\n    }\n\n    if (this.height || this.height === 0) {\n      overlayConfig.height = this.height;\n    }\n\n    if (this.minWidth || this.minWidth === 0) {\n      overlayConfig.minWidth = this.minWidth;\n    }\n\n    if (this.minHeight || this.minHeight === 0) {\n      overlayConfig.minHeight = this.minHeight;\n    }\n\n    if (this.backdropClass) {\n      overlayConfig.backdropClass = this.backdropClass;\n    }\n\n    if (this.panelClass) {\n      overlayConfig.panelClass = this.panelClass;\n    }\n\n    return overlayConfig;\n  }\n\n  /** Updates the state of a position strategy, based on the values of the directive inputs. */\n  private _updatePositionStrategy(positionStrategy: FlexibleConnectedPositionStrategy) {\n    const positions: ConnectedPosition[] = this.positions.map(currentPosition => ({\n      originX: currentPosition.originX,\n      originY: currentPosition.originY,\n      overlayX: currentPosition.overlayX,\n      overlayY: currentPosition.overlayY,\n      offsetX: currentPosition.offsetX || this.offsetX,\n      offsetY: currentPosition.offsetY || this.offsetY,\n      panelClass: currentPosition.panelClass || undefined,\n    }));\n\n    return positionStrategy\n      .setOrigin(this.origin.elementRef)\n      .withPositions(positions)\n      .withFlexibleDimensions(this.flexibleDimensions)\n      .withPush(this.push)\n      .withGrowAfterOpen(this.growAfterOpen)\n      .withViewportMargin(this.viewportMargin)\n      .withLockedPosition(this.lockPosition)\n      .withTransformOriginOn(this.transformOriginSelector);\n  }\n\n  /** Returns the position strategy of the overlay to be set on the overlay config */\n  private _createPositionStrategy(): FlexibleConnectedPositionStrategy {\n    const strategy = this._overlay.position().flexibleConnectedTo(this.origin.elementRef);\n    this._updatePositionStrategy(strategy);\n    return strategy;\n  }\n\n  /** Attaches the overlay and subscribes to backdrop clicks if backdrop exists */\n  private _attachOverlay() {\n    if (!this._overlayRef) {\n      this._createOverlay();\n    } else {\n      // Update the overlay size, in case the directive's inputs have changed\n      this._overlayRef.getConfig().hasBackdrop = this.hasBackdrop;\n    }\n\n    if (!this._overlayRef.hasAttached()) {\n      this._overlayRef.attach(this._templatePortal);\n    }\n\n    if (this.hasBackdrop) {\n      this._backdropSubscription = this._overlayRef.backdropClick().subscribe(event => {\n        this.backdropClick.emit(event);\n      });\n    } else {\n      this._backdropSubscription.unsubscribe();\n    }\n\n    this._positionSubscription.unsubscribe();\n\n    // Only subscribe to `positionChanges` if requested, because putting\n    // together all the information for it can be expensive.\n    if (this.positionChange.observers.length > 0) {\n      this._positionSubscription = this._position.positionChanges\n        .pipe(takeWhile(() => this.positionChange.observers.length > 0))\n        .subscribe(position => {\n          this.positionChange.emit(position);\n\n          if (this.positionChange.observers.length === 0) {\n            this._positionSubscription.unsubscribe();\n          }\n        });\n    }\n  }\n\n  /** Detaches the overlay and unsubscribes to backdrop clicks if backdrop exists */\n  private _detachOverlay() {\n    if (this._overlayRef) {\n      this._overlayRef.detach();\n    }\n\n    this._backdropSubscription.unsubscribe();\n    this._positionSubscription.unsubscribe();\n  }\n\n  static ngAcceptInputType_hasBackdrop: BooleanInput;\n  static ngAcceptInputType_lockPosition: BooleanInput;\n  static ngAcceptInputType_flexibleDimensions: BooleanInput;\n  static ngAcceptInputType_growAfterOpen: BooleanInput;\n  static ngAcceptInputType_push: BooleanInput;\n}\n\n\n/** @docs-private */\nexport function CDK_CONNECTED_OVERLAY_SCROLL_STRATEGY_PROVIDER_FACTORY(overlay: Overlay):\n    () => RepositionScrollStrategy {\n  return () => overlay.scrollStrategies.reposition();\n}\n\n/** @docs-private */\nexport const CDK_CONNECTED_OVERLAY_SCROLL_STRATEGY_PROVIDER = {\n  provide: CDK_CONNECTED_OVERLAY_SCROLL_STRATEGY,\n  deps: [Overlay],\n  useFactory: CDK_CONNECTED_OVERLAY_SCROLL_STRATEGY_PROVIDER_FACTORY,\n};\n"]} |
---|