UNPKG

@kushki/ng-suka

Version:

<p align="center"> <h1 align="center">Suka Components Angular</h1> <p align="center"> An Angular implementation of the Suka Design System </p> </p>

391 lines 23.9 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Directive, Input, ElementRef } from '@angular/core'; export class MarginDirective { /** * @param {?} elementRef */ constructor(elementRef) { this.m = {}; this.elementRef = elementRef; } /** * @return {?} */ ngOnInit() { try { /** @type {?} */ const marginKeys = Object.keys(this.m); marginKeys.forEach((/** * @param {?} key * @return {?} */ key => { if (key === 'all') { this.elementRef.nativeElement.classList.add(`m-${this.m[key]}`); } else { this.elementRef.nativeElement.classList.add(`m-${key}-${this.m[key]}`); } })); } catch (err) { console.error(`Malformed margins\`: ${err}`); } } } MarginDirective.decorators = [ { type: Directive, args: [{ // tslint:disable-next-line: directive-selector selector: '[m]' },] } ]; /** @nocollapse */ MarginDirective.ctorParameters = () => [ { type: ElementRef } ]; MarginDirective.propDecorators = { m: [{ type: Input }] }; if (false) { /** @type {?} */ MarginDirective.prototype.m; /** * @type {?} * @private */ MarginDirective.prototype.elementRef; } export class MarginTopDirective { /** * @param {?} elementRef */ constructor(elementRef) { this.mt = {}; this.elementRef = elementRef; } /** * @return {?} */ ngOnInit() { try { /** @type {?} */ const marginKeys = Object.keys(this.mt); marginKeys.forEach((/** * @param {?} key * @return {?} */ key => { if (key === 'all') { this.elementRef.nativeElement.classList.add(`mt-${this.mt[key]}`); } else { this.elementRef.nativeElement.classList.add(`mt-${key}-${this.mt[key]}`); } })); } catch (err) { console.error(`Malformed margins\`: ${err}`); } } } MarginTopDirective.decorators = [ { type: Directive, args: [{ // tslint:disable-next-line: directive-selector selector: '[mt]' },] } ]; /** @nocollapse */ MarginTopDirective.ctorParameters = () => [ { type: ElementRef } ]; MarginTopDirective.propDecorators = { mt: [{ type: Input }] }; if (false) { /** @type {?} */ MarginTopDirective.prototype.mt; /** * @type {?} * @private */ MarginTopDirective.prototype.elementRef; } export class MarginBottomDirective { /** * @param {?} elementRef */ constructor(elementRef) { this.mb = {}; this.elementRef = elementRef; } /** * @return {?} */ ngOnInit() { try { /** @type {?} */ const marginKeys = Object.keys(this.mb); marginKeys.forEach((/** * @param {?} key * @return {?} */ key => { if (key === 'all') { this.elementRef.nativeElement.classList.add(`mb-${this.mb[key]}`); } else { this.elementRef.nativeElement.classList.add(`mb-${key}-${this.mb[key]}`); } })); } catch (err) { console.error(`Malformed margins\`: ${err}`); } } } MarginBottomDirective.decorators = [ { type: Directive, args: [{ // tslint:disable-next-line: directive-selector selector: '[mb]' },] } ]; /** @nocollapse */ MarginBottomDirective.ctorParameters = () => [ { type: ElementRef } ]; MarginBottomDirective.propDecorators = { mb: [{ type: Input }] }; if (false) { /** @type {?} */ MarginBottomDirective.prototype.mb; /** * @type {?} * @private */ MarginBottomDirective.prototype.elementRef; } export class MarginLeftDirective { /** * @param {?} elementRef */ constructor(elementRef) { this.ml = {}; this.elementRef = elementRef; } /** * @return {?} */ ngOnInit() { try { /** @type {?} */ const marginKeys = Object.keys(this.ml); marginKeys.forEach((/** * @param {?} key * @return {?} */ key => { if (key === 'all') { this.elementRef.nativeElement.classList.add(`ml-${this.ml[key]}`); } else { this.elementRef.nativeElement.classList.add(`ml-${key}-${this.ml[key]}`); } })); } catch (err) { console.error(`Malformed margins\`: ${err}`); } } } MarginLeftDirective.decorators = [ { type: Directive, args: [{ // tslint:disable-next-line: directive-selector selector: '[ml]' },] } ]; /** @nocollapse */ MarginLeftDirective.ctorParameters = () => [ { type: ElementRef } ]; MarginLeftDirective.propDecorators = { ml: [{ type: Input }] }; if (false) { /** @type {?} */ MarginLeftDirective.prototype.ml; /** * @type {?} * @private */ MarginLeftDirective.prototype.elementRef; } export class MarginRightDirective { /** * @param {?} elementRef */ constructor(elementRef) { this.mr = {}; this.elementRef = elementRef; } /** * @return {?} */ ngOnInit() { try { /** @type {?} */ const marginKeys = Object.keys(this.mr); marginKeys.forEach((/** * @param {?} key * @return {?} */ key => { if (key === 'all') { this.elementRef.nativeElement.classList.add(`mr-${this.mr[key]}`); } else { this.elementRef.nativeElement.classList.add(`mr-${key}-${this.mr[key]}`); } })); } catch (err) { console.error(`Malformed margins\`: ${err}`); } } } MarginRightDirective.decorators = [ { type: Directive, args: [{ // tslint:disable-next-line: directive-selector selector: '[mr]' },] } ]; /** @nocollapse */ MarginRightDirective.ctorParameters = () => [ { type: ElementRef } ]; MarginRightDirective.propDecorators = { mr: [{ type: Input }] }; if (false) { /** @type {?} */ MarginRightDirective.prototype.mr; /** * @type {?} * @private */ MarginRightDirective.prototype.elementRef; } export class MarginHorizontalDirective { /** * @param {?} elementRef */ constructor(elementRef) { this.mx = {}; this.elementRef = elementRef; } /** * @return {?} */ ngOnInit() { try { /** @type {?} */ const marginKeys = Object.keys(this.mx); marginKeys.forEach((/** * @param {?} key * @return {?} */ key => { if (key === 'all') { this.elementRef.nativeElement.classList.add(`mx-${this.mx[key]}`); } else { this.elementRef.nativeElement.classList.add(`mx-${key}-${this.mx[key]}`); } })); } catch (err) { console.error(`Malformed margins\`: ${err}`); } } } MarginHorizontalDirective.decorators = [ { type: Directive, args: [{ // tslint:disable-next-line: directive-selector selector: '[mx]' },] } ]; /** @nocollapse */ MarginHorizontalDirective.ctorParameters = () => [ { type: ElementRef } ]; MarginHorizontalDirective.propDecorators = { mx: [{ type: Input }] }; if (false) { /** @type {?} */ MarginHorizontalDirective.prototype.mx; /** * @type {?} * @private */ MarginHorizontalDirective.prototype.elementRef; } export class MarginVerticalDirective { /** * @param {?} elementRef */ constructor(elementRef) { this.my = {}; this.elementRef = elementRef; } /** * @return {?} */ ngOnInit() { try { /** @type {?} */ const marginKeys = Object.keys(this.my); marginKeys.forEach((/** * @param {?} key * @return {?} */ key => { if (key === 'all') { this.elementRef.nativeElement.classList.add(`my-${this.my[key]}`); } else { this.elementRef.nativeElement.classList.add(`my-${key}-${this.my[key]}`); } })); } catch (err) { console.error(`Malformed margins\`: ${err}`); } } } MarginVerticalDirective.decorators = [ { type: Directive, args: [{ // tslint:disable-next-line: directive-selector selector: '[my]' },] } ]; /** @nocollapse */ MarginVerticalDirective.ctorParameters = () => [ { type: ElementRef } ]; MarginVerticalDirective.propDecorators = { my: [{ type: Input }] }; if (false) { /** @type {?} */ MarginVerticalDirective.prototype.my; /** * @type {?} * @private */ MarginVerticalDirective.prototype.elementRef; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"margin.directive.js","sourceRoot":"ng://@kushki/ng-suka/","sources":["lib/spacing/margin.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, Input, OnInit, ElementRef } from '@angular/core';\n\n@Directive({\n  // tslint:disable-next-line: directive-selector\n  selector: '[m]'\n})\nexport class MarginDirective implements OnInit {\n  @Input() m = {};\n\n  private elementRef: ElementRef;\n\n  constructor(elementRef: ElementRef) {\n    this.elementRef = elementRef;\n  }\n\n  ngOnInit() {\n    try {\n      const marginKeys = Object.keys(this.m);\n\n      marginKeys.forEach(key => {\n        if (key === 'all') {\n          this.elementRef.nativeElement.classList.add(`m-${this.m[key]}`);\n        } else {\n          this.elementRef.nativeElement.classList.add(`m-${key}-${this.m[key]}`);\n        }\n      });\n    } catch (err) {\n      console.error(`Malformed margins\\`: ${err}`);\n    }\n  }\n}\n\n@Directive({\n  // tslint:disable-next-line: directive-selector\n  selector: '[mt]'\n})\nexport class MarginTopDirective implements OnInit {\n  @Input() mt = {};\n\n  private elementRef: ElementRef;\n\n  constructor(elementRef: ElementRef) {\n    this.elementRef = elementRef;\n  }\n\n  ngOnInit() {\n    try {\n      const marginKeys = Object.keys(this.mt);\n\n      marginKeys.forEach(key => {\n        if (key === 'all') {\n          this.elementRef.nativeElement.classList.add(`mt-${this.mt[key]}`);\n        } else {\n          this.elementRef.nativeElement.classList.add(`mt-${key}-${this.mt[key]}`);\n        }\n      });\n    } catch (err) {\n      console.error(`Malformed margins\\`: ${err}`);\n    }\n  }\n}\n\n@Directive({\n  // tslint:disable-next-line: directive-selector\n  selector: '[mb]'\n})\nexport class MarginBottomDirective implements OnInit {\n  @Input() mb = {};\n\n  private elementRef: ElementRef;\n\n  constructor(elementRef: ElementRef) {\n    this.elementRef = elementRef;\n  }\n\n  ngOnInit() {\n    try {\n      const marginKeys = Object.keys(this.mb);\n\n      marginKeys.forEach(key => {\n        if (key === 'all') {\n          this.elementRef.nativeElement.classList.add(`mb-${this.mb[key]}`);\n        } else {\n          this.elementRef.nativeElement.classList.add(`mb-${key}-${this.mb[key]}`);\n        }\n      });\n    } catch (err) {\n      console.error(`Malformed margins\\`: ${err}`);\n    }\n  }\n}\n\n@Directive({\n  // tslint:disable-next-line: directive-selector\n  selector: '[ml]'\n})\nexport class MarginLeftDirective implements OnInit {\n  @Input() ml = {};\n\n  private elementRef: ElementRef;\n\n  constructor(elementRef: ElementRef) {\n    this.elementRef = elementRef;\n  }\n\n  ngOnInit() {\n    try {\n      const marginKeys = Object.keys(this.ml);\n\n      marginKeys.forEach(key => {\n        if (key === 'all') {\n          this.elementRef.nativeElement.classList.add(`ml-${this.ml[key]}`);\n        } else {\n          this.elementRef.nativeElement.classList.add(`ml-${key}-${this.ml[key]}`);\n        }\n      });\n    } catch (err) {\n      console.error(`Malformed margins\\`: ${err}`);\n    }\n  }\n}\n\n@Directive({\n  // tslint:disable-next-line: directive-selector\n  selector: '[mr]'\n})\nexport class MarginRightDirective implements OnInit {\n  @Input() mr = {};\n\n  private elementRef: ElementRef;\n\n  constructor(elementRef: ElementRef) {\n    this.elementRef = elementRef;\n  }\n\n  ngOnInit() {\n    try {\n      const marginKeys = Object.keys(this.mr);\n\n      marginKeys.forEach(key => {\n        if (key === 'all') {\n          this.elementRef.nativeElement.classList.add(`mr-${this.mr[key]}`);\n        } else {\n          this.elementRef.nativeElement.classList.add(`mr-${key}-${this.mr[key]}`);\n        }\n      });\n    } catch (err) {\n      console.error(`Malformed margins\\`: ${err}`);\n    }\n  }\n}\n\n@Directive({\n  // tslint:disable-next-line: directive-selector\n  selector: '[mx]'\n})\nexport class MarginHorizontalDirective implements OnInit {\n  @Input() mx = {};\n\n  private elementRef: ElementRef;\n\n  constructor(elementRef: ElementRef) {\n    this.elementRef = elementRef;\n  }\n\n  ngOnInit() {\n    try {\n      const marginKeys = Object.keys(this.mx);\n\n      marginKeys.forEach(key => {\n        if (key === 'all') {\n          this.elementRef.nativeElement.classList.add(`mx-${this.mx[key]}`);\n        } else {\n          this.elementRef.nativeElement.classList.add(`mx-${key}-${this.mx[key]}`);\n        }\n      });\n    } catch (err) {\n      console.error(`Malformed margins\\`: ${err}`);\n    }\n  }\n}\n\n@Directive({\n  // tslint:disable-next-line: directive-selector\n  selector: '[my]'\n})\nexport class MarginVerticalDirective implements OnInit {\n  @Input() my = {};\n\n  private elementRef: ElementRef;\n\n  constructor(elementRef: ElementRef) {\n    this.elementRef = elementRef;\n  }\n\n  ngOnInit() {\n    try {\n      const marginKeys = Object.keys(this.my);\n\n      marginKeys.forEach(key => {\n        if (key === 'all') {\n          this.elementRef.nativeElement.classList.add(`my-${this.my[key]}`);\n        } else {\n          this.elementRef.nativeElement.classList.add(`my-${key}-${this.my[key]}`);\n        }\n      });\n    } catch (err) {\n      console.error(`Malformed margins\\`: ${err}`);\n    }\n  }\n}\n"]}