ngx-materialize
Version:
An Angular wrap around Materialize library
197 lines (196 loc) • 15.1 kB
JavaScript
/**
* @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":";;;;;AAAA,OAAO,EAEL,SAAS,EACT,UAAU,EACV,KAAK,EACL,QAAQ,GACT,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;;IAYX,+CAAiB;IAcxD,6BAAoB,UAAsB,EAAU,QAAkB;QAAtE,YACE,iBAAO,SACP;QAFkB,gBAAU,GAAV,UAAU,CAAY;QAAU,cAAQ,GAAR,QAAQ,CAAU;;KAEpE;;;;IAEF,6CAAe;;;IAAf;QACE,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,IAAI,CAAC,yBAAyB,EAAE,CAAC;QACjC,IAAI,CAAC,gBAAgB,EAAE,CAAC;KACzB;;;;IAED,mCAAK;;;IAAL;QAAA,iBAEC;QADC,UAAU,CAAC,cAAM,OAAA,KAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,KAAI,CAAC,qBAAqB,EAAE,UAAU,EAAE,CAAC,OAAO,CAAC,CAAC,EAApF,CAAoF,CAAC,CAAC;KACxG;;;;IAED,uDAAyB;;;IAAzB;QACE,IAAI,CAAC,qBAAqB,GAAG,CAAC,CAAC,MAAI,IAAI,CAAC,gBAAkB,CAAC,CAAC;KAC7D;;;;IAED,0CAAY;;;IAAZ;QAAA,iBAaC;QAZC,IAAI,CAAC,QAAQ,GAAG;YACd,KAAK,EAAE,cAAM,OAAA,KAAI,CAAC,cAAc,EAAE,EAArB,CAAqB;YAClC,WAAW,EAAE,cAAM,OAAA,KAAI,CAAC,cAAc,EAAE,EAArB,CAAqB;YACxC,cAAc,EAAE,cAAM,OAAA,KAAI,CAAC,cAAc,EAAE,EAArB,CAAqB;YAC3C,gBAAgB,EAAE,cAAM,OAAA,KAAI,CAAC,mBAAmB,EAAE,EAA1B,CAA0B;YAClD,MAAM,EAAE,cAAM,OAAA,KAAI,CAAC,cAAc,EAAE,EAArB,CAAqB;YACnC,KAAK,EAAE,cAAM,OAAA,KAAI,CAAC,cAAc,EAAE,EAArB,CAAqB;YAClC,EAAE,EAAE,cAAM,OAAA,KAAI,CAAC,cAAc,EAAE,EAArB,CAAqB;YAC/B,UAAU,EAAE,cAAM,OAAA,KAAI,CAAC,cAAc,EAAE,EAArB,CAAqB;YACvC,WAAW,EAAE,cAAM,OAAA,KAAI,CAAC,cAAc,EAAE,EAArB,CAAqB;YACxC,eAAe,EAAE,cAAM,OAAA,KAAI,CAAC,cAAc,EAAE,EAArB,CAAqB;SAC7C,CAAC;KACH;;;;IAED,iDAAmB;;;IAAnB;QACE,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAAC,EAAE,gBAAgB,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;KAC7F;;;;IAED,4CAAc;;;IAAd;QACE,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAE1B,qBAAM,OAAO,GAAgC;YAC3C,SAAS,EAAE,IAAI,CAAC,KAAK;YACrB,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,cAAc,EAAE,IAAI,CAAC,cAAc;YACnC,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,UAAU,EAAE,IAAI,CAAC,UAAU;YAC3B,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,eAAe,EAAE,IAAI,CAAC,eAAe;SACtC,CAAC;;QAGF,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,IAAI,CAAC,qBAAqB,EAAE,UAAU,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC;KACtF;;;;IAED,8CAAgB;;;IAAhB;QACE,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC3B,IAAI,CAAC,cAAc,EAAE,CAAC;KACvB;;;;IAED,kCAAI;;;IAAJ;QAAA,iBAEC;QADC,UAAU,CAAC,cAAM,OAAA,KAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,KAAI,CAAC,qBAAqB,EAAE,UAAU,EAAE,CAAC,MAAM,CAAC,CAAC,EAAnF,CAAmF,CAAC,CAAC;KACvG;;;;IAED,gDAAkB;;;IAAlB;QACE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;YACb,MAAM,IAAI,KAAK,CAAC,+CAA+C,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;SAClG;QAED,EAAE,CAAC,CAAC,IAAI,CAAC,qBAAqB,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC;YAC5C,MAAM,IAAI,KAAK,CACb,+FAA+F;gBAC/F,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;SAClC;KACF;;gBAlGF,SAAS,SAAC;oBACT,QAAQ,EAAE,aAAa;oBACvB,QAAQ,EAAE,8FAKN;oBACJ,MAAM,EAAE,CAAC,EAAE,CAAC;iBACb;;;;gBAhBC,UAAU;gBAEV,QAAQ;;;0BAgBP,KAAK;gCACL,KAAK;mCACL,KAAK;qCACL,KAAK;2BACL,KAAK;0BACL,KAAK;uBACL,KAAK;+BACL,KAAK;gCACL,KAAK;oCACL,KAAK;;8BA9BR;EAoByC,iBAAiB;SAA7C,mBAAmB","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"]}