UNPKG

ngx-materialize

Version:

An Angular wrap around Materialize library

164 lines (163 loc) 15.8 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import { Component, ContentChild, Input } from '@angular/core'; import { NgControl } from '@angular/forms'; import { MzValidationComponent } from '../../validation/validation.component'; import { MzSelectDirective } from '../select.directive'; var MzSelectContainerComponent = /** @class */ (function () { function MzSelectContainerComponent() { } /** * @return {?} */ MzSelectContainerComponent.prototype.ngAfterViewInit = /** * @return {?} */ function () { this.initControlSubscription(); this.initSelectSubscription(); }; /** * @return {?} */ MzSelectContainerComponent.prototype.ngOnDestroy = /** * @return {?} */ function () { this.removeControlSubscription(); this.removeSelectSubscription(); }; /** * @return {?} */ MzSelectContainerComponent.prototype.initControlSubscription = /** * @return {?} */ function () { var _this = this; if (this.ngControl) { this.mzSelectDirective.disabled = this.ngControl.control.disabled; this.statusChangesSubscription = this.ngControl.control.statusChanges.subscribe(function (status) { // to handle enabling/disabling formControl var /** @type {?} */ disabled = status === 'DISABLED'; if (disabled !== _this.mzSelectDirective.disabled) { _this.mzSelectDirective.disabled = disabled; _this.mzSelectDirective.handleDisabled(); } }); this.selectValueSubscription = this.ngControl.valueChanges.subscribe(function (value) { // to synchronize input and select when value changes programmatically var /** @type {?} */ isDropdownOpen = _this.mzSelectDirective.inputElement.hasClass('active'); var /** @type {?} */ inputValue = _this.mzSelectDirective.inputElement.val(); var /** @type {?} */ options = _this.mzSelectDirective.selectElement.children('option'); var /** @type {?} */ selectedOptions = options.filter('option:selected').toArray(); var /** @type {?} */ disabledOptions = options.filter(':disabled').toArray(); var /** @type {?} */ selectedOptionText = selectedOptions.length === 0 ? disabledOptions.map(function (option) { return option.textContent; })[0] : selectedOptions.map(function (option) { return option.textContent; }).join(', '); if (inputValue !== selectedOptionText && !isDropdownOpen) { _this.mzSelectDirective.updateMaterialSelect(); } }); } }; /** * @return {?} */ MzSelectContainerComponent.prototype.initSelectSubscription = /** * @return {?} */ function () { var _this = this; if (this.mzSelectDirective) { this.mzSelectDirective.update .subscribe(function () { return _this.registerOnBlur(); }) .next(); } }; /** * @return {?} */ MzSelectContainerComponent.prototype.registerOnBlur = /** * @return {?} */ function () { var _this = this; this.mzSelectDirective.inputElement.on('blur', function () { if (_this.ngControl) { _this.ngControl.control.markAsTouched(); } if (_this.mzValidationComponent) { _this.mzValidationComponent.setValidationState(); } }); }; /** * @return {?} */ MzSelectContainerComponent.prototype.removeControlSubscription = /** * @return {?} */ function () { if (this.mzSelectDirective) { this.mzSelectDirective.update.unsubscribe(); this.mzSelectDirective.inputElement.off(); } }; /** * @return {?} */ MzSelectContainerComponent.prototype.removeSelectSubscription = /** * @return {?} */ function () { if (this.statusChangesSubscription) { this.statusChangesSubscription.unsubscribe(); } if (this.selectValueSubscription) { this.selectValueSubscription.unsubscribe(); } }; MzSelectContainerComponent.decorators = [ { type: Component, args: [{ selector: 'mz-select-container', template: "<div\n class=\"input-field\"\n [class.inline]=\"inline\"\n>\n <ng-content></ng-content>\n</div>", styles: [".input-field:not(.inline){display:block}/deep/ .input-field .dropdown-content [type=checkbox]+label{top:-11px}"], },] }, ]; /** @nocollapse */ MzSelectContainerComponent.propDecorators = { "inline": [{ type: Input },], "mzSelectDirective": [{ type: ContentChild, args: [MzSelectDirective,] },], "mzValidationComponent": [{ type: ContentChild, args: [MzValidationComponent,] },], "ngControl": [{ type: ContentChild, args: [NgControl,] },], }; return MzSelectContainerComponent; }()); export { MzSelectContainerComponent }; function MzSelectContainerComponent_tsickle_Closure_declarations() { /** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */ MzSelectContainerComponent.decorators; /** * @nocollapse * @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>} */ MzSelectContainerComponent.ctorParameters; /** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */ MzSelectContainerComponent.propDecorators; /** @type {?} */ MzSelectContainerComponent.prototype.inline; /** @type {?} */ MzSelectContainerComponent.prototype.mzSelectDirective; /** @type {?} */ MzSelectContainerComponent.prototype.mzValidationComponent; /** @type {?} */ MzSelectContainerComponent.prototype.ngControl; /** @type {?} */ MzSelectContainerComponent.prototype.selectValueSubscription; /** @type {?} */ MzSelectContainerComponent.prototype.statusChangesSubscription; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-container.component.js","sourceRoot":"ng://ngx-materialize/","sources":["src/select/select-container/select-container.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ContentChild, Input, OnDestroy } from '@angular/core';\r\nimport { NgControl } from '@angular/forms';\r\nimport { Subscription } from 'rxjs';\r\n\r\nimport { MzValidationComponent } from '../../validation/validation.component';\r\nimport { MzSelectDirective } from '../select.directive';\r\n\r\n@Component({\r\n  selector: 'mz-select-container',\r\n  template: `<div\r\n  class=\"input-field\"\r\n  [class.inline]=\"inline\"\r\n>\r\n  <ng-content></ng-content>\r\n</div>`,\r\n  styles: [`.input-field:not(.inline){display:block}/deep/ .input-field .dropdown-content [type=checkbox]+label{top:-11px}`],\r\n})\r\nexport class MzSelectContainerComponent implements AfterViewInit, OnDestroy {\r\n  @Input() inline: boolean;\r\n\r\n  @ContentChild(MzSelectDirective) mzSelectDirective: MzSelectDirective;\r\n  @ContentChild(MzValidationComponent) mzValidationComponent: MzValidationComponent;\r\n  @ContentChild(NgControl) ngControl: NgControl;\r\n\r\n  selectValueSubscription: Subscription;\r\n  statusChangesSubscription: Subscription;\r\n\r\n  ngAfterViewInit() {\r\n    this.initControlSubscription();\r\n    this.initSelectSubscription();\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.removeControlSubscription();\r\n    this.removeSelectSubscription();\r\n  }\r\n\r\n  initControlSubscription() {\r\n    if (this.ngControl) {\r\n      this.mzSelectDirective.disabled = this.ngControl.control.disabled;\r\n\r\n      this.statusChangesSubscription = this.ngControl.control.statusChanges.subscribe((status: string) => {\r\n        // to handle enabling/disabling formControl\r\n        const disabled = status === 'DISABLED';\r\n        if (disabled !== this.mzSelectDirective.disabled) {\r\n          this.mzSelectDirective.disabled = disabled;\r\n          this.mzSelectDirective.handleDisabled();\r\n        }\r\n      });\r\n\r\n      this.selectValueSubscription = this.ngControl.valueChanges.subscribe((value: any) => {\r\n        // to synchronize input and select when value changes programmatically\r\n        const isDropdownOpen = this.mzSelectDirective.inputElement.hasClass('active');\r\n        const inputValue = this.mzSelectDirective.inputElement.val();\r\n        const options = this.mzSelectDirective.selectElement.children('option');\r\n        const selectedOptions = options.filter('option:selected').toArray();\r\n        const disabledOptions = options.filter(':disabled').toArray();\r\n\r\n        const selectedOptionText = selectedOptions.length === 0\r\n          ? disabledOptions.map(option => option.textContent)[0]\r\n          : selectedOptions.map(option => option.textContent).join(', ');\r\n\r\n        if (inputValue !== selectedOptionText && !isDropdownOpen) {\r\n          this.mzSelectDirective.updateMaterialSelect();\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  initSelectSubscription() {\r\n    if (this.mzSelectDirective) {\r\n      this.mzSelectDirective.update\r\n        .subscribe(() => this.registerOnBlur())\r\n        .next();\r\n    }\r\n  }\r\n\r\n  registerOnBlur() {\r\n    this.mzSelectDirective.inputElement.on('blur', () => {\r\n      if (this.ngControl) {\r\n        this.ngControl.control.markAsTouched();\r\n      }\r\n      if (this.mzValidationComponent) {\r\n        this.mzValidationComponent.setValidationState();\r\n      }\r\n    });\r\n  }\r\n\r\n  removeControlSubscription() {\r\n    if (this.mzSelectDirective) {\r\n      this.mzSelectDirective.update.unsubscribe();\r\n      this.mzSelectDirective.inputElement.off();\r\n    }\r\n  }\r\n\r\n  removeSelectSubscription() {\r\n    if (this.statusChangesSubscription) {\r\n      this.statusChangesSubscription.unsubscribe();\r\n    }\r\n    if (this.selectValueSubscription) {\r\n      this.selectValueSubscription.unsubscribe();\r\n    }\r\n  }\r\n}\r\n"]}