UNPKG

igniteui-angular

Version:

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

427 lines • 23.5 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Directive, HostBinding, Input, NgModule } from '@angular/core'; export class IgxLayoutDirective { constructor() { /** * 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'; } /** * @hidden * @return {?} */ get flexwrap() { return this.wrap; } /** * @hidden * @return {?} */ get justifycontent() { return this.justify; } /** * @hidden * @return {?} */ get align() { return this.itemAlign; } /** * @hidden * @return {?} */ get direction() { if (this.reverse) { return (this.dir === 'row') ? 'row-reverse' : 'column-reverse'; } return (this.dir === 'row') ? 'row' : 'column'; } } IgxLayoutDirective.decorators = [ { type: Directive, args: [{ selector: '[igxLayout]' },] } ]; IgxLayoutDirective.propDecorators = { dir: [{ type: Input, args: ['igxLayoutDir',] }], reverse: [{ type: Input, args: ['igxLayoutReverse',] }], wrap: [{ type: Input, args: ['igxLayoutWrap',] }], justify: [{ type: Input, args: ['igxLayoutJustify',] }], itemAlign: [{ type: Input, args: ['igxLayoutItemAlign',] }], display: [{ type: HostBinding, args: ['style.display',] }], flexwrap: [{ type: HostBinding, args: ['style.flex-wrap',] }], justifycontent: [{ type: HostBinding, args: ['style.justify-content',] }], align: [{ type: HostBinding, args: ['style.align-items',] }], direction: [{ type: HostBinding, args: ['style.flex-direction',] }] }; if (false) { /** * 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> * ``` * @type {?} */ IgxLayoutDirective.prototype.dir; /** * 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> * ``` * @type {?} */ IgxLayoutDirective.prototype.reverse; /** * 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> * ``` * @type {?} */ IgxLayoutDirective.prototype.wrap; /** * 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> * ``` * @type {?} */ IgxLayoutDirective.prototype.justify; /** * 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> * ``` * @type {?} */ IgxLayoutDirective.prototype.itemAlign; /** * @hidden * @type {?} */ IgxLayoutDirective.prototype.display; } export class IgxFlexDirective { constructor() { /** * 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'; } /** * @hidden * @return {?} */ get style() { if (this.flex) { return `${this.flex}`; } return `${this.grow} ${this.shrink} ${this.basis}`; } /** * @hidden * @return {?} */ get itemorder() { return this.order || 0; } } IgxFlexDirective.decorators = [ { type: Directive, args: [{ selector: '[igxFlex]' },] } ]; IgxFlexDirective.propDecorators = { grow: [{ type: Input, args: ['igxFlexGrow',] }], shrink: [{ type: Input, args: ['igxFlexShrink',] }], flex: [{ type: Input, args: ['igxFlex',] }], order: [{ type: Input, args: ['igxFlexOrder',] }], basis: [{ type: Input, args: ['igxFlexBasis',] }], style: [{ type: HostBinding, args: ['style.flex',] }], itemorder: [{ type: HostBinding, args: ['style.order',] }] }; if (false) { /** * 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> * ``` * @type {?} */ IgxFlexDirective.prototype.grow; /** * 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> * ``` * @type {?} */ IgxFlexDirective.prototype.shrink; /** * Applies the directive to an element. * * Possible values include `igxFlexGrow`, `igxFlexShrink`, `igxFlexOrder`, `igxFlexBasis`. * * ```html * <div igxFlex>Content</div> * ``` * @type {?} */ IgxFlexDirective.prototype.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> * ``` * @type {?} */ IgxFlexDirective.prototype.order; /** * 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> * ``` * @type {?} */ IgxFlexDirective.prototype.basis; } /** * @hidden */ export class IgxLayoutModule { } IgxLayoutModule.decorators = [ { type: NgModule, args: [{ declarations: [IgxFlexDirective, IgxLayoutDirective], exports: [IgxFlexDirective, IgxLayoutDirective] },] } ]; //# 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"]}