UNPKG

@catull/igniteui-angular

Version:

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

331 lines 22.3 kB
import { __decorate, __metadata } from "tslib"; import { Directive, HostBinding, Input, NgModule } from '@angular/core'; var IgxLayoutDirective = /** @class */ (function () { function IgxLayoutDirective() { /** * Sets the default flow direction of the container's children. * * Defaults to `rows`. * * ```html * <div * igxLayout * igxLayoutDir="row"> * <div igxFlex>1</div> * <div igxFlex>2</div> * <div igxFlex>3</div> * </div> * ``` */ this.dir = 'row'; /** * Defines the direction flex children are placed in the flex container. * * When set to `true`, the `rows` direction goes right to left and `columns` goes bottom to top. * * ```html * <div * igxLayout * igxLayoutReverse="true"> * <div igxFlex>1</div> * <div igxFlex>2</div> * <div igxFlex>3</div> * </div> * ``` */ this.reverse = false; /** * By default the immediate children will all try to fit onto one line. * * The default value `nowrap` sets this behavior. * * Other accepted values are `wrap` and `wrap-reverse`. * * ```html * <div * igxLayout * igxLayoutDir="row" * igxLayoutWrap="wrap"> * <div igxFlex igxFlexGrow="0">1</div> * <div igxFlex igxFlexGrow="0">2</div> * <div igxFlex igxFlexGrow="0">3</div> * </div> * ``` */ this.wrap = 'nowrap'; /** * Defines the alignment along the main axis. * * Defaults to `flex-start` which packs the children toward the start line. * * Other possible values are `flex-end`, `center`, `space-between`, `space-around`. * * ```html * <div * igxLayout * igxLayoutDir="column" * igxLayoutJustify="space-between"> * <div>1</div> * <div>2</div> * <div>3</div> * </div> * ``` */ this.justify = 'flex-start'; /** * Defines the default behavior for how children are laid out along the corss axis of the current line. * * Defaults to `flex-start`. * * Other possible values are `flex-end`, `center`, `baseline`, and `stretch`. * * ```html * <div * igxLayout * igxLayoutDir="column" * igxLayoutItemAlign="start"> * <div igxFlex igxFlexGrow="0">1</div> * <div igxFlex igxFlexGrow="0">2</div> * <div igxFlex igxFlexGrow="0">3</div> * </div> * ``` */ this.itemAlign = 'stretch'; /** * @hidden */ this.display = 'flex'; } Object.defineProperty(IgxLayoutDirective.prototype, "flexwrap", { /** * @hidden */ get: function () { return this.wrap; }, enumerable: true, configurable: true }); Object.defineProperty(IgxLayoutDirective.prototype, "justifycontent", { /** * @hidden */ get: function () { return this.justify; }, enumerable: true, configurable: true }); Object.defineProperty(IgxLayoutDirective.prototype, "align", { /** * @hidden */ get: function () { return this.itemAlign; }, enumerable: true, configurable: true }); Object.defineProperty(IgxLayoutDirective.prototype, "direction", { /** * @hidden */ get: function () { if (this.reverse) { return (this.dir === 'row') ? 'row-reverse' : 'column-reverse'; } return (this.dir === 'row') ? 'row' : 'column'; }, enumerable: true, configurable: true }); __decorate([ Input('igxLayoutDir'), __metadata("design:type", Object) ], IgxLayoutDirective.prototype, "dir", void 0); __decorate([ Input('igxLayoutReverse'), __metadata("design:type", Object) ], IgxLayoutDirective.prototype, "reverse", void 0); __decorate([ Input('igxLayoutWrap'), __metadata("design:type", Object) ], IgxLayoutDirective.prototype, "wrap", void 0); __decorate([ Input('igxLayoutJustify'), __metadata("design:type", Object) ], IgxLayoutDirective.prototype, "justify", void 0); __decorate([ Input('igxLayoutItemAlign'), __metadata("design:type", Object) ], IgxLayoutDirective.prototype, "itemAlign", void 0); __decorate([ HostBinding('style.display'), __metadata("design:type", Object) ], IgxLayoutDirective.prototype, "display", void 0); __decorate([ HostBinding('style.flex-wrap'), __metadata("design:type", Object), __metadata("design:paramtypes", []) ], IgxLayoutDirective.prototype, "flexwrap", null); __decorate([ HostBinding('style.justify-content'), __metadata("design:type", Object), __metadata("design:paramtypes", []) ], IgxLayoutDirective.prototype, "justifycontent", null); __decorate([ HostBinding('style.align-items'), __metadata("design:type", Object), __metadata("design:paramtypes", []) ], IgxLayoutDirective.prototype, "align", null); __decorate([ HostBinding('style.flex-direction'), __metadata("design:type", Object), __metadata("design:paramtypes", []) ], IgxLayoutDirective.prototype, "direction", null); IgxLayoutDirective = __decorate([ Directive({ selector: '[igxLayout]' }) ], IgxLayoutDirective); return IgxLayoutDirective; }()); export { IgxLayoutDirective }; var IgxFlexDirective = /** @class */ (function () { function IgxFlexDirective() { /** * Applies the `grow` attribute to an element that uses the directive. * * Default value is `1`. * * ```html * <div> * <div igxFlex igxFlexGrow="0">Content1</div> * <div igxFlex igxFlexGrow="1">Content2</div> * <div igxFlex igxFlexGrow="0">Content3</div> * </div> * ``` */ this.grow = 1; /** * Applies the `shrink` attribute to an element that uses the directive. * * Default value is `1`. * * ```html * <div> * <div igxFlex igxFlexShrink="1">Content1</div> * <div igxFlex igxFlexShrink="0">Content2</div> * <div igxFlex igxFlexShrink="1">Content3</div> * </div> * ``` */ this.shrink = 1; /** * Applies the directive to an element. * * Possible values include `igxFlexGrow`, `igxFlexShrink`, `igxFlexOrder`, `igxFlexBasis`. * * ```html * <div igxFlex>Content</div> * ``` */ this.flex = ''; /** * Applies the `order` attribute to an element that uses the directive. * * Default value is `0`. * * ```html * <div> * <div igxFlex igxFlexOrder="1">Content1</div> * <div igxFlex igxFlexOrder="0">Content2</div> * <div igxFlex igxFlexOrder="2">Content3</div> * </div> * ``` */ this.order = 0; /** * Applies the `flex-basis` attribute to an element that uses the directive. * * Default value is `auto`. * * Other possible values include `content`, `max-content`, `min-content`, `fit-content`. * * ```html * <div igxFlex igxFlexBasis="fit-content">Content</div> * ``` */ this.basis = 'auto'; } Object.defineProperty(IgxFlexDirective.prototype, "style", { /** * @hidden */ get: function () { if (this.flex) { return "" + this.flex; } return this.grow + " " + this.shrink + " " + this.basis; }, enumerable: true, configurable: true }); Object.defineProperty(IgxFlexDirective.prototype, "itemorder", { /** * @hidden */ get: function () { return this.order || 0; }, enumerable: true, configurable: true }); __decorate([ Input('igxFlexGrow'), __metadata("design:type", Object) ], IgxFlexDirective.prototype, "grow", void 0); __decorate([ Input('igxFlexShrink'), __metadata("design:type", Object) ], IgxFlexDirective.prototype, "shrink", void 0); __decorate([ Input('igxFlex'), __metadata("design:type", Object) ], IgxFlexDirective.prototype, "flex", void 0); __decorate([ Input('igxFlexOrder'), __metadata("design:type", Object) ], IgxFlexDirective.prototype, "order", void 0); __decorate([ Input('igxFlexBasis'), __metadata("design:type", Object) ], IgxFlexDirective.prototype, "basis", void 0); __decorate([ HostBinding('style.flex'), __metadata("design:type", Object), __metadata("design:paramtypes", []) ], IgxFlexDirective.prototype, "style", null); __decorate([ HostBinding('style.order'), __metadata("design:type", Object), __metadata("design:paramtypes", []) ], IgxFlexDirective.prototype, "itemorder", null); IgxFlexDirective = __decorate([ Directive({ selector: '[igxFlex]' }) ], IgxFlexDirective); return IgxFlexDirective; }()); export { IgxFlexDirective }; /** * @hidden */ var IgxLayoutModule = /** @class */ (function () { function IgxLayoutModule() { } IgxLayoutModule = __decorate([ NgModule({ declarations: [IgxFlexDirective, IgxLayoutDirective], exports: [IgxFlexDirective, IgxLayoutDirective] }) ], IgxLayoutModule); return IgxLayoutModule; }()); export { IgxLayoutModule }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"layout.directive.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/directives/layout/layout.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, HostBinding, Input, NgModule } from '@angular/core';\n\n@Directive({\n    selector: '[igxLayout]'\n})\nexport class IgxLayoutDirective {\n    /**\n     * Sets the default flow direction of the container's children.\n     *\n     * Defaults to `rows`.\n     *\n     * ```html\n     *  <div\n     *   igxLayout\n     *   igxLayoutDir=\"row\">\n     *    <div igxFlex>1</div>\n     *    <div igxFlex>2</div>\n     *    <div igxFlex>3</div>\n     *  </div>\n     * ```\n     */\n    @Input('igxLayoutDir') public dir = 'row';\n\n    /**\n     * Defines the direction flex children are placed in the flex container.\n     *\n     * When set to `true`, the `rows` direction goes right to left and `columns` goes bottom to top.\n     *\n     * ```html\n     * <div\n     *   igxLayout\n     *   igxLayoutReverse=\"true\">\n     *    <div igxFlex>1</div>\n     *    <div igxFlex>2</div>\n     *    <div igxFlex>3</div>\n     * </div>\n     * ```\n     */\n    @Input('igxLayoutReverse') public reverse = false;\n\n    /**\n     * By default the immediate children will all try to fit onto one line.\n     *\n     * The default value `nowrap` sets this behavior.\n     *\n     * Other accepted values are `wrap` and `wrap-reverse`.\n     *\n     * ```html\n     * <div\n     *   igxLayout\n     *   igxLayoutDir=\"row\"\n     *   igxLayoutWrap=\"wrap\">\n     *    <div igxFlex igxFlexGrow=\"0\">1</div>\n     *    <div igxFlex igxFlexGrow=\"0\">2</div>\n     *    <div igxFlex igxFlexGrow=\"0\">3</div>\n     * </div>\n     * ```\n     */\n    @Input('igxLayoutWrap') public wrap = 'nowrap';\n\n    /**\n     * Defines the alignment along the main axis.\n     *\n     * Defaults to `flex-start` which packs the children toward the start line.\n     *\n     * Other possible values are `flex-end`, `center`, `space-between`, `space-around`.\n     *\n     * ```html\n     * <div\n     *   igxLayout\n     *   igxLayoutDir=\"column\"\n     *   igxLayoutJustify=\"space-between\">\n     *    <div>1</div>\n     *    <div>2</div>\n     *    <div>3</div>\n     * </div>\n     * ```\n     */\n    @Input('igxLayoutJustify') public justify = 'flex-start';\n\n    /**\n     * Defines the default behavior for how children are laid out along the corss axis of the current line.\n     *\n     * Defaults to `flex-start`.\n     *\n     * Other possible values are `flex-end`, `center`, `baseline`, and `stretch`.\n     *\n     * ```html\n     * <div\n     *   igxLayout\n     *   igxLayoutDir=\"column\"\n     *   igxLayoutItemAlign=\"start\">\n     *    <div igxFlex igxFlexGrow=\"0\">1</div>\n     *    <div igxFlex igxFlexGrow=\"0\">2</div>\n     *    <div igxFlex igxFlexGrow=\"0\">3</div>\n     * </div>\n     * ```\n     */\n    @Input('igxLayoutItemAlign') public itemAlign = 'stretch';\n\n    /**\n     * @hidden\n     */\n    @HostBinding('style.display') public display = 'flex';\n\n    /**\n     * @hidden\n     */\n    @HostBinding('style.flex-wrap') get flexwrap() { return this.wrap; }\n\n    /**\n     * @hidden\n     */\n    @HostBinding('style.justify-content') get justifycontent() { return this.justify; }\n\n    /**\n     * @hidden\n     */\n    @HostBinding('style.align-items') get align() { return this.itemAlign; }\n\n    /**\n     * @hidden\n     */\n    @HostBinding('style.flex-direction')\n    get direction() {\n        if (this.reverse) {\n            return (this.dir === 'row') ? 'row-reverse' : 'column-reverse';\n        }\n        return (this.dir === 'row') ? 'row' : 'column';\n    }\n}\n\n@Directive({\n    selector: '[igxFlex]'\n})\nexport class IgxFlexDirective {\n\n    /**\n     * Applies the `grow` attribute to an element that uses the directive.\n     *\n     * Default value is `1`.\n     *\n     * ```html\n     * <div>\n     *    <div igxFlex igxFlexGrow=\"0\">Content1</div>\n     *    <div igxFlex igxFlexGrow=\"1\">Content2</div>\n     *    <div igxFlex igxFlexGrow=\"0\">Content3</div>\n     * </div>\n     * ```\n     */\n    @Input('igxFlexGrow') public grow = 1;\n\n    /**\n     * Applies the `shrink` attribute to an element that uses the directive.\n     *\n     * Default value is `1`.\n     *\n     * ```html\n     * <div>\n     *    <div igxFlex igxFlexShrink=\"1\">Content1</div>\n     *    <div igxFlex igxFlexShrink=\"0\">Content2</div>\n     *    <div igxFlex igxFlexShrink=\"1\">Content3</div>\n     * </div>\n     * ```\n     */\n    @Input('igxFlexShrink') public shrink = 1;\n\n    /**\n     * Applies the directive to an element.\n     *\n     * Possible values include `igxFlexGrow`, `igxFlexShrink`, `igxFlexOrder`, `igxFlexBasis`.\n     *\n     * ```html\n     * <div igxFlex>Content</div>\n     * ```\n     */\n    @Input('igxFlex') public flex = '';\n\n    /**\n     * Applies the `order` attribute to an element that uses the directive.\n     *\n     * Default value is `0`.\n     *\n     * ```html\n     * <div>\n     *    <div igxFlex igxFlexOrder=\"1\">Content1</div>\n     *    <div igxFlex igxFlexOrder=\"0\">Content2</div>\n     *    <div igxFlex igxFlexOrder=\"2\">Content3</div>\n     * </div>\n     * ```\n     */\n    @Input('igxFlexOrder') public order = 0;\n\n    /**\n     * Applies the `flex-basis` attribute to an element that uses the directive.\n     *\n     * Default value is `auto`.\n     *\n     * Other possible values include `content`, `max-content`, `min-content`, `fit-content`.\n     *\n     * ```html\n     * <div igxFlex igxFlexBasis=\"fit-content\">Content</div>\n     * ```\n     */\n    @Input('igxFlexBasis') public basis = 'auto';\n\n    /**\n     * @hidden\n     */\n    @HostBinding('style.flex')\n    get style() {\n        if (this.flex) {\n            return `${this.flex}`;\n        }\n        return `${this.grow} ${this.shrink} ${this.basis}`;\n    }\n\n    /**\n     * @hidden\n     */\n    @HostBinding('style.order')\n    get itemorder() {\n        return this.order || 0;\n    }\n}\n\n/**\n * @hidden\n */\n@NgModule({\n    declarations: [IgxFlexDirective, IgxLayoutDirective],\n    exports: [IgxFlexDirective, IgxLayoutDirective]\n})\nexport class IgxLayoutModule { }\n"]}