UNPKG

@catull/igniteui-angular

Version:

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

444 lines 36.2 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'; 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"]}