@coreui/angular
Version:
CoreUI for Angular UI components library
156 lines • 18.2 kB
JavaScript
import { Directive, HostBinding, Input } from '@angular/core';
import { coerceBooleanProperty, coerceNumberProperty } from '@angular/cdk/coercion';
import { BreakpointInfix } from '../coreui.types';
import * as i0 from "@angular/core";
export class ColDirective {
constructor() {
this._xs = false;
this._sm = false;
this._md = false;
this._lg = false;
this._xl = false;
this._xxl = false;
}
/**
* The number of columns/offset/order on extra small devices (<576px).
* @type { 'auto' | number | boolean }
*/
set cCol(value) {
this.xs = this.xs || this.coerceInput(value);
}
set xs(value) {
this._xs = this.coerceInput(value);
}
get xs() {
return this._xs;
}
/**
* The number of columns/offset/order on small devices (<768px).
* @type { 'auto' | number | boolean }
*/
set sm(value) {
this._sm = this.coerceInput(value);
}
get sm() {
return this._sm;
}
/**
* The number of columns/offset/order on medium devices (<992px).
* @type { 'auto' | number | boolean }
*/
set md(value) {
this._md = this.coerceInput(value);
}
get md() {
return this._md;
}
/**
* The number of columns/offset/order on large devices (<1200px).
* @type { 'auto' | number | boolean }
*/
set lg(value) {
this._lg = this.coerceInput(value);
}
get lg() {
return this._lg;
}
/**
* The number of columns/offset/order on X-Large devices (<1400px).
* @type { 'auto' | number | boolean }
*/
set xl(value) {
this._xl = this.coerceInput(value);
}
get xl() {
return this._xl;
}
/**
* The number of columns/offset/order on XX-Large devices (≥1400px).
* @type { 'auto' | number | boolean }
*/
set xxl(value) {
this._xxl = this.coerceInput(value);
}
get xxl() {
return this._xxl;
}
get hostClasses() {
const classes = {
col: true
};
Object.keys(BreakpointInfix).forEach((breakpoint) => {
// @ts-ignore
const value = this[breakpoint];
const infix = breakpoint === 'xs' ? '' : `-${breakpoint}`;
classes[`col${infix}`] = value === true;
classes[`col${infix}-${value}`] = (typeof value === 'number') || (typeof value === 'string');
});
if (typeof this.offset === 'object') {
const offset = { ...this.offset };
Object.entries(offset).forEach((entry) => {
const [breakpoint, value] = [...entry];
const infix = breakpoint === 'xs' ? '' : `-${breakpoint}`;
classes[`offset${infix}-${value}`] = value >= 0 && value <= 11;
});
}
else {
classes[`offset-${this.offset}`] = (typeof this.offset === 'number') && this.offset > 0 && this.offset <= 11;
}
if (typeof this.order === 'object') {
const order = { ...this.order };
Object.entries(order).forEach((entry) => {
const [breakpoint, value] = [...entry];
const infix = breakpoint === 'xs' ? '' : `-${breakpoint}`;
classes[`order${infix}-${value}`] = value;
});
}
else {
classes[`order-${this.order}`] = !!this.order;
}
// if there is no 'col' class, add one
classes.col = (!Object.entries(classes).filter(i => i[0].startsWith('col-') && i[1]).length) || this.xs === true;
return classes;
}
coerceInput(value) {
if (value === 'auto') {
return value;
}
if (value === '' || value === undefined || value === null) {
return coerceBooleanProperty(value);
}
if (typeof value === 'boolean') {
return value;
}
return coerceNumberProperty(value);
}
}
ColDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ColDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
ColDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.0", type: ColDirective, selector: "[cCol]", inputs: { cCol: "cCol", xs: "xs", sm: "sm", md: "md", lg: "lg", xl: "xl", xxl: "xxl", offset: "offset", order: "order" }, host: { properties: { "class": "this.hostClasses" } }, ngImport: i0 });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ColDirective, decorators: [{
type: Directive,
args: [{
selector: '[cCol]'
}]
}], propDecorators: { cCol: [{
type: Input
}], xs: [{
type: Input
}], sm: [{
type: Input
}], md: [{
type: Input
}], lg: [{
type: Input
}], xl: [{
type: Input
}], xxl: [{
type: Input
}], offset: [{
type: Input
}], order: [{
type: Input
}], hostClasses: [{
type: HostBinding,
args: ['class']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"col.directive.js","sourceRoot":"","sources":["../../../../../projects/coreui-angular/src/lib/grid/col.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, HostBinding, Input } from '@angular/core';\r\nimport { BooleanInput, coerceBooleanProperty, coerceNumberProperty, NumberInput } from '@angular/cdk/coercion';\r\n\r\nimport { ColOrder, ICol } from './col.type';\r\nimport { BreakpointInfix } from '../coreui.types';\r\n\r\n@Directive({\r\n  selector: '[cCol]'\r\n})\r\nexport class ColDirective implements ICol {\r\n\r\n  static ngAcceptInputType_cCol: (BooleanInput | NumberInput);\r\n  static ngAcceptInputType_xs: (BooleanInput | NumberInput);\r\n  static ngAcceptInputType_sm: (BooleanInput | NumberInput);\r\n  static ngAcceptInputType_md: (BooleanInput | NumberInput);\r\n  static ngAcceptInputType_lg: (BooleanInput | NumberInput);\r\n  static ngAcceptInputType_xl: (BooleanInput | NumberInput);\r\n  static ngAcceptInputType_xxl: (BooleanInput | NumberInput);\r\n\r\n  /**\r\n   * The number of columns/offset/order on extra small devices (<576px).\r\n   * @type { 'auto' | number |  boolean }\r\n   */\r\n  @Input()\r\n  set cCol(value: (BooleanInput | NumberInput)) {\r\n    this.xs = this.xs || this.coerceInput(value);\r\n  }\r\n  @Input()\r\n  set xs(value) {\r\n    this._xs = this.coerceInput(value);\r\n  }\r\n  get xs(): (BooleanInput | NumberInput) {\r\n    return this._xs;\r\n  }\r\n  private _xs: (BooleanInput | NumberInput) = false;\r\n\r\n  /**\r\n   * The number of columns/offset/order on small devices (<768px).\r\n   * @type { 'auto' | number |  boolean }\r\n   */\r\n  @Input()\r\n  set sm(value) {\r\n    this._sm = this.coerceInput(value);\r\n  }\r\n  get sm(): (BooleanInput | NumberInput) {\r\n    return this._sm;\r\n  }\r\n  private _sm: (BooleanInput | NumberInput) = false;\r\n\r\n  /**\r\n   * The number of columns/offset/order on medium devices (<992px).\r\n   * @type { 'auto' | number |  boolean }\r\n   */\r\n  @Input()\r\n  set md(value) {\r\n    this._md = this.coerceInput(value);\r\n  }\r\n  get md(): (BooleanInput | NumberInput) {\r\n    return this._md;\r\n  }\r\n  private _md: (BooleanInput | NumberInput) = false;\r\n\r\n  /**\r\n   * The number of columns/offset/order on large devices (<1200px).\r\n   * @type { 'auto' | number |  boolean }\r\n   */\r\n  @Input()\r\n  set lg(value) {\r\n    this._lg = this.coerceInput(value);\r\n  }\r\n  get lg(): (BooleanInput | NumberInput) {\r\n    return this._lg;\r\n  }\r\n  private _lg: (BooleanInput | NumberInput) = false;\r\n\r\n  /**\r\n   * The number of columns/offset/order on X-Large devices (<1400px).\r\n   * @type { 'auto' | number |  boolean }\r\n   */\r\n  @Input()\r\n  set xl(value) {\r\n    this._xl = this.coerceInput(value);\r\n  }\r\n  get xl(): (BooleanInput | NumberInput) {\r\n    return this._xl;\r\n  }\r\n  private _xl: (BooleanInput | NumberInput) = false;\r\n\r\n  /**\r\n   * The number of columns/offset/order on XX-Large devices (≥1400px).\r\n   * @type { 'auto' | number |  boolean }\r\n   */\r\n  @Input()\r\n  set xxl(value) {\r\n    this._xxl = this.coerceInput(value);\r\n  }\r\n  get xxl(): (BooleanInput | NumberInput) {\r\n    return this._xxl;\r\n  }\r\n  private _xxl: (BooleanInput | NumberInput) = false;\r\n\r\n  @Input() offset?: (number | { 'xs'?: number, sm?: number, md?: number, lg?: number, xl?: number, xxl?: number });\r\n  @Input() order?: (ColOrder | { xs?: ColOrder, sm?: ColOrder, md?: ColOrder, lg?: ColOrder, xl?: ColOrder, xxl?: ColOrder });\r\n\r\n  @HostBinding('class')\r\n  get hostClasses(): any {\r\n\r\n    const classes: any = {\r\n      col: true\r\n    };\r\n\r\n    Object.keys(BreakpointInfix).forEach((breakpoint) => {\r\n      // @ts-ignore\r\n      const value: number | string | boolean = this[breakpoint];\r\n      const infix = breakpoint === 'xs' ? '' : `-${breakpoint}`;\r\n      classes[`col${infix}`] = value === true;\r\n      classes[`col${infix}-${value}`] = (typeof value === 'number') || (typeof value === 'string');\r\n    });\r\n\r\n    if (typeof this.offset === 'object') {\r\n      const offset = { ...this.offset };\r\n      Object.entries(offset).forEach((entry) => {\r\n        const [breakpoint, value] = [...entry];\r\n        const infix = breakpoint === 'xs' ? '' : `-${breakpoint}`;\r\n        classes[`offset${infix}-${value}`] = value >= 0 && value <= 11;\r\n      });\r\n    } else {\r\n      classes[`offset-${this.offset}`] = (typeof this.offset === 'number') && this.offset > 0 && this.offset <= 11;\r\n    }\r\n\r\n    if (typeof this.order === 'object') {\r\n      const order = { ...this.order };\r\n      Object.entries(order).forEach((entry) => {\r\n        const [breakpoint, value] = [...entry];\r\n        const infix = breakpoint === 'xs' ? '' : `-${breakpoint}`;\r\n        classes[`order${infix}-${value}`] = value;\r\n      });\r\n    } else {\r\n      classes[`order-${this.order}`] = !!this.order;\r\n    }\r\n\r\n    // if there is no 'col' class, add one\r\n    classes.col = (!Object.entries(classes).filter(i => i[0].startsWith('col-') && i[1]).length) || this.xs === true;\r\n    return classes;\r\n  }\r\n\r\n  coerceInput(value: (BooleanInput | NumberInput)) {\r\n    if (value === 'auto') {\r\n      return value;\r\n    }\r\n    if (value === '' || value === undefined || value === null) {\r\n      return coerceBooleanProperty(value);\r\n    }\r\n    if (typeof value === 'boolean') {\r\n      return value;\r\n    }\r\n    return coerceNumberProperty(value);\r\n  }\r\n}\r\n"]}