@ngx-performance-ui/ui
Version:
Ngx Performance UI - UI
221 lines • 17.4 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Directive, ElementRef, Input, Renderer2, ViewContainerRef } from '@angular/core';
import { Select } from '@ngxs/store';
import { Observable } from 'rxjs';
import { createProjectableNode } from '../utils';
import { EventListenerState, takeUntilDestroy } from '@ngx-performance-ui/core';
import { filter } from 'rxjs/operators';
var DropdownDirective = /** @class */ (function () {
function DropdownDirective(renderer, elRef, vcRef) {
this.renderer = renderer;
this.elRef = elRef;
this.vcRef = vcRef;
this.show = false;
this.trigger = 'click';
}
Object.defineProperty(DropdownDirective.prototype, "pDropdown", {
get: /**
* @return {?}
*/
function () {
return this._pDropdown;
},
set: /**
* @param {?} v
* @return {?}
*/
function (v) {
this._pDropdown = v;
if (this.dropdownContainer)
this.remove();
this.view();
},
enumerable: true,
configurable: true
});
/**
* @private
* @return {?}
*/
DropdownDirective.prototype.subscribeToMouse = /**
* @private
* @return {?}
*/
function () {
var _this = this;
(this.trigger === 'mousemove' ? this.mousemove$ : this.click$)
.pipe(takeUntilDestroy(this), filter((/**
* @param {?} event
* @return {?}
*/
function (event) { return !!event; })))
.subscribe((/**
* @param {?} event
* @return {?}
*/
function (event) {
if (_this.elRef.nativeElement.contains(event.target)) {
if (_this.show) {
_this.hide();
}
else {
// this.renderer.removeClass(this.dropdownContainer, 'collapse-top');
_this.renderer.removeClass(_this.dropdownContainer, 'd-none');
_this.show = true;
}
}
else if (!_this.elRef.nativeElement.contains(event.target) &&
!_this.dropdownContainer.contains((/** @type {?} */ (event.target)))) {
_this.hide();
}
}));
};
/**
* @return {?}
*/
DropdownDirective.prototype.ngOnInit = /**
* @return {?}
*/
function () {
this.view();
this.subscribeToMouse();
};
/**
* @return {?}
*/
DropdownDirective.prototype.ngOnDestroy = /**
* @return {?}
*/
function () { };
/**
* @return {?}
*/
DropdownDirective.prototype.view = /**
* @return {?}
*/
function () {
var _this = this;
/** @type {?} */
var element = this.elRef.nativeElement;
/** @type {?} */
var elWidth = element.offsetWidth;
this.container = this.renderer.createElement('div');
this.renderer.setStyle(this.container, 'position', 'relative');
this.renderer.addClass(this.container, 'd-inline-block');
/** @type {?} */
var parent = this.renderer.parentNode(element);
this.renderer.appendChild(this.container, element);
this.dropdownContainer = this.renderer.createElement('div');
if (!this.show)
this.renderer.addClass(this.dropdownContainer, 'd-none');
this.renderer.addClass(this.dropdownContainer, 'card');
this.renderer.setStyle(this.dropdownContainer, 'position', 'absolute');
this.renderer.setStyle(this.dropdownContainer, 'min-width', elWidth + "px");
this.renderer.setStyle(this.dropdownContainer, 'padding', "1.25rem");
this.renderer.setStyle(this.dropdownContainer, 'z-index', "1000");
/** @type {?} */
var dropdownContentNode = createProjectableNode.call(this, this.pDropdown);
dropdownContentNode.forEach((/**
* @param {?} node
* @return {?}
*/
function (node) {
_this.renderer.appendChild(_this.dropdownContainer, node);
}));
this.renderer.appendChild(this.container, this.dropdownContainer);
this.renderer.appendChild(parent, this.container);
// this.renderer.addClass(this.dropdownContainer, 'expand-top');
};
/**
* @return {?}
*/
DropdownDirective.prototype.hide = /**
* @return {?}
*/
function () {
var _this = this;
// this.renderer.addClass(this.dropdownContainer, 'collapse-top');
setTimeout((/**
* @return {?}
*/
function () {
_this.renderer.addClass(_this.dropdownContainer, 'd-none');
}), 270);
this.show = false;
};
/**
* @return {?}
*/
DropdownDirective.prototype.remove = /**
* @return {?}
*/
function () {
this.dropdownContainer.remove();
};
DropdownDirective.decorators = [
{ type: Directive, args: [{
selector: '[pDropdown]',
exportAs: 'pDropdown',
},] }
];
/** @nocollapse */
DropdownDirective.ctorParameters = function () { return [
{ type: Renderer2 },
{ type: ElementRef },
{ type: ViewContainerRef }
]; };
DropdownDirective.propDecorators = {
pDropdown: [{ type: Input }],
show: [{ type: Input, args: ['pDropdownShowInitialize',] }],
trigger: [{ type: Input, args: ['pDropdownTrigger',] }]
};
tslib_1.__decorate([
Select(EventListenerState.getOne('mousemove')),
tslib_1.__metadata("design:type", Observable)
], DropdownDirective.prototype, "mousemove$", void 0);
tslib_1.__decorate([
Select(EventListenerState.getOne('click')),
tslib_1.__metadata("design:type", Observable)
], DropdownDirective.prototype, "click$", void 0);
return DropdownDirective;
}());
export { DropdownDirective };
if (false) {
/**
* @type {?}
* @private
*/
DropdownDirective.prototype._pDropdown;
/** @type {?} */
DropdownDirective.prototype.show;
/** @type {?} */
DropdownDirective.prototype.trigger;
/** @type {?} */
DropdownDirective.prototype.mousemove$;
/** @type {?} */
DropdownDirective.prototype.click$;
/** @type {?} */
DropdownDirective.prototype.container;
/** @type {?} */
DropdownDirective.prototype.dropdownContainer;
/**
* @type {?}
* @private
*/
DropdownDirective.prototype.renderer;
/**
* @type {?}
* @private
*/
DropdownDirective.prototype.elRef;
/**
* @type {?}
* @private
*/
DropdownDirective.prototype.vcRef;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.directive.js","sourceRoot":"ng://@ngx-performance-ui/ui/","sources":["lib/directives/dropdown.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Input, Renderer2, ViewContainerRef, TemplateRef, Type } from '@angular/core';\nimport { Select } from '@ngxs/store';\nimport { Observable } from 'rxjs';\nimport { createProjectableNode } from '../utils';\nimport { EventListenerState, takeUntilDestroy } from '@ngx-performance-ui/core';\nimport { filter } from 'rxjs/operators';\n\n@Directive({\n  selector: '[pDropdown]',\n  exportAs: 'pDropdown',\n})\nexport class DropdownDirective {\n  private _pDropdown: string | TemplateRef<any> | Type<any>;\n\n  @Input()\n  set pDropdown(v: string | TemplateRef<any> | Type<any>) {\n    this._pDropdown = v;\n\n    if (this.dropdownContainer) this.remove();\n    this.view();\n  }\n  get pDropdown() {\n    return this._pDropdown;\n  }\n\n  @Input('pDropdownShowInitialize')\n  show: boolean = false;\n\n  @Input('pDropdownTrigger')\n  trigger: 'mousemove' | 'click' = 'click';\n\n  @Select(EventListenerState.getOne('mousemove'))\n  mousemove$: Observable<MouseEvent>;\n\n  @Select(EventListenerState.getOne('click'))\n  click$: Observable<MouseEvent>;\n\n  container: HTMLElement;\n  dropdownContainer: HTMLElement;\n\n  constructor(private renderer: Renderer2, private elRef: ElementRef, private vcRef: ViewContainerRef) {}\n  private subscribeToMouse() {\n    (this.trigger === 'mousemove' ? this.mousemove$ : this.click$)\n      .pipe(\n        takeUntilDestroy(this),\n        filter(event => !!event),\n      )\n      .subscribe(event => {\n        if (this.elRef.nativeElement.contains(event.target)) {\n          if (this.show) {\n            this.hide();\n          } else {\n            // this.renderer.removeClass(this.dropdownContainer, 'collapse-top');\n            this.renderer.removeClass(this.dropdownContainer, 'd-none');\n            this.show = true;\n          }\n        } else if (\n          !this.elRef.nativeElement.contains(event.target) &&\n          !this.dropdownContainer.contains(event.target as Node)\n        ) {\n          this.hide();\n        }\n      });\n  }\n\n  ngOnInit(): void {\n    this.view();\n    this.subscribeToMouse();\n  }\n\n  ngOnDestroy(): void {}\n\n  view() {\n    const element: HTMLElement = this.elRef.nativeElement;\n    const elWidth = element.offsetWidth;\n\n    this.container = this.renderer.createElement('div');\n    this.renderer.setStyle(this.container, 'position', 'relative');\n    this.renderer.addClass(this.container, 'd-inline-block');\n    const parent = this.renderer.parentNode(element);\n    this.renderer.appendChild(this.container, element);\n\n    this.dropdownContainer = this.renderer.createElement('div');\n\n    if (!this.show) this.renderer.addClass(this.dropdownContainer, 'd-none');\n\n    this.renderer.addClass(this.dropdownContainer, 'card');\n    this.renderer.setStyle(this.dropdownContainer, 'position', 'absolute');\n    this.renderer.setStyle(this.dropdownContainer, 'min-width', `${elWidth}px`);\n    this.renderer.setStyle(this.dropdownContainer, 'padding', `1.25rem`);\n    this.renderer.setStyle(this.dropdownContainer, 'z-index', `1000`);\n\n    const dropdownContentNode = createProjectableNode.call(this, this.pDropdown);\n    dropdownContentNode.forEach(node => {\n      this.renderer.appendChild(this.dropdownContainer, node);\n    });\n\n    this.renderer.appendChild(this.container, this.dropdownContainer);\n    this.renderer.appendChild(parent, this.container);\n\n    // this.renderer.addClass(this.dropdownContainer, 'expand-top');\n  }\n\n  hide() {\n    // this.renderer.addClass(this.dropdownContainer, 'collapse-top');\n    setTimeout(() => {\n      this.renderer.addClass(this.dropdownContainer, 'd-none');\n    }, 270);\n    this.show = false;\n  }\n\n  remove() {\n    this.dropdownContainer.remove();\n  }\n}\n"]}