Socket
Socket
Sign inDemoInstall

ngx-kjua

Package Overview
Dependencies
Maintainers
1
Versions
52
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

ngx-kjua - npm Package Compare versions

Comparing version 1.8.0 to 1.12.0

2

app/modules/ngx-kjua/ngx-kjua.component.d.ts

@@ -51,3 +51,3 @@ import { AfterViewInit, OnChanges, SimpleChanges } from "@angular/core";

*/
mode: "plain" | "label" | "image";
mode: "plain" | "label" | "image" | "imagelabel" | "labelimage";
/**

@@ -54,0 +54,0 @@ * label/image size and pos in pc= 0..100

@@ -14,3 +14,3 @@ (function (global, factory) {

*/
this.render = "image";
this.render = "svg";
/**

@@ -17,0 +17,0 @@ * render pixel-perfect lines

@@ -1,2 +0,2 @@

!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("@angular/common")):"function"==typeof define&&define.amd?define("ngx-kjua",["exports","@angular/core","@angular/common"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self)["ngx-kjua"]={},e.ng.core,e.ng.common)}(this,(function(e,t,i){"use strict";var n,o=function(){function e(e){this.platformId=e,this.render="image",this.crisp=!0,this.minVersion=1,this.ecLevel="L",this.size=200,this.ratio=void 0,this.fill="#333",this.back="#fff",this.text="",this.rounded=0,this.quiet=0,this.mode="plain",this.mSize=30,this.mPosX=50,this.mPosY=50,this.image=void 0,this.imageAsCode=!1,this.label="",this.fontname="sans-serif",this.fontcolor="#333",this.fontoutline=!0,this.renderAsync=!1,this.viewInitialized=!1,i.isPlatformServer(this.platformId)||n||(n=require("kjua-svg"))}return e.prototype.ngAfterViewInit=function(){this.viewInitialized=!0,this.updateView()},e.prototype.ngOnChanges=function(e){this.viewInitialized&&this.updateView()},Object.defineProperty(e.prototype,"template",{get:function(){var e={render:this.render,crisp:this.crisp,minVersion:this.minVersion,ecLevel:this.ecLevel,size:this.size,ratio:this.ratio,fill:this.fill,back:this.back,text:this.text,rounded:this.rounded,quiet:this.quiet,mode:this.mode,mSize:this.mSize,mPosX:this.mPosX,mPosY:this.mPosY,label:this.label,fontname:this.fontname,fontcolor:this.fontcolor,image:this.image,fontoutline:this.fontoutline,imageAsCode:this.imageAsCode};return console.debug("kjua settings used:",e),n(e)},enumerable:!1,configurable:!0}),e.prototype.renderCode=function(){this.div.nativeElement.innerHTML="",this.div.nativeElement.appendChild(this.template)},e.prototype.updateView=function(){var e=this;this.div.nativeElement.style.width=+this.size,this.div.nativeElement.style.height=+this.size,this.renderAsync?requestAnimationFrame((function(){return e.renderCode()})):this.renderCode()},e}();o.decorators=[{type:t.Component,args:[{selector:"ngx-kjua",template:'\n <div [class]="cssClass" #elem></div>',changeDetection:t.ChangeDetectionStrategy.OnPush,styles:["\n :host {\n display: block;\n }\n "]}]}],o.ctorParameters=function(){return[{type:Object,decorators:[{type:t.Inject,args:[t.PLATFORM_ID]}]}]},o.propDecorators={render:[{type:t.Input}],crisp:[{type:t.Input}],minVersion:[{type:t.Input}],ecLevel:[{type:t.Input}],size:[{type:t.Input}],ratio:[{type:t.Input}],fill:[{type:t.Input}],back:[{type:t.Input}],text:[{type:t.Input}],rounded:[{type:t.Input}],quiet:[{type:t.Input}],mode:[{type:t.Input}],mSize:[{type:t.Input}],mPosX:[{type:t.Input}],mPosY:[{type:t.Input}],image:[{type:t.Input}],imageAsCode:[{type:t.Input}],label:[{type:t.Input}],fontname:[{type:t.Input}],fontcolor:[{type:t.Input}],fontoutline:[{type:t.Input}],renderAsync:[{type:t.Input}],cssClass:[{type:t.Input}],div:[{type:t.ViewChild,args:["elem"]}]};var s=function(){};s.decorators=[{type:t.NgModule,args:[{imports:[i.CommonModule],declarations:[o],exports:[o]}]}];var r=function(){function e(){}return e.makeSMS=function(e,t){return t?t.length>160?"SMSTO:"+e+":"+t.substr(0,160):"SMSTO:"+e+":"+t:"SMSTO:"+e},e.makeCall=function(e){return"tel:"+e},e.makeGeo=function(e,t,i){return void 0===i&&(i=400),"geo:"+e+","+t+","+i},e.makeEvent=function(e,t,i){return"BEGIN:VEVENT\nSUMMARY:"+e+"\nDTSTART:"+t+"\nDTEND:"+i+"\nEND:VEVENT"},e.makeEmail=function(e,t,i){var n="MATMSG:TO:"+e+";";return t&&(n+="SUB:"+t),n+=";",i&&(n+="BODY:"+i),n+=";;"},e.makeWifi=function(e,t,i){void 0===i&&(i=!1);var n="WIFI:"+(t?"T:WPA":"T:nopass")+";S:"+e+";";return t&&(n+="P:"+t),n+=";",i&&(n+="H:true"),n+=";"},e.makeContactMeCard=function(e,t,i,n,o){var s="MECARD:N:"+e+";";if(i&&(s+="ADR:"+i+";"),t&&t.length>0)for(var r=0;r<t.length;r++)s+="TEL:"+t[r]+";";return n&&(s+="EMAIL:"+n+";"),o&&(s+="URL:"+o+";"),s+=";"},e}();e.NgxKjuaModule=s,e.QrCodeHelper=r,e.ɵa=o,Object.defineProperty(e,"__esModule",{value:!0})}));
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("@angular/common")):"function"==typeof define&&define.amd?define("ngx-kjua",["exports","@angular/core","@angular/common"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self)["ngx-kjua"]={},e.ng.core,e.ng.common)}(this,(function(e,t,n){"use strict";var i,o=function(){function e(e){this.platformId=e,this.render="svg",this.crisp=!0,this.minVersion=1,this.ecLevel="L",this.size=200,this.ratio=void 0,this.fill="#333",this.back="#fff",this.text="",this.rounded=0,this.quiet=0,this.mode="plain",this.mSize=30,this.mPosX=50,this.mPosY=50,this.image=void 0,this.imageAsCode=!1,this.label="",this.fontname="sans-serif",this.fontcolor="#333",this.fontoutline=!0,this.renderAsync=!1,this.viewInitialized=!1,n.isPlatformServer(this.platformId)||i||(i=require("kjua-svg"))}return e.prototype.ngAfterViewInit=function(){this.viewInitialized=!0,this.updateView()},e.prototype.ngOnChanges=function(e){this.viewInitialized&&this.updateView()},Object.defineProperty(e.prototype,"template",{get:function(){var e={render:this.render,crisp:this.crisp,minVersion:this.minVersion,ecLevel:this.ecLevel,size:this.size,ratio:this.ratio,fill:this.fill,back:this.back,text:this.text,rounded:this.rounded,quiet:this.quiet,mode:this.mode,mSize:this.mSize,mPosX:this.mPosX,mPosY:this.mPosY,label:this.label,fontname:this.fontname,fontcolor:this.fontcolor,image:this.image,fontoutline:this.fontoutline,imageAsCode:this.imageAsCode};return console.debug("kjua settings used:",e),i(e)},enumerable:!1,configurable:!0}),e.prototype.renderCode=function(){this.div.nativeElement.innerHTML="",this.div.nativeElement.appendChild(this.template)},e.prototype.updateView=function(){var e=this;this.div.nativeElement.style.width=+this.size,this.div.nativeElement.style.height=+this.size,this.renderAsync?requestAnimationFrame((function(){return e.renderCode()})):this.renderCode()},e}();o.decorators=[{type:t.Component,args:[{selector:"ngx-kjua",template:'\n <div [class]="cssClass" #elem></div>',changeDetection:t.ChangeDetectionStrategy.OnPush,styles:["\n :host {\n display: block;\n }\n "]}]}],o.ctorParameters=function(){return[{type:Object,decorators:[{type:t.Inject,args:[t.PLATFORM_ID]}]}]},o.propDecorators={render:[{type:t.Input}],crisp:[{type:t.Input}],minVersion:[{type:t.Input}],ecLevel:[{type:t.Input}],size:[{type:t.Input}],ratio:[{type:t.Input}],fill:[{type:t.Input}],back:[{type:t.Input}],text:[{type:t.Input}],rounded:[{type:t.Input}],quiet:[{type:t.Input}],mode:[{type:t.Input}],mSize:[{type:t.Input}],mPosX:[{type:t.Input}],mPosY:[{type:t.Input}],image:[{type:t.Input}],imageAsCode:[{type:t.Input}],label:[{type:t.Input}],fontname:[{type:t.Input}],fontcolor:[{type:t.Input}],fontoutline:[{type:t.Input}],renderAsync:[{type:t.Input}],cssClass:[{type:t.Input}],div:[{type:t.ViewChild,args:["elem"]}]};var s=function(){};s.decorators=[{type:t.NgModule,args:[{imports:[n.CommonModule],declarations:[o],exports:[o]}]}];var r=function(){function e(){}return e.makeSMS=function(e,t){return t?t.length>160?"SMSTO:"+e+":"+t.substr(0,160):"SMSTO:"+e+":"+t:"SMSTO:"+e},e.makeCall=function(e){return"tel:"+e},e.makeGeo=function(e,t,n){return void 0===n&&(n=400),"geo:"+e+","+t+","+n},e.makeEvent=function(e,t,n){return"BEGIN:VEVENT\nSUMMARY:"+e+"\nDTSTART:"+t+"\nDTEND:"+n+"\nEND:VEVENT"},e.makeEmail=function(e,t,n){var i="MATMSG:TO:"+e+";";return t&&(i+="SUB:"+t),i+=";",n&&(i+="BODY:"+n),i+=";;"},e.makeWifi=function(e,t,n){void 0===n&&(n=!1);var i="WIFI:"+(t?"T:WPA":"T:nopass")+";S:"+e+";";return t&&(i+="P:"+t),i+=";",n&&(i+="H:true"),i+=";"},e.makeContactMeCard=function(e,t,n,i,o){var s="MECARD:N:"+e+";";if(n&&(s+="ADR:"+n+";"),t&&t.length>0)for(var r=0;r<t.length;r++)s+="TEL:"+t[r]+";";return i&&(s+="EMAIL:"+i+";"),o&&(s+="URL:"+o+";"),s+=";"},e}();e.NgxKjuaModule=s,e.QrCodeHelper=r,e.ɵa=o,Object.defineProperty(e,"__esModule",{value:!0})}));
//# sourceMappingURL=ngx-kjua.umd.min.js.map

@@ -10,3 +10,3 @@ import { ChangeDetectionStrategy, Component, Inject, Input, PLATFORM_ID, ViewChild, } from "@angular/core";

*/
this.render = "image";
this.render = "svg";
/**

@@ -177,2 +177,2 @@ * render pixel-perfect lines

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-kjua.component.js","sourceRoot":"","sources":["../../../../../src/app/modules/ngx-kjua/ngx-kjua.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgB,uBAAuB,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAa,WAAW,EAAiB,SAAS,GAAE,MAAM,eAAe,CAAC;AAElJ,OAAO,EAAC,gBAAgB,EAAC,MAAM,iBAAiB,CAAC;AAMjD,IAAI,IAAS,CAAC;AAad,MAAM,OAAO,gBAAgB;IAuH3B,YAAyC,UAAkB;QAAlB,eAAU,GAAV,UAAU,CAAQ;QArH3D;;WAEG;QAEH,WAAM,GAA+B,OAAO,CAAC;QAE7C;;WAEG;QAEH,UAAK,GAAG,IAAI,CAAC;QAEb;;WAEG;QAEH,eAAU,GAAG,CAAC,CAAC;QAEf;;WAEG;QAEH,YAAO,GAA0B,GAAG,CAAC;QAErC;;WAEG;QAEH,SAAI,GAAG,GAAG,CAAC;QAEX;;WAEG;QAEH,UAAK,GAAG,SAAS,CAAC;QAElB;;WAEG;QAEH,SAAI,GAAG,MAAM,CAAC;QAEd;;WAEG;QAEH,SAAI,GAAG,MAAM,CAAC;QAEd;;WAEG;QAEH,SAAI,GAAG,EAAE,CAAC;QAEV;;WAEG;QAEH,YAAO,GAAG,CAAC,CAAC;QAEZ;;WAEG;QAEH,UAAK,GAAG,CAAC,CAAC;QAEV;;WAEG;QAEH,SAAI,GAAgC,OAAO,CAAC;QAE5C;;WAEG;QAEH,UAAK,GAAG,EAAE,CAAC;QAEX,UAAK,GAAG,EAAE,CAAC;QAEX,UAAK,GAAG,EAAE,CAAC;QAEX,UAAK,GAAG,SAAS,CAAC;QAElB,gBAAW,GAAG,KAAK,CAAC;QAEpB;;WAEG;QAEH,UAAK,GAAG,EAAE,CAAC;QAEX,aAAQ,GAAG,YAAY,CAAC;QAExB,cAAS,GAAG,MAAM,CAAC;QAEnB,gBAAW,GAAG,IAAI,CAAC;QAEnB;;;WAGG;QAEH,gBAAW,GAAG,KAAK,CAAC;QAYZ,oBAAe,GAAG,KAAK,CAAC;QAG9B,IAAI,gBAAgB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE;YACrC,OAAO;SACR;aAAM,IAAI,CAAC,IAAI,EAAE;YAChB,IAAI,GAAG,OAAO,CAAC,UAAU,CAAC,CAAC;SAC5B;IACH,CAAC;IAED,eAAe;QACb,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;QAC5B,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,IAAI,CAAC,eAAe,EAAE;YACxB,IAAI,CAAC,UAAU,EAAE,CAAC;SACnB;IACH,CAAC;IAED,IAAI,QAAQ;QACV,MAAM,QAAQ,GAAgB;YAC5B,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,UAAU,EAAE,IAAI,CAAC,UAAU;YAC3B,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,WAAW,EAAE,IAAI,CAAC,WAAW;SAC9B,CAAC;QACF,OAAO,CAAC,KAAK,CAAC,qBAAqB,EAAE,QAAQ,CAAC,CAAC;QAC/C,OAAO,IAAI,CAAC,QAAQ,CAAC,CAAC;IACxB,CAAC;IAED,UAAU;QACR,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,SAAS,GAAG,EAAE,CAAC;QACtC,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACpD,CAAC;IAED,UAAU;QACR,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,KAAK,CAAC,KAAK,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC;QAChD,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC;QACjD,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,qBAAqB,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC;SAChD;aAAM;YACL,IAAI,CAAC,UAAU,EAAE,CAAC;SACnB;IACH,CAAC;;;YA9LF,SAAS,SAAC;gBACT,QAAQ,EAAE,UAAU;gBACpB,QAAQ,EAAE;yCAC6B;gBAMvC,eAAe,EAAE,uBAAuB,CAAC,MAAM;yBALtC;;;;GAIR;aAEF;;;YAwHsD,MAAM,uBAA9C,MAAM,SAAC,WAAW;;;qBAlH9B,KAAK;oBAML,KAAK;yBAML,KAAK;sBAML,KAAK;mBAML,KAAK;oBAML,KAAK;mBAML,KAAK;mBAML,KAAK;mBAML,KAAK;sBAML,KAAK;oBAML,KAAK;mBAML,KAAK;oBAML,KAAK;oBAEL,KAAK;oBAEL,KAAK;oBAEL,KAAK;0BAEL,KAAK;oBAML,KAAK;uBAEL,KAAK;wBAEL,KAAK;0BAEL,KAAK;0BAOL,KAAK;uBAOL,KAAK;kBAGL,SAAS,SAAC,MAAM","sourcesContent":["import {AfterViewInit, ChangeDetectionStrategy, Component, Inject, Input, OnChanges, PLATFORM_ID, SimpleChanges, ViewChild,} from \"@angular/core\";\r\n\r\nimport {isPlatformServer} from \"@angular/common\";\r\nimport {KjuaOptions} from \"kjua-svg\";\r\n\r\n// Because kjua uses `window` and `document` directly, we cannot `import` during SSR\r\n// instead, we load dynamically via `require('kjua')` in `ngAfterViewInit()`\r\ndeclare var require: any;\r\nlet kjua: any;\r\n\r\n@Component({\r\n  selector: \"ngx-kjua\",\r\n  template: `\r\n    <div [class]=\"cssClass\" #elem></div>`,\r\n  styles: [`\r\n    :host {\r\n      display: block;\r\n    }\r\n  `],\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class NgxKjuaComponent implements AfterViewInit, OnChanges {\r\n\r\n  /**\r\n   * render method\r\n   */\r\n  @Input()\r\n  render: \"image\" | \"svg\" | \"canvas\" = \"image\";\r\n\r\n  /**\r\n   * render pixel-perfect lines\r\n   */\r\n  @Input()\r\n  crisp = true;\r\n\r\n  /**\r\n   * minimum version= 1..40\r\n   */\r\n  @Input()\r\n  minVersion = 1;\r\n\r\n  /**\r\n   * error correction level\r\n   */\r\n  @Input()\r\n  ecLevel: \"L\" | \"M\" | \"Q\" | \"H\" = \"L\";\r\n\r\n  /**\r\n   * size in pixel\r\n   */\r\n  @Input()\r\n  size = 200;\r\n\r\n  /**\r\n   * pixel-ratio; undefined for devicePixelRatio\r\n   */\r\n  @Input()\r\n  ratio = undefined;\r\n\r\n  /**\r\n   * code color\r\n   */\r\n  @Input()\r\n  fill = \"#333\";\r\n\r\n  /**\r\n   * background color\r\n   */\r\n  @Input()\r\n  back = \"#fff\";\r\n\r\n  /**\r\n   * content\r\n   */\r\n  @Input()\r\n  text = \"\";\r\n\r\n  /**\r\n   * roundend corners in pc= 0..100\r\n   */\r\n  @Input()\r\n  rounded = 0;\r\n\r\n  /**\r\n   * quiet zone in modules\r\n   */\r\n  @Input()\r\n  quiet = 0;\r\n\r\n  /**\r\n   * modes\r\n   */\r\n  @Input()\r\n  mode: \"plain\" | \"label\" | \"image\" = \"plain\";\r\n\r\n  /**\r\n   * label/image size and pos in pc= 0..100\r\n   */\r\n  @Input()\r\n  mSize = 30;\r\n  @Input()\r\n  mPosX = 50;\r\n  @Input()\r\n  mPosY = 50;\r\n  @Input()\r\n  image = undefined;\r\n  @Input()\r\n  imageAsCode = false;\r\n\r\n  /**\r\n   * label\r\n   */\r\n  @Input()\r\n  label = \"\";\r\n  @Input()\r\n  fontname = \"sans-serif\";\r\n  @Input()\r\n  fontcolor = \"#333\";\r\n  @Input()\r\n  fontoutline = true;\r\n\r\n  /**\r\n   * If true, rendering is done inside \"requestAnimationFrame\"-call.\r\n   * Use this if you want to generate more than one code (e.g. batch)\r\n   */\r\n  @Input()\r\n  renderAsync = false;\r\n\r\n  /**\r\n   * If set, this css-class will be appended to the div-container that contains\r\n   * the qr-code (which is either an img or a canvas)\r\n   */\r\n  @Input()\r\n  cssClass;\r\n\r\n  @ViewChild(\"elem\")\r\n  div;\r\n\r\n  private viewInitialized = false;\r\n\r\n  constructor(@Inject(PLATFORM_ID) private platformId: Object) {\r\n    if (isPlatformServer(this.platformId)) {\r\n      return;\r\n    } else if (!kjua) {\r\n      kjua = require(\"kjua-svg\");\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.viewInitialized = true;\r\n    this.updateView();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (this.viewInitialized) {\r\n      this.updateView();\r\n    }\r\n  }\r\n\r\n  get template(): Node {\r\n    const settings: KjuaOptions = {\r\n      render: this.render,\r\n      crisp: this.crisp,\r\n      minVersion: this.minVersion,\r\n      ecLevel: this.ecLevel,\r\n      size: this.size,\r\n      ratio: this.ratio,\r\n      fill: this.fill,\r\n      back: this.back,\r\n      text: this.text,\r\n      rounded: this.rounded,\r\n      quiet: this.quiet,\r\n      mode: this.mode,\r\n      mSize: this.mSize,\r\n      mPosX: this.mPosX,\r\n      mPosY: this.mPosY,\r\n      label: this.label,\r\n      fontname: this.fontname,\r\n      fontcolor: this.fontcolor,\r\n      image: this.image,\r\n      fontoutline: this.fontoutline,\r\n      imageAsCode: this.imageAsCode\r\n    };\r\n    console.debug(\"kjua settings used:\", settings);\r\n    return kjua(settings);\r\n  }\r\n\r\n  renderCode() {\r\n    this.div.nativeElement.innerHTML = \"\";\r\n    this.div.nativeElement.appendChild(this.template);\r\n  }\r\n\r\n  updateView() {\r\n    this.div.nativeElement.style.width = +this.size;\r\n    this.div.nativeElement.style.height = +this.size;\r\n    if (this.renderAsync) {\r\n      requestAnimationFrame(() => this.renderCode());\r\n    } else {\r\n      this.renderCode();\r\n    }\r\n  }\r\n}\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-kjua.component.js","sourceRoot":"","sources":["../../../../../src/app/modules/ngx-kjua/ngx-kjua.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, ChangeDetectionStrategy, Component, Inject, Input, OnChanges, PLATFORM_ID, SimpleChanges, ViewChild,} from \"@angular/core\";\r\n\r\nimport {isPlatformServer} from \"@angular/common\";\r\nimport {KjuaOptions} from \"kjua-svg\";\r\n\r\n// Because kjua uses `window` and `document` directly, we cannot `import` during SSR\r\n// instead, we load dynamically via `require('kjua')` in `ngAfterViewInit()`\r\ndeclare var require: any;\r\nlet kjua: any;\r\n\r\n@Component({\r\n  selector: \"ngx-kjua\",\r\n  template: `\r\n    <div [class]=\"cssClass\" #elem></div>`,\r\n  styles: [`\r\n    :host {\r\n      display: block;\r\n    }\r\n  `],\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class NgxKjuaComponent implements AfterViewInit, OnChanges {\r\n\r\n  /**\r\n   * render method\r\n   */\r\n  @Input()\r\n  render: \"image\" | \"svg\" | \"canvas\" = \"svg\";\r\n\r\n  /**\r\n   * render pixel-perfect lines\r\n   */\r\n  @Input()\r\n  crisp = true;\r\n\r\n  /**\r\n   * minimum version= 1..40\r\n   */\r\n  @Input()\r\n  minVersion = 1;\r\n\r\n  /**\r\n   * error correction level\r\n   */\r\n  @Input()\r\n  ecLevel: \"L\" | \"M\" | \"Q\" | \"H\" = \"L\";\r\n\r\n  /**\r\n   * size in pixel\r\n   */\r\n  @Input()\r\n  size = 200;\r\n\r\n  /**\r\n   * pixel-ratio; undefined for devicePixelRatio\r\n   */\r\n  @Input()\r\n  ratio = undefined;\r\n\r\n  /**\r\n   * code color\r\n   */\r\n  @Input()\r\n  fill = \"#333\";\r\n\r\n  /**\r\n   * background color\r\n   */\r\n  @Input()\r\n  back = \"#fff\";\r\n\r\n  /**\r\n   * content\r\n   */\r\n  @Input()\r\n  text = \"\";\r\n\r\n  /**\r\n   * roundend corners in pc= 0..100\r\n   */\r\n  @Input()\r\n  rounded = 0;\r\n\r\n  /**\r\n   * quiet zone in modules\r\n   */\r\n  @Input()\r\n  quiet = 0;\r\n\r\n  /**\r\n   * modes\r\n   */\r\n  @Input()\r\n  mode: \"plain\" | \"label\" | \"image\" | \"imagelabel\" | \"labelimage\" = \"plain\";\r\n\r\n  /**\r\n   * label/image size and pos in pc= 0..100\r\n   */\r\n  @Input()\r\n  mSize = 30;\r\n  @Input()\r\n  mPosX = 50;\r\n  @Input()\r\n  mPosY = 50;\r\n  @Input()\r\n  image = undefined;\r\n  @Input()\r\n  imageAsCode = false;\r\n\r\n  /**\r\n   * label\r\n   */\r\n  @Input()\r\n  label = \"\";\r\n  @Input()\r\n  fontname = \"sans-serif\";\r\n  @Input()\r\n  fontcolor = \"#333\";\r\n  @Input()\r\n  fontoutline = true;\r\n\r\n  /**\r\n   * If true, rendering is done inside \"requestAnimationFrame\"-call.\r\n   * Use this if you want to generate more than one code (e.g. batch)\r\n   */\r\n  @Input()\r\n  renderAsync = false;\r\n\r\n  /**\r\n   * If set, this css-class will be appended to the div-container that contains\r\n   * the qr-code (which is either an img or a canvas)\r\n   */\r\n  @Input()\r\n  cssClass;\r\n\r\n  @ViewChild(\"elem\")\r\n  div;\r\n\r\n  private viewInitialized = false;\r\n\r\n  constructor(@Inject(PLATFORM_ID) private platformId: Object) {\r\n    if (isPlatformServer(this.platformId)) {\r\n      return;\r\n    } else if (!kjua) {\r\n      kjua = require(\"kjua-svg\");\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.viewInitialized = true;\r\n    this.updateView();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (this.viewInitialized) {\r\n      this.updateView();\r\n    }\r\n  }\r\n\r\n  get template(): Node {\r\n    const settings: KjuaOptions = {\r\n      render: this.render,\r\n      crisp: this.crisp,\r\n      minVersion: this.minVersion,\r\n      ecLevel: this.ecLevel,\r\n      size: this.size,\r\n      ratio: this.ratio,\r\n      fill: this.fill,\r\n      back: this.back,\r\n      text: this.text,\r\n      rounded: this.rounded,\r\n      quiet: this.quiet,\r\n      mode: this.mode,\r\n      mSize: this.mSize,\r\n      mPosX: this.mPosX,\r\n      mPosY: this.mPosY,\r\n      label: this.label,\r\n      fontname: this.fontname,\r\n      fontcolor: this.fontcolor,\r\n      image: this.image,\r\n      fontoutline: this.fontoutline,\r\n      imageAsCode: this.imageAsCode\r\n    };\r\n    console.debug(\"kjua settings used:\", settings);\r\n    return kjua(settings);\r\n  }\r\n\r\n  renderCode() {\r\n    this.div.nativeElement.innerHTML = \"\";\r\n    this.div.nativeElement.appendChild(this.template);\r\n  }\r\n\r\n  updateView() {\r\n    this.div.nativeElement.style.width = +this.size;\r\n    this.div.nativeElement.style.height = +this.size;\r\n    if (this.renderAsync) {\r\n      requestAnimationFrame(() => this.renderCode());\r\n    } else {\r\n      this.renderCode();\r\n    }\r\n  }\r\n}\r\n"]}

@@ -11,3 +11,3 @@ import { Component, ChangeDetectionStrategy, Inject, PLATFORM_ID, Input, ViewChild, NgModule } from '@angular/core';

*/
this.render = "image";
this.render = "svg";
/**

@@ -14,0 +14,0 @@ * render pixel-perfect lines

{
"name": "ngx-kjua",
"description": "Angular QR-Code generator component.",
"version": "1.8.0",
"version": "1.12.0",
"license": "MIT",

@@ -28,3 +28,3 @@ "private": false,

"dependencies": {
"kjua-svg": "^1.10.0",
"kjua-svg": "^1.12.0",
"tslib": "^2.0.0"

@@ -31,0 +31,0 @@ },

@@ -129,2 +129,7 @@ [![NPM version](https://img.shields.io/npm/v/ngx-kjua.svg?&label=npm)](https://www.npmjs.com/package/ngx-kjua)

### Labelimage and Imagelabel
Use this, if you want a label AND an image. In these modes `mSize`, `mPosX` and `mPosY` can be provided as an array.
In mode `labelimage`, the first value (index 0) of the `mSize`, `mPosX` and `mPosY` arrays is used for the label,
the second value (index 1) is used for image and vice versa. Also in `labelimage` mode, the label is drawn before the
image is drawn and therefore kinda "in the background" if the two overlap.

@@ -131,0 +136,0 @@ ### All options

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc