UNPKG

igniteui-angular

Version:

Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps

483 lines • 29.8 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, ChangeDetectorRef, EventEmitter, HostBinding, Input, Output, ContentChild, forwardRef, } from '@angular/core'; import { AnimationBuilder, useAnimation } from '@angular/animations'; import { growVerOut, growVerIn } from '../animations/main'; import { IgxExpansionPanelBodyComponent } from './expansion-panel-body.component'; import { IgxExpansionPanelHeaderComponent } from './expansion-panel-header.component'; import { IGX_EXPANSION_PANEL_COMPONENT } from './expansion-panel.common'; /** @type {?} */ var NEXT_ID = 0; /** * @record */ export function AnimationSettings() { } if (false) { /** @type {?} */ AnimationSettings.prototype.openAnimation; /** @type {?} */ AnimationSettings.prototype.closeAnimation; } var IgxExpansionPanelComponent = /** @class */ (function () { function IgxExpansionPanelComponent(cdr, builder) { this.cdr = cdr; this.builder = builder; /** * Sets/gets the animation settings of the expansion panel component * Open and Close animation should be passed * * Get * ```typescript * const currentAnimations = this.panel.animationSettings; * ``` * Set * ```typescript * import { slideInLeft, slideOutRight } from 'igniteui-angular'; * ... * this.panel.animationsSettings = { * openAnimation: slideInLeft, * closeAnimation: slideOutRight * }; * ``` * or via template * ```typescript * import { slideInLeft, slideOutRight } from 'igniteui-angular'; * ... * myCustomAnimationObject = { * openAnimation: slideInLeft, * closeAnimation: slideOutRight * }; * ```html * <igx-expansion-panel [animationSettings]='myCustomAnimationObject'> * ... * </igx-expansion-panel> * ``` */ this.animationSettings = { openAnimation: growVerIn, closeAnimation: growVerOut }; /** * Sets/gets the `id` of the expansion panel component. * If not set, `id` will have value `"igx-expansion-panel-0"`; * ```html * <igx-expansion-panel id = "my-first-expansion-panel"></igx-expansion-panel> * ``` * ```typescript * let panelId = this.panel.id; * ``` * \@memberof IgxExpansionPanelComponent */ this.id = "igx-expansion-panel-" + NEXT_ID++; /** * @hidden */ this.cssClass = 'igx-expansion-panel'; /** * Gets/sets whether the component is collapsed (its content is hidden) * Get * ```typescript * const myPanelState: boolean = this.panel.collapsed; * ``` * Set * ```html * this.panel.collapsed = true; * ``` */ this.collapsed = true; /** * Emitted when the expansion panel finishes collapsing * ```typescript * handleCollapsed(event: { * panel: IgxExpansionPanelComponent, * event: Event * }) * ``` * ```html * <igx-expansion-panel (onCollapsed)="handleCollapsed($event)"> * ... * </igx-expansion-panel> * ``` */ this.onCollapsed = new EventEmitter(); /** * Emitted when the expansion panel finishes expanding * ```typescript * handleExpanded(event: { * panel: IgxExpansionPanelComponent, * event: Event * }) * ``` * ```html * <igx-expansion-panel (onExpanded)="handleExpanded($event)"> * ... * </igx-expansion-panel> * ``` */ this.onExpanded = new EventEmitter(); } Object.defineProperty(IgxExpansionPanelComponent.prototype, "headerId", { /** * @hidden */ get: /** * @hidden * @return {?} */ function () { return this.header ? this.id + "-header" : ''; }, enumerable: true, configurable: true }); /** * @private * @param {?} cb * @return {?} */ IgxExpansionPanelComponent.prototype.playOpenAnimation = /** * @private * @param {?} cb * @return {?} */ function (cb) { if (!this.body) { // if not body element is passed, there is nothing to animate return; } /** @type {?} */ var animation = useAnimation(this.animationSettings.openAnimation); /** @type {?} */ var animationBuilder = this.builder.build(animation); /** @type {?} */ var openAnimationPlayer = animationBuilder.create(this.body.element.nativeElement); openAnimationPlayer.onDone(function () { cb(); openAnimationPlayer.reset(); }); openAnimationPlayer.play(); }; /** * @private * @param {?} cb * @return {?} */ IgxExpansionPanelComponent.prototype.playCloseAnimation = /** * @private * @param {?} cb * @return {?} */ function (cb) { if (!this.body) { // if not body element is passed, there is nothing to animate return; } /** @type {?} */ var animation = useAnimation(this.animationSettings.closeAnimation); /** @type {?} */ var animationBuilder = this.builder.build(animation); /** @type {?} */ var closeAnimationPlayer = animationBuilder.create(this.body.element.nativeElement); closeAnimationPlayer.onDone(function () { cb(); closeAnimationPlayer.reset(); }); closeAnimationPlayer.play(); }; /** * Collapses the panel * * ```html * <igx-expansion-panel #myPanel> * ... * </igx-expansion-panel> * <button (click)="myPanel.collapse($event)">Collpase Panel</button> * ``` */ /** * Collapses the panel * * ```html * <igx-expansion-panel #myPanel> * ... * </igx-expansion-panel> * <button (click)="myPanel.collapse($event)">Collpase Panel</button> * ``` * @param {?=} evt * @return {?} */ IgxExpansionPanelComponent.prototype.collapse = /** * Collapses the panel * * ```html * <igx-expansion-panel #myPanel> * ... * </igx-expansion-panel> * <button (click)="myPanel.collapse($event)">Collpase Panel</button> * ``` * @param {?=} evt * @return {?} */ function (evt) { var _this = this; if (this.collapsed) { // If expansion panel is already collapsed, do nothing return; } this.playCloseAnimation(function () { _this.onCollapsed.emit({ event: evt, panel: _this }); _this.collapsed = true; }); }; /** * Expands the panel * * ```html * <igx-expansion-panel #myPanel> * ... * </igx-expansion-panel> * <button (click)="myPanel.expand($event)">Expand Panel</button> * ``` */ /** * Expands the panel * * ```html * <igx-expansion-panel #myPanel> * ... * </igx-expansion-panel> * <button (click)="myPanel.expand($event)">Expand Panel</button> * ``` * @param {?=} evt * @return {?} */ IgxExpansionPanelComponent.prototype.expand = /** * Expands the panel * * ```html * <igx-expansion-panel #myPanel> * ... * </igx-expansion-panel> * <button (click)="myPanel.expand($event)">Expand Panel</button> * ``` * @param {?=} evt * @return {?} */ function (evt) { var _this = this; if (!this.collapsed) { // If the panel is already opened, do nothing return; } this.collapsed = false; this.cdr.detectChanges(); this.playOpenAnimation(function () { _this.onExpanded.emit({ event: evt, panel: _this }); }); }; /** * Toggles the panel * * ```html * <igx-expansion-panel #myPanel> * ... * </igx-expansion-panel> * <button (click)="myPanel.toggle($event)">Expand Panel</button> * ``` */ /** * Toggles the panel * * ```html * <igx-expansion-panel #myPanel> * ... * </igx-expansion-panel> * <button (click)="myPanel.toggle($event)">Expand Panel</button> * ``` * @param {?=} evt * @return {?} */ IgxExpansionPanelComponent.prototype.toggle = /** * Toggles the panel * * ```html * <igx-expansion-panel #myPanel> * ... * </igx-expansion-panel> * <button (click)="myPanel.toggle($event)">Expand Panel</button> * ``` * @param {?=} evt * @return {?} */ function (evt) { if (this.collapsed) { this.open(evt); } else { this.close(evt); } }; /** * @param {?=} evt * @return {?} */ IgxExpansionPanelComponent.prototype.open = /** * @param {?=} evt * @return {?} */ function (evt) { this.expand(evt); }; /** * @param {?=} evt * @return {?} */ IgxExpansionPanelComponent.prototype.close = /** * @param {?=} evt * @return {?} */ function (evt) { this.collapse(evt); }; IgxExpansionPanelComponent.decorators = [ { type: Component, args: [{ selector: 'igx-expansion-panel', template: "<ng-content select=\"igx-expansion-panel-header\"></ng-content>\n<ng-content *ngIf=\"!collapsed\" select=\"igx-expansion-panel-body\"></ng-content>\n", providers: [{ provide: IGX_EXPANSION_PANEL_COMPONENT, useExisting: IgxExpansionPanelComponent }] }] } ]; /** @nocollapse */ IgxExpansionPanelComponent.ctorParameters = function () { return [ { type: ChangeDetectorRef }, { type: AnimationBuilder } ]; }; IgxExpansionPanelComponent.propDecorators = { animationSettings: [{ type: Input }], id: [{ type: HostBinding, args: ['attr.id',] }, { type: Input }], cssClass: [{ type: HostBinding, args: ['class.igx-expansion-panel',] }], collapsed: [{ type: Input }], onCollapsed: [{ type: Output }], onExpanded: [{ type: Output }], body: [{ type: ContentChild, args: [forwardRef(function () { return IgxExpansionPanelBodyComponent; }), { read: forwardRef(function () { return IgxExpansionPanelBodyComponent; }) },] }], header: [{ type: ContentChild, args: [forwardRef(function () { return IgxExpansionPanelHeaderComponent; }), { read: forwardRef(function () { return IgxExpansionPanelHeaderComponent; }) },] }] }; return IgxExpansionPanelComponent; }()); export { IgxExpansionPanelComponent }; if (false) { /** * Sets/gets the animation settings of the expansion panel component * Open and Close animation should be passed * * Get * ```typescript * const currentAnimations = this.panel.animationSettings; * ``` * Set * ```typescript * import { slideInLeft, slideOutRight } from 'igniteui-angular'; * ... * this.panel.animationsSettings = { * openAnimation: slideInLeft, * closeAnimation: slideOutRight * }; * ``` * or via template * ```typescript * import { slideInLeft, slideOutRight } from 'igniteui-angular'; * ... * myCustomAnimationObject = { * openAnimation: slideInLeft, * closeAnimation: slideOutRight * }; * ```html * <igx-expansion-panel [animationSettings]='myCustomAnimationObject'> * ... * </igx-expansion-panel> * ``` * @type {?} */ IgxExpansionPanelComponent.prototype.animationSettings; /** * Sets/gets the `id` of the expansion panel component. * If not set, `id` will have value `"igx-expansion-panel-0"`; * ```html * <igx-expansion-panel id = "my-first-expansion-panel"></igx-expansion-panel> * ``` * ```typescript * let panelId = this.panel.id; * ``` * \@memberof IgxExpansionPanelComponent * @type {?} */ IgxExpansionPanelComponent.prototype.id; /** * @hidden * @type {?} */ IgxExpansionPanelComponent.prototype.cssClass; /** * Gets/sets whether the component is collapsed (its content is hidden) * Get * ```typescript * const myPanelState: boolean = this.panel.collapsed; * ``` * Set * ```html * this.panel.collapsed = true; * ``` * @type {?} */ IgxExpansionPanelComponent.prototype.collapsed; /** * Emitted when the expansion panel finishes collapsing * ```typescript * handleCollapsed(event: { * panel: IgxExpansionPanelComponent, * event: Event * }) * ``` * ```html * <igx-expansion-panel (onCollapsed)="handleCollapsed($event)"> * ... * </igx-expansion-panel> * ``` * @type {?} */ IgxExpansionPanelComponent.prototype.onCollapsed; /** * Emitted when the expansion panel finishes expanding * ```typescript * handleExpanded(event: { * panel: IgxExpansionPanelComponent, * event: Event * }) * ``` * ```html * <igx-expansion-panel (onExpanded)="handleExpanded($event)"> * ... * </igx-expansion-panel> * ``` * @type {?} */ IgxExpansionPanelComponent.prototype.onExpanded; /** * @hidden * @type {?} */ IgxExpansionPanelComponent.prototype.body; /** * @hidden * @type {?} */ IgxExpansionPanelComponent.prototype.header; /** * @type {?} * @private */ IgxExpansionPanelComponent.prototype.cdr; /** * @type {?} * @private */ IgxExpansionPanelComponent.prototype.builder; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"expansion-panel.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/expansion-panel/expansion-panel.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ChangeDetectorRef,\n    EventEmitter,\n    ElementRef,\n    HostBinding,\n    Input,\n    Output,\n    ContentChild,\n    forwardRef,\n} from '@angular/core';\nimport { AnimationBuilder, AnimationReferenceMetadata, useAnimation, AnimationAnimateRefMetadata } from '@angular/animations';\nimport { growVerOut, growVerIn } from '../animations/main';\nimport { IgxExpansionPanelBodyComponent } from './expansion-panel-body.component';\nimport { IgxExpansionPanelHeaderComponent } from './expansion-panel-header.component';\nimport { IGX_EXPANSION_PANEL_COMPONENT, IgxExpansionPanelBase, IExpansionPanelEventArgs } from './expansion-panel.common';\n\nlet NEXT_ID = 0;\n\nexport interface AnimationSettings {\n    openAnimation: AnimationReferenceMetadata;\n    closeAnimation: AnimationReferenceMetadata;\n}\n@Component({\n    selector: 'igx-expansion-panel',\n    templateUrl: 'expansion-panel.component.html',\n    providers: [{ provide: IGX_EXPANSION_PANEL_COMPONENT, useExisting: IgxExpansionPanelComponent }]\n})\nexport class IgxExpansionPanelComponent implements IgxExpansionPanelBase {\n\n    /**\n     * Sets/gets the animation settings of the expansion panel component\n     * Open and Close animation should be passed\n     *\n     * Get\n     * ```typescript\n     *  const currentAnimations = this.panel.animationSettings;\n     * ```\n     * Set\n     * ```typescript\n     *  import { slideInLeft, slideOutRight } from 'igniteui-angular';\n     *  ...\n     *  this.panel.animationsSettings = {\n     *      openAnimation: slideInLeft,\n     *      closeAnimation: slideOutRight\n     * };\n     * ```\n     * or via template\n     * ```typescript\n     *  import { slideInLeft, slideOutRight } from 'igniteui-angular';\n     *  ...\n     *  myCustomAnimationObject = {\n     *      openAnimation: slideInLeft,\n     *      closeAnimation: slideOutRight\n     * };\n     * ```html\n     *  <igx-expansion-panel [animationSettings]='myCustomAnimationObject'>\n     *  ...\n     *  </igx-expansion-panel>\n     * ```\n     */\n    @Input()\n    public animationSettings: AnimationSettings = {\n        openAnimation: growVerIn,\n        closeAnimation: growVerOut\n    };\n\n    /**\n     * Sets/gets the `id` of the expansion panel component.\n     * If not set, `id` will have value `\"igx-expansion-panel-0\"`;\n     * ```html\n     * <igx-expansion-panel id = \"my-first-expansion-panel\"></igx-expansion-panel>\n     * ```\n     * ```typescript\n     * let panelId =  this.panel.id;\n     * ```\n     * @memberof IgxExpansionPanelComponent\n     */\n    @HostBinding('attr.id')\n    @Input()\n    public id = `igx-expansion-panel-${NEXT_ID++}`;\n\n    /**\n     * @hidden\n     */\n    @HostBinding('class.igx-expansion-panel')\n    public cssClass = 'igx-expansion-panel';\n\n    /**\n     * Gets/sets whether the component is collapsed (its content is hidden)\n     * Get\n     * ```typescript\n     *  const myPanelState: boolean = this.panel.collapsed;\n     * ```\n     * Set\n     * ```html\n     *  this.panel.collapsed = true;\n     * ```\n     */\n    @Input()\n    public collapsed = true;\n\n    /**\n     * Emitted when the expansion panel finishes collapsing\n     * ```typescript\n     *  handleCollapsed(event: {\n     *  panel: IgxExpansionPanelComponent,\n     *  event: Event\n     * })\n     * ```\n     * ```html\n     *  <igx-expansion-panel (onCollapsed)=\"handleCollapsed($event)\">\n     *      ...\n     *  </igx-expansion-panel>\n     * ```\n     */\n    @Output()\n    public onCollapsed = new EventEmitter<IExpansionPanelEventArgs>();\n\n    /**\n     * Emitted when the expansion panel finishes expanding\n     * ```typescript\n     *  handleExpanded(event: {\n     *  panel: IgxExpansionPanelComponent,\n     *  event: Event\n     * })\n     * ```\n     * ```html\n     *  <igx-expansion-panel (onExpanded)=\"handleExpanded($event)\">\n     *      ...\n     *  </igx-expansion-panel>\n     * ```\n     */\n    @Output()\n    public onExpanded = new EventEmitter<IExpansionPanelEventArgs>();\n\n    /**\n     * @hidden\n     */\n    public get headerId() {\n        return this.header ? `${this.id}-header` : '';\n    }\n    constructor(private cdr: ChangeDetectorRef, private builder: AnimationBuilder) { }\n\n    /**\n     * @hidden\n     */\n    @ContentChild(forwardRef(() => IgxExpansionPanelBodyComponent), { read: forwardRef(() => IgxExpansionPanelBodyComponent) })\n    public body: IgxExpansionPanelBodyComponent;\n\n    /**\n     * @hidden\n     */\n    @ContentChild(forwardRef(() => IgxExpansionPanelHeaderComponent), { read: forwardRef(() => IgxExpansionPanelHeaderComponent) })\n    public header: IgxExpansionPanelHeaderComponent;\n\n\n    private playOpenAnimation(cb: () => void) {\n        if (!this.body) { // if not body element is passed, there is nothing to animate\n            return;\n        }\n        const animation = useAnimation(this.animationSettings.openAnimation);\n        const animationBuilder = this.builder.build(animation);\n        const openAnimationPlayer = animationBuilder.create(this.body.element.nativeElement);\n\n        openAnimationPlayer.onDone(() => {\n            cb();\n            openAnimationPlayer.reset();\n        });\n\n        openAnimationPlayer.play();\n    }\n\n    private playCloseAnimation(cb: () => void) {\n        if (!this.body) { // if not body element is passed, there is nothing to animate\n            return;\n        }\n        const animation = useAnimation(this.animationSettings.closeAnimation);\n        const animationBuilder = this.builder.build(animation);\n        const closeAnimationPlayer = animationBuilder.create(this.body.element.nativeElement);\n        closeAnimationPlayer.onDone(() => {\n            cb();\n            closeAnimationPlayer.reset();\n        });\n\n        closeAnimationPlayer.play();\n    }\n\n    /**\n     * Collapses the panel\n     *\n     * ```html\n     *  <igx-expansion-panel #myPanel>\n     *      ...\n     *  </igx-expansion-panel>\n     *  <button (click)=\"myPanel.collapse($event)\">Collpase Panel</button>\n     * ```\n     */\n    collapse(evt?: Event) {\n        if (this.collapsed) { // If expansion panel is already collapsed, do nothing\n            return;\n        }\n        this.playCloseAnimation(\n            () => {\n                this.onCollapsed.emit({ event: evt, panel: this });\n                this.collapsed = true;\n            }\n        );\n    }\n\n    /**\n     * Expands the panel\n     *\n     * ```html\n     *  <igx-expansion-panel #myPanel>\n     *      ...\n     *  </igx-expansion-panel>\n     *  <button (click)=\"myPanel.expand($event)\">Expand Panel</button>\n     * ```\n     */\n    expand(evt?: Event) {\n        if (!this.collapsed) { // If the panel is already opened, do nothing\n            return;\n        }\n        this.collapsed = false;\n        this.cdr.detectChanges();\n        this.playOpenAnimation(\n            () => {\n                this.onExpanded.emit({ event: evt, panel: this });\n            }\n        );\n    }\n\n    /**\n     * Toggles the panel\n     *\n     * ```html\n     *  <igx-expansion-panel #myPanel>\n     *      ...\n     *  </igx-expansion-panel>\n     *  <button (click)=\"myPanel.toggle($event)\">Expand Panel</button>\n     * ```\n     */\n    toggle(evt?: Event) {\n        if (this.collapsed) {\n            this.open(evt);\n        } else {\n            this.close(evt);\n        }\n    }\n\n    open(evt?: Event) {\n        this.expand(evt);\n    }\n    close(evt?: Event) {\n        this.collapse(evt);\n    }\n\n}\n"]}