ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
277 lines • 19.5 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { ContentChildren, Component, QueryList, Input, forwardRef, HostListener, Output, EventEmitter, HostBinding } from '@angular/core';
import { AccordionService } from './accordion.service';
import { AccordionGroupComponent } from './accordion-group/accordion-group.component';
var AccordionComponent = /** @class */ (function () {
function AccordionComponent(_accordionService) {
this._accordionService = _accordionService;
this.isFirstChange = true;
this.expandAll = false;
this.openAnimation = {};
this.accordion = false;
this.onChange = new EventEmitter();
this.amAccordion = true;
this._accordionService.getComponent(this);
}
/**
* @return {?}
*/
AccordionComponent.prototype.click = /**
* @return {?}
*/
function () {
var _this = this;
/** @type {?} */
var result = [];
this.groups.toArray().forEach((/**
* @param {?} group
* @return {?}
*/
function (group) {
if (group.isOpened) {
if (_this.accordion) {
result = group.key;
}
else {
result.push(group.key);
}
}
}));
this.onChange.emit(result);
};
/**
* @return {?}
*/
AccordionComponent.prototype.closeAll = /**
* @return {?}
*/
function () {
this.groups.toArray().forEach((/**
* @param {?} group
* @return {?}
*/
function (group) {
group.isOpened = false;
}));
};
/**
* @return {?}
*/
AccordionComponent.prototype.init = /**
* @return {?}
*/
function () {
var _this = this;
if (this.expandAll && this.groups && this.groups.length > 0) {
this._oldGroups = this.groups.toArray();
this._oldGroups.forEach((/**
* @param {?} group
* @return {?}
*/
function (group) {
group.openOnInitialization();
}));
this._subscription = this.groups.changes.subscribe((/**
* @param {?} change
* @return {?}
*/
function (change) {
/** @type {?} */
var newGroups = _this.groups.toArray().filter((/**
* @param {?} group
* @return {?}
*/
function (group) {
return _this._oldGroups.indexOf(group) === -1;
}));
newGroups.forEach((/**
* @param {?} group
* @return {?}
*/
function (group) {
group.openOnInitialization();
}));
_this._oldGroups = _this.groups.toArray();
}));
}
/** @type {?} */
var currentActiveKey = [];
if (this.activeKey && this.activeKey.length > 0) {
currentActiveKey = this.toArray(this.activeKey);
if (this.accordion) {
currentActiveKey = currentActiveKey.slice(0, 1);
}
}
else if (this.defaultActiveKey) {
currentActiveKey = [this.defaultActiveKey];
}
if (this.groups && this.groups.length > 0) {
this.groups.forEach((/**
* @param {?} group
* @param {?} index
* @return {?}
*/
function (group, index) {
currentActiveKey.forEach((/**
* @param {?} key
* @return {?}
*/
function (key) {
if (index === parseInt(key, 0)) {
setTimeout((/**
* @return {?}
*/
function () {
group.isOpened = true;
group.openOnInitialization();
}), 0);
}
}));
}));
}
};
/**
* @param {?} activeKey
* @return {?}
*/
AccordionComponent.prototype.toArray = /**
* @param {?} activeKey
* @return {?}
*/
function (activeKey) {
/** @type {?} */
var currentActiveKey = activeKey;
if (!Array.isArray(currentActiveKey)) {
currentActiveKey = currentActiveKey !== undefined && currentActiveKey !== '' ? [currentActiveKey] : [];
}
return currentActiveKey;
};
/**
* @param {?} changes
* @return {?}
*/
AccordionComponent.prototype.ngOnChanges = /**
* @param {?} changes
* @return {?}
*/
function (changes) {
if (changes.accordion) {
this._accordionService.getComponent(this);
}
if (changes.expandAll || changes.accordion) {
this.init();
}
};
/**
* @return {?}
*/
AccordionComponent.prototype.ngAfterContentInit = /**
* @return {?}
*/
function () {
var _this = this;
if (this.groups && this.groups.length > 0) {
this.init();
}
else {
this.groupsSubscription = this.groups.changes.subscribe((/**
* @param {?} group
* @return {?}
*/
function (group) {
if (_this.isFirstChange) {
_this.init();
}
_this.isFirstChange = false;
}));
}
};
/**
* @return {?}
*/
AccordionComponent.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
if (this._subscription) {
this._subscription.unsubscribe();
}
if (this.groupsSubscription) {
this.groupsSubscription.unsubscribe();
}
};
AccordionComponent.decorators = [
{ type: Component, args: [{
selector: 'Accordion, nzm-accordion',
template: "<ng-content></ng-content>\n",
providers: [AccordionService]
}] }
];
/** @nocollapse */
AccordionComponent.ctorParameters = function () { return [
{ type: AccordionService }
]; };
AccordionComponent.propDecorators = {
groups: [{ type: ContentChildren, args: [forwardRef((/**
* @return {?}
*/
function () { return AccordionGroupComponent; })),] }],
expandAll: [{ type: Input }],
activeKey: [{ type: Input }],
defaultActiveKey: [{ type: Input }],
openAnimation: [{ type: Input }],
accordion: [{ type: Input }],
onChange: [{ type: Output }],
amAccordion: [{ type: HostBinding, args: ['class.am-accordion',] }],
click: [{ type: HostListener, args: ['click',] }]
};
return AccordionComponent;
}());
export { AccordionComponent };
if (false) {
/**
* @type {?}
* @private
*/
AccordionComponent.prototype._oldGroups;
/**
* @type {?}
* @private
*/
AccordionComponent.prototype._subscription;
/**
* @type {?}
* @private
*/
AccordionComponent.prototype.groupsSubscription;
/**
* @type {?}
* @private
*/
AccordionComponent.prototype.isFirstChange;
/** @type {?} */
AccordionComponent.prototype.groups;
/** @type {?} */
AccordionComponent.prototype.expandAll;
/** @type {?} */
AccordionComponent.prototype.activeKey;
/** @type {?} */
AccordionComponent.prototype.defaultActiveKey;
/** @type {?} */
AccordionComponent.prototype.openAnimation;
/** @type {?} */
AccordionComponent.prototype.accordion;
/** @type {?} */
AccordionComponent.prototype.onChange;
/** @type {?} */
AccordionComponent.prototype.amAccordion;
/**
* @type {?}
* @private
*/
AccordionComponent.prototype._accordionService;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"accordion.component.js","sourceRoot":"ng://ng-zorro-antd-mobile/","sources":["accordion/accordion.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ContentChildren,\n  Component,\n  QueryList,\n  Input,\n  forwardRef,\n  AfterContentInit,\n  OnDestroy,\n  HostListener,\n  Output,\n  EventEmitter,\n  OnChanges,\n  SimpleChanges,\n  HostBinding\n} from '@angular/core';\nimport { AccordionService } from './accordion.service';\nimport { AccordionGroupComponent } from './accordion-group/accordion-group.component';\nimport { Subscription } from 'rxjs';\n\n@Component({\n  selector: 'Accordion, nzm-accordion',\n  templateUrl: './accordion.component.html',\n  providers: [AccordionService]\n})\nexport class AccordionComponent implements AfterContentInit, OnDestroy, OnChanges {\n  private _oldGroups: AccordionGroupComponent[];\n  private _subscription: Subscription;\n  private groupsSubscription: Subscription;\n  private isFirstChange: boolean = true;\n\n  @ContentChildren(forwardRef(() => AccordionGroupComponent))\n  groups: QueryList<AccordionGroupComponent>;\n\n  @Input()\n  expandAll = false;\n  @Input()\n  activeKey: Array<string> | string;\n  @Input()\n  defaultActiveKey: string;\n  @Input()\n  openAnimation = {};\n  @Input()\n  accordion = false;\n  @Output()\n  onChange: any = new EventEmitter();\n\n  @HostBinding('class.am-accordion')\n  amAccordion: boolean = true;\n\n  @HostListener('click')\n  click() {\n    let result: any = [];\n    this.groups.toArray().forEach(group => {\n      if (group.isOpened) {\n        if (this.accordion) {\n          result = group.key;\n        } else {\n          result.push(group.key);\n        }\n      }\n    });\n    this.onChange.emit(result);\n  }\n\n  constructor(private _accordionService: AccordionService) {\n    this._accordionService.getComponent(this);\n  }\n\n  closeAll() {\n    this.groups.toArray().forEach(group => {\n      group.isOpened = false;\n    });\n  }\n\n  init() {\n    if (this.expandAll && this.groups && this.groups.length > 0) {\n      this._oldGroups = this.groups.toArray();\n      this._oldGroups.forEach((group) => {\n        group.openOnInitialization();\n      });\n      this._subscription = this.groups.changes.subscribe(change => {\n        const newGroups = this.groups.toArray().filter(group => {\n          return this._oldGroups.indexOf(group) === -1;\n        });\n        newGroups.forEach(group => {\n          group.openOnInitialization();\n        });\n        this._oldGroups = this.groups.toArray();\n      });\n    }\n\n    let currentActiveKey: Array<any> = [];\n    if (this.activeKey && this.activeKey.length > 0) {\n      currentActiveKey = this.toArray(this.activeKey);\n      if (this.accordion) {\n        currentActiveKey = currentActiveKey.slice(0, 1);\n      }\n    } else if (this.defaultActiveKey) {\n      currentActiveKey = [this.defaultActiveKey];\n    }\n    if (this.groups && this.groups.length > 0) {\n      this.groups.forEach((group, index) => {\n        currentActiveKey.forEach(key => {\n          if (index === parseInt(key, 0)) {\n            setTimeout(() => {\n              group.isOpened = true;\n              group.openOnInitialization();\n            }, 0);\n          }\n        });\n      });\n    }\n  }\n\n  toArray(activeKey) {\n    let currentActiveKey = activeKey;\n    if (!Array.isArray(currentActiveKey)) {\n      currentActiveKey = currentActiveKey !== undefined && currentActiveKey !== '' ? [currentActiveKey] : [];\n    }\n    return currentActiveKey;\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.accordion) {\n      this._accordionService.getComponent(this);\n    }\n\n    if (changes.expandAll || changes.accordion) {\n      this.init();\n    }\n  }\n\n  ngAfterContentInit() {\n    if (this.groups && this.groups.length > 0) {\n      this.init();\n    } else {\n      this.groupsSubscription = this.groups.changes.subscribe(group => {\n        if (this.isFirstChange) {\n          this.init();\n        }\n        this.isFirstChange = false;\n      });\n    }\n  }\n\n  ngOnDestroy() {\n    if (this._subscription) {\n      this._subscription.unsubscribe();\n    }\n    if (this.groupsSubscription) {\n      this.groupsSubscription.unsubscribe();\n    }\n  }\n}\n"]}