UNPKG

@junte/ui

Version:

Quality Angular UI components kit

192 lines 22.6 kB
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'; const ANIMATION_CLOSE_DURATION = 300; const BACKDROP_FILTER = 'blur(5px)'; var ModalState; (function (ModalState) { ModalState["hidden"] = "hidden"; ModalState["visible"] = "visible"; })(ModalState || (ModalState = {})); export class ModalOptions { constructor(defs = null) { this.maxWidth = '800'; this.maxHeight = '600'; this.hold = false; this.animation = true; Object.assign(this, defs); } } var Display; (function (Display) { Display["block"] = "block"; Display["none"] = "none"; })(Display || (Display = {})); let ModalComponent = class ModalComponent { constructor(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; } set opened(opened) { this._opened = opened; this.opened$.emit(opened); } get opened() { return this._opened; } get windows() { return this.device.platform.windows; } set content(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); } } start(event) { if (event.fromState === ModalState.hidden) { this.display = Display.block; } } done(event) { if (event.toState === ModalState.hidden) { this.display = Display.none; } } // TODO: options to type with optionals?. open(content, 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; } close() { 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(() => { this.content = null; this.renderer.removeStyle(this.backdrop.nativeElement, 'animation'); }, ANIMATION_CLOSE_DURATION); } }; ModalComponent.ctorParameters = () => [ { 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); 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"]}