igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
427 lines • 23.5 kB
JavaScript
/**
* @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"]}