@catull/igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
444 lines • 36.2 kB
JavaScript
import { __decorate, __metadata, __param } from "tslib";
import { CommonModule } from '@angular/common';
import { Component, Directive, HostBinding, Optional, Inject, Input, NgModule } from '@angular/core';
import { IgxButtonModule } from '../directives/button/button.directive';
let NEXT_ID = 0;
/**
* IgxCardMedia is container for the card media section.
* Use it to wrap images and videos.
*/
let IgxCardMediaDirective = class IgxCardMediaDirective {
constructor() {
/**
* @hidden
*/
this.cssClass = 'igx-card__media';
/**
* An @Input property that sets the `width` and `min-width` style property
* of the media container. If not provided it will be set to `auto`.
* ```html
* <igx-card-media width="300px"></igx-card-media>
* ```
*/
this.width = 'auto';
/**
* An @Input property that sets the `height` style property of the media container.
* If not provided it will be set to `auto`.
* ```html
* <igx-card-media height="50%"></igx-card-media>
* ```
*/
this.height = 'auto';
/**
* An @Input property that sets the `role` attribute of the media container.
*/
this.role = 'img';
}
};
__decorate([
HostBinding('class.igx-card__media'),
__metadata("design:type", Object)
], IgxCardMediaDirective.prototype, "cssClass", void 0);
__decorate([
HostBinding('style.width'),
HostBinding('style.min-width'),
Input(),
__metadata("design:type", Object)
], IgxCardMediaDirective.prototype, "width", void 0);
__decorate([
HostBinding('style.height'),
Input(),
__metadata("design:type", Object)
], IgxCardMediaDirective.prototype, "height", void 0);
__decorate([
HostBinding('attr.role'),
Input(),
__metadata("design:type", Object)
], IgxCardMediaDirective.prototype, "role", void 0);
IgxCardMediaDirective = __decorate([
Directive({
// tslint:disable-next-line:directive-selector
selector: 'igx-card-media'
})
], IgxCardMediaDirective);
export { IgxCardMediaDirective };
/**
* IgxCardHeader is container for the card header
*/
let IgxCardHeaderComponent = class IgxCardHeaderComponent {
constructor() {
/**
* @hidden
*/
this.cssClass = 'igx-card-header';
/**
* An @Input property that sets the layout style of the header.
* By default the header elements(thumbnail and title/subtitle) are aligned horizontally.
* ```html
* <igx-card-header [vertical]="true"></igx-card-header>
* ```
*/
this.vertical = false;
/**
* An @Input property that sets the value of the `role` attribute of the card header.
* By default the value is set to `header`.
* ```html
* <igx-card-header role="header"></igx-card-header>
* ```
*/
this.role = 'header';
}
};
__decorate([
HostBinding('class.igx-card-header'),
__metadata("design:type", Object)
], IgxCardHeaderComponent.prototype, "cssClass", void 0);
__decorate([
HostBinding('class.igx-card-header--vertical'),
Input(),
__metadata("design:type", Object)
], IgxCardHeaderComponent.prototype, "vertical", void 0);
__decorate([
HostBinding('attr.role'),
__metadata("design:type", Object)
], IgxCardHeaderComponent.prototype, "role", void 0);
IgxCardHeaderComponent = __decorate([
Component({
selector: 'igx-card-header',
template: "<div class=\"igx-card-header__thumbnail\">\n <ng-content select=\"igx-avatar, igx-card-media, [igxCardThumbnail]\"></ng-content>\n</div>\n\n<div class=\"igx-card-header__titles\">\n <ng-content select=\"\n [igxCardHeaderTitle],\n [igxCardHeaderSubtitle],\n .igx-card-header__title,\n .igx-card-header__subtitle\">\n </ng-content>\n</div>\n\n<ng-content></ng-content>\n"
})
], IgxCardHeaderComponent);
export { IgxCardHeaderComponent };
/**
* IgxCardThumbnail is container for the card thumbnail section.
* Use it to wrap anything you want to be used as a thumbnail.
*/
let IgxCardThumbnailDirective = class IgxCardThumbnailDirective {
};
IgxCardThumbnailDirective = __decorate([
Directive({
selector: '[igxCardThumbnail]'
})
], IgxCardThumbnailDirective);
export { IgxCardThumbnailDirective };
/**
* igxCardHeaderTitle is used to denote the header title in a card.
* Use it to tag text nodes.
*/
let IgxCardHeaderTitleDirective = class IgxCardHeaderTitleDirective {
constructor() {
/**
* @hidden
*/
this.cssClass = 'igx-card__header__title';
}
};
__decorate([
HostBinding('class.igx-card-header__title'),
__metadata("design:type", Object)
], IgxCardHeaderTitleDirective.prototype, "cssClass", void 0);
IgxCardHeaderTitleDirective = __decorate([
Directive({
selector: '[igxCardHeaderTitle]'
})
], IgxCardHeaderTitleDirective);
export { IgxCardHeaderTitleDirective };
/**
* igxCardHeaderSubtitle is used to denote the header subtitle in a card.
* Use it to tag text nodes.
*/
let IgxCardHeaderSubtitleDirective = class IgxCardHeaderSubtitleDirective {
constructor() {
/**
* @hidden
*/
this.cssClass = 'igx-card-header__subtitle';
}
};
__decorate([
HostBinding('class.igx-card-header__subtitle'),
__metadata("design:type", Object)
], IgxCardHeaderSubtitleDirective.prototype, "cssClass", void 0);
IgxCardHeaderSubtitleDirective = __decorate([
Directive({
selector: '[igxCardHeaderSubtitle]'
})
], IgxCardHeaderSubtitleDirective);
export { IgxCardHeaderSubtitleDirective };
/**
* IgxCardContent is container for the card content.
*/
let IgxCardContentDirective = class IgxCardContentDirective {
constructor() {
/**
* @hidden
*/
this.cssClass = 'igx-card-content';
}
};
__decorate([
HostBinding('class.igx-card-content'),
__metadata("design:type", Object)
], IgxCardContentDirective.prototype, "cssClass", void 0);
IgxCardContentDirective = __decorate([
Directive({
// tslint:disable-next-line:directive-selector
selector: 'igx-card-content'
})
], IgxCardContentDirective);
export { IgxCardContentDirective };
/**
* IgxCardFooter is container for the card footer
*/
let IgxCardFooterDirective = class IgxCardFooterDirective {
constructor() {
/**
* An @Input property that sets the value of the `role` attribute of the card footer.
* By default the value is set to `footer`.
* ```html
* <igx-card-footer role="footer"></igx-card-footer>
* ```
*/
this.role = 'footer';
}
};
__decorate([
HostBinding('attr.role'),
Input(),
__metadata("design:type", Object)
], IgxCardFooterDirective.prototype, "role", void 0);
IgxCardFooterDirective = __decorate([
Directive({
// tslint:disable-next-line:directive-selector
selector: 'igx-card-footer'
})
], IgxCardFooterDirective);
export { IgxCardFooterDirective };
/**
* **Ignite UI for Angular Card** -
* [Documentation](https://www.infragistics.com/products/ignite-ui-angular/angular/components/card.html)
*
* The Ignite UI Card serves as a container that allows custom content to be organized in an appealing way. There are
* five sections in a card that you can use to organize your content. These are header, media, content, actions, and footer.
*
* Example:
* ```html
* <igx-card>
* <igx-card-header>
* <h3 igxCardHeaderTitle>{{title}}</h3>
* <h5 igxCardHeaderSubtitle>{{subtitle}}</h5>
* </igx-card-header>
* <igx-card-actions>
* <button igxButton igxRipple>Share</button>
* <button igxButton igxRipple>Play Album</button>
* </igx-card-actions>
* </igx-card>
* ```
*/
export var IgxCardType;
(function (IgxCardType) {
IgxCardType["DEFAULT"] = "default";
IgxCardType["OUTLINED"] = "outlined";
})(IgxCardType || (IgxCardType = {}));
let IgxCardComponent = class IgxCardComponent {
constructor() {
/**
* Sets/gets the `id` of the card.
* If not set, `id` will have value `"igx-card-0"`;
* ```html
* <igx-card id = "my-first-card"></igx-card>
* ```
* ```typescript
* let cardId = this.card.id;
* ```
* @memberof IgxCardComponent
*/
this.id = `igx-card-${NEXT_ID++}`;
/**
* An @Input property that sets the value of the `role` attribute of the card.
* By default the value is set to `group`.
* ```html
* <igx-card role="group"></igx-card>
* ```
*/
this.role = 'group';
/**
* An @Input property that sets the value of the `type` attribute of the card.
* By default the value is set to `default`. You can make the card use the
* outlined style by setting the value to `outlined`.
* ```html
* <igx-card type="outlined"></igx-card>
* ```
*/
this.type = IgxCardType.DEFAULT;
/**
* An @Input property that sets the value of the `horizontal` attribute of the card.
* Setting this to `true` will make the different card sections align horizontally,
* essentially flipping the card to the side.
* ```html
* <igx-card [horizontal]="true"></igx-card>
* ```
*/
this.horizontal = false;
}
/**
* A getter which will return true if the card type is `outlined`.
*/
get isOutlinedCard() {
return this.type === IgxCardType.OUTLINED;
}
};
__decorate([
HostBinding('attr.id'),
Input(),
__metadata("design:type", Object)
], IgxCardComponent.prototype, "id", void 0);
__decorate([
HostBinding('attr.role'),
Input(),
__metadata("design:type", Object)
], IgxCardComponent.prototype, "role", void 0);
__decorate([
HostBinding('class.igx-card'),
Input(),
__metadata("design:type", String)
], IgxCardComponent.prototype, "type", void 0);
__decorate([
HostBinding('class.igx-card--outlined'),
__metadata("design:type", Object),
__metadata("design:paramtypes", [])
], IgxCardComponent.prototype, "isOutlinedCard", null);
__decorate([
HostBinding('class.igx-card--horizontal'),
Input(),
__metadata("design:type", Object)
], IgxCardComponent.prototype, "horizontal", void 0);
IgxCardComponent = __decorate([
Component({
selector: 'igx-card',
template: "<ng-container select='igx-card-media'></ng-container>\n\n<ng-container select='igx-card-header'></ng-container>\n<ng-container select='igx-card-content'>\n <ng-content></ng-content>\n</ng-container>\n\n<ng-container select='igx-card-actions'></ng-container>\n"
})
], IgxCardComponent);
export { IgxCardComponent };
export var IgxCardActionsLayout;
(function (IgxCardActionsLayout) {
IgxCardActionsLayout["DEFAULT"] = "default";
IgxCardActionsLayout["JUSTIFY"] = "justify";
})(IgxCardActionsLayout || (IgxCardActionsLayout = {}));
/**
* IgxCardActions is container for the card actions.
*/
let IgxCardActionsComponent = class IgxCardActionsComponent {
constructor(card) {
this.card = card;
this.isVerticalSet = false;
/**
* An @Input property that sets the layout style of the actions.
* By default icons and icon buttons, as well as regular buttons
* are split into two containers, which are then positioned on both ends
* of the card-actions area.
* You can justify the elements in those groups so they are positioned equally
* from one another taking up all the space available along the card actions axis.
* ```html
* <igx-card-actions layout="justify"></igx-card-actions>
* ```
*/
this.layout = 'default';
/**
* An @Input property that sets order of the buttons the actions area.
* By default all icons/icon buttons are placed at the end of the action
* area. Any regular buttons(flat, raised) will appear before the icons/icon buttons
* placed in the actions area.
* If you want to reverse their positions so that icons appear first, use the `reverse`
* attribute.
* ```html
* <igx-card-actions [reverse]="true"></igx-card-actions>
* ```
*/
this.reverse = false;
}
/**
* A getter that returns `true` when the layout has been
* set to `justify`.
*/
get isJustifyLayout() {
return this.layout === IgxCardActionsLayout.JUSTIFY;
}
ngOnChanges(changes) {
for (const prop in changes) {
if (prop === 'vertical') {
this.isVerticalSet = true;
}
}
}
ngOnInit() {
this.vertical = !this.isVerticalSet && this.card.horizontal;
}
};
IgxCardActionsComponent.ctorParameters = () => [
{ type: IgxCardComponent, decorators: [{ type: Optional }, { type: Inject, args: [IgxCardComponent,] }] }
];
__decorate([
HostBinding('class.igx-card-actions'),
Input(),
__metadata("design:type", String)
], IgxCardActionsComponent.prototype, "layout", void 0);
__decorate([
HostBinding('class.igx-card-actions--vertical'),
Input(),
__metadata("design:type", Boolean)
], IgxCardActionsComponent.prototype, "vertical", void 0);
__decorate([
HostBinding('class.igx-card-actions--justify'),
__metadata("design:type", Object),
__metadata("design:paramtypes", [])
], IgxCardActionsComponent.prototype, "isJustifyLayout", null);
__decorate([
HostBinding('class.igx-card-actions--reverse'),
Input(),
__metadata("design:type", Object)
], IgxCardActionsComponent.prototype, "reverse", void 0);
IgxCardActionsComponent = __decorate([
Component({
// tslint:disable-next-line:directive-selector
selector: 'igx-card-actions',
template: "<div class=\"igx-card-actions__icons\">\n <ng-content select=\"igx-icon, [igxButton='icon']\"></ng-content>\n</div>\n\n<div #buttons class=\"igx-card-actions__buttons\">\n <ng-content select=\"[igxButton]\"></ng-content>\n</div>\n\n\n<ng-content></ng-content>\n"
}),
__param(0, Optional()), __param(0, Inject(IgxCardComponent)),
__metadata("design:paramtypes", [IgxCardComponent])
], IgxCardActionsComponent);
export { IgxCardActionsComponent };
/**
* @hidden
*/
let IgxCardModule = class IgxCardModule {
};
IgxCardModule = __decorate([
NgModule({
declarations: [
IgxCardComponent,
IgxCardHeaderComponent,
IgxCardMediaDirective,
IgxCardContentDirective,
IgxCardActionsComponent,
IgxCardFooterDirective,
IgxCardHeaderTitleDirective,
IgxCardHeaderSubtitleDirective,
IgxCardThumbnailDirective,
],
exports: [
IgxCardComponent,
IgxCardHeaderComponent,
IgxCardMediaDirective,
IgxCardContentDirective,
IgxCardActionsComponent,
IgxCardFooterDirective,
IgxCardHeaderTitleDirective,
IgxCardHeaderSubtitleDirective,
IgxCardThumbnailDirective,
],
imports: [CommonModule, IgxButtonModule]
})
], IgxCardModule);
export { IgxCardModule };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"card.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/card/card.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n    Component,\n    Directive,\n    HostBinding,\n    Optional,\n    Inject,\n    Input,\n    NgModule,\n    OnInit,\n    OnChanges,\n    SimpleChanges\n} from '@angular/core';\nimport { IgxButtonModule } from '../directives/button/button.directive';\n\nlet NEXT_ID = 0;\n\n/**\n * IgxCardMedia is container for the card media section.\n * Use it to wrap images and videos.\n */\n@Directive({\n    // tslint:disable-next-line:directive-selector\n    selector: 'igx-card-media'\n})\nexport class IgxCardMediaDirective {\n    /**\n     * @hidden\n     */\n    @HostBinding('class.igx-card__media')\n    public cssClass = 'igx-card__media';\n\n    /**\n     * An @Input property that sets the `width` and `min-width` style property\n     * of the media container. If not provided it will be set to `auto`.\n     * ```html\n     * <igx-card-media width=\"300px\"></igx-card-media>\n     * ```\n     */\n    @HostBinding('style.width')\n    @HostBinding('style.min-width')\n    @Input()\n    public width = 'auto';\n\n    /**\n     * An @Input property that sets the `height` style property of the media container.\n     * If not provided it will be set to `auto`.\n     * ```html\n     * <igx-card-media height=\"50%\"></igx-card-media>\n     * ```\n     */\n    @HostBinding('style.height')\n    @Input()\n    public height = 'auto';\n\n    /**\n     * An @Input property that sets the `role` attribute of the media container.\n     */\n    @HostBinding('attr.role')\n    @Input()\n    public role = 'img';\n}\n\n/**\n * IgxCardHeader is container for the card header\n */\n@Component({\n    selector: 'igx-card-header',\n    templateUrl: 'card-header.component.html'\n})\nexport class IgxCardHeaderComponent {\n    /**\n     * @hidden\n     */\n    @HostBinding('class.igx-card-header')\n    public cssClass = 'igx-card-header';\n\n    /**\n     * An @Input property that sets the layout style of the header.\n     * By default the header elements(thumbnail and title/subtitle) are aligned horizontally.\n     * ```html\n     * <igx-card-header [vertical]=\"true\"></igx-card-header>\n     * ```\n     */\n    @HostBinding('class.igx-card-header--vertical')\n    @Input()\n    public vertical = false;\n\n    /**\n     * An @Input property that sets the value of the `role` attribute of the card header.\n     * By default the value is set to `header`.\n     * ```html\n     * <igx-card-header role=\"header\"></igx-card-header>\n     * ```\n     */\n    @HostBinding('attr.role')\n    public role = 'header';\n}\n\n/**\n * IgxCardThumbnail is container for the card thumbnail section.\n * Use it to wrap anything you want to be used as a thumbnail.\n */\n@Directive({\n    selector: '[igxCardThumbnail]'\n})\nexport class IgxCardThumbnailDirective { }\n\n/**\n * igxCardHeaderTitle is used to denote the header title in a card.\n * Use it to tag text nodes.\n */\n@Directive({\n    selector: '[igxCardHeaderTitle]'\n})\nexport class IgxCardHeaderTitleDirective {\n    /**\n     * @hidden\n     */\n    @HostBinding('class.igx-card-header__title')\n    public cssClass = 'igx-card__header__title';\n}\n\n/**\n * igxCardHeaderSubtitle is used to denote the header subtitle in a card.\n * Use it to tag text nodes.\n */\n@Directive({\n    selector: '[igxCardHeaderSubtitle]'\n})\nexport class IgxCardHeaderSubtitleDirective {\n    /**\n     * @hidden\n     */\n    @HostBinding('class.igx-card-header__subtitle')\n    public cssClass = 'igx-card-header__subtitle';\n}\n/**\n * IgxCardContent is container for the card content.\n */\n@Directive({\n    // tslint:disable-next-line:directive-selector\n    selector: 'igx-card-content'\n})\nexport class IgxCardContentDirective {\n    /**\n     * @hidden\n     */\n    @HostBinding('class.igx-card-content')\n    public cssClass = 'igx-card-content';\n}\n\n/**\n * IgxCardFooter is container for the card footer\n */\n@Directive({\n    // tslint:disable-next-line:directive-selector\n    selector: 'igx-card-footer'\n})\nexport class IgxCardFooterDirective {\n    /**\n     * An @Input property that sets the value of the `role` attribute of the card footer.\n     * By default the value is set to `footer`.\n     * ```html\n     * <igx-card-footer role=\"footer\"></igx-card-footer>\n     * ```\n     */\n    @HostBinding('attr.role')\n    @Input()\n    public role = 'footer';\n}\n\n/**\n * **Ignite UI for Angular Card** -\n * [Documentation](https://www.infragistics.com/products/ignite-ui-angular/angular/components/card.html)\n *\n * The Ignite UI Card serves as a container that allows custom content to be organized in an appealing way. There are\n * five sections in a card that you can use to organize your content. These are header, media, content, actions, and footer.\n *\n * Example:\n * ```html\n * <igx-card>\n *   <igx-card-header>\n *     <h3 igxCardHeaderTitle>{{title}}</h3>\n *     <h5 igxCardHeaderSubtitle>{{subtitle}}</h5>\n *   </igx-card-header>\n *   <igx-card-actions>\n *       <button igxButton igxRipple>Share</button>\n *       <button igxButton igxRipple>Play Album</button>\n *   </igx-card-actions>\n * </igx-card>\n * ```\n */\n\nexport enum IgxCardType {\n    DEFAULT = 'default',\n    OUTLINED = 'outlined'\n}\n\n@Component({\n    selector: 'igx-card',\n    templateUrl: 'card.component.html'\n})\nexport class IgxCardComponent {\n    /**\n     * Sets/gets the `id` of the card.\n     * If not set, `id` will have value `\"igx-card-0\"`;\n     * ```html\n     * <igx-card id = \"my-first-card\"></igx-card>\n     * ```\n     * ```typescript\n     * let cardId =  this.card.id;\n     * ```\n     * @memberof IgxCardComponent\n     */\n    @HostBinding('attr.id')\n    @Input()\n    public id = `igx-card-${NEXT_ID++}`;\n\n    /**\n     * An @Input property that sets the value of the `role` attribute of the card.\n     * By default the value is set to `group`.\n     * ```html\n     * <igx-card role=\"group\"></igx-card>\n     * ```\n     */\n    @HostBinding('attr.role')\n    @Input()\n    public role = 'group';\n\n    /**\n     * An @Input property that sets the value of the `type` attribute of the card.\n     * By default the value is set to `default`. You can make the card use the\n     * outlined style by setting the value to `outlined`.\n     * ```html\n     * <igx-card type=\"outlined\"></igx-card>\n     * ```\n     */\n    @HostBinding('class.igx-card')\n    @Input()\n    public type: IgxCardType | string = IgxCardType.DEFAULT;\n\n    /**\n     * A getter which will return true if the card type is `outlined`.\n     */\n    @HostBinding('class.igx-card--outlined')\n    get isOutlinedCard() {\n        return this.type === IgxCardType.OUTLINED;\n    }\n\n    /**\n     * An @Input property that sets the value of the `horizontal` attribute of the card.\n     * Setting this to `true` will make the different card sections align horizontally,\n     * essentially flipping the card to the side.\n     * ```html\n     * <igx-card [horizontal]=\"true\"></igx-card>\n     * ```\n     */\n    @HostBinding('class.igx-card--horizontal')\n    @Input()\n    public horizontal = false;\n}\n\nexport enum IgxCardActionsLayout {\n    DEFAULT = 'default',\n    JUSTIFY = 'justify',\n}\n\n/**\n * IgxCardActions is container for the card actions.\n */\n@Component({\n    // tslint:disable-next-line:directive-selector\n    selector: 'igx-card-actions',\n    templateUrl: 'card-actions.component.html'\n})\nexport class IgxCardActionsComponent implements OnInit, OnChanges {\n    private isVerticalSet = false;\n\n    constructor(@Optional() @Inject(IgxCardComponent) public card: IgxCardComponent) { }\n\n    /**\n     * An @Input property that sets the layout style of the actions.\n     * By default icons and icon buttons, as well as regular buttons\n     * are split into two containers, which are then positioned on both ends\n     * of the card-actions area.\n     * You can justify the elements in those groups so they are positioned equally\n     * from one another taking up all the space available along the card actions axis.\n     * ```html\n     * <igx-card-actions layout=\"justify\"></igx-card-actions>\n     * ```\n     */\n    @HostBinding('class.igx-card-actions')\n    @Input()\n    public layout: IgxCardActionsLayout | string = 'default';\n\n    /**\n     * An @Input property that sets the vertical attribute of the actions.\n     * When set to `true` the actions will be layed out vertically.\n     */\n    @HostBinding('class.igx-card-actions--vertical')\n    @Input()\n    public vertical: boolean;\n\n    /**\n     * A getter that returns `true` when the layout has been\n     * set to `justify`.\n     */\n    @HostBinding('class.igx-card-actions--justify')\n    get isJustifyLayout() {\n        return this.layout === IgxCardActionsLayout.JUSTIFY;\n    }\n\n    /**\n     * An @Input property that sets order of the buttons the actions area.\n     * By default all icons/icon buttons are placed at the end of the action\n     * area. Any regular buttons(flat, raised) will appear before the icons/icon buttons\n     * placed in the actions area.\n     * If you want to reverse their positions so that icons appear first, use the `reverse`\n     * attribute.\n     * ```html\n     * <igx-card-actions [reverse]=\"true\"></igx-card-actions>\n     * ```\n     */\n    @HostBinding('class.igx-card-actions--reverse')\n    @Input()\n    public reverse = false;\n\n    ngOnChanges(changes: SimpleChanges) {\n        for (const prop in changes) {\n            if (prop === 'vertical') {\n                this.isVerticalSet = true;\n            }\n        }\n    }\n\n    ngOnInit() {\n        this.vertical = !this.isVerticalSet && this.card.horizontal;\n    }\n}\n\n/**\n * @hidden\n */\n@NgModule({\n    declarations: [\n        IgxCardComponent,\n        IgxCardHeaderComponent,\n        IgxCardMediaDirective,\n        IgxCardContentDirective,\n        IgxCardActionsComponent,\n        IgxCardFooterDirective,\n        IgxCardHeaderTitleDirective,\n        IgxCardHeaderSubtitleDirective,\n        IgxCardThumbnailDirective,\n    ],\n    exports: [\n        IgxCardComponent,\n        IgxCardHeaderComponent,\n        IgxCardMediaDirective,\n        IgxCardContentDirective,\n        IgxCardActionsComponent,\n        IgxCardFooterDirective,\n        IgxCardHeaderTitleDirective,\n        IgxCardHeaderSubtitleDirective,\n        IgxCardThumbnailDirective,\n    ],\n    imports: [CommonModule, IgxButtonModule]\n})\nexport class IgxCardModule { }\n"]}