ngx-materialize
Version:
An Angular wrap around Materialize library
141 lines (140 loc) • 14.6 kB
JavaScript
/**
* @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"]}