UNPKG

ngx-materialize

Version:

An Angular wrap around Materialize library

141 lines (140 loc) 14.6 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'; export class MzSelectContainerComponent { /** * @return {?} */ ngAfterViewInit() { this.initControlSubscription(); this.initSelectSubscription(); } /** * @return {?} */ ngOnDestroy() { this.removeControlSubscription(); this.removeSelectSubscription(); } /** * @return {?} */ initControlSubscription() { if (this.ngControl) { this.mzSelectDirective.disabled = this.ngControl.control.disabled; this.statusChangesSubscription = this.ngControl.control.statusChanges.subscribe((status) => { // to handle enabling/disabling formControl const /** @type {?} */ disabled = status === 'DISABLED'; if (disabled !== this.mzSelectDirective.disabled) { this.mzSelectDirective.disabled = disabled; this.mzSelectDirective.handleDisabled(); } }); this.selectValueSubscription = this.ngControl.valueChanges.subscribe((value) => { // to synchronize input and select when value changes programmatically const /** @type {?} */ isDropdownOpen = this.mzSelectDirective.inputElement.hasClass('active'); const /** @type {?} */ inputValue = this.mzSelectDirective.inputElement.val(); const /** @type {?} */ options = this.mzSelectDirective.selectElement.children('option'); const /** @type {?} */ selectedOptions = options.filter('option:selected').toArray(); const /** @type {?} */ disabledOptions = options.filter(':disabled').toArray(); const /** @type {?} */ selectedOptionText = selectedOptions.length === 0 ? disabledOptions.map(option => option.textContent)[0] : selectedOptions.map(option => option.textContent).join(', '); if (inputValue !== selectedOptionText && !isDropdownOpen) { this.mzSelectDirective.updateMaterialSelect(); } }); } } /** * @return {?} */ initSelectSubscription() { if (this.mzSelectDirective) { this.mzSelectDirective.update .subscribe(() => this.registerOnBlur()) .next(); } } /** * @return {?} */ registerOnBlur() { this.mzSelectDirective.inputElement.on('blur', () => { if (this.ngControl) { this.ngControl.control.markAsTouched(); } if (this.mzValidationComponent) { this.mzValidationComponent.setValidationState(); } }); } /** * @return {?} */ removeControlSubscription() { if (this.mzSelectDirective) { this.mzSelectDirective.update.unsubscribe(); this.mzSelectDirective.inputElement.off(); } } /** * @return {?} */ removeSelectSubscription() { if (this.statusChangesSubscription) { this.statusChangesSubscription.unsubscribe(); } if (this.selectValueSubscription) { this.selectValueSubscription.unsubscribe(); } } } MzSelectContainerComponent.decorators = [ { type: Component, args: [{ selector: 'mz-select-container', template: `<div class="input-field" [class.inline]="inline" > <ng-content></ng-content> </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,] },], }; 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"]}