UNPKG

@junte/ui

Version:

Quality Angular UI components kit

253 lines 24.5 kB
import { __decorate, __metadata } from "tslib"; import { Component, ContentChild, EventEmitter, HostBinding, Input, Output, TemplateRef } from '@angular/core'; import { Height } from '../../core/enums/height'; import { Breakpoint } from '../../core/enums/breakpoint'; import { BreakpointService } from '../responsive/breakpoint.service'; import { ContentApi, PropertyApi } from '../../core/decorators/api'; import { Feature } from '../../core/enums/feature'; import { Gutter } from '../../core/enums/gutter'; import { Position } from '../../core/enums/position'; import { State } from '../../core/enums/state'; import { UI } from '../../core/enums/ui'; import { Width } from '../../core/enums/width'; var Picture = /** @class */ (function () { function Picture(defs) { if (defs === void 0) { defs = null; } this.position = Position.left; this.width = 70; this.height = 70; Object.assign(this, defs); } return Picture; }()); var CardComponent = /** @class */ (function () { function CardComponent(breakpoint) { this.breakpoint = breakpoint; this.ui = UI; this.host = 'jnt-card-host'; this._height = Height.default; this._padding = Gutter.normal; this.width = Width.default; this.features = []; this.selected = new EventEmitter(); } Object.defineProperty(CardComponent.prototype, "hasColor", { get: function () { return !!this.color; }, enumerable: true, configurable: true }); Object.defineProperty(CardComponent.prototype, "hasAction", { get: function () { return !!this.icon || !!this.cardActionsTemplate; }, enumerable: true, configurable: true }); Object.defineProperty(CardComponent.prototype, "height", { set: function (height) { this._height = height || Height.default; }, enumerable: true, configurable: true }); Object.defineProperty(CardComponent.prototype, "__picture__", { set: function (picture) { if (!!picture) { this.picture = typeof (picture) === 'string' ? new Picture({ url: picture, template: null, position: Position.left, width: 70, height: 70 }) : new Picture(picture); } else { this.picture = null; } }, enumerable: true, configurable: true }); Object.defineProperty(CardComponent.prototype, "padding", { set: function (padding) { this._padding = padding || Gutter.normal; }, enumerable: true, configurable: true }); CardComponent.prototype.hideActions = function () { this.popover.hide(); }; Object.defineProperty(CardComponent.prototype, "mobile", { get: function () { return this.breakpoint.current === Breakpoint.mobile; }, enumerable: true, configurable: true }); CardComponent.ctorParameters = function () { return [ { type: BreakpointService } ]; }; __decorate([ HostBinding('attr.host'), __metadata("design:type", Object) ], CardComponent.prototype, "host", void 0); __decorate([ HostBinding('attr.data-height'), __metadata("design:type", String) ], CardComponent.prototype, "_height", void 0); __decorate([ HostBinding('attr.data-has-color'), __metadata("design:type", Object), __metadata("design:paramtypes", []) ], CardComponent.prototype, "hasColor", null); __decorate([ HostBinding('attr.data-has-icon'), __metadata("design:type", Object), __metadata("design:paramtypes", []) ], CardComponent.prototype, "hasAction", null); __decorate([ HostBinding('attr.data-padding'), __metadata("design:type", Object) ], CardComponent.prototype, "_padding", void 0); __decorate([ PropertyApi({ description: 'Title of card', type: 'string' }), Input(), __metadata("design:type", String) ], CardComponent.prototype, "title", void 0); __decorate([ PropertyApi({ description: 'Height of card', path: 'ui.height', options: [Height.default, Height.fluid], default: Height.default }), Input(), __metadata("design:type", String), __metadata("design:paramtypes", [String]) ], CardComponent.prototype, "height", null); __decorate([ PropertyApi({ description: 'Picture on card', type: 'string' }), Input('picture'), __metadata("design:type", Object), __metadata("design:paramtypes", [Object]) ], CardComponent.prototype, "__picture__", null); __decorate([ ContentApi({ selector: '#cardHeaderTemplate', description: 'Card header template' }), ContentChild('cardHeaderTemplate'), __metadata("design:type", TemplateRef) ], CardComponent.prototype, "headerTemplate", void 0); __decorate([ ContentApi({ selector: '#cardTitleTemplate', description: 'Card title template' }), ContentChild('cardTitleTemplate'), __metadata("design:type", TemplateRef) ], CardComponent.prototype, "titleTemplate", void 0); __decorate([ ContentApi({ selector: '#cardFooterTemplate', description: 'Card footer template' }), ContentChild('cardFooterTemplate'), __metadata("design:type", TemplateRef) ], CardComponent.prototype, "footerTemplate", void 0); __decorate([ ContentApi({ selector: '#cardActionsTemplate', description: 'Card actions template' }), ContentChild('cardActionsTemplate'), __metadata("design:type", TemplateRef) ], CardComponent.prototype, "cardActionsTemplate", void 0); __decorate([ PropertyApi({ description: 'Icon indicator', type: 'string' }), Input(), __metadata("design:type", String) ], CardComponent.prototype, "icon", void 0); __decorate([ PropertyApi({ description: 'State of card', path: 'ui.state', options: [State.error, State.loading] }), Input(), __metadata("design:type", String) ], CardComponent.prototype, "state", void 0); __decorate([ PropertyApi({ description: 'Padding for card', path: 'ui.gutter', options: [Gutter.none, Gutter.tiny, Gutter.small, Gutter.normal, Gutter.large, Gutter.big, Gutter.huge] }), Input(), __metadata("design:type", String), __metadata("design:paramtypes", [String]) ], CardComponent.prototype, "padding", null); __decorate([ PropertyApi({ description: 'Card width', path: 'ui.width', default: Width.default, options: [Width.default, Width.fluid] }), HostBinding('attr.data-width'), Input(), __metadata("design:type", String) ], CardComponent.prototype, "width", void 0); __decorate([ PropertyApi({ description: 'Сlickable card; Adapted card on mobile view', path: 'ui.feature', options: [Feature.clickable, Feature.adapted] }), HostBinding('attr.data-features'), Input(), __metadata("design:type", Array) ], CardComponent.prototype, "features", void 0); __decorate([ PropertyApi({ description: 'Card indicator color', type: 'string', default: 'purple' }), Input(), __metadata("design:type", String) ], CardComponent.prototype, "color", void 0); __decorate([ PropertyApi({ description: 'Output event of click on card content', type: 'Event Emitter' }), Output(), __metadata("design:type", Object) ], CardComponent.prototype, "selected", void 0); CardComponent = __decorate([ Component({ selector: 'jnt-card', template: "<div child-of=\"jnt-card-host\" *ngIf=\"!!icon && !cardActionsTemplate\" data-indicator>\n <jnt-icon child-of=\"jnt-card-host\" [icon]=\"icon\"></jnt-icon>\n</div>\n\n<ng-template #cardImageTemplate>\n <img child-of=\"jnt-card-host\" data-image [src]=\"picture.url\" [width]=\"picture.width\" [height]=\"picture.height\" />\n</ng-template>\n\n<jnt-stack child-of=\"jnt-card-host\" data-card\n [attr.tabindex]=\"(features | includes : ui.feature.clickable) ? 1 : null\"\n [orientation]=\"ui.orientation.horizontal\"\n [gutter]=\"ui.gutter.none\"\n [align]=\"ui.align.stretch\">\n <div child-of=\"jnt-card-host\" data-line *ngIf=\"color\" [style.background-color]=\"color\"></div>\n\n <jnt-stack child-of=\"jnt-card-host\" data-main [align]=\"ui.align.stretch\">\n <div child-of=\"jnt-card-host\" *ngIf=\"!!headerTemplate\" data-header>\n <ng-container *ngTemplateOutlet=\"headerTemplate\"></ng-container>\n </div>\n <jnt-stack child-of=\"jnt-card-host\" data-body\n [align]=\"ui.align.stretch\"\n [orientation]=\"(features | includes : ui.feature.adapted) && mobile ? ui.orientation.vertical : ui.orientation.horizontal\"\n (click)=\"!!features && features.includes(ui.feature.clickable) ? selected.emit() : null\">\n <div child-of=\"jnt-card-host\" data-picture *ngIf=\"!!picture && picture.position === ui.position.left\">\n <ng-container *ngIf=\"!!picture.template; else cardImageTemplate\">\n <ng-container *ngTemplateOutlet=\"picture.template\"></ng-container>\n </ng-container>\n </div>\n <div child-of=\"jnt-card-host\" data-content>\n <div child-of=\"jnt-card-host\" *ngIf=\"!!title || !!titleTemplate\" data-title>\n <div child-of=\"jnt-card-host\" data-text *ngIf=\"!!title && !titleTemplate\">{{title}}</div>\n <ng-container *ngIf=\"!!titleTemplate\">\n <ng-container *ngTemplateOutlet=\"titleTemplate\"></ng-container>\n </ng-container>\n </div>\n <ng-content></ng-content>\n </div>\n <div child-of=\"jnt-card-host\" data-picture *ngIf=\"!!picture && picture.position === ui.position.right\">\n <ng-container *ngIf=\"!!picture.template; else cardImageTemplate\">\n <ng-container *ngTemplateOutlet=\"picture.template\"></ng-container>\n </ng-container>\n </div>\n </jnt-stack>\n\n <div child-of=\"jnt-card-host\" *ngIf=\"!!footerTemplate\" data-footer>\n <ng-container *ngTemplateOutlet=\"footerTemplate\"></ng-container>\n </div>\n </jnt-stack>\n\n</jnt-stack>\n\n<jnt-button child-of=\"jnt-card-host\" *ngIf=\"!!cardActionsTemplate\"\n data-action\n [scheme]=\"ui.scheme.secondary\"\n [size]=\"ui.size.small\"\n [icon]=\"ui.icons.actions\"\n (attached)=\"popover = $event\"\n [jntPopover]=\"{\n contentTemplate: dropdownTemplate,\n position: ui.position.right,\n trigger: ui.trigger.click\n }\">\n</jnt-button>\n\n<ng-template #dropdownTemplate>\n <ng-container *ngTemplateOutlet=\"cardActionsTemplate; context: {hide: hideActions.bind(this)}\"></ng-container>\n</ng-template>\n\n<div child-of=\"jnt-card-host\" *ngIf=\"state === ui.state.loading\" data-load>\n <jnt-spinner child-of=\"jnt-card-host\" [size]=\"ui.size.large\"></jnt-spinner>\n</div>\n<div child-of=\"jnt-card-host\" *ngIf=\"state === ui.state.error\" data-error>\n <jnt-icon child-of=\"jnt-card-host\" [icon]=\"ui.icons.sad\"></jnt-icon>\n</div>" }), __metadata("design:paramtypes", [BreakpointService]) ], CardComponent); return CardComponent; }()); export { CardComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"card.component.js","sourceRoot":"ng://@junte/ui/","sources":["lib/layout/card/card.component.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,YAAY,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC/G,OAAO,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAC;AACjD,OAAO,EAAE,UAAU,EAAE,MAAM,6BAA6B,CAAC;AACzD,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AACrE,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAC;AACpE,OAAO,EAAE,OAAO,EAAE,MAAM,0BAA0B,CAAC;AACnD,OAAO,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAC;AACjD,OAAO,EAAE,QAAQ,EAAE,MAAM,2BAA2B,CAAC;AACrD,OAAO,EAAE,KAAK,EAAE,MAAM,wBAAwB,CAAC;AAC/C,OAAO,EAAE,EAAE,EAAE,MAAM,qBAAqB,CAAC;AACzC,OAAO,EAAE,KAAK,EAAE,MAAM,wBAAwB,CAAC;AAG/C;IAOE,iBAAY,IAAgB;QAAhB,qBAAA,EAAA,WAAgB;QAJ5B,aAAQ,GAAa,QAAQ,CAAC,IAAI,CAAC;QACnC,UAAK,GAAG,EAAE,CAAC;QACX,WAAM,GAAG,EAAE,CAAC;QAGV,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IAC5B,CAAC;IACH,cAAC;AAAD,CAAC,AAVD,IAUC;AAMD;IA6JE,uBAAoB,UAA6B;QAA7B,eAAU,GAAV,UAAU,CAAmB;QA3JjD,OAAE,GAAG,EAAE,CAAC;QAE2B,SAAI,GAAG,eAAe,CAAC;QAM1D,YAAO,GAAW,MAAM,CAAC,OAAO,CAAC;QAajC,aAAQ,GAAG,MAAM,CAAC,MAAM,CAAC;QAqGzB,UAAK,GAAU,KAAK,CAAC,OAAO,CAAC;QAS7B,aAAQ,GAAc,EAAE,CAAC;QAcf,aAAQ,GAAG,IAAI,YAAY,EAAO,CAAC;IAW7C,CAAC;IAjJD,sBAAI,mCAAQ;aAAZ;YACE,OAAO,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC;QACtB,CAAC;;;OAAA;IAGD,sBAAI,oCAAS;aAAb;YACE,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC;QACnD,CAAC;;;OAAA;IAkBQ,sBAAI,iCAAM;aAAV,UAAW,MAAc;YAChC,IAAI,CAAC,OAAO,GAAG,MAAM,IAAI,MAAM,CAAC,OAAO,CAAC;QAC1C,CAAC;;;OAAA;IAOD,sBAAI,sCAAW;aAAf,UAAgB,OAAyB;YACvC,IAAI,CAAC,CAAC,OAAO,EAAE;gBACb,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,KAAK,QAAQ;oBAC1C,CAAC,CAAC,IAAI,OAAO,CAAC,EAAC,GAAG,EAAE,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,QAAQ,EAAE,QAAQ,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAC,CAAC,CAAC,CAAC,CAAC,IAAI,OAAO,CAAC,OAAO,CAAC,CAAC;aACxH;iBAAM;gBACL,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;aACrB;QACH,CAAC;;;OAAA;IAyDQ,sBAAI,kCAAO;aAAX,UAAY,OAAe;YAClC,IAAI,CAAC,QAAQ,GAAG,OAAO,IAAI,MAAM,CAAC,MAAM,CAAC;QAC3C,CAAC;;;OAAA;IAoCD,mCAAW,GAAX;QACE,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;IACtB,CAAC;IAED,sBAAI,iCAAM;aAAV;YACE,OAAO,IAAI,CAAC,UAAU,CAAC,OAAO,KAAK,UAAU,CAAC,MAAM,CAAC;QACvD,CAAC;;;OAAA;;gBAE+B,iBAAiB;;IAzJvB;QAAzB,WAAW,CAAC,WAAW,CAAC;;+CAAiC;IAM1D;QADC,WAAW,CAAC,kBAAkB,CAAC;;kDACC;IAGjC;QADC,WAAW,CAAC,qBAAqB,CAAC;;;iDAGlC;IAGD;QADC,WAAW,CAAC,oBAAoB,CAAC;;;kDAGjC;IAGD;QADC,WAAW,CAAC,mBAAmB,CAAC;;mDACR;IAOzB;QALC,WAAW,CAAC;YACX,WAAW,EAAE,eAAe;YAC5B,IAAI,EAAE,QAAQ;SACf,CAAC;QACD,KAAK,EAAE;;gDACM;IAQL;QANR,WAAW,CAAC;YACX,WAAW,EAAE,gBAAgB;YAC7B,IAAI,EAAE,WAAW;YACjB,OAAO,EAAE,CAAC,MAAM,CAAC,OAAO,EAAE,MAAM,CAAC,KAAK,CAAC;YACvC,OAAO,EAAE,MAAM,CAAC,OAAO;SACxB,CAAC;QACD,KAAK,EAAE;;;+CAEP;IAOD;QALC,WAAW,CAAC;YACX,WAAW,EAAE,iBAAiB;YAC9B,IAAI,EAAE,QAAQ;SACf,CAAC;QACD,KAAK,CAAC,SAAS,CAAC;;;oDAQhB;IAOD;QALC,UAAU,CAAC;YACV,QAAQ,EAAE,qBAAqB;YAC/B,WAAW,EAAE,sBAAsB;SACpC,CAAC;QACD,YAAY,CAAC,oBAAoB,CAAC;kCACnB,WAAW;yDAAM;IAOjC;QALC,UAAU,CAAC;YACV,QAAQ,EAAE,oBAAoB;YAC9B,WAAW,EAAE,qBAAqB;SACnC,CAAC;QACD,YAAY,CAAC,mBAAmB,CAAC;kCACnB,WAAW;wDAAM;IAOhC;QALC,UAAU,CAAC;YACV,QAAQ,EAAE,qBAAqB;YAC/B,WAAW,EAAE,sBAAsB;SACpC,CAAC;QACD,YAAY,CAAC,oBAAoB,CAAC;kCACnB,WAAW;yDAAM;IAOjC;QALC,UAAU,CAAC;YACV,QAAQ,EAAE,sBAAsB;YAChC,WAAW,EAAE,uBAAuB;SACrC,CAAC;QACD,YAAY,CAAC,qBAAqB,CAAC;kCACf,WAAW;8DAAM;IAOtC;QALC,WAAW,CAAC;YACX,WAAW,EAAE,gBAAgB;YAC7B,IAAI,EAAE,QAAQ;SACf,CAAC;QACD,KAAK,EAAE;;+CACK;IASb;QAPC,WAAW,CAAC;YACX,WAAW,EAAE,eAAe;YAC5B,IAAI,EAAE,UAAU;YAChB,OAAO,EAAE,CAAC,KAAK,CAAC,KAAK;gBACnB,KAAK,CAAC,OAAO,CAAC;SACjB,CAAC;QACD,KAAK,EAAE;;gDACK;IAaJ;QAXR,WAAW,CAAC;YACX,WAAW,EAAE,kBAAkB;YAC/B,IAAI,EAAE,WAAW;YACjB,OAAO,EAAE,CAAC,MAAM,CAAC,IAAI;gBACnB,MAAM,CAAC,IAAI;gBACX,MAAM,CAAC,KAAK;gBACZ,MAAM,CAAC,MAAM;gBACb,MAAM,CAAC,KAAK;gBACZ,MAAM,CAAC,GAAG;gBACV,MAAM,CAAC,IAAI,CAAC;SACf,CAAC;QACD,KAAK,EAAE;;;gDAEP;IAWD;QATC,WAAW,CAAC;YACX,WAAW,EAAE,YAAY;YACzB,IAAI,EAAE,UAAU;YAChB,OAAO,EAAE,KAAK,CAAC,OAAO;YACtB,OAAO,EAAE,CAAC,KAAK,CAAC,OAAO;gBACrB,KAAK,CAAC,KAAK,CAAC;SACf,CAAC;QACD,WAAW,CAAC,iBAAiB,CAAC;QAC9B,KAAK,EAAE;;gDACqB;IAS7B;QAPC,WAAW,CAAC;YACX,WAAW,EAAE,6CAA6C;YAC1D,IAAI,EAAE,YAAY;YAClB,OAAO,EAAE,CAAC,OAAO,CAAC,SAAS,EAAE,OAAO,CAAC,OAAO,CAAC;SAC9C,CAAC;QACD,WAAW,CAAC,oBAAoB,CAAC;QACjC,KAAK,EAAE;;mDACiB;IAQzB;QANC,WAAW,CAAC;YACX,WAAW,EAAE,sBAAsB;YACnC,IAAI,EAAE,QAAQ;YACd,OAAO,EAAE,QAAQ;SAClB,CAAC;QACD,KAAK,EAAE;;gDACM;IAMJ;QAJT,WAAW,CAAC;YACX,WAAW,EAAE,uCAAuC;YACpD,IAAI,EAAE,eAAe;SACtB,CAAC;QACD,MAAM,EAAE;;mDAAoC;IAnJlC,aAAa;QAJzB,SAAS,CAAC;YACT,QAAQ,EAAE,UAAU;YACpB,shHAAuC;SACxC,CAAC;yCA8JgC,iBAAiB;OA7JtC,aAAa,CAgKzB;IAAD,oBAAC;CAAA,AAhKD,IAgKC;SAhKY,aAAa","sourcesContent":["import { Component, ContentChild, EventEmitter, HostBinding, Input, Output, TemplateRef } from '@angular/core';\nimport { Height } from '../../core/enums/height';\nimport { Breakpoint } from '../../core/enums/breakpoint';\nimport { BreakpointService } from '../responsive/breakpoint.service';\nimport { ContentApi, PropertyApi } from '../../core/decorators/api';\nimport { Feature } from '../../core/enums/feature';\nimport { Gutter } from '../../core/enums/gutter';\nimport { Position } from '../../core/enums/position';\nimport { State } from '../../core/enums/state';\nimport { UI } from '../../core/enums/ui';\nimport { Width } from '../../core/enums/width';\nimport { PopoverComponent } from '../../overlays/popover/popover.component';\n\nclass Picture {\n  url: string;\n  template: TemplateRef<any>;\n  position: Position = Position.left;\n  width = 70;\n  height = 70;\n\n  constructor(defs: any = null) {\n    Object.assign(this, defs);\n  }\n}\n\n@Component({\n  selector: 'jnt-card',\n  templateUrl: './card.encapsulated.html'\n})\nexport class CardComponent {\n\n  ui = UI;\n\n  @HostBinding('attr.host') readonly host = 'jnt-card-host';\n\n  picture: Picture;\n  popover: PopoverComponent;\n\n  @HostBinding('attr.data-height')\n  _height: Height = Height.default;\n\n  @HostBinding('attr.data-has-color')\n  get hasColor() {\n    return !!this.color;\n  }\n\n  @HostBinding('attr.data-has-icon')\n  get hasAction() {\n    return !!this.icon || !!this.cardActionsTemplate;\n  }\n\n  @HostBinding('attr.data-padding')\n  _padding = Gutter.normal;\n\n  @PropertyApi({\n    description: 'Title of card',\n    type: 'string'\n  })\n  @Input()\n  title: string;\n\n  @PropertyApi({\n    description: 'Height of card',\n    path: 'ui.height',\n    options: [Height.default, Height.fluid],\n    default: Height.default\n  })\n  @Input() set height(height: Height) {\n    this._height = height || Height.default;\n  }\n\n  @PropertyApi({\n    description: 'Picture on card',\n    type: 'string'\n  })\n  @Input('picture')\n  set __picture__(picture: string | Picture) {\n    if (!!picture) {\n      this.picture = typeof (picture) === 'string'\n        ? new Picture({url: picture, template: null, position: Position.left, width: 70, height: 70}) : new Picture(picture);\n    } else {\n      this.picture = null;\n    }\n  }\n\n  @ContentApi({\n    selector: '#cardHeaderTemplate',\n    description: 'Card header template'\n  })\n  @ContentChild('cardHeaderTemplate')\n  headerTemplate: TemplateRef<any>;\n\n  @ContentApi({\n    selector: '#cardTitleTemplate',\n    description: 'Card title template'\n  })\n  @ContentChild('cardTitleTemplate')\n  titleTemplate: TemplateRef<any>;\n\n  @ContentApi({\n    selector: '#cardFooterTemplate',\n    description: 'Card footer template'\n  })\n  @ContentChild('cardFooterTemplate')\n  footerTemplate: TemplateRef<any>;\n\n  @ContentApi({\n    selector: '#cardActionsTemplate',\n    description: 'Card actions template'\n  })\n  @ContentChild('cardActionsTemplate')\n  cardActionsTemplate: TemplateRef<any>;\n\n  @PropertyApi({\n    description: 'Icon indicator',\n    type: 'string'\n  })\n  @Input()\n  icon: string;\n\n  @PropertyApi({\n    description: 'State of card',\n    path: 'ui.state',\n    options: [State.error,\n      State.loading]\n  })\n  @Input()\n  state: State;\n\n  @PropertyApi({\n    description: 'Padding for card',\n    path: 'ui.gutter',\n    options: [Gutter.none,\n      Gutter.tiny,\n      Gutter.small,\n      Gutter.normal,\n      Gutter.large,\n      Gutter.big,\n      Gutter.huge]\n  })\n  @Input() set padding(padding: Gutter) {\n    this._padding = padding || Gutter.normal;\n  }\n\n  @PropertyApi({\n    description: 'Card width',\n    path: 'ui.width',\n    default: Width.default,\n    options: [Width.default,\n      Width.fluid]\n  })\n  @HostBinding('attr.data-width')\n  @Input()\n  width: Width = Width.default;\n\n  @PropertyApi({\n    description: 'Сlickable card; Adapted card on mobile view',\n    path: 'ui.feature',\n    options: [Feature.clickable, Feature.adapted]\n  })\n  @HostBinding('attr.data-features')\n  @Input()\n  features: Feature[] = [];\n\n  @PropertyApi({\n    description: 'Card indicator color',\n    type: 'string',\n    default: 'purple'\n  })\n  @Input()\n  color: string;\n\n  @PropertyApi({\n    description: 'Output event of click on card content',\n    type: 'Event Emitter'\n  })\n  @Output() selected = new EventEmitter<any>();\n\n  hideActions() {\n    this.popover.hide();\n  }\n\n  get mobile() {\n    return this.breakpoint.current === Breakpoint.mobile;\n  }\n\n  constructor(private breakpoint: BreakpointService) {\n  }\n\n}\n"]}