ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
112 lines • 15.1 kB
JavaScript
import { Component, Input, ChangeDetectorRef, Output, EventEmitter, ViewEncapsulation, HostBinding } from '@angular/core';
import { animate, state, style, transition, trigger } from '@angular/animations';
import { AccordionService } from '../accordion.service';
import { isTemplateRef } from 'ng-zorro-antd-mobile/core';
import * as i0 from "@angular/core";
import * as i1 from "../accordion.service";
import * as i2 from "@angular/common";
export class AccordionGroupComponent {
constructor(_accordionService, _cdr) {
this._accordionService = _accordionService;
this._cdr = _cdr;
this.isShowChild = true;
this.isOpened = false;
this.disabled = false;
this.onOpen = new EventEmitter();
this.onClose = new EventEmitter();
this.onChange = new EventEmitter();
this.isTemplateRef = isTemplateRef;
this.amItem = true;
this.isActive = this.isOpened;
this.addon = true;
}
checkAndToggle() {
this.toggle();
}
get slide() {
return this.isOpened ? 'down' : 'up';
}
toggle() {
if (this.disabled) {
return;
}
this.isShowChild = true;
const isOpenedBeforeWeChange = this.isOpened;
if (this._accordionService.accordion) {
this._accordionService.component.closeAll();
}
this.isOpened = !isOpenedBeforeWeChange;
if (this.isOpened) {
this.onOpen.emit();
}
else {
this.onClose.emit();
}
this.onChange.emit(this.isOpened);
}
openOnInitialization() {
setTimeout(() => {
this.isOpened = true;
this._cdr.detectChanges();
}, 0);
}
slideAnimationDoen(event) {
if (event.fromState === 'down' && event.toState === 'up') {
setTimeout(() => {
this.isShowChild = false;
}, 0);
}
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: AccordionGroupComponent, deps: [{ token: i1.AccordionService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: AccordionGroupComponent, selector: "AccordionPanel, nzm-accordion-panel", inputs: { key: "key", header: "header", isOpened: "isOpened", disabled: "disabled" }, outputs: { onOpen: "onOpen", onClose: "onClose", onChange: "onChange" }, host: { properties: { "class.am-accordion-item": "this.amItem", "class.am-accordion-item-active": "this.isActive", "class.addon": "this.addon" } }, ngImport: i0, template: "<div\n role=\"tab\"\n class=\"am-accordion-header\"\n data-scale=\"true\"\n [attr.aria-expanded]=\"isOpened\"\n (click)=\"checkAndToggle()\"\n>\n <i class=\"arrow\"></i>\n <ng-container *ngIf=\"!isTemplateRef(header)\">{{ header }}</ng-container>\n <ng-template *ngIf=\"isTemplateRef(header)\" [ngTemplateOutlet]=\"header\"></ng-template>\n</div>\n<div\n role=\"tabpanel\"\n class=\"am-accordion-content\"\n [ngClass]=\"{ 'am-accordion-content-active': isOpened }\"\n [@slide]=\"slide\"\n (@slide.done)=\"slideAnimationDoen($event)\"\n>\n <div *ngIf=\"isShowChild\" class=\"am-accordion-content-box\">\n <ng-content></ng-content>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], animations: [
trigger('slide', [
state('up', style({ height: 0 })),
state('down', style({ height: '*' })),
transition('down => up', [animate(200, style({ height: 0 }))]),
transition('up => down', [
animate(200, style({
height: '*'
}))
])
])
], encapsulation: i0.ViewEncapsulation.None }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: AccordionGroupComponent, decorators: [{
type: Component,
args: [{ selector: 'AccordionPanel, nzm-accordion-panel', encapsulation: ViewEncapsulation.None, animations: [
trigger('slide', [
state('up', style({ height: 0 })),
state('down', style({ height: '*' })),
transition('down => up', [animate(200, style({ height: 0 }))]),
transition('up => down', [
animate(200, style({
height: '*'
}))
])
])
], template: "<div\n role=\"tab\"\n class=\"am-accordion-header\"\n data-scale=\"true\"\n [attr.aria-expanded]=\"isOpened\"\n (click)=\"checkAndToggle()\"\n>\n <i class=\"arrow\"></i>\n <ng-container *ngIf=\"!isTemplateRef(header)\">{{ header }}</ng-container>\n <ng-template *ngIf=\"isTemplateRef(header)\" [ngTemplateOutlet]=\"header\"></ng-template>\n</div>\n<div\n role=\"tabpanel\"\n class=\"am-accordion-content\"\n [ngClass]=\"{ 'am-accordion-content-active': isOpened }\"\n [@slide]=\"slide\"\n (@slide.done)=\"slideAnimationDoen($event)\"\n>\n <div *ngIf=\"isShowChild\" class=\"am-accordion-content-box\">\n <ng-content></ng-content>\n </div>\n</div>\n" }]
}], ctorParameters: () => [{ type: i1.AccordionService }, { type: i0.ChangeDetectorRef }], propDecorators: { key: [{
type: Input
}], header: [{
type: Input
}], isOpened: [{
type: Input
}], disabled: [{
type: Input
}], onOpen: [{
type: Output
}], onClose: [{
type: Output
}], onChange: [{
type: Output
}], amItem: [{
type: HostBinding,
args: ['class.am-accordion-item']
}], isActive: [{
type: HostBinding,
args: ['class.am-accordion-item-active']
}], addon: [{
type: HostBinding,
args: ['class.addon']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"accordion-group.component.js","sourceRoot":"","sources":["../../../../components/accordion/accordion-group/accordion-group.component.ts","../../../../components/accordion/accordion-group/accordion-group.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  ChangeDetectorRef,\n  Output,\n  EventEmitter,\n  ViewEncapsulation,\n  HostBinding,\n  TemplateRef\n} from '@angular/core';\nimport { animate, state, style, transition, trigger } from '@angular/animations';\nimport { AccordionService } from '../accordion.service';\nimport { isTemplateRef } from 'ng-zorro-antd-mobile/core';\n\n@Component({\n  selector: 'AccordionPanel, nzm-accordion-panel',\n  templateUrl: './accordion-group.component.html',\n  encapsulation: ViewEncapsulation.None,\n  animations: [\n    trigger('slide', [\n      state('up', style({ height: 0 })),\n      state('down', style({ height: '*' })),\n      transition('down => up', [animate(200, style({ height: 0 }))]),\n      transition('up => down', [\n        animate(\n          200,\n          style({\n            height: '*'\n          })\n        )\n      ])\n    ])\n  ]\n})\nexport class AccordionGroupComponent {\n  isShowChild: boolean = true;\n\n  @Input()\n  key: string;\n  @Input()\n  header: string | TemplateRef<void>;\n  @Input()\n  isOpened: boolean = false;\n  @Input()\n  disabled: boolean = false;\n  @Output()\n  onOpen = new EventEmitter();\n  @Output()\n  onClose = new EventEmitter();\n  @Output()\n  onChange = new EventEmitter();\n  isTemplateRef = isTemplateRef;\n\n  @HostBinding('class.am-accordion-item') public amItem = true;\n  @HostBinding('class.am-accordion-item-active') public isActive = this.isOpened;\n  @HostBinding('class.addon') public addon = true;\n\n  constructor(private _accordionService: AccordionService, private _cdr: ChangeDetectorRef) {}\n\n  checkAndToggle() {\n    this.toggle();\n  }\n\n  get slide(): string {\n    return this.isOpened ? 'down' : 'up';\n  }\n\n  toggle() {\n    if (this.disabled) {\n      return;\n    }\n    this.isShowChild = true;\n    const isOpenedBeforeWeChange = this.isOpened;\n    if (this._accordionService.accordion) {\n      this._accordionService.component.closeAll();\n    }\n    this.isOpened = !isOpenedBeforeWeChange;\n    if (this.isOpened) {\n      this.onOpen.emit();\n    } else {\n      this.onClose.emit();\n    }\n    this.onChange.emit(this.isOpened);\n  }\n\n  openOnInitialization() {\n    setTimeout(() => {\n      this.isOpened = true;\n      this._cdr.detectChanges();\n    }, 0);\n  }\n\n  slideAnimationDoen(event) {\n    if (event.fromState === 'down' && event.toState === 'up') {\n      setTimeout(() => {\n        this.isShowChild = false;\n      }, 0);\n    }\n  }\n}\n","<div\n  role=\"tab\"\n  class=\"am-accordion-header\"\n  data-scale=\"true\"\n  [attr.aria-expanded]=\"isOpened\"\n  (click)=\"checkAndToggle()\"\n>\n  <i class=\"arrow\"></i>\n  <ng-container *ngIf=\"!isTemplateRef(header)\">{{ header }}</ng-container>\n  <ng-template *ngIf=\"isTemplateRef(header)\" [ngTemplateOutlet]=\"header\"></ng-template>\n</div>\n<div\n  role=\"tabpanel\"\n  class=\"am-accordion-content\"\n  [ngClass]=\"{ 'am-accordion-content-active': isOpened }\"\n  [@slide]=\"slide\"\n  (@slide.done)=\"slideAnimationDoen($event)\"\n>\n  <div *ngIf=\"isShowChild\" class=\"am-accordion-content-box\">\n    <ng-content></ng-content>\n  </div>\n</div>\n"]}