@junte/ui
Version:
Quality Angular UI components kit
210 lines • 24 kB
JavaScript
import { __decorate, __metadata } from "tslib";
import { animate, state, style, transition, trigger } from '@angular/animations';
import { Component, ComponentRef, ElementRef, EventEmitter, HostBinding, Input, Output, Renderer2, TemplateRef, ViewChild, ViewContainerRef } from '@angular/core';
import { DeviceService } from '../../layout/responsive/device.service';
import { MethodApi } from '../../core/decorators/api';
import { Breakpoint } from '../../core/enums/breakpoint';
import { UI } from '../../core/enums/ui';
import { BreakpointService } from '../../layout/responsive/breakpoint.service';
var ANIMATION_CLOSE_DURATION = 300;
var BACKDROP_FILTER = 'blur(5px)';
var ModalState;
(function (ModalState) {
ModalState["hidden"] = "hidden";
ModalState["visible"] = "visible";
})(ModalState || (ModalState = {}));
var ModalOptions = /** @class */ (function () {
function ModalOptions(defs) {
if (defs === void 0) { defs = null; }
this.maxWidth = '800';
this.maxHeight = '600';
this.hold = false;
this.animation = true;
Object.assign(this, defs);
}
return ModalOptions;
}());
export { ModalOptions };
var Display;
(function (Display) {
Display["block"] = "block";
Display["none"] = "none";
})(Display || (Display = {}));
var ModalComponent = /** @class */ (function () {
function ModalComponent(renderer, hostRef, breakpoint, device) {
this.renderer = renderer;
this.hostRef = hostRef;
this.breakpoint = breakpoint;
this.device = device;
this.host = 'jnt-modal-host';
this.ui = UI;
this.options = new ModalOptions();
this.mobile = this.breakpoint.current === Breakpoint.mobile;
this.opened$ = new EventEmitter();
this.display = Display.none;
}
Object.defineProperty(ModalComponent.prototype, "opened", {
get: function () {
return this._opened;
},
set: function (opened) {
this._opened = opened;
this.opened$.emit(opened);
},
enumerable: true,
configurable: true
});
Object.defineProperty(ModalComponent.prototype, "windows", {
get: function () {
return this.device.platform.windows;
},
enumerable: true,
configurable: true
});
Object.defineProperty(ModalComponent.prototype, "content", {
set: function (content) {
this.contentTemplate = null;
this.container.clear();
if (content instanceof TemplateRef) {
this.contentTemplate = content;
}
else if (content instanceof ComponentRef) {
this.container.insert(content.hostView, 0);
}
},
enumerable: true,
configurable: true
});
ModalComponent.prototype.start = function (event) {
if (event.fromState === ModalState.hidden) {
this.display = Display.block;
}
};
ModalComponent.prototype.done = function (event) {
if (event.toState === ModalState.hidden) {
this.display = Display.none;
}
};
// TODO: options to type with optionals?.
ModalComponent.prototype.open = function (content, options) {
if (options === void 0) { options = {}; }
this.options = new ModalOptions(options);
this.content = content;
if (!!this.backdrop) {
this.renderer.setStyle(this.backdrop.nativeElement, 'filter', BACKDROP_FILTER);
if (!this.mobile && this.options.animation) {
this.renderer.setStyle(this.backdrop.nativeElement, 'animation', 'jnt-scale-in .5s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards');
}
}
this.renderer.setStyle(document.body, 'overflow', 'hidden');
this.opened = true;
};
ModalComponent.prototype.close = function () {
var _this = this;
this.renderer.removeStyle(document.body, 'overflow');
if (!!this.backdrop) {
this.renderer.removeStyle(this.backdrop.nativeElement, 'filter');
if (!this.mobile && this.options.animation) {
this.renderer.setStyle(this.backdrop.nativeElement, 'animation', 'jnt-scale-out ' + ANIMATION_CLOSE_DURATION + 'ms cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards');
}
}
this.opened = false;
this.hostRef.nativeElement.scrollTop = 0;
setTimeout(function () {
_this.content = null;
_this.renderer.removeStyle(_this.backdrop.nativeElement, 'animation');
}, ANIMATION_CLOSE_DURATION);
};
ModalComponent.ctorParameters = function () { return [
{ type: Renderer2 },
{ type: ElementRef },
{ type: BreakpointService },
{ type: DeviceService }
]; };
__decorate([
HostBinding('attr.host'),
__metadata("design:type", Object)
], ModalComponent.prototype, "host", void 0);
__decorate([
Input(),
__metadata("design:type", ElementRef)
], ModalComponent.prototype, "backdrop", void 0);
__decorate([
Output(),
__metadata("design:type", Object)
], ModalComponent.prototype, "opened$", void 0);
__decorate([
ViewChild('container', { read: ViewContainerRef }),
__metadata("design:type", Object)
], ModalComponent.prototype, "container", void 0);
__decorate([
HostBinding('style.display'),
__metadata("design:type", Object)
], ModalComponent.prototype, "display", void 0);
__decorate([
Input(),
__metadata("design:type", Boolean),
__metadata("design:paramtypes", [Boolean])
], ModalComponent.prototype, "opened", null);
__decorate([
HostBinding('attr.data-windows'),
__metadata("design:type", Object),
__metadata("design:paramtypes", [])
], ModalComponent.prototype, "windows", null);
__decorate([
MethodApi({ description: 'show modal' }),
__metadata("design:type", Function),
__metadata("design:paramtypes", [Object, Object]),
__metadata("design:returntype", void 0)
], ModalComponent.prototype, "open", null);
__decorate([
MethodApi({ description: 'close modal' }),
__metadata("design:type", Function),
__metadata("design:paramtypes", []),
__metadata("design:returntype", void 0)
], ModalComponent.prototype, "close", null);
ModalComponent = __decorate([
Component({
selector: 'jnt-modal',
template: "<jnt-block child-of=\"jnt-modal-host\" [padding]=\"ui.gutter.none\" data-modal\n [@.disabled]=\"mobile\"\n [@move]=\"opened ? 'visible' : 'hidden'\"\n (@move.start)='start($event)'\n (@move.done)='done($event)'>\n <jnt-stack child-of=\"jnt-modal-host\" data-title *ngIf=\"!!options.title\"\n [orientation]=\"ui.orientation.horizontal\"\n [justify]=\"ui.justify.between\"\n [align]=\"ui.align.center\">\n <jnt-stack child-of=\"jnt-modal-host\" [orientation]=\"ui.orientation.horizontal\"\n [gutter]=\"ui.gutter.small\">\n <jnt-icon child-of=\"jnt-modal-host\" *ngIf=\"!!options.title.icon\"\n [icon]=\"options.title.icon\"></jnt-icon>\n <span child-of=\"jnt-modal-host\" data-text>{{options.title.text}}</span>\n </jnt-stack>\n\n <jnt-button child-of=\"jnt-modal-host\" *ngIf=\"!options.hold\"\n [scheme]=\"ui.scheme.secondary\"\n [outline]=\"ui.outline.transparent\"\n [size]=\"ui.size.small\"\n [shape]=\"ui.shape.circle\"\n [icon]=\"ui.icons.close\"\n (click)=\"close()\">\n </jnt-button>\n </jnt-stack>\n\n <div child-of=\"jnt-modal-host\" data-content [ngStyle]=\"{'max-height.px': options.maxHeight, 'max-width.px': options.maxWidth}\"\n [attr.data-windows]=\"device.platform.windows\">\n <ng-container #container>\n <ng-container *ngIf=\"!!contentTemplate\">\n <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\n </ng-container>\n <ng-container *ngIf=\"!!options.content\">\n <ng-container *ngTemplateOutlet=\"options.content\"></ng-container>\n </ng-container>\n </ng-container>\n </div>\n <ng-container *ngIf=\"!!options.footer\">\n <ng-container *ngTemplateOutlet=\"options.footer\"></ng-container>\n </ng-container>\n\n</jnt-block>\n<div child-of=\"jnt-modal-host\" *ngIf=\"!!opened\" #backdrop data-overlay\n (click)=\"!options.hold ? close() : null\"\n [@.disabled]=\"mobile\"\n [@blackout]=\"opened\"></div>",
animations: [
trigger('move', [
state('hidden', style({
top: '100%',
left: '50%',
transform: 'translate(-50%, 0)',
})),
state('visible', style({
top: '50%',
left: '50%',
transform: 'translate(-50%, -50%)',
})),
transition('hidden => visible', [
animate('.5s cubic-bezier(0.165, 0.840, 0.440, 1.000)')
]),
transition('visible => hidden', [
animate('.3s cubic-bezier(0.165, 0.840, 0.440, 1.000)')
]),
]),
trigger('blackout', [
state('void', style({
opacity: 0,
})),
state('*', style({
opacity: 1,
})),
transition('void <=> *', [
animate('.5s ease-in-out')
]),
]),
]
}),
__metadata("design:paramtypes", [Renderer2,
ElementRef,
BreakpointService,
DeviceService])
], ModalComponent);
return ModalComponent;
}());
export { ModalComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"ng://@junte/ui/","sources":["lib/overlays/modal/modal.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { animate, AnimationEvent, state, style, transition, trigger } from '@angular/animations';\nimport {\n  Component,\n  ComponentRef,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Input,\n  Output,\n  Renderer2,\n  TemplateRef,\n  ViewChild,\n  ViewContainerRef\n} from '@angular/core';\nimport { DeviceService } from '../../layout/responsive/device.service';\nimport { MethodApi } from '../../core/decorators/api';\nimport { Breakpoint } from '../../core/enums/breakpoint';\nimport { UI } from '../../core/enums/ui';\nimport { BreakpointService } from '../../layout/responsive/breakpoint.service';\n\nconst ANIMATION_CLOSE_DURATION = 300;\nconst BACKDROP_FILTER = 'blur(5px)';\n\nenum ModalState {\n  hidden = 'hidden',\n  visible = 'visible'\n}\n\ninterface ModalTitle {\n  text?: string;\n  icon?: string;\n}\n\nexport class ModalOptions {\n\n  maxWidth = '800';\n  maxHeight = '600';\n  hold = false;\n  title?: ModalTitle;\n  footer?: TemplateRef<any>;\n  content?: TemplateRef<any>;\n  animation = true;\n\n  constructor(defs: Partial<ModalOptions> = null) {\n    Object.assign(this, defs);\n  }\n\n}\n\nexport type ModalContent = TemplateRef<any> | ComponentRef<any>;\n\nenum Display {\n  block = 'block',\n  none = 'none'\n}\n\n@Component({\n  selector: 'jnt-modal',\n  templateUrl: './modal.encapsulated.html',\n  animations: [\n    trigger('move', [\n        state(\n          'hidden',\n          style({\n            top: '100%',\n            left: '50%',\n            transform: 'translate(-50%, 0)',\n          })\n        ),\n        state(\n          'visible',\n          style({\n            top: '50%',\n            left: '50%',\n            transform: 'translate(-50%, -50%)',\n          })\n        ),\n        transition(\n          'hidden => visible',\n          [\n            animate('.5s cubic-bezier(0.165, 0.840, 0.440, 1.000)')\n          ],\n        ),\n        transition(\n          'visible => hidden',\n          [\n            animate('.3s cubic-bezier(0.165, 0.840, 0.440, 1.000)')\n          ],\n        ),\n      ]\n    ),\n\n    trigger('blackout', [\n        state(\n          'void',\n          style({\n            opacity: 0,\n          })\n        ),\n        state(\n          '*',\n          style({\n            opacity: 1,\n          })\n        ),\n        transition(\n          'void <=> *',\n          [\n            animate('.5s ease-in-out')\n          ]\n        ),\n      ]\n    ),\n  ]\n})\n\nexport class ModalComponent {\n\n  private _opened: boolean;\n\n  @HostBinding('attr.host') readonly host = 'jnt-modal-host';\n\n  ui = UI;\n  contentTemplate: TemplateRef<any>;\n  options: ModalOptions = new ModalOptions();\n  mobile: boolean = this.breakpoint.current === Breakpoint.mobile;\n\n  @Input()\n  backdrop: ElementRef;\n\n  @Output()\n  opened$ = new EventEmitter<boolean>();\n\n  @ViewChild('container', {read: ViewContainerRef})\n  container;\n\n  @HostBinding('style.display')\n  display = Display.none;\n\n  @Input()\n  set opened(opened: boolean) {\n    this._opened = opened;\n    this.opened$.emit(opened);\n  }\n\n  get opened() {\n    return this._opened;\n  }\n\n  @HostBinding('attr.data-windows')\n  get windows() {\n    return this.device.platform.windows;\n  }\n\n  set content(content: ModalContent) {\n    this.contentTemplate = null;\n    this.container.clear();\n\n    if (content instanceof TemplateRef) {\n      this.contentTemplate = content;\n    } else if (content instanceof ComponentRef) {\n      this.container.insert(content.hostView, 0);\n    }\n  }\n\n  constructor(private renderer: Renderer2,\n              private hostRef: ElementRef,\n              private breakpoint: BreakpointService,\n              public device: DeviceService) {\n  }\n\n  start(event: AnimationEvent) {\n    if (event.fromState === ModalState.hidden) {\n      this.display = Display.block;\n    }\n  }\n\n  done(event: AnimationEvent) {\n    if (event.toState === ModalState.hidden) {\n      this.display = Display.none;\n    }\n  }\n\n  // TODO: options to type with optionals?.\n  @MethodApi({description: 'show modal'})\n  open(content: ModalContent, options: Partial<ModalOptions> = {}) {\n    this.options = new ModalOptions(options);\n    this.content = content;\n    if (!!this.backdrop) {\n      this.renderer.setStyle(this.backdrop.nativeElement, 'filter', BACKDROP_FILTER);\n      if (!this.mobile && this.options.animation) {\n        this.renderer.setStyle(this.backdrop.nativeElement, 'animation', 'jnt-scale-in .5s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards');\n      }\n    }\n    this.renderer.setStyle(document.body, 'overflow', 'hidden');\n    this.opened = true;\n  }\n\n  @MethodApi({description: 'close modal'})\n  close() {\n    this.renderer.removeStyle(document.body, 'overflow');\n    if (!!this.backdrop) {\n      this.renderer.removeStyle(this.backdrop.nativeElement, 'filter');\n      if (!this.mobile && this.options.animation) {\n        this.renderer.setStyle(this.backdrop.nativeElement, 'animation', 'jnt-scale-out ' + ANIMATION_CLOSE_DURATION + 'ms cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards');\n      }\n    }\n    this.opened = false;\n    this.hostRef.nativeElement.scrollTop = 0;\n    setTimeout(() => {\n      this.content = null;\n      this.renderer.removeStyle(this.backdrop.nativeElement, 'animation');\n    }, ANIMATION_CLOSE_DURATION);\n  }\n}\n"]}