@catull/igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
251 lines • 21.9 kB
JavaScript
import { __decorate, __metadata, __param } from "tslib";
import { Component, ChangeDetectorRef, ElementRef, HostBinding, HostListener, Input, Host, EventEmitter, Output, ContentChild, Inject } from '@angular/core';
import { IgxExpansionPanelIconDirective } from './expansion-panel.directives';
import { IGX_EXPANSION_PANEL_COMPONENT } from './expansion-panel.common';
/**
* @hidden
*/
export var ICON_POSITION;
(function (ICON_POSITION) {
ICON_POSITION["LEFT"] = "left";
ICON_POSITION["NONE"] = "none";
ICON_POSITION["RIGHT"] = "right";
})(ICON_POSITION || (ICON_POSITION = {}));
let IgxExpansionPanelHeaderComponent = class IgxExpansionPanelHeaderComponent {
constructor(panel, cdr, elementRef) {
this.panel = panel;
this.cdr = cdr;
this.elementRef = elementRef;
// properties section
this._iconTemplate = false;
/**
* Sets/gets the `id` of the expansion panel header.
* ```typescript
* let panelHeaderId = this.panel.header.id;
* ```
* @memberof IgxExpansionPanelComponent
*/
this.id = '';
/**
* Gets/sets the `aria-level` attribute of the header
* Get
* ```typescript
* const currentAriaLevel = this.panel.header.lv;
* ```
* Set
* ```typescript
* this.panel.header.lv = '5';
* ```
* ```html
* <igx-expansion-panel-header [lv]="myCustomLevel"></igx-expansion-panel-header>
* ```
*/
this.lv = '3';
/**
* Gets/sets the `role` attribute of the header
* Get
* ```typescript
* const currentRole = this.panel.header.role;
* ```
* Set
* ```typescript
* this.panel.header.role = '5';
* ```
* ```html
* <igx-expansion-panel-header [role]="'custom'"></igx-expansion-panel-header>
* ```
*/
this.role = 'heading';
/**
* Gets/sets the position of the expansion-panel-header expand/collapse icon
* Accepts `left`, `right` or `none`
* ```typescript
* const currentIconPosition = this.panel.header.iconPosition;
* ```
* Set
* ```typescript
* this.panel.header.iconPosition = 'left';
* ```
* ```html
* <igx-expansion-panel-header [iconPosition]="'right'"></igx-expansion-panel-header>
* ```
*/
this.iconPosition = ICON_POSITION.LEFT;
/**
* Emitted whenever a user interacts with the header host
* ```typescript
* handleInteraction(event: IExpansionPanelEventArgs) {
* ...
* }
* ```
* ```html
* <igx-expansion-panel-header (onInteraction)="handleInteraction($event)">
* ...
* </igx-expansion-panel-header>
* ```
*/
this.onInteraction = new EventEmitter();
/**
* @hidden
*/
this.cssClass = 'igx-expansion-panel__header';
/**
* Gets/sets the whether the header is disabled
* When disabled, the header will not handle user events and will stop their propagation
*
* ```typescript
* const isDisabled = this.panel.header.disabled;
* ```
* Set
* ```typescript
* this.panel.header.disabled = true;
* ```
* ```html
* <igx-expansion-panel-header [disabled]="true">
* ...
* </igx-expansion-panel-header>
* ```
*/
this.disabled = false;
this.id = `${this.panel.id}-header`;
}
/**
* @hidden
*/
set iconTemplate(val) {
this._iconTemplate = val;
}
/**
* @hidden
*/
get iconTemplate() {
return this._iconTemplate;
}
/**
* @hidden
*/
get controls() {
return this.panel.id;
}
/**
* @hidden
*/
get isExpanded() {
return !this.panel.collapsed;
}
/**
* @hidden
*/
onAction(evt) {
if (this.disabled) {
evt.stopPropagation();
return;
}
this.onInteraction.emit({ event: evt, panel: this.panel });
this.panel.toggle(evt);
evt.preventDefault();
}
/** @hidden @internal */
openPanel(event) {
if (event.altKey) {
this.panel.expand(event);
this.onInteraction.emit({ event: event, panel: this.panel });
}
}
/** @hidden @internal */
closePanel(event) {
if (event.altKey) {
this.panel.collapse(event);
this.onInteraction.emit({ event: event, panel: this.panel });
}
}
/**
* @hidden
*/
get iconPositionClass() {
switch (this.iconPosition) {
case (ICON_POSITION.LEFT):
return `igx-expansion-panel__header-icon--start`;
case (ICON_POSITION.RIGHT):
return `igx-expansion-panel__header-icon--end`;
case (ICON_POSITION.NONE):
return `igx-expansion-panel__header-icon--none`;
default:
return '';
}
}
};
IgxExpansionPanelHeaderComponent.ctorParameters = () => [
{ type: undefined, decorators: [{ type: Host }, { type: Inject, args: [IGX_EXPANSION_PANEL_COMPONENT,] }] },
{ type: ChangeDetectorRef },
{ type: ElementRef }
];
__decorate([
ContentChild(IgxExpansionPanelIconDirective),
__metadata("design:type", Object),
__metadata("design:paramtypes", [Object])
], IgxExpansionPanelHeaderComponent.prototype, "iconTemplate", null);
__decorate([
HostBinding('attr.aria-level'),
Input(),
__metadata("design:type", Object)
], IgxExpansionPanelHeaderComponent.prototype, "lv", void 0);
__decorate([
HostBinding('attr.role'),
Input(),
__metadata("design:type", Object)
], IgxExpansionPanelHeaderComponent.prototype, "role", void 0);
__decorate([
Input(),
__metadata("design:type", String)
], IgxExpansionPanelHeaderComponent.prototype, "iconPosition", void 0);
__decorate([
Output(),
__metadata("design:type", Object)
], IgxExpansionPanelHeaderComponent.prototype, "onInteraction", void 0);
__decorate([
HostBinding('class.igx-expansion-panel__header'),
__metadata("design:type", Object)
], IgxExpansionPanelHeaderComponent.prototype, "cssClass", void 0);
__decorate([
HostBinding('class.igx-expansion-panel__header--expanded'),
__metadata("design:type", Object),
__metadata("design:paramtypes", [])
], IgxExpansionPanelHeaderComponent.prototype, "isExpanded", null);
__decorate([
Input(),
HostBinding('class.igx-expansion-panel--disabled'),
__metadata("design:type", Object)
], IgxExpansionPanelHeaderComponent.prototype, "disabled", void 0);
__decorate([
HostListener('keydown.Enter', ['$event']),
HostListener('keydown.Space', ['$event']),
HostListener('keydown.Spacebar', ['$event']),
HostListener('click', ['$event']),
__metadata("design:type", Function),
__metadata("design:paramtypes", [Event]),
__metadata("design:returntype", void 0)
], IgxExpansionPanelHeaderComponent.prototype, "onAction", null);
__decorate([
HostListener('keydown.Alt.ArrowDown', ['$event']),
__metadata("design:type", Function),
__metadata("design:paramtypes", [KeyboardEvent]),
__metadata("design:returntype", void 0)
], IgxExpansionPanelHeaderComponent.prototype, "openPanel", null);
__decorate([
HostListener('keydown.Alt.ArrowUp', ['$event']),
__metadata("design:type", Function),
__metadata("design:paramtypes", [KeyboardEvent]),
__metadata("design:returntype", void 0)
], IgxExpansionPanelHeaderComponent.prototype, "closePanel", null);
IgxExpansionPanelHeaderComponent = __decorate([
Component({
selector: 'igx-expansion-panel-header',
template: "<div class=\"igx-expansion-panel__header-inner\" tabindex=\"0\" role=\"button\" [attr.id]=\"id\"\n[attr.aria-disabled]=\"disabled\" [attr.aria-expanded]=\"isExpanded\" [attr.aria-controls]=\"controls\">\n <div class=\"igx-expansion-panel__title-wrapper\">\n <ng-content select=\"igx-expansion-panel-title\"></ng-content>\n <ng-content select=\"igx-expansion-panel-description\"></ng-content>\n </div>\n <ng-content></ng-content>\n <div [class]=\"iconPositionClass\">\n <ng-content *ngIf=\"iconTemplate\" select=\"igx-expansion-panel-icon\"></ng-content>\n <igx-icon *ngIf=\"!iconTemplate\" fontSet=\"material\">\n {{panel.collapsed? 'expand_more':'expand_less'}}\n </igx-icon>\n </div>\n</div>\n"
}),
__param(0, Host()), __param(0, Inject(IGX_EXPANSION_PANEL_COMPONENT)),
__metadata("design:paramtypes", [Object, ChangeDetectorRef,
ElementRef])
], IgxExpansionPanelHeaderComponent);
export { IgxExpansionPanelHeaderComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"expansion-panel-header.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/expansion-panel/expansion-panel-header.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ChangeDetectorRef,\n    ElementRef,\n    HostBinding,\n    HostListener,\n    Input,\n    Host,\n    EventEmitter,\n    Output,\n    ContentChild,\n    Inject\n} from '@angular/core';\nimport { IgxExpansionPanelIconDirective } from './expansion-panel.directives';\nimport { IExpansionPanelEventArgs, IGX_EXPANSION_PANEL_COMPONENT, IgxExpansionPanelBase } from './expansion-panel.common';\n\n/**\n * @hidden\n */\nexport enum ICON_POSITION {\n    LEFT = 'left',\n    NONE = 'none',\n    RIGHT = 'right'\n}\n\n\n@Component({\n    selector: 'igx-expansion-panel-header',\n    templateUrl: 'expansion-panel-header.component.html'\n})\nexport class IgxExpansionPanelHeaderComponent {\n     // properties section\n    private _iconTemplate = false;\n    /**\n     * Sets/gets the `id` of the expansion panel header.\n     * ```typescript\n     * let panelHeaderId =  this.panel.header.id;\n     * ```\n     * @memberof IgxExpansionPanelComponent\n     */\n    public id = '';\n\n    /**\n     * @hidden\n     */\n    @ContentChild(IgxExpansionPanelIconDirective)\n    public set iconTemplate(val: any) {\n        this._iconTemplate = <boolean>val;\n    }\n\n    /**\n     * @hidden\n     */\n    public get iconTemplate(): any {\n        return this._iconTemplate;\n    }\n\n    /**\n     * Gets/sets the `aria-level` attribute of the header\n     * Get\n     * ```typescript\n     *  const currentAriaLevel = this.panel.header.lv;\n     * ```\n     * Set\n     * ```typescript\n     *  this.panel.header.lv = '5';\n     * ```\n     * ```html\n     *  <igx-expansion-panel-header [lv]=\"myCustomLevel\"></igx-expansion-panel-header>\n     * ```\n     */\n    @HostBinding('attr.aria-level')\n    @Input()\n    public lv = '3';\n\n    /**\n     * Gets/sets the `role` attribute of the header\n     * Get\n     * ```typescript\n     *  const currentRole = this.panel.header.role;\n     * ```\n     * Set\n     * ```typescript\n     *  this.panel.header.role = '5';\n     * ```\n     * ```html\n     *  <igx-expansion-panel-header [role]=\"'custom'\"></igx-expansion-panel-header>\n     * ```\n     */\n    @HostBinding('attr.role')\n    @Input()\n    public role = 'heading';\n\n    /**\n     * @hidden\n     */\n    public get controls (): string {\n        return this.panel.id;\n    }\n\n    /**\n     * Gets/sets the position of the expansion-panel-header expand/collapse icon\n     * Accepts `left`, `right` or `none`\n     * ```typescript\n     *  const currentIconPosition = this.panel.header.iconPosition;\n     * ```\n     * Set\n     * ```typescript\n     *  this.panel.header.iconPosition = 'left';\n     * ```\n     * ```html\n     *  <igx-expansion-panel-header [iconPosition]=\"'right'\"></igx-expansion-panel-header>\n     * ```\n     */\n    @Input()\n    public iconPosition: ICON_POSITION = ICON_POSITION.LEFT;\n\n    /**\n     * Emitted whenever a user interacts with the header host\n     * ```typescript\n     *  handleInteraction(event: IExpansionPanelEventArgs) {\n     *  ...\n     * }\n     * ```\n     * ```html\n     *  <igx-expansion-panel-header (onInteraction)=\"handleInteraction($event)\">\n     *      ...\n     *  </igx-expansion-panel-header>\n     * ```\n     */\n    @Output()\n    public onInteraction = new EventEmitter<IExpansionPanelEventArgs>();\n\n    /**\n     * @hidden\n     */\n     @HostBinding('class.igx-expansion-panel__header')\n     public cssClass = 'igx-expansion-panel__header';\n\n     /**\n     * @hidden\n     */\n     @HostBinding('class.igx-expansion-panel__header--expanded')\n     public get isExpanded () {\n            return !this.panel.collapsed;\n         }\n\n    /**\n     * Gets/sets the whether the header is disabled\n     * When disabled, the header will not handle user events and will stop their propagation\n     *\n     * ```typescript\n     *  const isDisabled = this.panel.header.disabled;\n     * ```\n     * Set\n     * ```typescript\n     *  this.panel.header.disabled = true;\n     * ```\n     * ```html\n     *  <igx-expansion-panel-header [disabled]=\"true\">\n     *     ...\n     *  </igx-expansion-panel-header>\n     * ```\n     */\n    @Input()\n    @HostBinding('class.igx-expansion-panel--disabled')\n    public disabled = false;\n\n    constructor(@Host() @Inject(IGX_EXPANSION_PANEL_COMPONENT) public panel: IgxExpansionPanelBase, public cdr: ChangeDetectorRef,\n     public elementRef: ElementRef) {\n         this.id = `${this.panel.id}-header`;\n     }\n\n     /**\n     * @hidden\n     */\n     @HostListener('keydown.Enter', ['$event'])\n     @HostListener('keydown.Space', ['$event'])\n     @HostListener('keydown.Spacebar', ['$event'])\n     @HostListener('click', ['$event'])\n     public onAction(evt?: Event) {\n         if (this.disabled) {\n            evt.stopPropagation();\n            return;\n         }\n         this.onInteraction.emit({ event: evt, panel: this.panel });\n         this.panel.toggle(evt);\n         evt.preventDefault();\n     }\n\n    /** @hidden @internal */\n    @HostListener('keydown.Alt.ArrowDown', ['$event'])\n    public openPanel(event: KeyboardEvent) {\n        if (event.altKey) {\n            this.panel.expand(event);\n            this.onInteraction.emit({ event: event, panel: this.panel });\n        }\n     }\n\n     /** @hidden @internal */\n     @HostListener('keydown.Alt.ArrowUp', ['$event'])\n     public closePanel(event: KeyboardEvent) {\n        if (event.altKey) {\n            this.panel.collapse(event);\n            this.onInteraction.emit({ event: event, panel: this.panel });\n        }\n     }\n\n     /**\n     * @hidden\n     */\n     public get iconPositionClass(): string {\n        switch (this.iconPosition) {\n            case (ICON_POSITION.LEFT):\n                return `igx-expansion-panel__header-icon--start`;\n            case (ICON_POSITION.RIGHT):\n                return `igx-expansion-panel__header-icon--end`;\n            case (ICON_POSITION.NONE):\n                return `igx-expansion-panel__header-icon--none`;\n            default:\n                return '';\n        }\n     }\n}\n"]}