@solar-angular/ui-sun 18.0.3 → 18.0.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/slider-captcha/slider-captcha.component.mjs +3 -2
- package/esm2022/slider-captcha/utils.mjs +1 -4
- package/fesm2022/solar-angular-ui-sun-slider-captcha.mjs +1 -3
- package/fesm2022/solar-angular-ui-sun-slider-captcha.mjs.map +1 -1
- package/package.json +3 -3
- package/slider-captcha/utils.d.ts +0 -1
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { afterNextRender, Component, EventEmitter, HostBinding, HostListener, Input, numberAttribute, Output, ViewChild } from '@angular/core';
|
|
2
|
+
import { withPixel } from '@solar-kit/core';
|
|
2
3
|
import { fromEvent, take, zip } from 'rxjs';
|
|
3
|
-
import { aesEncrypt, HTTP_OPTIONS, withDpr
|
|
4
|
+
import { aesEncrypt, HTTP_OPTIONS, withDpr } from './utils';
|
|
4
5
|
import * as i0 from "@angular/core";
|
|
5
6
|
import * as i1 from "@angular/common/http";
|
|
6
7
|
/** 验证码的原始尺寸 */
|
|
@@ -216,4 +217,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
216
217
|
type: HostListener,
|
|
217
218
|
args: ['window:pointermove', ['$event']]
|
|
218
219
|
}] } });
|
|
219
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider-captcha.component.js","sourceRoot":"","sources":["../../../../packages/ui-sun/slider-captcha/slider-captcha.component.ts","../../../../packages/ui-sun/slider-captcha/slider-captcha.component.html"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,SAAS,EAAc,YAAY,EAAE,WAAW,EAAE,YAAY,EAAE,KAAK,EAAE,eAAe,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAE3J,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,GAAG,EAAE,MAAM,MAAM,CAAC;AAE5C,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;;;AAEvE,eAAe;AACf,MAAM,MAAM,GAAG,GAAG,EAAE,KAAK,GAAG,GAAG,CAAC;AAChC,cAAc;AACd,MAAM,aAAa,GAAG,GAAG,EAAE,YAAY,GAAG,EAAE,CAAC;AAQ7C,MAAM,OAAO,gBAAgB;IA4C3B;;;OAGG;IACH,IAAI,QAAQ;QACV,OAAO;YACL,KAAK,EAAE,IAAI,CAAC,KAAK,GAAG,KAAK;YACzB,MAAM,EAAE,IAAI,CAAC,MAAM,GAAG,MAAM;SAC7B,CAAC;IACJ,CAAC;IAED,YAAoB,IAAgB;QAAhB,SAAI,GAAJ,IAAI,CAAY;QAtDK,YAAO,GAAG,KAAK,CAAC;QACd,cAAS,GAAG,KAAK,CAAC;QAQtB,UAAK,GAAG,KAAK,CAAC;QACd,WAAM,GAAG,MAAM,CAAC;QAE7C,aAAQ,GAAG,IAAI,YAAY,EAAmB,CAAC;QAOzD,eAAe;QACf,MAAC,GAAG,CAAC,CAAC;QAEN,YAAO,GAAyC,EAAS,CAAC;QAE1D,UAAK,GAA8D;YACjE,IAAI,EAAE,SAAS,EAAG,QAAQ;YAC1B,GAAG,EAAE,EAAE;YACP,IAAI,EAAE,KAAK;SACZ,CAAC;QAKF,aAAa;QACb,eAAU,GAAG,CAAC,CAAC,CAAC;QAChB,yBAAyB;QACzB,eAAU,GAAG,CAAC,CAAC;QAEf,QAAG,GAAG;YACJ,UAAU,EAAE,EAAE,EAAI,OAAO;YACzB,UAAU,EAAE,gCAAgC;SAC7C,CAAC;QAcA,eAAe,CAAC,GAAG,EAAE;YACnB,MAAM,GAAG,GAAG,gBAAgB,CAAC;YAC7B,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC;YAC3C,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,GAAG,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAChD,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAClD,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACxC,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAE1C,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,IAAI,CAAE,CAAC;YACzC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;YAEzB,UAAU,CAAC,GAAG,EAAE;gBACd,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAA;IACJ,CAAC;IAED,OAAO;QACL,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;QACvD,CAAC,EAAE,EAAE,CAAC,CAAC;QACP,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,GAAG,CAAC,UAAU,GAAG,gCAAgC,CAAC;QACvD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAkB,IAAI,CAAC,MAAM,EAAE,EAAE,WAAW,6CAAyB,EAAE,EAAE,YAAY,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE;YACxH,IAAI,QAAQ,CAAC,IAAI,KAAK,CAAC,EAAE,CAAC;gBACxB,IAAI,CAAC,OAAO,CAAC,SAAS,GAAG,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC;gBACjD,IAAI,CAAC,OAAO,CAAC,KAAK,GAAG,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC;gBACzC,IAAI,CAAC,OAAO,GAAG,IAAI,KAAK,EAAE,CAAC;gBAC3B,IAAI,CAAC,UAAU,GAAG,IAAI,KAAK,EAAE,CAAC;gBAC9B,2EAA2E;gBAC3E,IAAI,CAAC,OAAO,CAAC,GAAG,GAAG,yBAAyB,QAAQ,CAAC,IAAI,CAAC,mBAAmB,EAAE,CAAC;gBAChF,IAAI,CAAC,UAAU,CAAC,GAAG,GAAG,yBAAyB,QAAQ,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC;gBACjF,GAAG,CACD,SAAS,CAAC,IAAI,CAAC,OAAO,EAAE,MAAM,CAAC,EAC/B,SAAS,CAAC,IAAI,CAAC,UAAU,EAAE,MAAM,CAAC,CACnC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;oBAC7B,IAAI,CAAC,SAAS,GAAG,IAAI,IAAI,EAAE,CAAC,OAAO,EAAE,CAAC;oBACtC,IAAI,CAAC,IAAI,EAAE,CAAC;gBACd,CAAC,CAAC,CAAC;YACL,CAAC;iBAAM,CAAC;gBACN,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;YAC9B,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,IAAI,CAAC,CAAC,GAAG,CAAC;QAChB,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;QACX,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;QAClD,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;QAChE,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,QAAQ,CAAC,KAAK,GAAG,YAAY,EAAE,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,aAAa,CAAC,CAAC;QACzH,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;IACvB,CAAC;IAED,KAAK,CAAC,CAAS;QACb,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACf,CAAC;IAED,MAAM,CAAC,CAAS;QACd,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,YAAY;QACZ,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC;QAE5B,IAAI,CAAC,OAAO,GAAG,IAAI,IAAI,EAAE,CAAC,OAAO,EAAE,CAAC;QACpC,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC;QAC9C,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QAC3F,MAAM,UAAU,GAAG,OAAO,IAAI,CAAC,UAAU,KAAK,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC;QAC/F,MAAM,GAAG,GAAG;YACV,WAAW,6CAAyB;YACpC,SAAS;YACT,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,KAAK;YACzB,GAAG,UAAU;SACd,CAAC;QACF,IAAI,CAAC,IAAI,CAAC,IAAI,CAAkB,IAAI,CAAC,SAAS,EAAE,GAAG,EAAE,YAAY,CAAC,CAAC,SAAS,CAAC;YAC3E,IAAI,EAAE,QAAQ,CAAC,EAAE;gBACf,IAAI,QAAQ,CAAC,IAAI,KAAK,CAAC,EAAE,CAAC;oBACxB,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,OAAO,CAAC;oBAC1B,IAAI,CAAC,KAAK,CAAC,GAAG,GAAG,QAAQ,CAAC,GAAG,CAAC;oBAC9B,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,IAAI,CAAC;oBACvB,IAAI,CAAC,GAAG,CAAC,UAAU,GAAG,+BAA+B,CAAC;oBACtD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;wBACjB,IAAI,EAAE,CAAC,CAAC;wBACR,GAAG,EAAE,QAAQ,CAAC,GAAG;wBACjB,IAAI,EAAE,IAAK;qBACZ,CAAC,CAAC;oBACH,UAAU,CAAC,GAAG,EAAE;wBACd,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,KAAK,CAAC;wBACxB,IAAI,CAAC,OAAO,EAAE,CAAC;oBACjB,CAAC,EAAE,IAAI,CAAC,CAAC;gBACX,CAAC;qBAAM,CAAC;oBACN,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,SAAS,CAAC;oBAC5B,IAAI,CAAC,GAAG,CAAC,UAAU,GAAG,gCAAgC,CAAC;oBACvD,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC;oBAC/D,IAAI,CAAC,KAAK,CAAC,GAAG,GAAG,IAAI,OAAO,QAAQ,CAAC;oBACrC,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,IAAI,CAAC;oBACvB,MAAM,IAAI,GAAG,QAAQ,CAAC,IAAI,CAAC,KAAK,GAAG,KAAK,GAAG,IAAI,CAAC;oBAChD,QAAQ,CAAC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;oBACjG,8BAA8B;oBAC9B,oCAAoC;oBACpC,kCAAkC;oBAClC,+BAA+B;oBAC/B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;wBACjB,IAAI,EAAE,CAAC;wBACP,GAAG,EAAE,QAAQ,CAAC,GAAG;wBACjB,IAAI,EAAE,QAAQ,CAAC,IAAI;qBACpB,CAAC,CAAC;gBACL,CAAC;YACH,CAAC;YACD,QAAQ,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,GAAG,KAAK;SACvC,CAAC,CAAC;IACL,CAAC;IAED,SAAS,CAAC,KAAmB;QAC3B,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC;YACrC,KAAK,CAAC,eAAe,EAAE,CAAC;YACxB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,OAAO,CAAC;YAChC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,UAAU,CAAC;QAC5D,CAAC;IACH,CAAC;IAID,OAAO,CAAC,KAAmB;QACzB,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC,EAAE,CAAC;YACzB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;QACpE,CAAC;QACD,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC,CAAC;IACvB,CAAC;IAGD,UAAU,CAAC,KAAmB;QAC5B,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,SAAS;YACnC,MAAM,QAAQ,GAAG,KAAK,CAAC,OAAO,CAAC,CAAC,SAAS;YACzC,MAAM,MAAM,GAAG,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC,UAAU;YAErD,IAAI,IAAI,GAAG,IAAI,CAAC,UAAU,GAAG,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;YAEvD,IAAI,IAAI,IAAI,IAAI,CAAC,GAAG,CAAC,UAAU,EAAE,CAAC;gBAChC,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC;YAC7B,CAAC;iBAAM,IAAI,IAAI,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;gBAC9B,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC;YACpB,CAAC;YACD,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,UAAU,GAAG,IAAI,CAAC;YAC/C,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,CAAC;QAChC,CAAC;IACH,CAAC;+GA3MU,gBAAgB;mGAAhB,gBAAgB,8JAUP,eAAe,gCACf,eAAe,0hBC7BrC,q7CA+CA;;4FD7Ba,gBAAgB;kBAN5B,SAAS;+BACE,oBAAoB,cAClB,IAAI;+EAKyB,OAAO;sBAA/C,WAAW;uBAAC,0BAA0B;gBACI,SAAS;sBAAnD,WAAW;uBAAC,4BAA4B;gBAEF,SAAS;sBAA/C,SAAS;uBAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBACE,SAAS;sBAA/C,SAAS;uBAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAE5B,MAAM;sBAAd,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACiC,KAAK;sBAA3C,KAAK;uBAAC,EAAE,SAAS,EAAE,eAAe,EAAE;gBACE,MAAM;sBAA5C,KAAK;uBAAC,EAAE,SAAS,EAAE,eAAe,EAAE;gBAE3B,QAAQ;sBAAjB,MAAM;gBAqKP,OAAO;sBAFN,YAAY;uBAAC,kBAAkB,EAAE,CAAC,QAAQ,CAAC;;sBAC3C,YAAY;uBAAC,sBAAsB,EAAE,CAAC,QAAQ,CAAC;gBAUhD,UAAU;sBADT,YAAY;uBAAC,oBAAoB,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import { HttpClient } from '@angular/common/http';\nimport { afterNextRender, Component, ElementRef, EventEmitter, HostBinding, HostListener, Input, numberAttribute, Output, ViewChild } from '@angular/core';\nimport { Result } from '@solar-kit/planets/sun';\nimport { fromEvent, take, zip } from 'rxjs';\nimport { Captcha, CaptchaType } from './model';\nimport { aesEncrypt, HTTP_OPTIONS, withDpr, withPixel } from './utils';\n\n/** 验证码的原始尺寸 */\nconst HEIGHT = 155, WIDTH = 310;\n/** 拼图的原始尺寸 */\nconst PUZZLE_HEIGHT = 155, PUZZLE_WIDTH = 50;\n\n@Component({\n  selector: 'sun-slider-captcha',\n  standalone: true,\n  templateUrl: './slider-captcha.component.html',\n  styleUrl: './slider-captcha.component.scss',\n})\nexport class SunSliderCaptcha {\n  @HostBinding('class.sun-verify-loading') loading = false;\n  @HostBinding('class.sun-verify-verifying') verifying = false;\n\n  @ViewChild('canvas', { static: true }) canvasRef!: ElementRef<HTMLCanvasElement>;\n  @ViewChild('slider', { static: true }) sliderRef!: ElementRef<HTMLDivElement>;\n\n  @Input() srcUrl!: string;\n  @Input() verifyUrl!: string;\n  @Input() verifyData?: Record<string, any> | (() => Record<string, any>);\n  @Input({ transform: numberAttribute }) width = WIDTH;\n  @Input({ transform: numberAttribute }) height = HEIGHT;\n\n  @Output() verified = new EventEmitter<Result<Captcha>>();\n\n  private canvas!: HTMLCanvasElement;\n  private ctx!: CanvasRenderingContext2D;\n  private bgImage!: HTMLImageElement;\n  private slideImage!: HTMLImageElement;\n\n  /** 滑块拼图的x坐标 */\n  x = 0;\n\n  secrets: { secretKey: string, token: string } = {} as any;\n\n  alert: { type: 'success' | 'error', msg: string, show: boolean } = {\n    type: 'success',  // error\n    msg: '',\n    show: false\n  };\n\n  beginTime!: number;\n  endTime!: number;\n\n  /** 滑动开始的X */\n  dragStartX = -1;\n  /** 滑动bar初始的scrollLeft */\n  scrollLeft = 0;\n\n  bar = {\n    blockWidth: 42,   // 滑块宽度\n    background: 'var(--indicator-primary-color)'\n  };\n\n  /**\n   * 当前尺寸 除于 原始尺寸得到的商\n   * 用于等比例缩放\n   */\n  get quotient() {\n    return {\n      width: this.width / WIDTH,\n      height: this.height / HEIGHT\n    };\n  }\n\n  constructor(private http: HttpClient) {\n    afterNextRender(() => {\n      const dpr = devicePixelRatio;\n      this.canvas = this.canvasRef.nativeElement;\n      this.canvas.style.width = withPixel(this.width);\n      this.canvas.style.height = withPixel(this.height);\n      this.canvas.width = withDpr(this.width);\n      this.canvas.height = withDpr(this.height);\n\n      this.ctx = this.canvas.getContext('2d')!;\n      this.ctx.scale(dpr, dpr);\n\n      setTimeout(() => {\n        this.refresh();\n      });\n    })\n  }\n\n  refresh() {\n    setTimeout(() => {\n      this.sliderRef.nativeElement.scrollTo(this.width, 0);\n    }, 50);\n    this.alert.show = false;\n    this.bar.background = 'var(--indicator-primary-color)';\n    this.loading = true;\n    this.http.post<Result<Captcha>>(this.srcUrl, { captchaType: CaptchaType.BlockPuzzle }, HTTP_OPTIONS).subscribe(response => {\n      if (response.code === 0) {\n        this.secrets.secretKey = response.data.secretKey;\n        this.secrets.token = response.data.token;\n        this.bgImage = new Image();\n        this.slideImage = new Image();\n        // this.bgImage.src = `data:image/png;base64,${re.data.jigsawImageBase64}`;\n        this.bgImage.src = `data:image/png;base64,${response.data.originalImageBase64}`;\n        this.slideImage.src = `data:image/png;base64,${response.data.jigsawImageBase64}`;\n        zip(\n          fromEvent(this.bgImage, 'load'),\n          fromEvent(this.slideImage, 'load'),\n        ).pipe(take(1)).subscribe(() => {\n          this.beginTime = new Date().getTime();\n          this.draw();\n        });\n      } else {\n        console.error(response.msg);\n      }\n    });\n  }\n\n  private draw(x = 0) {\n    this.x = x;\n    this.ctx.clearRect(0, 0, this.width, this.height);\n    this.ctx.drawImage(this.bgImage, 0, 0, this.width, this.height);\n    this.ctx.drawImage(this.slideImage, this.x, 0, this.quotient.width * PUZZLE_WIDTH, this.quotient.height * PUZZLE_HEIGHT);\n    this.loading = false;\n  }\n\n  slide(x: number) {\n    this.draw(x);\n  }\n\n  verify(x: number) {\n    this.verifying = true;\n    // 计算出原始移动距离\n    x = x / this.quotient.width;\n\n    this.endTime = new Date().getTime();\n    const json = JSON.stringify({ x: x, y: 5.0 });\n    const pointJson = this.secrets.secretKey ? aesEncrypt(json, this.secrets.secretKey) : json;\n    const verifyData = typeof this.verifyData === 'function' ? this.verifyData() : this.verifyData;\n    const obj = {\n      captchaType: CaptchaType.BlockPuzzle,\n      pointJson,\n      token: this.secrets.token,\n      ...verifyData\n    };\n    this.http.post<Result<Captcha>>(this.verifyUrl, obj, HTTP_OPTIONS).subscribe({\n      next: response => {\n        if (response.code !== 0) {\n          this.alert.type = 'error';\n          this.alert.msg = response.msg;\n          this.alert.show = true;\n          this.bar.background = 'var(--indicator-danger-color)';\n          this.verified.emit({\n            code: -1,\n            msg: response.msg,\n            data: null!\n          });\n          setTimeout(() => {\n            this.alert.show = false;\n            this.refresh();\n          }, 1000);\n        } else {\n          this.alert.type = 'success';\n          this.bar.background = 'var(--indicator-primary-color)';\n          const seconds = Math.abs(this.endTime - this.beginTime) / 1000;\n          this.alert.msg = ` ${seconds}秒 验证成功`;\n          this.alert.show = true;\n          const temp = response.data.token + '---' + json;\n          response.data.captcha = this.secrets.secretKey ? aesEncrypt(temp, this.secrets.secretKey) : temp;\n          // delete response.data.token;\n          // delete response.data.captchaType;\n          // delete response.data.pointJson;\n          // delete response.data.result;\n          this.verified.emit({\n            code: 0,\n            msg: response.msg,\n            data: response.data\n          });\n        }\n      },\n      complete: () => this.verifying = false\n    });\n  }\n\n  markStart(event: PointerEvent) {\n    if (!this.loading && !this.verifying) {\n      event.stopPropagation();\n      this.dragStartX = event.clientX;\n      this.scrollLeft = this.sliderRef.nativeElement.scrollLeft;\n    }\n  }\n\n  @HostListener('window:pointerup', ['$event'])\n  @HostListener('window:pointercancel', ['$event'])\n  markEnd(event: PointerEvent) {\n    event.stopPropagation();\n    if (this.dragStartX > -1) {\n      this.verify(this.width - this.sliderRef.nativeElement.scrollLeft);\n    }\n    this.dragStartX = -1;\n  }\n\n  @HostListener('window:pointermove', ['$event'])\n  moveMarker(event: PointerEvent) {\n    event.stopPropagation();\n    if (this.dragStartX > -1) { // 如果在拖动了\n      const currentX = event.clientX; // 得到当前的X\n      const offset = currentX - this.dragStartX; // 得到拖动的距离\n\n      let left = this.scrollLeft - (offset < 0 ? 0 : offset);\n\n      if (left <= this.bar.blockWidth) {\n        left = this.bar.blockWidth;\n      } else if (left >= this.width) {\n        left = this.width;\n      }\n      this.sliderRef.nativeElement.scrollLeft = left;\n      this.slide(this.width - left);\n    }\n  }\n\n}\n","<div class=\"slide-block\" [style.width.px]=\"width\" [style.height.px]=\"height\">\n  <canvas #canvas></canvas>\n  @if (alert.show) {\n  <div\n    class=\"slide-alert\"\n    [class.slide-alert-success]=\"alert.type === 'success'\"\n    [class.slide-alert-danger]=\"alert.type === 'error'\"\n  >\n    {{ alert.msg }}\n  </div>\n  }\n</div>\n\n<div\n  #slider\n  class=\"verify-bar\"\n  [style.width.px]=\"width\"\n  (scroll)=\"$event.preventDefault()\"\n  (touchmove)=\"$event.preventDefault()\"\n  (mousewheel)=\"$event.preventDefault()\"\n>\n  <div\n    style=\"display: inline-block; height: 40px; vertical-align: top\"\n    [style]=\"{ background: bar.background }\"\n    [draggable]=\"false\"\n    [style.width.px]=\"width\"\n  ></div>\n  <div class=\"verify-bar-area\" [style.width.px]=\"width\" [draggable]=\"false\">\n    <span class=\"verify-msg\" [draggable]=\"false\">拖动滑块以完成拼图验证</span>\n    <div class=\"verify-left-bar\" [style.width.px]=\"bar.blockWidth\">\n      <div\n        class=\"verify-move-block\"\n        [draggable]=\"false\"\n        (pointerdown)=\"markStart($event)\"\n      >\n        <svg viewBox=\"0 0 512 512\">\n          <path\n            stroke-width=\"32\"\n            stroke-linecap=\"round\"\n            stroke-miterlimit=\"10\"\n            d=\"M80 160h352M80 256h352M80 352h352\"\n          ></path>\n        </svg>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|
|
220
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider-captcha.component.js","sourceRoot":"","sources":["../../../../packages/ui-sun/slider-captcha/slider-captcha.component.ts","../../../../packages/ui-sun/slider-captcha/slider-captcha.component.html"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\nimport { afterNextRender, Component, ElementRef, EventEmitter, HostBinding, HostListener, Input, numberAttribute, Output, ViewChild } from '@angular/core';\nimport { withPixel } from '@solar-kit/core';\nimport { Result } from '@solar-kit/planets/sun';\nimport { fromEvent, take, zip } from 'rxjs';\nimport { Captcha, CaptchaType } from './model';\nimport { aesEncrypt, HTTP_OPTIONS, withDpr } from './utils';\n\n/** 验证码的原始尺寸 */\nconst HEIGHT = 155, WIDTH = 310;\n/** 拼图的原始尺寸 */\nconst PUZZLE_HEIGHT = 155, PUZZLE_WIDTH = 50;\n\n@Component({\n  selector: 'sun-slider-captcha',\n  standalone: true,\n  templateUrl: './slider-captcha.component.html',\n  styleUrl: './slider-captcha.component.scss',\n})\nexport class SunSliderCaptcha {\n  @HostBinding('class.sun-verify-loading') loading = false;\n  @HostBinding('class.sun-verify-verifying') verifying = false;\n\n  @ViewChild('canvas', { static: true }) canvasRef!: ElementRef<HTMLCanvasElement>;\n  @ViewChild('slider', { static: true }) sliderRef!: ElementRef<HTMLDivElement>;\n\n  @Input() srcUrl!: string;\n  @Input() verifyUrl!: string;\n  @Input() verifyData?: Record<string, any> | (() => Record<string, any>);\n  @Input({ transform: numberAttribute }) width = WIDTH;\n  @Input({ transform: numberAttribute }) height = HEIGHT;\n\n  @Output() verified = new EventEmitter<Result<Captcha>>();\n\n  private canvas!: HTMLCanvasElement;\n  private ctx!: CanvasRenderingContext2D;\n  private bgImage!: HTMLImageElement;\n  private slideImage!: HTMLImageElement;\n\n  /** 滑块拼图的x坐标 */\n  x = 0;\n\n  secrets: { secretKey: string, token: string } = {} as any;\n\n  alert: { type: 'success' | 'error', msg: string, show: boolean } = {\n    type: 'success',  // error\n    msg: '',\n    show: false\n  };\n\n  beginTime!: number;\n  endTime!: number;\n\n  /** 滑动开始的X */\n  dragStartX = -1;\n  /** 滑动bar初始的scrollLeft */\n  scrollLeft = 0;\n\n  bar = {\n    blockWidth: 42,   // 滑块宽度\n    background: 'var(--indicator-primary-color)'\n  };\n\n  /**\n   * 当前尺寸 除于 原始尺寸得到的商\n   * 用于等比例缩放\n   */\n  get quotient() {\n    return {\n      width: this.width / WIDTH,\n      height: this.height / HEIGHT\n    };\n  }\n\n  constructor(private http: HttpClient) {\n    afterNextRender(() => {\n      const dpr = devicePixelRatio;\n      this.canvas = this.canvasRef.nativeElement;\n      this.canvas.style.width = withPixel(this.width);\n      this.canvas.style.height = withPixel(this.height);\n      this.canvas.width = withDpr(this.width);\n      this.canvas.height = withDpr(this.height);\n\n      this.ctx = this.canvas.getContext('2d')!;\n      this.ctx.scale(dpr, dpr);\n\n      setTimeout(() => {\n        this.refresh();\n      });\n    })\n  }\n\n  refresh() {\n    setTimeout(() => {\n      this.sliderRef.nativeElement.scrollTo(this.width, 0);\n    }, 50);\n    this.alert.show = false;\n    this.bar.background = 'var(--indicator-primary-color)';\n    this.loading = true;\n    this.http.post<Result<Captcha>>(this.srcUrl, { captchaType: CaptchaType.BlockPuzzle }, HTTP_OPTIONS).subscribe(response => {\n      if (response.code === 0) {\n        this.secrets.secretKey = response.data.secretKey;\n        this.secrets.token = response.data.token;\n        this.bgImage = new Image();\n        this.slideImage = new Image();\n        // this.bgImage.src = `data:image/png;base64,${re.data.jigsawImageBase64}`;\n        this.bgImage.src = `data:image/png;base64,${response.data.originalImageBase64}`;\n        this.slideImage.src = `data:image/png;base64,${response.data.jigsawImageBase64}`;\n        zip(\n          fromEvent(this.bgImage, 'load'),\n          fromEvent(this.slideImage, 'load'),\n        ).pipe(take(1)).subscribe(() => {\n          this.beginTime = new Date().getTime();\n          this.draw();\n        });\n      } else {\n        console.error(response.msg);\n      }\n    });\n  }\n\n  private draw(x = 0) {\n    this.x = x;\n    this.ctx.clearRect(0, 0, this.width, this.height);\n    this.ctx.drawImage(this.bgImage, 0, 0, this.width, this.height);\n    this.ctx.drawImage(this.slideImage, this.x, 0, this.quotient.width * PUZZLE_WIDTH, this.quotient.height * PUZZLE_HEIGHT);\n    this.loading = false;\n  }\n\n  slide(x: number) {\n    this.draw(x);\n  }\n\n  verify(x: number) {\n    this.verifying = true;\n    // 计算出原始移动距离\n    x = x / this.quotient.width;\n\n    this.endTime = new Date().getTime();\n    const json = JSON.stringify({ x: x, y: 5.0 });\n    const pointJson = this.secrets.secretKey ? aesEncrypt(json, this.secrets.secretKey) : json;\n    const verifyData = typeof this.verifyData === 'function' ? this.verifyData() : this.verifyData;\n    const obj = {\n      captchaType: CaptchaType.BlockPuzzle,\n      pointJson,\n      token: this.secrets.token,\n      ...verifyData\n    };\n    this.http.post<Result<Captcha>>(this.verifyUrl, obj, HTTP_OPTIONS).subscribe({\n      next: response => {\n        if (response.code !== 0) {\n          this.alert.type = 'error';\n          this.alert.msg = response.msg;\n          this.alert.show = true;\n          this.bar.background = 'var(--indicator-danger-color)';\n          this.verified.emit({\n            code: -1,\n            msg: response.msg,\n            data: null!\n          });\n          setTimeout(() => {\n            this.alert.show = false;\n            this.refresh();\n          }, 1000);\n        } else {\n          this.alert.type = 'success';\n          this.bar.background = 'var(--indicator-primary-color)';\n          const seconds = Math.abs(this.endTime - this.beginTime) / 1000;\n          this.alert.msg = ` ${seconds}秒 验证成功`;\n          this.alert.show = true;\n          const temp = response.data.token + '---' + json;\n          response.data.captcha = this.secrets.secretKey ? aesEncrypt(temp, this.secrets.secretKey) : temp;\n          // delete response.data.token;\n          // delete response.data.captchaType;\n          // delete response.data.pointJson;\n          // delete response.data.result;\n          this.verified.emit({\n            code: 0,\n            msg: response.msg,\n            data: response.data\n          });\n        }\n      },\n      complete: () => this.verifying = false\n    });\n  }\n\n  markStart(event: PointerEvent) {\n    if (!this.loading && !this.verifying) {\n      event.stopPropagation();\n      this.dragStartX = event.clientX;\n      this.scrollLeft = this.sliderRef.nativeElement.scrollLeft;\n    }\n  }\n\n  @HostListener('window:pointerup', ['$event'])\n  @HostListener('window:pointercancel', ['$event'])\n  markEnd(event: PointerEvent) {\n    event.stopPropagation();\n    if (this.dragStartX > -1) {\n      this.verify(this.width - this.sliderRef.nativeElement.scrollLeft);\n    }\n    this.dragStartX = -1;\n  }\n\n  @HostListener('window:pointermove', ['$event'])\n  moveMarker(event: PointerEvent) {\n    event.stopPropagation();\n    if (this.dragStartX > -1) { // 如果在拖动了\n      const currentX = event.clientX; // 得到当前的X\n      const offset = currentX - this.dragStartX; // 得到拖动的距离\n\n      let left = this.scrollLeft - (offset < 0 ? 0 : offset);\n\n      if (left <= this.bar.blockWidth) {\n        left = this.bar.blockWidth;\n      } else if (left >= this.width) {\n        left = this.width;\n      }\n      this.sliderRef.nativeElement.scrollLeft = left;\n      this.slide(this.width - left);\n    }\n  }\n\n}\n","<div class=\"slide-block\" [style.width.px]=\"width\" [style.height.px]=\"height\">\n  <canvas #canvas></canvas>\n  @if (alert.show) {\n  <div\n    class=\"slide-alert\"\n    [class.slide-alert-success]=\"alert.type === 'success'\"\n    [class.slide-alert-danger]=\"alert.type === 'error'\"\n  >\n    {{ alert.msg }}\n  </div>\n  }\n</div>\n\n<div\n  #slider\n  class=\"verify-bar\"\n  [style.width.px]=\"width\"\n  (scroll)=\"$event.preventDefault()\"\n  (touchmove)=\"$event.preventDefault()\"\n  (mousewheel)=\"$event.preventDefault()\"\n>\n  <div\n    style=\"display: inline-block; height: 40px; vertical-align: top\"\n    [style]=\"{ background: bar.background }\"\n    [draggable]=\"false\"\n    [style.width.px]=\"width\"\n  ></div>\n  <div class=\"verify-bar-area\" [style.width.px]=\"width\" [draggable]=\"false\">\n    <span class=\"verify-msg\" [draggable]=\"false\">拖动滑块以完成拼图验证</span>\n    <div class=\"verify-left-bar\" [style.width.px]=\"bar.blockWidth\">\n      <div\n        class=\"verify-move-block\"\n        [draggable]=\"false\"\n        (pointerdown)=\"markStart($event)\"\n      >\n        <svg viewBox=\"0 0 512 512\">\n          <path\n            stroke-width=\"32\"\n            stroke-linecap=\"round\"\n            stroke-miterlimit=\"10\"\n            d=\"M80 160h352M80 256h352M80 352h352\"\n          ></path>\n        </svg>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -17,7 +17,4 @@ export const aesEncrypt = (word, secret) => {
|
|
|
17
17
|
export function withDpr(value) {
|
|
18
18
|
return value * devicePixelRatio;
|
|
19
19
|
}
|
|
20
|
-
|
|
21
|
-
return value + 'px';
|
|
22
|
-
}
|
|
23
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy91aS1zdW4vc2xpZGVyLWNhcHRjaGEvdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ25ELE9BQU8sRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDNUQsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN4QyxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDM0MsT0FBTyxFQUFFLE9BQU8sSUFBSSxJQUFJLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUNyRCxPQUFPLEVBQUUsT0FBTyxJQUFJLE9BQU8sRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBRXpELE1BQU0sQ0FBQyxNQUFNLFlBQVksR0FBRztJQUMxQixlQUFlLEVBQUUsSUFBSTtJQUNyQixPQUFPLEVBQUUsSUFBSSxXQUFXLEVBQUUsQ0FBQyxHQUFHLENBQUMsU0FBUyxFQUFFLEtBQUssQ0FBQyxDQUFDLEdBQUcsQ0FBQyxVQUFVLEVBQUUsS0FBSyxDQUFDO0NBQ3hFLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxVQUFVLEdBQUcsQ0FBQyxJQUFZLEVBQUUsTUFBYyxFQUFFLEVBQUU7SUFDekQsTUFBTSxHQUFHLEdBQUcsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQzFCLE1BQU0sR0FBRyxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN4QixNQUFNLFNBQVMsR0FBRyxPQUFPLENBQUMsR0FBRyxFQUFFLEdBQUcsRUFBRSxFQUFFLElBQUksRUFBRSxPQUFPLEVBQUUsQ0FBQyxDQUFDO0lBQ3ZELE9BQU8sU0FBUyxDQUFDLFFBQVEsRUFBRSxDQUFDO0FBQzlCLENBQUMsQ0FBQztBQUVGLE1BQU0sVUFBVSxPQUFPLENBQUMsS0FBYTtJQUNuQyxPQUFPLEtBQUssR0FBRyxnQkFBZ0IsQ0FBQztBQUNsQyxDQUFDO0FBRUQsTUFBTSxVQUFVLFNBQVMsQ0FBQyxLQUFhO0lBQ3JDLE9BQU8sS0FBSyxHQUFHLElBQUksQ0FBQztBQUN0QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSHR0cENvbnRleHQgfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XG5pbXBvcnQgeyBBUElfVE9LRU4sIEFVVEhfVE9LRU4gfSBmcm9tICdAc29sYXItYW5ndWxhci9odHRwJztcbmltcG9ydCB7IGVuY3J5cHQgfSBmcm9tICdjcnlwdG8tanMvYWVzJztcbmltcG9ydCB7IHBhcnNlIH0gZnJvbSAnY3J5cHRvLWpzL2VuYy11dGY4JztcbmltcG9ydCB7IGRlZmF1bHQgYXMgbW9kZSB9IGZyb20gJ2NyeXB0by1qcy9tb2RlLWVjYic7XG5pbXBvcnQgeyBkZWZhdWx0IGFzIHBhZGRpbmcgfSBmcm9tICdjcnlwdG8tanMvcGFkLXBrY3M3JztcblxuZXhwb3J0IGNvbnN0IEhUVFBfT1BUSU9OUyA9IHtcbiAgd2l0aENyZWRlbnRpYWxzOiB0cnVlLFxuICBjb250ZXh0OiBuZXcgSHR0cENvbnRleHQoKS5zZXQoQVBJX1RPS0VOLCBmYWxzZSkuc2V0KEFVVEhfVE9LRU4sIGZhbHNlKVxufTtcblxuZXhwb3J0IGNvbnN0IGFlc0VuY3J5cHQgPSAod29yZDogc3RyaW5nLCBzZWNyZXQ6IHN0cmluZykgPT4ge1xuICBjb25zdCBrZXkgPSBwYXJzZShzZWNyZXQpO1xuICBjb25zdCBzcmMgPSBwYXJzZSh3b3JkKTtcbiAgY29uc3QgZW5jcnlwdGVkID0gZW5jcnlwdChzcmMsIGtleSwgeyBtb2RlLCBwYWRkaW5nIH0pO1xuICByZXR1cm4gZW5jcnlwdGVkLnRvU3RyaW5nKCk7XG59O1xuXG5leHBvcnQgZnVuY3Rpb24gd2l0aERwcih2YWx1ZTogbnVtYmVyKSB7XG4gIHJldHVybiB2YWx1ZSAqIGRldmljZVBpeGVsUmF0aW87XG59XG5cbmV4cG9ydCBmdW5jdGlvbiB3aXRoUGl4ZWwodmFsdWU6IG51bWJlcikge1xuICByZXR1cm4gdmFsdWUgKyAncHgnO1xufVxuIl19
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy91aS1zdW4vc2xpZGVyLWNhcHRjaGEvdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ25ELE9BQU8sRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDNUQsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN4QyxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDM0MsT0FBTyxFQUFFLE9BQU8sSUFBSSxJQUFJLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUNyRCxPQUFPLEVBQUUsT0FBTyxJQUFJLE9BQU8sRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBRXpELE1BQU0sQ0FBQyxNQUFNLFlBQVksR0FBRztJQUMxQixlQUFlLEVBQUUsSUFBSTtJQUNyQixPQUFPLEVBQUUsSUFBSSxXQUFXLEVBQUUsQ0FBQyxHQUFHLENBQUMsU0FBUyxFQUFFLEtBQUssQ0FBQyxDQUFDLEdBQUcsQ0FBQyxVQUFVLEVBQUUsS0FBSyxDQUFDO0NBQ3hFLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxVQUFVLEdBQUcsQ0FBQyxJQUFZLEVBQUUsTUFBYyxFQUFFLEVBQUU7SUFDekQsTUFBTSxHQUFHLEdBQUcsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQzFCLE1BQU0sR0FBRyxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN4QixNQUFNLFNBQVMsR0FBRyxPQUFPLENBQUMsR0FBRyxFQUFFLEdBQUcsRUFBRSxFQUFFLElBQUksRUFBRSxPQUFPLEVBQUUsQ0FBQyxDQUFDO0lBQ3ZELE9BQU8sU0FBUyxDQUFDLFFBQVEsRUFBRSxDQUFDO0FBQzlCLENBQUMsQ0FBQztBQUVGLE1BQU0sVUFBVSxPQUFPLENBQUMsS0FBYTtJQUNuQyxPQUFPLEtBQUssR0FBRyxnQkFBZ0IsQ0FBQztBQUNsQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSHR0cENvbnRleHQgfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XG5pbXBvcnQgeyBBUElfVE9LRU4sIEFVVEhfVE9LRU4gfSBmcm9tICdAc29sYXItYW5ndWxhci9odHRwJztcbmltcG9ydCB7IGVuY3J5cHQgfSBmcm9tICdjcnlwdG8tanMvYWVzJztcbmltcG9ydCB7IHBhcnNlIH0gZnJvbSAnY3J5cHRvLWpzL2VuYy11dGY4JztcbmltcG9ydCB7IGRlZmF1bHQgYXMgbW9kZSB9IGZyb20gJ2NyeXB0by1qcy9tb2RlLWVjYic7XG5pbXBvcnQgeyBkZWZhdWx0IGFzIHBhZGRpbmcgfSBmcm9tICdjcnlwdG8tanMvcGFkLXBrY3M3JztcblxuZXhwb3J0IGNvbnN0IEhUVFBfT1BUSU9OUyA9IHtcbiAgd2l0aENyZWRlbnRpYWxzOiB0cnVlLFxuICBjb250ZXh0OiBuZXcgSHR0cENvbnRleHQoKS5zZXQoQVBJX1RPS0VOLCBmYWxzZSkuc2V0KEFVVEhfVE9LRU4sIGZhbHNlKVxufTtcblxuZXhwb3J0IGNvbnN0IGFlc0VuY3J5cHQgPSAod29yZDogc3RyaW5nLCBzZWNyZXQ6IHN0cmluZykgPT4ge1xuICBjb25zdCBrZXkgPSBwYXJzZShzZWNyZXQpO1xuICBjb25zdCBzcmMgPSBwYXJzZSh3b3JkKTtcbiAgY29uc3QgZW5jcnlwdGVkID0gZW5jcnlwdChzcmMsIGtleSwgeyBtb2RlLCBwYWRkaW5nIH0pO1xuICByZXR1cm4gZW5jcnlwdGVkLnRvU3RyaW5nKCk7XG59O1xuXG5leHBvcnQgZnVuY3Rpb24gd2l0aERwcih2YWx1ZTogbnVtYmVyKSB7XG4gIHJldHVybiB2YWx1ZSAqIGRldmljZVBpeGVsUmF0aW87XG59XG4iXX0=
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
2
|
import { EventEmitter, afterNextRender, numberAttribute, Component, HostBinding, ViewChild, Input, Output, HostListener } from '@angular/core';
|
|
3
|
+
import { withPixel } from '@solar-kit/core';
|
|
3
4
|
import { zip, fromEvent, take } from 'rxjs';
|
|
4
5
|
import * as i1 from '@angular/common/http';
|
|
5
6
|
import { HttpContext } from '@angular/common/http';
|
|
@@ -22,9 +23,6 @@ const aesEncrypt = (word, secret) => {
|
|
|
22
23
|
function withDpr(value) {
|
|
23
24
|
return value * devicePixelRatio;
|
|
24
25
|
}
|
|
25
|
-
function withPixel(value) {
|
|
26
|
-
return value + 'px';
|
|
27
|
-
}
|
|
28
26
|
|
|
29
27
|
/** 验证码的原始尺寸 */
|
|
30
28
|
const HEIGHT = 155, WIDTH = 310;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"solar-angular-ui-sun-slider-captcha.mjs","sources":["../../../packages/ui-sun/slider-captcha/utils.ts","../../../packages/ui-sun/slider-captcha/slider-captcha.component.ts","../../../packages/ui-sun/slider-captcha/slider-captcha.component.html","../../../packages/ui-sun/slider-captcha/solar-angular-ui-sun-slider-captcha.ts"],"sourcesContent":["import { HttpContext } from '@angular/common/http';\nimport { API_TOKEN, AUTH_TOKEN } from '@solar-angular/http';\nimport { encrypt } from 'crypto-js/aes';\nimport { parse } from 'crypto-js/enc-utf8';\nimport { default as mode } from 'crypto-js/mode-ecb';\nimport { default as padding } from 'crypto-js/pad-pkcs7';\n\nexport const HTTP_OPTIONS = {\n withCredentials: true,\n context: new HttpContext().set(API_TOKEN, false).set(AUTH_TOKEN, false)\n};\n\nexport const aesEncrypt = (word: string, secret: string) => {\n const key = parse(secret);\n const src = parse(word);\n const encrypted = encrypt(src, key, { mode, padding });\n return encrypted.toString();\n};\n\nexport function withDpr(value: number) {\n return value * devicePixelRatio;\n}\n\nexport function withPixel(value: number) {\n return value + 'px';\n}\n","import { HttpClient } from '@angular/common/http';\nimport { afterNextRender, Component, ElementRef, EventEmitter, HostBinding, HostListener, Input, numberAttribute, Output, ViewChild } from '@angular/core';\nimport { Result } from '@solar-kit/planets/sun';\nimport { fromEvent, take, zip } from 'rxjs';\nimport { Captcha, CaptchaType } from './model';\nimport { aesEncrypt, HTTP_OPTIONS, withDpr, withPixel } from './utils';\n\n/** 验证码的原始尺寸 */\nconst HEIGHT = 155, WIDTH = 310;\n/** 拼图的原始尺寸 */\nconst PUZZLE_HEIGHT = 155, PUZZLE_WIDTH = 50;\n\n@Component({\n selector: 'sun-slider-captcha',\n standalone: true,\n templateUrl: './slider-captcha.component.html',\n styleUrl: './slider-captcha.component.scss',\n})\nexport class SunSliderCaptcha {\n @HostBinding('class.sun-verify-loading') loading = false;\n @HostBinding('class.sun-verify-verifying') verifying = false;\n\n @ViewChild('canvas', { static: true }) canvasRef!: ElementRef<HTMLCanvasElement>;\n @ViewChild('slider', { static: true }) sliderRef!: ElementRef<HTMLDivElement>;\n\n @Input() srcUrl!: string;\n @Input() verifyUrl!: string;\n @Input() verifyData?: Record<string, any> | (() => Record<string, any>);\n @Input({ transform: numberAttribute }) width = WIDTH;\n @Input({ transform: numberAttribute }) height = HEIGHT;\n\n @Output() verified = new EventEmitter<Result<Captcha>>();\n\n private canvas!: HTMLCanvasElement;\n private ctx!: CanvasRenderingContext2D;\n private bgImage!: HTMLImageElement;\n private slideImage!: HTMLImageElement;\n\n /** 滑块拼图的x坐标 */\n x = 0;\n\n secrets: { secretKey: string, token: string } = {} as any;\n\n alert: { type: 'success' | 'error', msg: string, show: boolean } = {\n type: 'success', // error\n msg: '',\n show: false\n };\n\n beginTime!: number;\n endTime!: number;\n\n /** 滑动开始的X */\n dragStartX = -1;\n /** 滑动bar初始的scrollLeft */\n scrollLeft = 0;\n\n bar = {\n blockWidth: 42, // 滑块宽度\n background: 'var(--indicator-primary-color)'\n };\n\n /**\n * 当前尺寸 除于 原始尺寸得到的商\n * 用于等比例缩放\n */\n get quotient() {\n return {\n width: this.width / WIDTH,\n height: this.height / HEIGHT\n };\n }\n\n constructor(private http: HttpClient) {\n afterNextRender(() => {\n const dpr = devicePixelRatio;\n this.canvas = this.canvasRef.nativeElement;\n this.canvas.style.width = withPixel(this.width);\n this.canvas.style.height = withPixel(this.height);\n this.canvas.width = withDpr(this.width);\n this.canvas.height = withDpr(this.height);\n\n this.ctx = this.canvas.getContext('2d')!;\n this.ctx.scale(dpr, dpr);\n\n setTimeout(() => {\n this.refresh();\n });\n })\n }\n\n refresh() {\n setTimeout(() => {\n this.sliderRef.nativeElement.scrollTo(this.width, 0);\n }, 50);\n this.alert.show = false;\n this.bar.background = 'var(--indicator-primary-color)';\n this.loading = true;\n this.http.post<Result<Captcha>>(this.srcUrl, { captchaType: CaptchaType.BlockPuzzle }, HTTP_OPTIONS).subscribe(response => {\n if (response.code === 0) {\n this.secrets.secretKey = response.data.secretKey;\n this.secrets.token = response.data.token;\n this.bgImage = new Image();\n this.slideImage = new Image();\n // this.bgImage.src = `data:image/png;base64,${re.data.jigsawImageBase64}`;\n this.bgImage.src = `data:image/png;base64,${response.data.originalImageBase64}`;\n this.slideImage.src = `data:image/png;base64,${response.data.jigsawImageBase64}`;\n zip(\n fromEvent(this.bgImage, 'load'),\n fromEvent(this.slideImage, 'load'),\n ).pipe(take(1)).subscribe(() => {\n this.beginTime = new Date().getTime();\n this.draw();\n });\n } else {\n console.error(response.msg);\n }\n });\n }\n\n private draw(x = 0) {\n this.x = x;\n this.ctx.clearRect(0, 0, this.width, this.height);\n this.ctx.drawImage(this.bgImage, 0, 0, this.width, this.height);\n this.ctx.drawImage(this.slideImage, this.x, 0, this.quotient.width * PUZZLE_WIDTH, this.quotient.height * PUZZLE_HEIGHT);\n this.loading = false;\n }\n\n slide(x: number) {\n this.draw(x);\n }\n\n verify(x: number) {\n this.verifying = true;\n // 计算出原始移动距离\n x = x / this.quotient.width;\n\n this.endTime = new Date().getTime();\n const json = JSON.stringify({ x: x, y: 5.0 });\n const pointJson = this.secrets.secretKey ? aesEncrypt(json, this.secrets.secretKey) : json;\n const verifyData = typeof this.verifyData === 'function' ? this.verifyData() : this.verifyData;\n const obj = {\n captchaType: CaptchaType.BlockPuzzle,\n pointJson,\n token: this.secrets.token,\n ...verifyData\n };\n this.http.post<Result<Captcha>>(this.verifyUrl, obj, HTTP_OPTIONS).subscribe({\n next: response => {\n if (response.code !== 0) {\n this.alert.type = 'error';\n this.alert.msg = response.msg;\n this.alert.show = true;\n this.bar.background = 'var(--indicator-danger-color)';\n this.verified.emit({\n code: -1,\n msg: response.msg,\n data: null!\n });\n setTimeout(() => {\n this.alert.show = false;\n this.refresh();\n }, 1000);\n } else {\n this.alert.type = 'success';\n this.bar.background = 'var(--indicator-primary-color)';\n const seconds = Math.abs(this.endTime - this.beginTime) / 1000;\n this.alert.msg = ` ${seconds}秒 验证成功`;\n this.alert.show = true;\n const temp = response.data.token + '---' + json;\n response.data.captcha = this.secrets.secretKey ? aesEncrypt(temp, this.secrets.secretKey) : temp;\n // delete response.data.token;\n // delete response.data.captchaType;\n // delete response.data.pointJson;\n // delete response.data.result;\n this.verified.emit({\n code: 0,\n msg: response.msg,\n data: response.data\n });\n }\n },\n complete: () => this.verifying = false\n });\n }\n\n markStart(event: PointerEvent) {\n if (!this.loading && !this.verifying) {\n event.stopPropagation();\n this.dragStartX = event.clientX;\n this.scrollLeft = this.sliderRef.nativeElement.scrollLeft;\n }\n }\n\n @HostListener('window:pointerup', ['$event'])\n @HostListener('window:pointercancel', ['$event'])\n markEnd(event: PointerEvent) {\n event.stopPropagation();\n if (this.dragStartX > -1) {\n this.verify(this.width - this.sliderRef.nativeElement.scrollLeft);\n }\n this.dragStartX = -1;\n }\n\n @HostListener('window:pointermove', ['$event'])\n moveMarker(event: PointerEvent) {\n event.stopPropagation();\n if (this.dragStartX > -1) { // 如果在拖动了\n const currentX = event.clientX; // 得到当前的X\n const offset = currentX - this.dragStartX; // 得到拖动的距离\n\n let left = this.scrollLeft - (offset < 0 ? 0 : offset);\n\n if (left <= this.bar.blockWidth) {\n left = this.bar.blockWidth;\n } else if (left >= this.width) {\n left = this.width;\n }\n this.sliderRef.nativeElement.scrollLeft = left;\n this.slide(this.width - left);\n }\n }\n\n}\n","<div class=\"slide-block\" [style.width.px]=\"width\" [style.height.px]=\"height\">\n <canvas #canvas></canvas>\n @if (alert.show) {\n <div\n class=\"slide-alert\"\n [class.slide-alert-success]=\"alert.type === 'success'\"\n [class.slide-alert-danger]=\"alert.type === 'error'\"\n >\n {{ alert.msg }}\n </div>\n }\n</div>\n\n<div\n #slider\n class=\"verify-bar\"\n [style.width.px]=\"width\"\n (scroll)=\"$event.preventDefault()\"\n (touchmove)=\"$event.preventDefault()\"\n (mousewheel)=\"$event.preventDefault()\"\n>\n <div\n style=\"display: inline-block; height: 40px; vertical-align: top\"\n [style]=\"{ background: bar.background }\"\n [draggable]=\"false\"\n [style.width.px]=\"width\"\n ></div>\n <div class=\"verify-bar-area\" [style.width.px]=\"width\" [draggable]=\"false\">\n <span class=\"verify-msg\" [draggable]=\"false\">拖动滑块以完成拼图验证</span>\n <div class=\"verify-left-bar\" [style.width.px]=\"bar.blockWidth\">\n <div\n class=\"verify-move-block\"\n [draggable]=\"false\"\n (pointerdown)=\"markStart($event)\"\n >\n <svg viewBox=\"0 0 512 512\">\n <path\n stroke-width=\"32\"\n stroke-linecap=\"round\"\n stroke-miterlimit=\"10\"\n d=\"M80 160h352M80 256h352M80 352h352\"\n ></path>\n </svg>\n </div>\n </div>\n </div>\n</div>\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"solar-angular-ui-sun-slider-captcha.mjs","sources":["../../../packages/ui-sun/slider-captcha/utils.ts","../../../packages/ui-sun/slider-captcha/slider-captcha.component.ts","../../../packages/ui-sun/slider-captcha/slider-captcha.component.html","../../../packages/ui-sun/slider-captcha/solar-angular-ui-sun-slider-captcha.ts"],"sourcesContent":["import { HttpContext } from '@angular/common/http';\nimport { API_TOKEN, AUTH_TOKEN } from '@solar-angular/http';\nimport { encrypt } from 'crypto-js/aes';\nimport { parse } from 'crypto-js/enc-utf8';\nimport { default as mode } from 'crypto-js/mode-ecb';\nimport { default as padding } from 'crypto-js/pad-pkcs7';\n\nexport const HTTP_OPTIONS = {\n withCredentials: true,\n context: new HttpContext().set(API_TOKEN, false).set(AUTH_TOKEN, false)\n};\n\nexport const aesEncrypt = (word: string, secret: string) => {\n const key = parse(secret);\n const src = parse(word);\n const encrypted = encrypt(src, key, { mode, padding });\n return encrypted.toString();\n};\n\nexport function withDpr(value: number) {\n return value * devicePixelRatio;\n}\n","import { HttpClient } from '@angular/common/http';\nimport { afterNextRender, Component, ElementRef, EventEmitter, HostBinding, HostListener, Input, numberAttribute, Output, ViewChild } from '@angular/core';\nimport { withPixel } from '@solar-kit/core';\nimport { Result } from '@solar-kit/planets/sun';\nimport { fromEvent, take, zip } from 'rxjs';\nimport { Captcha, CaptchaType } from './model';\nimport { aesEncrypt, HTTP_OPTIONS, withDpr } from './utils';\n\n/** 验证码的原始尺寸 */\nconst HEIGHT = 155, WIDTH = 310;\n/** 拼图的原始尺寸 */\nconst PUZZLE_HEIGHT = 155, PUZZLE_WIDTH = 50;\n\n@Component({\n selector: 'sun-slider-captcha',\n standalone: true,\n templateUrl: './slider-captcha.component.html',\n styleUrl: './slider-captcha.component.scss',\n})\nexport class SunSliderCaptcha {\n @HostBinding('class.sun-verify-loading') loading = false;\n @HostBinding('class.sun-verify-verifying') verifying = false;\n\n @ViewChild('canvas', { static: true }) canvasRef!: ElementRef<HTMLCanvasElement>;\n @ViewChild('slider', { static: true }) sliderRef!: ElementRef<HTMLDivElement>;\n\n @Input() srcUrl!: string;\n @Input() verifyUrl!: string;\n @Input() verifyData?: Record<string, any> | (() => Record<string, any>);\n @Input({ transform: numberAttribute }) width = WIDTH;\n @Input({ transform: numberAttribute }) height = HEIGHT;\n\n @Output() verified = new EventEmitter<Result<Captcha>>();\n\n private canvas!: HTMLCanvasElement;\n private ctx!: CanvasRenderingContext2D;\n private bgImage!: HTMLImageElement;\n private slideImage!: HTMLImageElement;\n\n /** 滑块拼图的x坐标 */\n x = 0;\n\n secrets: { secretKey: string, token: string } = {} as any;\n\n alert: { type: 'success' | 'error', msg: string, show: boolean } = {\n type: 'success', // error\n msg: '',\n show: false\n };\n\n beginTime!: number;\n endTime!: number;\n\n /** 滑动开始的X */\n dragStartX = -1;\n /** 滑动bar初始的scrollLeft */\n scrollLeft = 0;\n\n bar = {\n blockWidth: 42, // 滑块宽度\n background: 'var(--indicator-primary-color)'\n };\n\n /**\n * 当前尺寸 除于 原始尺寸得到的商\n * 用于等比例缩放\n */\n get quotient() {\n return {\n width: this.width / WIDTH,\n height: this.height / HEIGHT\n };\n }\n\n constructor(private http: HttpClient) {\n afterNextRender(() => {\n const dpr = devicePixelRatio;\n this.canvas = this.canvasRef.nativeElement;\n this.canvas.style.width = withPixel(this.width);\n this.canvas.style.height = withPixel(this.height);\n this.canvas.width = withDpr(this.width);\n this.canvas.height = withDpr(this.height);\n\n this.ctx = this.canvas.getContext('2d')!;\n this.ctx.scale(dpr, dpr);\n\n setTimeout(() => {\n this.refresh();\n });\n })\n }\n\n refresh() {\n setTimeout(() => {\n this.sliderRef.nativeElement.scrollTo(this.width, 0);\n }, 50);\n this.alert.show = false;\n this.bar.background = 'var(--indicator-primary-color)';\n this.loading = true;\n this.http.post<Result<Captcha>>(this.srcUrl, { captchaType: CaptchaType.BlockPuzzle }, HTTP_OPTIONS).subscribe(response => {\n if (response.code === 0) {\n this.secrets.secretKey = response.data.secretKey;\n this.secrets.token = response.data.token;\n this.bgImage = new Image();\n this.slideImage = new Image();\n // this.bgImage.src = `data:image/png;base64,${re.data.jigsawImageBase64}`;\n this.bgImage.src = `data:image/png;base64,${response.data.originalImageBase64}`;\n this.slideImage.src = `data:image/png;base64,${response.data.jigsawImageBase64}`;\n zip(\n fromEvent(this.bgImage, 'load'),\n fromEvent(this.slideImage, 'load'),\n ).pipe(take(1)).subscribe(() => {\n this.beginTime = new Date().getTime();\n this.draw();\n });\n } else {\n console.error(response.msg);\n }\n });\n }\n\n private draw(x = 0) {\n this.x = x;\n this.ctx.clearRect(0, 0, this.width, this.height);\n this.ctx.drawImage(this.bgImage, 0, 0, this.width, this.height);\n this.ctx.drawImage(this.slideImage, this.x, 0, this.quotient.width * PUZZLE_WIDTH, this.quotient.height * PUZZLE_HEIGHT);\n this.loading = false;\n }\n\n slide(x: number) {\n this.draw(x);\n }\n\n verify(x: number) {\n this.verifying = true;\n // 计算出原始移动距离\n x = x / this.quotient.width;\n\n this.endTime = new Date().getTime();\n const json = JSON.stringify({ x: x, y: 5.0 });\n const pointJson = this.secrets.secretKey ? aesEncrypt(json, this.secrets.secretKey) : json;\n const verifyData = typeof this.verifyData === 'function' ? this.verifyData() : this.verifyData;\n const obj = {\n captchaType: CaptchaType.BlockPuzzle,\n pointJson,\n token: this.secrets.token,\n ...verifyData\n };\n this.http.post<Result<Captcha>>(this.verifyUrl, obj, HTTP_OPTIONS).subscribe({\n next: response => {\n if (response.code !== 0) {\n this.alert.type = 'error';\n this.alert.msg = response.msg;\n this.alert.show = true;\n this.bar.background = 'var(--indicator-danger-color)';\n this.verified.emit({\n code: -1,\n msg: response.msg,\n data: null!\n });\n setTimeout(() => {\n this.alert.show = false;\n this.refresh();\n }, 1000);\n } else {\n this.alert.type = 'success';\n this.bar.background = 'var(--indicator-primary-color)';\n const seconds = Math.abs(this.endTime - this.beginTime) / 1000;\n this.alert.msg = ` ${seconds}秒 验证成功`;\n this.alert.show = true;\n const temp = response.data.token + '---' + json;\n response.data.captcha = this.secrets.secretKey ? aesEncrypt(temp, this.secrets.secretKey) : temp;\n // delete response.data.token;\n // delete response.data.captchaType;\n // delete response.data.pointJson;\n // delete response.data.result;\n this.verified.emit({\n code: 0,\n msg: response.msg,\n data: response.data\n });\n }\n },\n complete: () => this.verifying = false\n });\n }\n\n markStart(event: PointerEvent) {\n if (!this.loading && !this.verifying) {\n event.stopPropagation();\n this.dragStartX = event.clientX;\n this.scrollLeft = this.sliderRef.nativeElement.scrollLeft;\n }\n }\n\n @HostListener('window:pointerup', ['$event'])\n @HostListener('window:pointercancel', ['$event'])\n markEnd(event: PointerEvent) {\n event.stopPropagation();\n if (this.dragStartX > -1) {\n this.verify(this.width - this.sliderRef.nativeElement.scrollLeft);\n }\n this.dragStartX = -1;\n }\n\n @HostListener('window:pointermove', ['$event'])\n moveMarker(event: PointerEvent) {\n event.stopPropagation();\n if (this.dragStartX > -1) { // 如果在拖动了\n const currentX = event.clientX; // 得到当前的X\n const offset = currentX - this.dragStartX; // 得到拖动的距离\n\n let left = this.scrollLeft - (offset < 0 ? 0 : offset);\n\n if (left <= this.bar.blockWidth) {\n left = this.bar.blockWidth;\n } else if (left >= this.width) {\n left = this.width;\n }\n this.sliderRef.nativeElement.scrollLeft = left;\n this.slide(this.width - left);\n }\n }\n\n}\n","<div class=\"slide-block\" [style.width.px]=\"width\" [style.height.px]=\"height\">\n <canvas #canvas></canvas>\n @if (alert.show) {\n <div\n class=\"slide-alert\"\n [class.slide-alert-success]=\"alert.type === 'success'\"\n [class.slide-alert-danger]=\"alert.type === 'error'\"\n >\n {{ alert.msg }}\n </div>\n }\n</div>\n\n<div\n #slider\n class=\"verify-bar\"\n [style.width.px]=\"width\"\n (scroll)=\"$event.preventDefault()\"\n (touchmove)=\"$event.preventDefault()\"\n (mousewheel)=\"$event.preventDefault()\"\n>\n <div\n style=\"display: inline-block; height: 40px; vertical-align: top\"\n [style]=\"{ background: bar.background }\"\n [draggable]=\"false\"\n [style.width.px]=\"width\"\n ></div>\n <div class=\"verify-bar-area\" [style.width.px]=\"width\" [draggable]=\"false\">\n <span class=\"verify-msg\" [draggable]=\"false\">拖动滑块以完成拼图验证</span>\n <div class=\"verify-left-bar\" [style.width.px]=\"bar.blockWidth\">\n <div\n class=\"verify-move-block\"\n [draggable]=\"false\"\n (pointerdown)=\"markStart($event)\"\n >\n <svg viewBox=\"0 0 512 512\">\n <path\n stroke-width=\"32\"\n stroke-linecap=\"round\"\n stroke-miterlimit=\"10\"\n d=\"M80 160h352M80 256h352M80 352h352\"\n ></path>\n </svg>\n </div>\n </div>\n </div>\n</div>\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@solar-angular/ui-sun",
|
|
3
|
-
"version": "18.0.
|
|
3
|
+
"version": "18.0.5",
|
|
4
4
|
"sideEffects": false,
|
|
5
5
|
"publishConfig": {
|
|
6
6
|
"access": "public"
|
|
7
7
|
},
|
|
8
8
|
"dependencies": {
|
|
9
|
-
"@solar-angular/http": "18.0.
|
|
10
|
-
"@solar-angular/animations": "18.0.
|
|
9
|
+
"@solar-angular/http": "18.0.5",
|
|
10
|
+
"@solar-angular/animations": "18.0.5",
|
|
11
11
|
"crypto-js": "^4.2.0",
|
|
12
12
|
"tslib": "^2.3.0"
|
|
13
13
|
},
|