igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
483 lines • 29.8 kB
JavaScript
/**
* @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"]}