@hxui/angular
Version:
* * *
424 lines • 37.3 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
import { ContentChild, Directive, ElementRef, EventEmitter, Input, Output, ViewContainerRef } from '@angular/core';
import { takeUntil } from 'rxjs/operators';
import { DropdownConfig } from './dropdown.config';
import { DropdownMenuDirective } from './dropdown-menu.directive';
import { Subject } from 'rxjs/index';
import { TemplatePortal } from '@angular/cdk/portal';
import { Overlay } from '@angular/cdk/overlay';
var DropdownDirective = /** @class */ (function () {
function DropdownDirective(_elementRef, _viewContainerRef, overlay, _config) {
this._elementRef = _elementRef;
this._viewContainerRef = _viewContainerRef;
this.overlay = overlay;
this._config = _config;
this._destroyed = new Subject();
this.isOpen = false;
this.placement = 'bottom';
this._autoClose = this._config.autoClose;
this.isOpenChange = new EventEmitter();
this.onShown = new EventEmitter();
this.onHidden = new EventEmitter();
this.isDisabled = false;
this.showDelay = this._config.showDelay;
this.hideDelay = this._config.hideDelay;
}
Object.defineProperty(DropdownDirective.prototype, "autoClose", {
get: /**
* @return {?}
*/
function () {
return this._autoClose;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._autoClose = value;
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
DropdownDirective.prototype.ngOnInit = /**
* @return {?}
*/
function () { };
/**
* @return {?}
*/
DropdownDirective.prototype.ngAfterContentInit = /**
* @return {?}
*/
function () { };
/**
* @return {?}
*/
DropdownDirective.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
if (this._overlayRef) {
this._overlayRef.dispose();
this._overlayRef = null;
}
this._destroyed.next();
this._destroyed.complete();
};
/**
* Toggles an element’s popover. This is considered a “manual” triggering of
* the popover.
*/
/**
* Toggles an element’s popover. This is considered a “manual” triggering of
* the popover.
* @param {?=} value
* @return {?}
*/
DropdownDirective.prototype.toggle = /**
* Toggles an element’s popover. This is considered a “manual” triggering of
* the popover.
* @param {?=} value
* @return {?}
*/
function (value) {
if (this.isOpen || value === false) {
return this.hide();
}
return this.show();
};
/**
* @param {?=} delay
* @return {?}
*/
DropdownDirective.prototype.show = /**
* @param {?=} delay
* @return {?}
*/
function (delay) {
if (delay === void 0) { delay = this.showDelay; }
if (this.isDisabled || this.isOpen) {
return;
}
/** @type {?} */
var overlayRef = this._createOverlay();
this._detach();
overlayRef.attach(this._portal);
this._setWidthsRelativeTo(overlayRef);
this.isOpen = true;
this.isOpenChange.emit(this.isOpen);
this.onShown.emit();
};
/**
* @param {?=} delay
* @return {?}
*/
DropdownDirective.prototype.hide = /**
* @param {?=} delay
* @return {?}
*/
function (delay) {
if (delay === void 0) { delay = this.hideDelay; }
this._detach();
this.isOpen = false;
this.isOpenChange.emit(this.isOpen);
this.onHidden.emit();
};
/**
* @return {?}
*/
DropdownDirective.prototype._createOverlay = /**
* @return {?}
*/
function () {
var _this = this;
if (this._overlayRef) {
return this._overlayRef;
}
this._portal = new TemplatePortal(this.menu.templateRef, this._viewContainerRef);
/** @type {?} */
var positionStrategy = this.overlay
.position()
.flexibleConnectedTo(this._elementRef)
.withFlexibleDimensions(false)
.withDefaultOffsetX(0)
.withPositions([
{ originX: 'start', originY: 'top', overlayX: 'start', overlayY: 'top' }
])
.withTransformOriginOn('.hxa-dropdown-control');
this._overlayRef = this.overlay.create({
positionStrategy: positionStrategy,
panelClass: [
'hxui-reset',
'hxa-dropdown-panel',
'is-open',
this.minWidthRelativeTo ? 'is-fluid-min-width' : 'not-fuild-min-width'
],
hasBackdrop: true,
backdropClass: 'cdk-overlay-transparent-backdrop'
});
this._updatePosition();
this._overlayRef
.detachments()
.pipe(takeUntil(this._destroyed))
.subscribe(function () { return _this._detach(); });
this._overlayRef.backdropClick().subscribe(function () { return _this.hide(); });
/** @type {?} */
var position = (/** @type {?} */ (this._overlayRef.getConfig()
.positionStrategy));
position.positionChanges.pipe(takeUntil(this._destroyed)).subscribe(function (pos) {
if (pos.connectionPair.originX === 'start') {
_this.placement = 'left';
}
else if (pos.connectionPair.originX === 'end') {
_this.placement = 'right';
}
else if (pos.connectionPair.originY === 'top') {
_this.placement = 'top';
}
else if (pos.connectionPair.originY === 'bottom') {
_this.placement = 'bottom';
}
});
return this._overlayRef;
};
/**
* @return {?}
*/
DropdownDirective.prototype._detach = /**
* @return {?}
*/
function () {
if (this._overlayRef && this._overlayRef.hasAttached()) {
this._overlayRef.detach();
}
};
/**
* @param {?} overlayRef
* @return {?}
*/
DropdownDirective.prototype._setWidthsRelativeTo = /**
* @param {?} overlayRef
* @return {?}
*/
function (overlayRef) {
if (this.maxWidthRelativeTo && this.minWidthRelativeTo) {
/** @type {?} */
var elem = document.getElementById(this.maxWidthRelativeTo);
overlayRef.updateSize({
minWidth: elem.clientWidth,
maxWidth: elem.clientWidth
});
}
else if (this.maxWidthRelativeTo) {
/** @type {?} */
var elem = document.getElementById(this.maxWidthRelativeTo);
overlayRef.updateSize({ maxWidth: elem.clientWidth });
}
else if (this.minWidthRelativeTo) {
/** @type {?} */
var elem = document.getElementById(this.minWidthRelativeTo);
console.log(this.menu.templateRef);
overlayRef.updateSize({ minWidth: elem.clientWidth });
}
};
/**
* @return {?}
*/
DropdownDirective.prototype._updatePosition = /**
* @return {?}
*/
function () {
/** @type {?} */
var position = (/** @type {?} */ ((/** @type {?} */ (this._overlayRef)).getConfig()
.positionStrategy));
/** @type {?} */
var origin = this._getOrigin();
/** @type {?} */
var overlay = this._getOverlayPosition();
position.withPositions([
tslib_1.__assign({}, origin.main, overlay.main),
tslib_1.__assign({}, origin.fallback, overlay.fallback)
]);
};
/**
* Returns the origin position and a fallback position based on the user's position preference.
* The fallback position is the inverse of the origin (e.g. `'bottom' -> 'top'`).
*/
/**
* Returns the origin position and a fallback position based on the user's position preference.
* The fallback position is the inverse of the origin (e.g. `'bottom' -> 'top'`).
* @return {?}
*/
DropdownDirective.prototype._getOrigin = /**
* Returns the origin position and a fallback position based on the user's position preference.
* The fallback position is the inverse of the origin (e.g. `'bottom' -> 'top'`).
* @return {?}
*/
function () {
/** @type {?} */
var placement = this.placement;
/** @type {?} */
var originPlacement;
if (placement === 'top' || placement === 'bottom') {
originPlacement = {
originX: 'start',
originY: placement === 'top' ? 'top' : 'bottom'
};
}
else if (placement === 'left') {
originPlacement = { originX: 'start', originY: 'center' };
}
else if (placement === 'right') {
originPlacement = { originX: 'end', originY: 'center' };
}
else {
console.error('Position error', placement);
}
var _a = this._invertPosition(originPlacement.originX, originPlacement.originY), x = _a.x, y = _a.y;
return {
main: originPlacement,
fallback: { originX: x, originY: y }
};
};
/** Returns the overlay position and a fallback position based on the user's preference */
/**
* Returns the overlay position and a fallback position based on the user's preference
* @return {?}
*/
DropdownDirective.prototype._getOverlayPosition = /**
* Returns the overlay position and a fallback position based on the user's preference
* @return {?}
*/
function () {
/** @type {?} */
var placement = this.placement;
/** @type {?} */
var overlayPlacement;
if (placement === 'top') {
overlayPlacement = { overlayX: 'start', overlayY: 'bottom' };
}
else if (placement === 'bottom') {
overlayPlacement = { overlayX: 'start', overlayY: 'top' };
}
else if (placement === 'left') {
overlayPlacement = { overlayX: 'end', overlayY: 'center' };
}
else if (placement === 'right') {
overlayPlacement = { overlayX: 'start', overlayY: 'center' };
}
else {
console.error('Could not find a position', placement);
}
var _a = this._invertPosition(overlayPlacement.overlayX, overlayPlacement.overlayY), x = _a.x, y = _a.y;
return {
main: overlayPlacement,
fallback: { overlayX: x, overlayY: y }
};
};
/**
* @param {?} x
* @param {?} y
* @return {?}
*/
DropdownDirective.prototype._invertPosition = /**
* @param {?} x
* @param {?} y
* @return {?}
*/
function (x, y) {
if (this.placement === 'top' || this.placement === 'bottom') {
if (y === 'top') {
y = 'bottom';
}
else if (y === 'bottom') {
y = 'top';
}
}
else {
if (x === 'end') {
x = 'start';
}
else if (x === 'start') {
x = 'end';
}
}
return { x: x, y: y };
};
DropdownDirective.decorators = [
{ type: Directive, args: [{
selector: '[hxaDropdown],[hxDropdown]',
exportAs: 'hx-dropdown, hxa-dropdown'
},] },
];
/** @nocollapse */
DropdownDirective.ctorParameters = function () { return [
{ type: ElementRef },
{ type: ViewContainerRef },
{ type: Overlay },
{ type: DropdownConfig }
]; };
DropdownDirective.propDecorators = {
menu: [{ type: ContentChild, args: [DropdownMenuDirective,] }],
placement: [{ type: Input }],
autoClose: [{ type: Input }],
isOpenChange: [{ type: Output }],
onShown: [{ type: Output }],
onHidden: [{ type: Output }],
isDisabled: [{ type: Input }],
showDelay: [{ type: Input }],
hideDelay: [{ type: Input }],
maxWidthRelativeTo: [{ type: Input }],
minWidthRelativeTo: [{ type: Input }]
};
return DropdownDirective;
}());
export { DropdownDirective };
if (false) {
/** @type {?} */
DropdownDirective.prototype.menu;
/** @type {?} */
DropdownDirective.prototype._overlayRef;
/** @type {?} */
DropdownDirective.prototype._portal;
/** @type {?} */
DropdownDirective.prototype._destroyed;
/** @type {?} */
DropdownDirective.prototype.isOpen;
/** @type {?} */
DropdownDirective.prototype.placement;
/** @type {?} */
DropdownDirective.prototype._autoClose;
/** @type {?} */
DropdownDirective.prototype.isOpenChange;
/** @type {?} */
DropdownDirective.prototype.onShown;
/** @type {?} */
DropdownDirective.prototype.onHidden;
/** @type {?} */
DropdownDirective.prototype.isDisabled;
/** @type {?} */
DropdownDirective.prototype.showDelay;
/** @type {?} */
DropdownDirective.prototype.hideDelay;
/** @type {?} */
DropdownDirective.prototype.maxWidthRelativeTo;
/** @type {?} */
DropdownDirective.prototype.minWidthRelativeTo;
/** @type {?} */
DropdownDirective.prototype._elementRef;
/** @type {?} */
DropdownDirective.prototype._viewContainerRef;
/** @type {?} */
DropdownDirective.prototype.overlay;
/** @type {?} */
DropdownDirective.prototype._config;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.directive.js","sourceRoot":"ng://@hxui/angular/","sources":["lib/dropdown/dropdown.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterContentInit,\r\n  AfterViewInit,\r\n  ComponentFactoryResolver,\r\n  ContentChild,\r\n  ContentChildren,\r\n  Directive,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostListener,\r\n  Input,\r\n  NgZone,\r\n  OnDestroy,\r\n  OnInit,\r\n  Optional,\r\n  Output,\r\n  QueryList,\r\n  ViewChildren,\r\n  ViewContainerRef\r\n} from '@angular/core';\r\n\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { DropdownConfig } from './dropdown.config';\r\nimport { DropdownMenuDirective } from './dropdown-menu.directive';\r\nimport { Subject } from 'rxjs/index';\r\nimport { TemplatePortal } from '@angular/cdk/portal';\r\nimport {\r\n  FlexibleConnectedPositionStrategy,\r\n  Overlay,\r\n  OverlayRef,\r\n  OverlaySizeConfig,\r\n  ScrollDispatcher,\r\n  OriginConnectionPosition,\r\n  OverlayConnectionPosition,\r\n  HorizontalConnectionPos,\r\n  VerticalConnectionPos\r\n} from '@angular/cdk/overlay';\r\nimport { Directionality } from '@angular/cdk/bidi';\r\nimport { DropdownToggleDirective } from './dropdown-toggle.directive';\r\nimport { DropdownItemDirective } from './dropdown-item.directive';\r\n\r\n@Directive({\r\n  selector: '[hxaDropdown],[hxDropdown]',\r\n  exportAs: 'hx-dropdown, hxa-dropdown'\r\n})\r\nexport class DropdownDirective implements OnInit, OnDestroy, AfterContentInit {\r\n  @ContentChild(DropdownMenuDirective) menu: DropdownMenuDirective;\r\n\r\n  _overlayRef: OverlayRef | null;\r\n  private _portal: TemplatePortal;\r\n  private readonly _destroyed = new Subject();\r\n  public isOpen = false;\r\n\r\n  @Input()\r\n  placement: 'top' | 'bottom' | 'left' | 'right' = 'bottom';\r\n\r\n  private _autoClose = this._config.autoClose;\r\n  @Input()\r\n  set autoClose(value: boolean) {\r\n    this._autoClose = value;\r\n  }\r\n\r\n  get autoClose(): boolean {\r\n    return this._autoClose;\r\n  }\r\n\r\n  @Output() isOpenChange: EventEmitter<boolean> = new EventEmitter<boolean>();\r\n\r\n  @Output() onShown: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  @Output() onHidden: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  @Input()\r\n  isDisabled = false;\r\n\r\n  @Input()\r\n  showDelay = this._config.showDelay;\r\n\r\n  @Input()\r\n  hideDelay = this._config.hideDelay;\r\n\r\n  @Input()\r\n  maxWidthRelativeTo: string;\r\n\r\n  @Input()\r\n  minWidthRelativeTo: string;\r\n\r\n  constructor(\r\n    private _elementRef: ElementRef,\r\n    private _viewContainerRef: ViewContainerRef,\r\n    public overlay: Overlay,\r\n    public _config: DropdownConfig\r\n  ) {}\r\n\r\n  ngOnInit(): void {}\r\n\r\n  ngAfterContentInit() {}\r\n\r\n  ngOnDestroy(): void {\r\n    if (this._overlayRef) {\r\n      this._overlayRef.dispose();\r\n      this._overlayRef = null;\r\n    }\r\n    this._destroyed.next();\r\n    this._destroyed.complete();\r\n  }\r\n\r\n  /**\r\n   * Toggles an element’s popover. This is considered a “manual” triggering of\r\n   * the popover.\r\n   */\r\n  toggle(value?: boolean): void {\r\n    if (this.isOpen || value === false) {\r\n      return this.hide();\r\n    }\r\n\r\n    return this.show();\r\n  }\r\n\r\n  show(delay: number = this.showDelay) {\r\n    if (this.isDisabled || this.isOpen) {\r\n      return;\r\n    }\r\n\r\n    const overlayRef = this._createOverlay();\r\n    this._detach();\r\n    overlayRef.attach(this._portal);\r\n    this._setWidthsRelativeTo(overlayRef);\r\n    this.isOpen = true;\r\n    this.isOpenChange.emit(this.isOpen);\r\n    this.onShown.emit();\r\n  }\r\n\r\n  hide(delay: number = this.hideDelay) {\r\n    this._detach();\r\n    this.isOpen = false;\r\n    this.isOpenChange.emit(this.isOpen);\r\n    this.onHidden.emit();\r\n  }\r\n\r\n  private _createOverlay(): OverlayRef {\r\n    if (this._overlayRef) {\r\n      return this._overlayRef;\r\n    }\r\n\r\n    this._portal = new TemplatePortal(\r\n      this.menu.templateRef,\r\n      this._viewContainerRef\r\n    );\r\n\r\n     const positionStrategy = this.overlay\r\n      .position()\r\n      .flexibleConnectedTo(this._elementRef)\r\n      .withFlexibleDimensions(false)\r\n      .withDefaultOffsetX(0)\r\n      .withPositions([\r\n        { originX: 'start', originY: 'top', overlayX: 'start', overlayY: 'top' }\r\n      ])\r\n      .withTransformOriginOn('.hxa-dropdown-control');\r\n\r\n    this._overlayRef = this.overlay.create({\r\n      positionStrategy: positionStrategy,\r\n      panelClass: [\r\n        'hxui-reset',\r\n        'hxa-dropdown-panel',\r\n        'is-open',\r\n        this.minWidthRelativeTo ? 'is-fluid-min-width' : 'not-fuild-min-width'\r\n      ],\r\n      hasBackdrop: true,\r\n      backdropClass: 'cdk-overlay-transparent-backdrop'\r\n    });\r\n\r\n    this._updatePosition();\r\n\r\n    this._overlayRef\r\n      .detachments()\r\n      .pipe(takeUntil(this._destroyed))\r\n      .subscribe(() => this._detach());\r\n\r\n    this._overlayRef.backdropClick().subscribe(() => this.hide());\r\n\r\n    const position = this._overlayRef.getConfig()\r\n      .positionStrategy as FlexibleConnectedPositionStrategy;\r\n    position.positionChanges.pipe(takeUntil(this._destroyed)).subscribe(pos => {\r\n      if (pos.connectionPair.originX === 'start') {\r\n        this.placement = 'left';\r\n      } else if (pos.connectionPair.originX === 'end') {\r\n        this.placement = 'right';\r\n      } else if (pos.connectionPair.originY === 'top') {\r\n        this.placement = 'top';\r\n      } else if (pos.connectionPair.originY === 'bottom') {\r\n        this.placement = 'bottom';\r\n      }\r\n    });\r\n\r\n    return this._overlayRef;\r\n  }\r\n\r\n  private _detach() {\r\n    if (this._overlayRef && this._overlayRef.hasAttached()) {\r\n      this._overlayRef.detach();\r\n    }\r\n  }\r\n\r\n  private _setWidthsRelativeTo(overlayRef: OverlayRef) {\r\n    if (this.maxWidthRelativeTo && this.minWidthRelativeTo) {\r\n      const elem: Element = document.getElementById(this.maxWidthRelativeTo);\r\n      overlayRef.updateSize({\r\n        minWidth: elem.clientWidth,\r\n        maxWidth: elem.clientWidth\r\n      });\r\n    } else if (this.maxWidthRelativeTo) {\r\n      const elem: Element = document.getElementById(this.maxWidthRelativeTo);\r\n      overlayRef.updateSize({ maxWidth: elem.clientWidth });\r\n    } else if (this.minWidthRelativeTo) {\r\n      const elem: Element = document.getElementById(this.minWidthRelativeTo);\r\n      console.log(this.menu.templateRef);\r\n      overlayRef.updateSize({ minWidth: elem.clientWidth });\r\n    }\r\n  }\r\n\r\n  private _updatePosition() {\r\n    const position = this._overlayRef!.getConfig()\r\n      .positionStrategy as FlexibleConnectedPositionStrategy;\r\n    const origin = this._getOrigin();\r\n    const overlay = this._getOverlayPosition();\r\n\r\n    position.withPositions([\r\n      { ...origin.main, ...overlay.main },\r\n      { ...origin.fallback, ...overlay.fallback }\r\n    ]);\r\n  }\r\n\r\n  /**\r\n   * Returns the origin position and a fallback position based on the user's position preference.\r\n   * The fallback position is the inverse of the origin (e.g. `'bottom' -> 'top'`).\r\n   */\r\n  private _getOrigin(): {\r\n    main: OriginConnectionPosition;\r\n    fallback: OriginConnectionPosition;\r\n  } {\r\n    const placement = this.placement;\r\n    let originPlacement: OriginConnectionPosition;\r\n\r\n    if (placement === 'top' || placement === 'bottom') {\r\n      originPlacement = {\r\n        originX: 'start',\r\n        originY: placement === 'top' ? 'top' : 'bottom'\r\n      };\r\n    } else if (placement === 'left') {\r\n      originPlacement = { originX: 'start', originY: 'center' };\r\n    } else if (placement === 'right') {\r\n      originPlacement = { originX: 'end', originY: 'center' };\r\n    } else {\r\n      console.error('Position error', placement);\r\n    }\r\n\r\n    const { x, y } = this._invertPosition(\r\n      originPlacement.originX,\r\n      originPlacement.originY\r\n    );\r\n\r\n    return {\r\n      main: originPlacement,\r\n      fallback: { originX: x, originY: y }\r\n    };\r\n  }\r\n\r\n  /** Returns the overlay position and a fallback position based on the user's preference */\r\n  private _getOverlayPosition(): {\r\n    main: OverlayConnectionPosition;\r\n    fallback: OverlayConnectionPosition;\r\n  } {\r\n    const placement = this.placement;\r\n    let overlayPlacement: OverlayConnectionPosition;\r\n\r\n    if (placement === 'top') {\r\n      overlayPlacement = { overlayX: 'start', overlayY: 'bottom' };\r\n    } else if (placement === 'bottom') {\r\n      overlayPlacement = { overlayX: 'start', overlayY: 'top' };\r\n    } else if (placement === 'left') {\r\n      overlayPlacement = { overlayX: 'end', overlayY: 'center' };\r\n    } else if (placement === 'right') {\r\n      overlayPlacement = { overlayX: 'start', overlayY: 'center' };\r\n    } else {\r\n      console.error('Could not find a position', placement);\r\n    }\r\n\r\n    const { x, y } = this._invertPosition(\r\n      overlayPlacement.overlayX,\r\n      overlayPlacement.overlayY\r\n    );\r\n\r\n    return {\r\n      main: overlayPlacement,\r\n      fallback: { overlayX: x, overlayY: y }\r\n    };\r\n  }\r\n\r\n  private _invertPosition(\r\n    x: HorizontalConnectionPos,\r\n    y: VerticalConnectionPos\r\n  ) {\r\n    if (this.placement === 'top' || this.placement === 'bottom') {\r\n      if (y === 'top') {\r\n        y = 'bottom';\r\n      } else if (y === 'bottom') {\r\n        y = 'top';\r\n      }\r\n    } else {\r\n      if (x === 'end') {\r\n        x = 'start';\r\n      } else if (x === 'start') {\r\n        x = 'end';\r\n      }\r\n    }\r\n\r\n    return { x, y };\r\n  }\r\n}\r\n"]}