UNPKG

@catull/igniteui-angular

Version:

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

466 lines 37.9 kB
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'; var NEXT_ID = 0; /** * IgxCardMedia is container for the card media section. * Use it to wrap images and videos. */ var IgxCardMediaDirective = /** @class */ (function () { function IgxCardMediaDirective() { /** * @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); return IgxCardMediaDirective; }()); export { IgxCardMediaDirective }; /** * IgxCardHeader is container for the card header */ var IgxCardHeaderComponent = /** @class */ (function () { function IgxCardHeaderComponent() { /** * @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); return IgxCardHeaderComponent; }()); export { IgxCardHeaderComponent }; /** * IgxCardThumbnail is container for the card thumbnail section. * Use it to wrap anything you want to be used as a thumbnail. */ var IgxCardThumbnailDirective = /** @class */ (function () { function IgxCardThumbnailDirective() { } IgxCardThumbnailDirective = __decorate([ Directive({ selector: '[igxCardThumbnail]' }) ], IgxCardThumbnailDirective); return IgxCardThumbnailDirective; }()); export { IgxCardThumbnailDirective }; /** * igxCardHeaderTitle is used to denote the header title in a card. * Use it to tag text nodes. */ var IgxCardHeaderTitleDirective = /** @class */ (function () { function IgxCardHeaderTitleDirective() { /** * @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); return IgxCardHeaderTitleDirective; }()); export { IgxCardHeaderTitleDirective }; /** * igxCardHeaderSubtitle is used to denote the header subtitle in a card. * Use it to tag text nodes. */ var IgxCardHeaderSubtitleDirective = /** @class */ (function () { function IgxCardHeaderSubtitleDirective() { /** * @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); return IgxCardHeaderSubtitleDirective; }()); export { IgxCardHeaderSubtitleDirective }; /** * IgxCardContent is container for the card content. */ var IgxCardContentDirective = /** @class */ (function () { function IgxCardContentDirective() { /** * @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); return IgxCardContentDirective; }()); export { IgxCardContentDirective }; /** * IgxCardFooter is container for the card footer */ var IgxCardFooterDirective = /** @class */ (function () { function IgxCardFooterDirective() { /** * 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); return 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 = {})); var IgxCardComponent = /** @class */ (function () { function IgxCardComponent() { /** * 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; } Object.defineProperty(IgxCardComponent.prototype, "isOutlinedCard", { /** * A getter which will return true if the card type is `outlined`. */ get: function () { return this.type === IgxCardType.OUTLINED; }, enumerable: true, configurable: true }); __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); return IgxCardComponent; }()); export { IgxCardComponent }; export var IgxCardActionsLayout; (function (IgxCardActionsLayout) { IgxCardActionsLayout["DEFAULT"] = "default"; IgxCardActionsLayout["JUSTIFY"] = "justify"; })(IgxCardActionsLayout || (IgxCardActionsLayout = {})); /** * IgxCardActions is container for the card actions. */ var IgxCardActionsComponent = /** @class */ (function () { function IgxCardActionsComponent(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; } Object.defineProperty(IgxCardActionsComponent.prototype, "isJustifyLayout", { /** * A getter that returns `true` when the layout has been * set to `justify`. */ get: function () { return this.layout === IgxCardActionsLayout.JUSTIFY; }, enumerable: true, configurable: true }); IgxCardActionsComponent.prototype.ngOnChanges = function (changes) { for (var prop in changes) { if (prop === 'vertical') { this.isVerticalSet = true; } } }; IgxCardActionsComponent.prototype.ngOnInit = function () { this.vertical = !this.isVerticalSet && this.card.horizontal; }; IgxCardActionsComponent.ctorParameters = function () { return [ { 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); return IgxCardActionsComponent; }()); export { IgxCardActionsComponent }; /** * @hidden */ var IgxCardModule = /** @class */ (function () { function 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); return 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"]}