@junte/ui
Version:
Quality Angular UI components kit
175 lines • 16.8 kB
JavaScript
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"]}