UNPKG

ngx-materialize

Version:

An Angular wrap around Materialize library

197 lines (196 loc) 15.1 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import * as tslib_1 from "tslib"; import { Component, ElementRef, Input, Renderer, } from '@angular/core'; import { HandlePropChanges } from '../shared/index'; var MzDropdownComponent = /** @class */ (function (_super) { tslib_1.__extends(MzDropdownComponent, _super); function MzDropdownComponent(elementRef, renderer) { var _this = _super.call(this) || this; _this.elementRef = elementRef; _this.renderer = renderer; return _this; } /** * @return {?} */ MzDropdownComponent.prototype.ngAfterViewInit = /** * @return {?} */ function () { this.initHandlers(); this.initDropdownButtonElement(); this.handleProperties(); }; /** * @return {?} */ MzDropdownComponent.prototype.close = /** * @return {?} */ function () { var _this = this; setTimeout(function () { return _this.renderer.invokeElementMethod(_this.dropdownButtonElement, 'dropdown', ['close']); }); }; /** * @return {?} */ MzDropdownComponent.prototype.initDropdownButtonElement = /** * @return {?} */ function () { this.dropdownButtonElement = $("#" + this.dropdownButtonId); }; /** * @return {?} */ MzDropdownComponent.prototype.initHandlers = /** * @return {?} */ function () { var _this = this; this.handlers = { align: function () { return _this.handleDropdown(); }, belowOrigin: function () { return _this.handleDropdown(); }, constrainWidth: function () { return _this.handleDropdown(); }, dropdownButtonId: function () { return _this.handleDataActivates(); }, gutter: function () { return _this.handleDropdown(); }, hover: function () { return _this.handleDropdown(); }, id: function () { return _this.handleDropdown(); }, inDuration: function () { return _this.handleDropdown(); }, outDuration: function () { return _this.handleDropdown(); }, stopPropagation: function () { return _this.handleDropdown(); }, }; }; /** * @return {?} */ MzDropdownComponent.prototype.handleDataActivates = /** * @return {?} */ function () { this.renderer.setElementAttribute(this.dropdownButtonElement[0], 'data-activates', this.id); }; /** * @return {?} */ MzDropdownComponent.prototype.handleDropdown = /** * @return {?} */ function () { this.validateProperties(); var /** @type {?} */ options = { alignment: this.align, belowOrigin: this.belowOrigin, constrainWidth: this.constrainWidth, gutter: this.gutter, hover: this.hover, inDuration: this.inDuration, outDuration: this.outDuration, stopPropagation: this.stopPropagation, }; // Initialize dropdown button for dropdown this.renderer.invokeElementMethod(this.dropdownButtonElement, 'dropdown', [options]); }; /** * @return {?} */ MzDropdownComponent.prototype.handleProperties = /** * @return {?} */ function () { this.handleDataActivates(); this.handleDropdown(); }; /** * @return {?} */ MzDropdownComponent.prototype.open = /** * @return {?} */ function () { var _this = this; setTimeout(function () { return _this.renderer.invokeElementMethod(_this.dropdownButtonElement, 'dropdown', ['open']); }); }; /** * @return {?} */ MzDropdownComponent.prototype.validateProperties = /** * @return {?} */ function () { if (!this.id) { throw new Error('Attribute [id] from mz-dropdown is required. ' + this.elementRef.nativeElement); } if (this.dropdownButtonElement.length === 0) { throw new Error('Attribute [dropdownButtonId] from mz-dropdown is required and should be an existing element. ' + this.elementRef.nativeElement); } }; MzDropdownComponent.decorators = [ { type: Component, args: [{ selector: 'mz-dropdown', template: "<ul\n class=\"dropdown-content\"\n [attr.id]=\"id\"\n>\n <ng-content></ng-content>\n</ul>", styles: [""], },] }, ]; /** @nocollapse */ MzDropdownComponent.ctorParameters = function () { return [ { type: ElementRef, }, { type: Renderer, }, ]; }; MzDropdownComponent.propDecorators = { "align": [{ type: Input },], "belowOrigin": [{ type: Input },], "constrainWidth": [{ type: Input },], "dropdownButtonId": [{ type: Input },], "gutter": [{ type: Input },], "hover": [{ type: Input },], "id": [{ type: Input },], "inDuration": [{ type: Input },], "outDuration": [{ type: Input },], "stopPropagation": [{ type: Input },], }; return MzDropdownComponent; }(HandlePropChanges)); export { MzDropdownComponent }; function MzDropdownComponent_tsickle_Closure_declarations() { /** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */ MzDropdownComponent.decorators; /** * @nocollapse * @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>} */ MzDropdownComponent.ctorParameters; /** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */ MzDropdownComponent.propDecorators; /** @type {?} */ MzDropdownComponent.prototype.align; /** @type {?} */ MzDropdownComponent.prototype.belowOrigin; /** @type {?} */ MzDropdownComponent.prototype.constrainWidth; /** @type {?} */ MzDropdownComponent.prototype.dropdownButtonId; /** @type {?} */ MzDropdownComponent.prototype.gutter; /** @type {?} */ MzDropdownComponent.prototype.hover; /** @type {?} */ MzDropdownComponent.prototype.id; /** @type {?} */ MzDropdownComponent.prototype.inDuration; /** @type {?} */ MzDropdownComponent.prototype.outDuration; /** @type {?} */ MzDropdownComponent.prototype.stopPropagation; /** @type {?} */ MzDropdownComponent.prototype.dropdownButtonElement; /** @type {?} */ MzDropdownComponent.prototype.elementRef; /** @type {?} */ MzDropdownComponent.prototype.renderer; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"ng://ngx-materialize/","sources":["src/dropdown/dropdown.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  Component,\r\n  ElementRef,\r\n  Input,\r\n  Renderer,\r\n} from '@angular/core';\r\n\r\nimport { HandlePropChanges } from '../shared/index';\r\n\r\n@Component({\r\n  selector: 'mz-dropdown',\r\n  template: `<ul\r\n  class=\"dropdown-content\"\r\n  [attr.id]=\"id\"\r\n>\r\n  <ng-content></ng-content>\r\n</ul>`,\r\n  styles: [``],\r\n})\r\nexport class MzDropdownComponent extends HandlePropChanges implements AfterViewInit {\r\n  @Input() align: string;\r\n  @Input() belowOrigin: boolean;\r\n  @Input() constrainWidth: boolean;\r\n  @Input() dropdownButtonId: string;\r\n  @Input() gutter: number;\r\n  @Input() hover: boolean;\r\n  @Input() id: string;\r\n  @Input() inDuration: number;\r\n  @Input() outDuration: number;\r\n  @Input() stopPropagation: boolean;\r\n\r\n  dropdownButtonElement: JQuery;\r\n\r\n  constructor(private elementRef: ElementRef, private renderer: Renderer) {\r\n    super();\r\n   }\r\n\r\n  ngAfterViewInit() {\r\n    this.initHandlers();\r\n    this.initDropdownButtonElement();\r\n    this.handleProperties();\r\n  }\r\n\r\n  close() {\r\n    setTimeout(() => this.renderer.invokeElementMethod(this.dropdownButtonElement, 'dropdown', ['close']));\r\n  }\r\n\r\n  initDropdownButtonElement() {\r\n    this.dropdownButtonElement = $(`#${this.dropdownButtonId}`);\r\n  }\r\n\r\n  initHandlers() {\r\n    this.handlers = {\r\n      align: () => this.handleDropdown(),\r\n      belowOrigin: () => this.handleDropdown(),\r\n      constrainWidth: () => this.handleDropdown(),\r\n      dropdownButtonId: () => this.handleDataActivates(),\r\n      gutter: () => this.handleDropdown(),\r\n      hover: () => this.handleDropdown(),\r\n      id: () => this.handleDropdown(),\r\n      inDuration: () => this.handleDropdown(),\r\n      outDuration: () => this.handleDropdown(),\r\n      stopPropagation: () => this.handleDropdown(),\r\n    };\r\n  }\r\n\r\n  handleDataActivates() {\r\n    this.renderer.setElementAttribute(this.dropdownButtonElement[0], 'data-activates', this.id);\r\n  }\r\n\r\n  handleDropdown() {\r\n    this.validateProperties();\r\n\r\n    const options: Materialize.DropDownOptions = {\r\n      alignment: this.align,\r\n      belowOrigin: this.belowOrigin,\r\n      constrainWidth: this.constrainWidth,\r\n      gutter: this.gutter,\r\n      hover: this.hover,\r\n      inDuration: this.inDuration,\r\n      outDuration: this.outDuration,\r\n      stopPropagation: this.stopPropagation,\r\n    };\r\n\r\n    // Initialize dropdown button for dropdown\r\n    this.renderer.invokeElementMethod(this.dropdownButtonElement, 'dropdown', [options]);\r\n  }\r\n\r\n  handleProperties() {\r\n    this.handleDataActivates();\r\n    this.handleDropdown();\r\n  }\r\n\r\n  open() {\r\n    setTimeout(() => this.renderer.invokeElementMethod(this.dropdownButtonElement, 'dropdown', ['open']));\r\n  }\r\n\r\n  validateProperties() {\r\n    if (!this.id) {\r\n      throw new Error('Attribute [id] from mz-dropdown is required. ' + this.elementRef.nativeElement);\r\n    }\r\n\r\n    if (this.dropdownButtonElement.length === 0) {\r\n      throw new Error(\r\n        'Attribute [dropdownButtonId] from mz-dropdown is required and should be an existing element. ' +\r\n        this.elementRef.nativeElement);\r\n    }\r\n  }\r\n}\r\n"]}