@angular/cdk
Version:
Angular Material Component Development Kit
188 lines • 14.9 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: src/cdk/overlay/position/connected-position.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* @license
* Copyright Google LLC All Rights Reserved.
*
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://angular.io/license
*/
/** Horizontal dimension of a connection point on the perimeter of the origin or overlay element. */
import { Optional } from '@angular/core';
/**
* A connection point on the origin element.
* @record
*/
export function OriginConnectionPosition() { }
if (false) {
/** @type {?} */
OriginConnectionPosition.prototype.originX;
/** @type {?} */
OriginConnectionPosition.prototype.originY;
}
/**
* A connection point on the overlay element.
* @record
*/
export function OverlayConnectionPosition() { }
if (false) {
/** @type {?} */
OverlayConnectionPosition.prototype.overlayX;
/** @type {?} */
OverlayConnectionPosition.prototype.overlayY;
}
/**
* The points of the origin element and the overlay element to connect.
*/
export class ConnectionPositionPair {
/**
* @param {?} origin
* @param {?} overlay
* @param {?=} offsetX
* @param {?=} offsetY
* @param {?=} panelClass
*/
constructor(origin, overlay, offsetX, offsetY, panelClass) {
this.offsetX = offsetX;
this.offsetY = offsetY;
this.panelClass = panelClass;
this.originX = origin.originX;
this.originY = origin.originY;
this.overlayX = overlay.overlayX;
this.overlayY = overlay.overlayY;
}
}
if (false) {
/**
* X-axis attachment point for connected overlay origin. Can be 'start', 'end', or 'center'.
* @type {?}
*/
ConnectionPositionPair.prototype.originX;
/**
* Y-axis attachment point for connected overlay origin. Can be 'top', 'bottom', or 'center'.
* @type {?}
*/
ConnectionPositionPair.prototype.originY;
/**
* X-axis attachment point for connected overlay. Can be 'start', 'end', or 'center'.
* @type {?}
*/
ConnectionPositionPair.prototype.overlayX;
/**
* Y-axis attachment point for connected overlay. Can be 'top', 'bottom', or 'center'.
* @type {?}
*/
ConnectionPositionPair.prototype.overlayY;
/**
* Offset along the X axis.
* @type {?}
*/
ConnectionPositionPair.prototype.offsetX;
/**
* Offset along the Y axis.
* @type {?}
*/
ConnectionPositionPair.prototype.offsetY;
/**
* Class(es) to be applied to the panel while this position is active.
* @type {?}
*/
ConnectionPositionPair.prototype.panelClass;
}
/**
* Set of properties regarding the position of the origin and overlay relative to the viewport
* with respect to the containing Scrollable elements.
*
* The overlay and origin are clipped if any part of their bounding client rectangle exceeds the
* bounds of any one of the strategy's Scrollable's bounding client rectangle.
*
* The overlay and origin are outside view if there is no overlap between their bounding client
* rectangle and any one of the strategy's Scrollable's bounding client rectangle.
*
* ----------- -----------
* | outside | | clipped |
* | view | --------------------------
* | | | | | |
* ---------- | ----------- |
* -------------------------- | |
* | | | Scrollable |
* | | | |
* | | --------------------------
* | Scrollable |
* | |
* --------------------------
*
* \@docs-private
*/
export class ScrollingVisibility {
}
if (false) {
/** @type {?} */
ScrollingVisibility.prototype.isOriginClipped;
/** @type {?} */
ScrollingVisibility.prototype.isOriginOutsideView;
/** @type {?} */
ScrollingVisibility.prototype.isOverlayClipped;
/** @type {?} */
ScrollingVisibility.prototype.isOverlayOutsideView;
}
/**
* The change event emitted by the strategy when a fallback position is used.
*/
export class ConnectedOverlayPositionChange {
/**
* @param {?} connectionPair
* @param {?} scrollableViewProperties
*/
constructor(connectionPair, scrollableViewProperties) {
this.connectionPair = connectionPair;
this.scrollableViewProperties = scrollableViewProperties;
}
}
/** @nocollapse */
ConnectedOverlayPositionChange.ctorParameters = () => [
{ type: ConnectionPositionPair },
{ type: ScrollingVisibility, decorators: [{ type: Optional }] }
];
if (false) {
/**
* The position used as a result of this change.
* @type {?}
*/
ConnectedOverlayPositionChange.prototype.connectionPair;
/**
* \@docs-private
* @type {?}
*/
ConnectedOverlayPositionChange.prototype.scrollableViewProperties;
}
/**
* Validates whether a vertical position property matches the expected values.
* \@docs-private
* @param {?} property Name of the property being validated.
* @param {?} value Value of the property being validated.
* @return {?}
*/
export function validateVerticalPosition(property, value) {
if (value !== 'top' && value !== 'bottom' && value !== 'center') {
throw Error(`ConnectedPosition: Invalid ${property} "${value}". ` +
`Expected "top", "bottom" or "center".`);
}
}
/**
* Validates whether a horizontal position property matches the expected values.
* \@docs-private
* @param {?} property Name of the property being validated.
* @param {?} value Value of the property being validated.
* @return {?}
*/
export function validateHorizontalPosition(property, value) {
if (value !== 'start' && value !== 'end' && value !== 'center') {
throw Error(`ConnectedPosition: Invalid ${property} "${value}". ` +
`Expected "start", "end" or "center".`);
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"connected-position.js","sourceRoot":"","sources":["../../../../../../../src/cdk/overlay/position/connected-position.ts"],"names":[],"mappings":";;;;;;;;;;;;;AASA,OAAO,EAAC,QAAQ,EAAC,MAAM,eAAe,CAAC;;;;;AAQvC,8CAGC;;;IAFC,2CAAiC;;IACjC,2CAA+B;;;;;;AAIjC,+CAGC;;;IAFC,6CAAkC;;IAClC,6CAAgC;;;;;AAIlC,MAAM,OAAO,sBAAsB;;;;;;;;IAUjC,YACE,MAAgC,EAChC,OAAkC,EAE3B,OAAgB,EAEhB,OAAgB,EAEhB,UAA8B;QAJ9B,YAAO,GAAP,OAAO,CAAS;QAEhB,YAAO,GAAP,OAAO,CAAS;QAEhB,eAAU,GAAV,UAAU,CAAoB;QAErC,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC;QAC9B,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC;QAC9B,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC;QACjC,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC;IACnC,CAAC;CACF;;;;;;IAvBC,yCAAiC;;;;;IAEjC,yCAA+B;;;;;IAE/B,0CAAkC;;;;;IAElC,0CAAgC;;;;;IAM9B,yCAAuB;;;;;IAEvB,yCAAuB;;;;;IAEvB,4CAAqC;;;;;;;;;;;;;;;;;;;;;;;;;;;AAkCzC,MAAM,OAAO,mBAAmB;CAK/B;;;IAJC,8CAAyB;;IACzB,kDAA6B;;IAC7B,+CAA0B;;IAC1B,mDAA8B;;;;;AAIhC,MAAM,OAAO,8BAA8B;;;;;IACzC,YAEW,cAAsC,EAE1B,wBAA6C;QAFzD,mBAAc,GAAd,cAAc,CAAwB;QAE1B,6BAAwB,GAAxB,wBAAwB,CAAqB;IAAG,CAAC;;;;YAF7C,sBAAsB;YAEA,mBAAmB,uBAA/D,QAAQ;;;;;;;IAFT,wDAA6C;;;;;IAE7C,kEAAgE;;;;;;;;;AAStE,MAAM,UAAU,wBAAwB,CAAC,QAAgB,EAAE,KAA4B;IACrF,IAAI,KAAK,KAAK,KAAK,IAAI,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,QAAQ,EAAE;QAC/D,MAAM,KAAK,CAAC,8BAA8B,QAAQ,KAAK,KAAK,KAAK;YACrD,uCAAuC,CAAC,CAAC;KACtD;AACH,CAAC;;;;;;;;AAQD,MAAM,UAAU,0BAA0B,CAAC,QAAgB,EAAE,KAA8B;IACzF,IAAI,KAAK,KAAK,OAAO,IAAI,KAAK,KAAK,KAAK,IAAI,KAAK,KAAK,QAAQ,EAAE;QAC9D,MAAM,KAAK,CAAC,8BAA8B,QAAQ,KAAK,KAAK,KAAK;YACrD,sCAAsC,CAAC,CAAC;KACrD;AACH,CAAC","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\n/** Horizontal dimension of a connection point on the perimeter of the origin or overlay element. */\nimport {Optional} from '@angular/core';\nexport type HorizontalConnectionPos = 'start' | 'center' | 'end';\n\n/** Vertical dimension of a connection point on the perimeter of the origin or overlay element. */\nexport type VerticalConnectionPos = 'top' | 'center' | 'bottom';\n\n\n/** A connection point on the origin element. */\nexport interface OriginConnectionPosition {\n  originX: HorizontalConnectionPos;\n  originY: VerticalConnectionPos;\n}\n\n/** A connection point on the overlay element. */\nexport interface OverlayConnectionPosition {\n  overlayX: HorizontalConnectionPos;\n  overlayY: VerticalConnectionPos;\n}\n\n/** The points of the origin element and the overlay element to connect. */\nexport class ConnectionPositionPair {\n  /** X-axis attachment point for connected overlay origin. Can be 'start', 'end', or 'center'. */\n  originX: HorizontalConnectionPos;\n  /** Y-axis attachment point for connected overlay origin. Can be 'top', 'bottom', or 'center'. */\n  originY: VerticalConnectionPos;\n  /** X-axis attachment point for connected overlay. Can be 'start', 'end', or 'center'. */\n  overlayX: HorizontalConnectionPos;\n  /** Y-axis attachment point for connected overlay. Can be 'top', 'bottom', or 'center'. */\n  overlayY: VerticalConnectionPos;\n\n  constructor(\n    origin: OriginConnectionPosition,\n    overlay: OverlayConnectionPosition,\n    /** Offset along the X axis. */\n    public offsetX?: number,\n    /** Offset along the Y axis. */\n    public offsetY?: number,\n    /** Class(es) to be applied to the panel while this position is active. */\n    public panelClass?: string | string[]) {\n\n    this.originX = origin.originX;\n    this.originY = origin.originY;\n    this.overlayX = overlay.overlayX;\n    this.overlayY = overlay.overlayY;\n  }\n}\n\n/**\n * Set of properties regarding the position of the origin and overlay relative to the viewport\n * with respect to the containing Scrollable elements.\n *\n * The overlay and origin are clipped if any part of their bounding client rectangle exceeds the\n * bounds of any one of the strategy's Scrollable's bounding client rectangle.\n *\n * The overlay and origin are outside view if there is no overlap between their bounding client\n * rectangle and any one of the strategy's Scrollable's bounding client rectangle.\n *\n *       -----------                    -----------\n *       | outside |                    | clipped |\n *       |  view   |              --------------------------\n *       |         |              |     |         |        |\n *       ----------               |     -----------        |\n *  --------------------------    |                        |\n *  |                        |    |      Scrollable        |\n *  |                        |    |                        |\n *  |                        |     --------------------------\n *  |      Scrollable        |\n *  |                        |\n *  --------------------------\n *\n *  @docs-private\n */\nexport class ScrollingVisibility {\n  isOriginClipped: boolean;\n  isOriginOutsideView: boolean;\n  isOverlayClipped: boolean;\n  isOverlayOutsideView: boolean;\n}\n\n/** The change event emitted by the strategy when a fallback position is used. */\nexport class ConnectedOverlayPositionChange {\n  constructor(\n      /** The position used as a result of this change. */\n      public connectionPair: ConnectionPositionPair,\n      /** @docs-private */\n      @Optional() public scrollableViewProperties: ScrollingVisibility) {}\n}\n\n/**\n * Validates whether a vertical position property matches the expected values.\n * @param property Name of the property being validated.\n * @param value Value of the property being validated.\n * @docs-private\n */\nexport function validateVerticalPosition(property: string, value: VerticalConnectionPos) {\n  if (value !== 'top' && value !== 'bottom' && value !== 'center') {\n    throw Error(`ConnectedPosition: Invalid ${property} \"${value}\". ` +\n                `Expected \"top\", \"bottom\" or \"center\".`);\n  }\n}\n\n/**\n * Validates whether a horizontal position property matches the expected values.\n * @param property Name of the property being validated.\n * @param value Value of the property being validated.\n * @docs-private\n */\nexport function validateHorizontalPosition(property: string, value: HorizontalConnectionPos) {\n  if (value !== 'start' && value !== 'end' && value !== 'center') {\n    throw Error(`ConnectedPosition: Invalid ${property} \"${value}\". ` +\n                `Expected \"start\", \"end\" or \"center\".`);\n  }\n}\n"]}