UNPKG

@junte/ui

Version:

Quality Angular UI components kit

153 lines 15.2 kB
import { __decorate, __metadata } from "tslib"; import { Directive, EmbeddedViewRef, Input, OnDestroy, OnInit, TemplateRef, ViewContainerRef } from '@angular/core'; import { takeWhile } from 'rxjs/operators'; import { PropertyApi } from '../../core/decorators/api'; import { Breakpoint } from '../../core/enums/breakpoint'; import { BreakpointService } from './breakpoint.service'; const breakpoints = [Breakpoint.mobile, Breakpoint.tablet, Breakpoint.desktop, Breakpoint.wide]; export class BreakpointDirective { constructor(breakpoint, templateRef, viewContainerRef) { this.breakpoint = breakpoint; this.templateRef = templateRef; this.viewContainerRef = viewContainerRef; this.destroyed = false; this._target = []; } ngOnInit() { this.matched(this.breakpoint.current); this.breakpoint.changed .pipe(takeWhile(() => !this.destroyed)) .subscribe(b => this.matched(b)); } ngOnDestroy() { this.destroyed = true; } matched(breakpoint) { if (this._target.includes(breakpoint)) { if (!this.view) { this.view = this.viewContainerRef.createEmbeddedView(this.templateRef); } } else { if (!!this.view) { this.viewContainerRef.clear(); this.view = null; } } } } let ForDirective = class ForDirective extends BreakpointDirective { constructor(breakpoint, templateRef, viewContainerRef) { super(breakpoint, templateRef, viewContainerRef); } set target(target) { this._target = [target]; } }; ForDirective.ctorParameters = () => [ { type: BreakpointService }, { type: TemplateRef }, { type: ViewContainerRef } ]; __decorate([ PropertyApi({ name: 'jntFor', description: 'Target break point for rendering', path: 'ui.breakpoints', options: breakpoints }), Input('jntFor'), __metadata("design:type", String), __metadata("design:paramtypes", [String]) ], ForDirective.prototype, "target", null); ForDirective = __decorate([ Directive({ selector: '[jntFor]' }), __metadata("design:paramtypes", [BreakpointService, TemplateRef, ViewContainerRef]) ], ForDirective); export { ForDirective }; const min = { [Breakpoint.mobile]: [Breakpoint.mobile, Breakpoint.tablet, Breakpoint.desktop, Breakpoint.wide], [Breakpoint.tablet]: [Breakpoint.tablet, Breakpoint.desktop, Breakpoint.wide], [Breakpoint.desktop]: [Breakpoint.desktop, Breakpoint.wide], [Breakpoint.wide]: [Breakpoint.wide] }; let ForMinDirective = class ForMinDirective extends BreakpointDirective { constructor(breakpoint, templateRef, viewContainerRef) { super(breakpoint, templateRef, viewContainerRef); } set target(target) { this._target = min[target]; } }; ForMinDirective.ctorParameters = () => [ { type: BreakpointService }, { type: TemplateRef }, { type: ViewContainerRef } ]; __decorate([ PropertyApi({ name: 'jntMinFor', description: 'Min break point for rendering', path: 'ui.breakpoints', options: breakpoints }), Input('jntMinFor'), __metadata("design:type", String), __metadata("design:paramtypes", [String]) ], ForMinDirective.prototype, "target", null); ForMinDirective = __decorate([ Directive({ selector: '[jntMinFor]' }), __metadata("design:paramtypes", [BreakpointService, TemplateRef, ViewContainerRef]) ], ForMinDirective); export { ForMinDirective }; const max = { [Breakpoint.mobile]: [Breakpoint.mobile], [Breakpoint.tablet]: [Breakpoint.mobile, Breakpoint.tablet], [Breakpoint.desktop]: [Breakpoint.mobile, Breakpoint.tablet, Breakpoint.desktop], [Breakpoint.wide]: [Breakpoint.mobile, Breakpoint.tablet, Breakpoint.desktop, Breakpoint.wide] }; let ForMaxDirective = class ForMaxDirective extends BreakpointDirective { constructor(breakpoint, templateRef, viewContainerRef) { super(breakpoint, templateRef, viewContainerRef); } set target(target) { this._target = max[target]; } }; ForMaxDirective.ctorParameters = () => [ { type: BreakpointService }, { type: TemplateRef }, { type: ViewContainerRef } ]; __decorate([ PropertyApi({ name: 'jntMaxFor', description: 'Max break point for rendering', path: 'ui.breakpoints', options: breakpoints }), Input('jntMaxFor'), __metadata("design:type", String), __metadata("design:paramtypes", [String]) ], ForMaxDirective.prototype, "target", null); ForMaxDirective = __decorate([ Directive({ selector: '[jntMaxFor]' }), __metadata("design:paramtypes", [BreakpointService, TemplateRef, ViewContainerRef]) ], ForMaxDirective); export { ForMaxDirective }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"responsive.directives.js","sourceRoot":"ng://@junte/ui/","sources":["lib/layout/responsive/responsive.directives.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, EmbeddedViewRef, Input, OnDestroy, OnInit, TemplateRef, ViewContainerRef } from '@angular/core';\nimport { takeWhile } from 'rxjs/operators';\nimport { PropertyApi } from '../../core/decorators/api';\nimport { Breakpoint } from '../../core/enums/breakpoint';\nimport { BreakpointService } from './breakpoint.service';\n\nconst breakpoints = [Breakpoint.mobile,\n  Breakpoint.tablet,\n  Breakpoint.desktop,\n  Breakpoint.wide];\n\nexport abstract class BreakpointDirective implements OnInit, OnDestroy {\n\n  private destroyed = false;\n  private view: EmbeddedViewRef<any>;\n  protected _target = [];\n\n  protected constructor(private breakpoint: BreakpointService,\n                        private templateRef: TemplateRef<any>,\n                        private viewContainerRef: ViewContainerRef) {\n  }\n\n  ngOnInit() {\n    this.matched(this.breakpoint.current);\n    this.breakpoint.changed\n      .pipe(takeWhile(() => !this.destroyed))\n      .subscribe(b => this.matched(b));\n  }\n\n  ngOnDestroy() {\n    this.destroyed = true;\n  }\n\n  private matched(breakpoint: Breakpoint) {\n    if (this._target.includes(breakpoint)) {\n      if (!this.view) {\n        this.view = this.viewContainerRef.createEmbeddedView(this.templateRef);\n      }\n    } else {\n      if (!!this.view) {\n        this.viewContainerRef.clear();\n        this.view = null;\n      }\n    }\n  }\n\n}\n\n@Directive({\n  selector: '[jntFor]'\n})\nexport class ForDirective extends BreakpointDirective {\n\n  @PropertyApi({\n    name: 'jntFor',\n    description: 'Target break point for rendering',\n    path: 'ui.breakpoints',\n    options: breakpoints\n  })\n  @Input('jntFor')\n  set target(target: Breakpoint) {\n    this._target = [target];\n  }\n\n  constructor(breakpoint: BreakpointService,\n              templateRef: TemplateRef<any>,\n              viewContainerRef: ViewContainerRef) {\n    super(breakpoint, templateRef, viewContainerRef);\n  }\n\n}\n\nconst min = {\n  [Breakpoint.mobile]: [Breakpoint.mobile, Breakpoint.tablet, Breakpoint.desktop, Breakpoint.wide],\n  [Breakpoint.tablet]: [Breakpoint.tablet, Breakpoint.desktop, Breakpoint.wide],\n  [Breakpoint.desktop]: [Breakpoint.desktop, Breakpoint.wide],\n  [Breakpoint.wide]: [Breakpoint.wide]\n};\n\n@Directive({\n  selector: '[jntMinFor]'\n})\nexport class ForMinDirective extends BreakpointDirective {\n\n  @PropertyApi({\n    name: 'jntMinFor',\n    description: 'Min break point for rendering',\n    path: 'ui.breakpoints',\n    options: breakpoints\n  })\n  @Input('jntMinFor')\n  set target(target: Breakpoint) {\n    this._target = min[target];\n  }\n\n  constructor(breakpoint: BreakpointService,\n              templateRef: TemplateRef<any>,\n              viewContainerRef: ViewContainerRef) {\n    super(breakpoint, templateRef, viewContainerRef);\n  }\n\n}\n\nconst max = {\n  [Breakpoint.mobile]: [Breakpoint.mobile],\n  [Breakpoint.tablet]: [Breakpoint.mobile, Breakpoint.tablet],\n  [Breakpoint.desktop]: [Breakpoint.mobile, Breakpoint.tablet, Breakpoint.desktop],\n  [Breakpoint.wide]: [Breakpoint.mobile, Breakpoint.tablet, Breakpoint.desktop, Breakpoint.wide]\n};\n\n@Directive({\n  selector: '[jntMaxFor]'\n})\nexport class ForMaxDirective extends BreakpointDirective {\n\n  @PropertyApi({\n    name: 'jntMaxFor',\n    description: 'Max break point for rendering',\n    path: 'ui.breakpoints',\n    options: breakpoints\n  })\n  @Input('jntMaxFor')\n  set target(target: Breakpoint) {\n    this._target = max[target];\n  }\n\n  constructor(breakpoint: BreakpointService,\n              templateRef: TemplateRef<any>,\n              viewContainerRef: ViewContainerRef) {\n    super(breakpoint, templateRef, viewContainerRef);\n  }\n\n}\n"]}