UNPKG

@junte/ui

Version:

Quality Angular UI components kit

175 lines 16.8 kB
var _a, _b; import { __decorate, __extends, __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'; var breakpoints = [Breakpoint.mobile, Breakpoint.tablet, Breakpoint.desktop, Breakpoint.wide]; var BreakpointDirective = /** @class */ (function () { function BreakpointDirective(breakpoint, templateRef, viewContainerRef) { this.breakpoint = breakpoint; this.templateRef = templateRef; this.viewContainerRef = viewContainerRef; this.destroyed = false; this._target = []; } BreakpointDirective.prototype.ngOnInit = function () { var _this = this; this.matched(this.breakpoint.current); this.breakpoint.changed .pipe(takeWhile(function () { return !_this.destroyed; })) .subscribe(function (b) { return _this.matched(b); }); }; BreakpointDirective.prototype.ngOnDestroy = function () { this.destroyed = true; }; BreakpointDirective.prototype.matched = function (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; } } }; return BreakpointDirective; }()); export { BreakpointDirective }; var ForDirective = /** @class */ (function (_super) { __extends(ForDirective, _super); function ForDirective(breakpoint, templateRef, viewContainerRef) { return _super.call(this, breakpoint, templateRef, viewContainerRef) || this; } Object.defineProperty(ForDirective.prototype, "target", { set: function (target) { this._target = [target]; }, enumerable: true, configurable: true }); ForDirective.ctorParameters = function () { return [ { 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); return ForDirective; }(BreakpointDirective)); export { ForDirective }; var min = (_a = {}, _a[Breakpoint.mobile] = [Breakpoint.mobile, Breakpoint.tablet, Breakpoint.desktop, Breakpoint.wide], _a[Breakpoint.tablet] = [Breakpoint.tablet, Breakpoint.desktop, Breakpoint.wide], _a[Breakpoint.desktop] = [Breakpoint.desktop, Breakpoint.wide], _a[Breakpoint.wide] = [Breakpoint.wide], _a); var ForMinDirective = /** @class */ (function (_super) { __extends(ForMinDirective, _super); function ForMinDirective(breakpoint, templateRef, viewContainerRef) { return _super.call(this, breakpoint, templateRef, viewContainerRef) || this; } Object.defineProperty(ForMinDirective.prototype, "target", { set: function (target) { this._target = min[target]; }, enumerable: true, configurable: true }); ForMinDirective.ctorParameters = function () { return [ { 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); return ForMinDirective; }(BreakpointDirective)); export { ForMinDirective }; var max = (_b = {}, _b[Breakpoint.mobile] = [Breakpoint.mobile], _b[Breakpoint.tablet] = [Breakpoint.mobile, Breakpoint.tablet], _b[Breakpoint.desktop] = [Breakpoint.mobile, Breakpoint.tablet, Breakpoint.desktop], _b[Breakpoint.wide] = [Breakpoint.mobile, Breakpoint.tablet, Breakpoint.desktop, Breakpoint.wide], _b); var ForMaxDirective = /** @class */ (function (_super) { __extends(ForMaxDirective, _super); function ForMaxDirective(breakpoint, templateRef, viewContainerRef) { return _super.call(this, breakpoint, templateRef, viewContainerRef) || this; } Object.defineProperty(ForMaxDirective.prototype, "target", { set: function (target) { this._target = max[target]; }, enumerable: true, configurable: true }); ForMaxDirective.ctorParameters = function () { return [ { 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); return ForMaxDirective; }(BreakpointDirective)); 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"]}