igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
543 lines • 37.7 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { CommonModule } from '@angular/common';
import { Component, Directive, HostBinding, Optional, Inject, Input, NgModule } from '@angular/core';
import { IgxButtonModule } from '../directives/button/button.directive';
/** @type {?} */
let NEXT_ID = 0;
/**
* IgxCardMedia is container for the card media section.
* Use it to wrap images and videos.
*/
export 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';
}
}
IgxCardMediaDirective.decorators = [
{ type: Directive, args: [{
// tslint:disable-next-line:directive-selector
selector: 'igx-card-media'
},] }
];
IgxCardMediaDirective.propDecorators = {
cssClass: [{ type: HostBinding, args: ['class.igx-card__media',] }],
width: [{ type: HostBinding, args: ['style.width',] }, { type: HostBinding, args: ['style.min-width',] }, { type: Input }],
height: [{ type: HostBinding, args: ['style.height',] }, { type: Input }],
role: [{ type: HostBinding, args: ['attr.role',] }, { type: Input }]
};
if (false) {
/**
* @hidden
* @type {?}
*/
IgxCardMediaDirective.prototype.cssClass;
/**
* 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>
* ```
* @type {?}
*/
IgxCardMediaDirective.prototype.width;
/**
* 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>
* ```
* @type {?}
*/
IgxCardMediaDirective.prototype.height;
/**
* An \@Input property that sets the `role` attribute of the media container.
* @type {?}
*/
IgxCardMediaDirective.prototype.role;
}
/**
* IgxCardHeader is container for the card header
*/
export 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';
}
}
IgxCardHeaderComponent.decorators = [
{ type: Component, args: [{
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.propDecorators = {
cssClass: [{ type: HostBinding, args: ['class.igx-card-header',] }],
vertical: [{ type: HostBinding, args: ['class.igx-card-header--vertical',] }, { type: Input }],
role: [{ type: HostBinding, args: ['attr.role',] }]
};
if (false) {
/**
* @hidden
* @type {?}
*/
IgxCardHeaderComponent.prototype.cssClass;
/**
* 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>
* ```
* @type {?}
*/
IgxCardHeaderComponent.prototype.vertical;
/**
* 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>
* ```
* @type {?}
*/
IgxCardHeaderComponent.prototype.role;
}
/**
* IgxCardThumbnail is container for the card thumbnail section.
* Use it to wrap anything you want to be used as a thumbnail.
*/
export class IgxCardThumbnailDirective {
}
IgxCardThumbnailDirective.decorators = [
{ type: Directive, args: [{
selector: '[igxCardThumbnail]'
},] }
];
/**
* igxCardHeaderTitle is used to denote the header title in a card.
* Use it to tag text nodes.
*/
export class IgxCardHeaderTitleDirective {
constructor() {
/**
* @hidden
*/
this.cssClass = 'igx-card__header__title';
}
}
IgxCardHeaderTitleDirective.decorators = [
{ type: Directive, args: [{
selector: '[igxCardHeaderTitle]'
},] }
];
IgxCardHeaderTitleDirective.propDecorators = {
cssClass: [{ type: HostBinding, args: ['class.igx-card-header__title',] }]
};
if (false) {
/**
* @hidden
* @type {?}
*/
IgxCardHeaderTitleDirective.prototype.cssClass;
}
/**
* igxCardHeaderSubtitle is used to denote the header subtitle in a card.
* Use it to tag text nodes.
*/
export class IgxCardHeaderSubtitleDirective {
constructor() {
/**
* @hidden
*/
this.cssClass = 'igx-card-header__subtitle';
}
}
IgxCardHeaderSubtitleDirective.decorators = [
{ type: Directive, args: [{
selector: '[igxCardHeaderSubtitle]'
},] }
];
IgxCardHeaderSubtitleDirective.propDecorators = {
cssClass: [{ type: HostBinding, args: ['class.igx-card-header__subtitle',] }]
};
if (false) {
/**
* @hidden
* @type {?}
*/
IgxCardHeaderSubtitleDirective.prototype.cssClass;
}
/**
* IgxCardContent is container for the card content.
*/
export class IgxCardContentDirective {
constructor() {
/**
* @hidden
*/
this.cssClass = 'igx-card-content';
}
}
IgxCardContentDirective.decorators = [
{ type: Directive, args: [{
// tslint:disable-next-line:directive-selector
selector: 'igx-card-content'
},] }
];
IgxCardContentDirective.propDecorators = {
cssClass: [{ type: HostBinding, args: ['class.igx-card-content',] }]
};
if (false) {
/**
* @hidden
* @type {?}
*/
IgxCardContentDirective.prototype.cssClass;
}
/**
* IgxCardFooter is container for the card footer
*/
export 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';
}
}
IgxCardFooterDirective.decorators = [
{ type: Directive, args: [{
// tslint:disable-next-line:directive-selector
selector: 'igx-card-footer'
},] }
];
IgxCardFooterDirective.propDecorators = {
role: [{ type: HostBinding, args: ['attr.role',] }, { type: Input }]
};
if (false) {
/**
* 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>
* ```
* @type {?}
*/
IgxCardFooterDirective.prototype.role;
}
/** @enum {string} */
const IgxCardType = {
DEFAULT: 'default',
OUTLINED: 'outlined',
};
export { IgxCardType };
export 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`.
* @return {?}
*/
get isOutlinedCard() {
return this.type === IgxCardType.OUTLINED;
}
}
IgxCardComponent.decorators = [
{ type: Component, args: [{
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.propDecorators = {
id: [{ type: HostBinding, args: ['attr.id',] }, { type: Input }],
role: [{ type: HostBinding, args: ['attr.role',] }, { type: Input }],
type: [{ type: HostBinding, args: ['class.igx-card',] }, { type: Input }],
isOutlinedCard: [{ type: HostBinding, args: ['class.igx-card--outlined',] }],
horizontal: [{ type: HostBinding, args: ['class.igx-card--horizontal',] }, { type: Input }]
};
if (false) {
/**
* 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
* @type {?}
*/
IgxCardComponent.prototype.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>
* ```
* @type {?}
*/
IgxCardComponent.prototype.role;
/**
* 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>
* ```
* @type {?}
*/
IgxCardComponent.prototype.type;
/**
* 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>
* ```
* @type {?}
*/
IgxCardComponent.prototype.horizontal;
}
/** @enum {string} */
const IgxCardActionsLayout = {
DEFAULT: 'default',
JUSTIFY: 'justify',
};
export { IgxCardActionsLayout };
/**
* IgxCardActions is container for the card actions.
*/
export class IgxCardActionsComponent {
/**
* @param {?} card
*/
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`.
* @return {?}
*/
get isJustifyLayout() {
return this.layout === IgxCardActionsLayout.JUSTIFY;
}
/**
* @param {?} changes
* @return {?}
*/
ngOnChanges(changes) {
for (const prop in changes) {
if (prop === 'vertical') {
this.isVerticalSet = true;
}
}
}
/**
* @return {?}
*/
ngOnInit() {
this.vertical = !this.isVerticalSet && this.card.horizontal;
}
}
IgxCardActionsComponent.decorators = [
{ type: Component, args: [{
// 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"
}] }
];
/** @nocollapse */
IgxCardActionsComponent.ctorParameters = () => [
{ type: IgxCardComponent, decorators: [{ type: Optional }, { type: Inject, args: [IgxCardComponent,] }] }
];
IgxCardActionsComponent.propDecorators = {
layout: [{ type: HostBinding, args: ['class.igx-card-actions',] }, { type: Input }],
vertical: [{ type: HostBinding, args: ['class.igx-card-actions--vertical',] }, { type: Input }],
isJustifyLayout: [{ type: HostBinding, args: ['class.igx-card-actions--justify',] }],
reverse: [{ type: HostBinding, args: ['class.igx-card-actions--reverse',] }, { type: Input }]
};
if (false) {
/**
* @type {?}
* @private
*/
IgxCardActionsComponent.prototype.isVerticalSet;
/**
* 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>
* ```
* @type {?}
*/
IgxCardActionsComponent.prototype.layout;
/**
* An \@Input property that sets the vertical attribute of the actions.
* When set to `true` the actions will be layed out vertically.
* @type {?}
*/
IgxCardActionsComponent.prototype.vertical;
/**
* 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>
* ```
* @type {?}
*/
IgxCardActionsComponent.prototype.reverse;
/** @type {?} */
IgxCardActionsComponent.prototype.card;
}
/**
* @hidden
*/
export class IgxCardModule {
}
IgxCardModule.decorators = [
{ type: NgModule, args: [{
declarations: [
IgxCardComponent,
IgxCardHeaderComponent,
IgxCardMediaDirective,
IgxCardContentDirective,
IgxCardActionsComponent,
IgxCardFooterDirective,
IgxCardHeaderTitleDirective,
IgxCardHeaderSubtitleDirective,
IgxCardThumbnailDirective,
],
exports: [
IgxCardComponent,
IgxCardHeaderComponent,
IgxCardMediaDirective,
IgxCardContentDirective,
IgxCardActionsComponent,
IgxCardFooterDirective,
IgxCardHeaderTitleDirective,
IgxCardHeaderSubtitleDirective,
IgxCardThumbnailDirective,
],
imports: [CommonModule, IgxButtonModule]
},] }
];
//# 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"]}