UNPKG

@universis/common

Version:

Universis - common directives and services

185 lines (184 loc) 18.2 kB
import * as tslib_1 from "tslib"; import { Component, Input, ElementRef } from '@angular/core'; import { TranslateService } from '@ngx-translate/core'; import * as jQuery from 'jquery'; const $ = jQuery; import 'bootstrap/js/dist/modal'; export var DIALOG_BUTTONS; (function (DIALOG_BUTTONS) { DIALOG_BUTTONS[DIALOG_BUTTONS["Ok"] = 1] = "Ok"; DIALOG_BUTTONS[DIALOG_BUTTONS["Yes"] = 2] = "Yes"; DIALOG_BUTTONS[DIALOG_BUTTONS["No"] = 4] = "No"; DIALOG_BUTTONS[DIALOG_BUTTONS["Abort"] = 8] = "Abort"; DIALOG_BUTTONS[DIALOG_BUTTONS["Retry"] = 16] = "Retry"; DIALOG_BUTTONS[DIALOG_BUTTONS["Ignore"] = 32] = "Ignore"; DIALOG_BUTTONS[DIALOG_BUTTONS["Cancel"] = 64] = "Cancel"; DIALOG_BUTTONS[DIALOG_BUTTONS["YesNo"] = 6] = "YesNo"; DIALOG_BUTTONS[DIALOG_BUTTONS["AbortRetryIgnore"] = 54] = "AbortRetryIgnore"; DIALOG_BUTTONS[DIALOG_BUTTONS["OkCancel"] = 65] = "OkCancel"; DIALOG_BUTTONS[DIALOG_BUTTONS["YesNoCancel"] = 70] = "YesNoCancel"; })(DIALOG_BUTTONS || (DIALOG_BUTTONS = {})); /** * * A modal dialog component with ok and cancel buttons * @export * @class DialogComponent */ export class DialogComponent { constructor(_element, _translateService) { this._element = _element; this._translateService = _translateService; this.buttons = DIALOG_BUTTONS.Ok; this.language = 'en'; this.language = this._translateService.currentLang; } bitwiseAnd(a, b) { return a & b; } /** * Shows modal dialog * @returns Promise<any> */ show() { return new Promise((resolve, reject) => { if (this.modalRef) { this.modalRef.one('hide.bs.modal', (event) => { // get related target if any const result = this.modalRef.data('result'); // return result return resolve(result); }); this.modalRef.modal('show'); } else { reject('Modal element may not be empty at this context'); } }); } /** * Hides modal dialog * @param value */ hide(value) { this.modalRef.data('result', value); this.modalRef.modal('hide'); } /** * Converts modal buttons classes modal-ok, modal-yes-no etc to dialog buttons * @param {Array<string>} classList */ classListToButtons(classList) { return classList.map(classListElement => { // maps each item to an array of matches (if match) return /^modal(-ok)?(-yes)?(-no)?(-abort)?(-retry)?(-ignore)?(-cancel)?/ig.exec(classListElement); }).filter(match => { // filter not matched elements return match != null; }).map(match => { // maps each match as an array of 2 ^ k results return match.map((item, k) => { if (item && k > 0) { return Math.pow(2, k - 1); } return 0; }).reduce((a, b) => { // return a sum of results return a + b; }); }).reduce((a, b) => { // return a final sum of results return a | b; }); } ngOnInit() { return tslib_1.__awaiter(this, void 0, void 0, function* () { // get element classes const classList = Array.from(this._element.nativeElement.classList); // get buttons from element class list const classListButtons = this.classListToButtons(classList); // if element has button classes (modal-ok, modal-yes-no etc) if (classListButtons) { // set dialog buttons this.buttons = classListButtons; } this.modalRef = $(this._element.nativeElement); // initialize modal this.modalRef.modal({ backdrop: 'static', focus: true, keyboard: false, show: false }); }); } } DialogComponent.decorators = [ { type: Component, args: [{ selector: 'universis-dialog.modal', template: ` <div class="modal-dialog" [ngClass]="theme" role="document"> <div class="modal-content"> <div class="modal-header"> <h4 class="modal-title">{{title | translate}}</h4> </div> <div class="modal-body" [innerHTML]="message"></div> <div class="modal-footer"> <button [lang]="language" type="button" *ngIf="bitwiseAnd(buttons, 1)" (click)="hide('ok')" class="btn btn-theme btn-ok" [translate]="'OK'"></button> <button [lang]="language" type="button" *ngIf="bitwiseAnd(buttons, 2)" (click)="hide('yes')" class="btn btn-theme btn-yes" [translate]="'Yes'"></button> <button [lang]="language" type="button" *ngIf="bitwiseAnd(buttons, 4)" (click)="hide('no')" class="btn btn-gray-100 btn-no" [translate]="'No'"></button> <button [lang]="language" type="button" *ngIf="bitwiseAnd(buttons, 8)" (click)="hide('abort')" class="btn btn-danger btn-abort" [translate]="'Abort'"></button> <button [lang]="language" type="button" *ngIf="bitwiseAnd(buttons, 16)" (click)="hide('retry')" class="btn btn-gray-100 btn-retry" [translate]="'Retry'"></button> <button [lang]="language" type="button" *ngIf="bitwiseAnd(buttons, 32)" (click)="hide('ignore')" class="btn btn-gray-100 btn-ignore" [translate]="'Ignore'"></button> <button [lang]="language" type="button" *ngIf="bitwiseAnd(buttons, 64)" (click)="hide('cancel')" class="btn btn-gray-100 btn-cancel" [translate]="'Cancel'"></button> </div> </div> </div> `, styles: [` .modal-dialog .modal-body { margin-top: 0; margin-bottom: 0; } .modal-footer { border-top: 0; } .modal-ok { // } .modal-ok-cancel { // } .modal-yes-no { // } .modal-yes-no-cancel { // } .modal-abort-ignore-retry { // } .btn { text-transform: uppercase; font-size: 16px; } `] }] } ]; /** @nocollapse */ DialogComponent.ctorParameters = () => [ { type: ElementRef }, { type: TranslateService } ]; DialogComponent.propDecorators = { title: [{ type: Input }], message: [{ type: Input }], theme: [{ type: Input }] }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.component.js","sourceRoot":"ng://@universis/common/","sources":["shared/components/modal/dialog.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, OnInit, Input, ElementRef} from '@angular/core';\nimport {TranslateService} from '@ngx-translate/core';\nimport * as jQuery from 'jquery';\nconst $ = jQuery;\nimport 'bootstrap/js/dist/modal';\nexport enum DIALOG_BUTTONS {\n  Ok = 1,\n  Yes = 2,\n  No = 4,\n  Abort = 8,\n  Retry = 16,\n  Ignore = 32,\n  Cancel = 64,\n  YesNo = 6,\n  AbortRetryIgnore = 54,\n  OkCancel = 65,\n  YesNoCancel = 70\n}\n\n@Component({\n  selector: 'universis-dialog.modal',\n  styles: [`\n    .modal-dialog .modal-body {\n        margin-top: 0;\n        margin-bottom: 0;\n      }\n      .modal-footer {\n        border-top: 0;\n      }\n      .modal-ok {\n        //\n      }\n      .modal-ok-cancel {\n        //\n      }\n      .modal-yes-no {\n        //\n      }\n      .modal-yes-no-cancel {\n        //\n      }\n      .modal-abort-ignore-retry {\n        //\n      }\n      .btn {\n        text-transform: uppercase;\n        font-size: 16px;\n      }\n  `\n  ],\n  template: `\n    <div class=\"modal-dialog\" [ngClass]=\"theme\" role=\"document\">\n      <div class=\"modal-content\">\n        <div class=\"modal-header\">\n          <h4 class=\"modal-title\">{{title | translate}}</h4>\n        </div>\n        <div class=\"modal-body\" [innerHTML]=\"message\"></div>\n        <div class=\"modal-footer\">\n          <button [lang]=\"language\" type=\"button\" *ngIf=\"bitwiseAnd(buttons, 1)\"\n                  (click)=\"hide('ok')\" class=\"btn btn-theme btn-ok\" [translate]=\"'OK'\"></button>\n          <button [lang]=\"language\" type=\"button\" *ngIf=\"bitwiseAnd(buttons, 2)\"\n                  (click)=\"hide('yes')\" class=\"btn btn-theme btn-yes\" [translate]=\"'Yes'\"></button>\n          <button [lang]=\"language\" type=\"button\" *ngIf=\"bitwiseAnd(buttons, 4)\"\n                  (click)=\"hide('no')\" class=\"btn btn-gray-100 btn-no\" [translate]=\"'No'\"></button>\n          <button [lang]=\"language\" type=\"button\" *ngIf=\"bitwiseAnd(buttons, 8)\"\n                  (click)=\"hide('abort')\" class=\"btn btn-danger btn-abort\" [translate]=\"'Abort'\"></button>\n          <button [lang]=\"language\" type=\"button\" *ngIf=\"bitwiseAnd(buttons, 16)\"\n                  (click)=\"hide('retry')\" class=\"btn btn-gray-100 btn-retry\" [translate]=\"'Retry'\"></button>\n          <button [lang]=\"language\" type=\"button\" *ngIf=\"bitwiseAnd(buttons, 32)\"\n                  (click)=\"hide('ignore')\" class=\"btn btn-gray-100 btn-ignore\" [translate]=\"'Ignore'\"></button>\n          <button [lang]=\"language\" type=\"button\" *ngIf=\"bitwiseAnd(buttons, 64)\"\n                  (click)=\"hide('cancel')\"  class=\"btn btn-gray-100 btn-cancel\" [translate]=\"'Cancel'\"></button>\n        </div>\n      </div>\n    </div>\n  `\n})\n/**\n *\n * A modal dialog component with ok and cancel buttons\n * @export\n * @class DialogComponent\n */\nexport class DialogComponent implements OnInit {\n\n\n  @Input() title: string;\n  @Input() message: string;\n  @Input() theme: string;\n  public buttons: DIALOG_BUTTONS = DIALOG_BUTTONS.Ok;\n  private modalRef: any;\n  public language = 'en';\n\n  constructor(private _element: ElementRef, private _translateService: TranslateService) {\n    this.language = this._translateService.currentLang;\n  }\n\n  public bitwiseAnd(a, b) {\n    return a & b;\n  }\n\n  /**\n   * Shows modal dialog\n   * @returns Promise<any>\n   */\n  show() {\n    return new Promise((resolve, reject) => {\n        if (this.modalRef) {\n          this.modalRef.one('hide.bs.modal', (event) => {\n            // get related target if any\n            const result = this.modalRef.data('result');\n            // return result\n            return resolve(result);\n          });\n          this.modalRef.modal('show');\n        } else {\n          reject('Modal element may not be empty at this context');\n        }\n    });\n  }\n\n  /**\n   * Hides modal dialog\n   * @param value\n   */\n  hide(value: any) {\n    this.modalRef.data('result', value);\n    this.modalRef.modal('hide');\n  }\n\n  /**\n   * Converts modal buttons classes modal-ok, modal-yes-no etc to dialog buttons\n   * @param {Array<string>} classList\n   */\n  private classListToButtons(classList: Array<string>) {\n    return classList.map( classListElement => {\n      // maps each item to an array of matches (if match)\n      return /^modal(-ok)?(-yes)?(-no)?(-abort)?(-retry)?(-ignore)?(-cancel)?/ig.exec(classListElement);\n    }).filter(match => {\n      // filter not matched elements\n      return match != null;\n    }).map( match => {\n      // maps each match as an array of 2 ^ k results\n      return match.map((item, k) => {\n        if (item && k > 0) {\n          return Math.pow(2, k - 1);\n        }\n        return 0;\n      }).reduce( (a, b) => {\n        // return a sum of results\n        return a + b;\n      });\n    }).reduce( (a, b) => {\n      // return a final sum of results\n      return a | b;\n    });\n  }\n\n  async ngOnInit() {\n    // get element classes\n    const classList = Array.from((<HTMLDivElement>this._element.nativeElement).classList);\n    // get buttons from element class list\n    const classListButtons = this.classListToButtons(classList);\n    // if element has button classes (modal-ok, modal-yes-no etc)\n    if (classListButtons) {\n      // set dialog buttons\n      this.buttons = classListButtons;\n    }\n    this.modalRef = $(this._element.nativeElement);\n    // initialize modal\n    this.modalRef.modal({\n      backdrop: 'static',\n      focus: true,\n      keyboard: false,\n      show: false\n    });\n  }\n}\n"]}