ngx-materialize
Version:
An Angular wrap around Materialize library
164 lines (163 loc) • 15.8 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';
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"]}