ng-captcha
Version:
A pure front-end angular captcha module.
212 lines (204 loc) • 20.2 kB
JavaScript
(function (global, factory) {
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('@angular/common')) :
typeof define === 'function' && define.amd ? define('ng-captcha', ['exports', '@angular/core', '@angular/common'], factory) :
(factory((global['ng-captcha'] = {}),global.ng.core,global.ng.common));
}(this, (function (exports,core,common) { 'use strict';
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
var CaptchaComponent = /** @class */ (function () {
function CaptchaComponent() {
this.generateCode = new core.EventEmitter();
this.canvas = document.createElement('canvas');
this.letters = ["0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z", "A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z"];
this.code = '';
}
/**
* @return {?}
*/
CaptchaComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
this.init();
this.refresh();
};
/**
* @return {?}
*/
CaptchaComponent.prototype.onClick = /**
* @return {?}
*/
function () {
this.refresh();
};
/**
* @return {?}
*/
CaptchaComponent.prototype.init = /**
* @return {?}
*/
function () {
this.canvas.width = this.width || 100;
this.canvas.height = this.height || 50;
this.canvas.style.cursor = 'pointer';
this.canvas.innerHTML = '您的浏览器版本不支持canvas';
this.container.nativeElement.appendChild(this.canvas);
};
// generate code
// generate code
/**
* @return {?}
*/
CaptchaComponent.prototype.refresh =
// generate code
/**
* @return {?}
*/
function () {
this.code = '';
/** @type {?} */
var ctx = this.canvas.getContext('2d');
ctx.textBaseline = 'middle';
ctx.fillStyle = this.randomColor(180, 240);
ctx.fillRect(0, 0, this.canvas.width, this.canvas.height);
for (var i = 0; i < 4; i++) {
/** @type {?} */
var letter = this.letters[this.randomNum(0, this.letters.length)];
this.code += letter;
ctx.font = this.randomNum(this.canvas.height / 2, this.canvas.height) + 'px SimHei';
ctx.fillStyle = this.randomColor(50, 160);
ctx.shadowOffsetX = this.randomNum(-3, 3);
ctx.shadowOffsetY = this.randomNum(-3, 3);
ctx.shadowBlur = this.randomNum(-3, 3);
ctx.shadowColor = 'rgb(0, 0, 0, 0.3)';
/** @type {?} */
var x = this.canvas.width / 5 * i;
/** @type {?} */
var y = this.canvas.height / 2;
/** @type {?} */
var deg = this.randomNum(-30, 30);
// setting rotate and origin point
ctx.translate(x, y);
ctx.rotate(deg * Math.PI / 180);
ctx.fillText(letter, 0, 0);
// reset rotate and origin point
ctx.rotate(-deg * Math.PI / 180);
ctx.translate(-x, -y);
}
// draw interfering line
for (var i = 0; i < 4; i++) {
ctx.strokeStyle = this.randomColor(40, 180);
ctx.beginPath();
ctx.moveTo(this.randomNum(0, this.canvas.width), this.randomNum(0, this.canvas.height));
ctx.lineTo(this.randomNum(0, this.canvas.width), this.randomNum(0, this.canvas.height));
ctx.stroke();
}
// draw interfering point
for (var i = 0; i < this.canvas.width / 4; i++) {
ctx.fillStyle = this.randomColor();
ctx.beginPath();
ctx.arc(this.randomNum(0, this.canvas.width), this.randomNum(0, this.canvas.height), 1, 0, 2 * Math.PI);
ctx.fill();
}
this.generateCode.emit(this.code.toLowerCase());
};
/**
* return a random integer
* @param min 最小值
* @param max 最大值
*/
/**
* return a random integer
* @param {?} min 最小值
* @param {?} max 最大值
* @return {?}
*/
CaptchaComponent.prototype.randomNum = /**
* return a random integer
* @param {?} min 最小值
* @param {?} max 最大值
* @return {?}
*/
function (min, max) {
return Math.floor(Math.random() * (max - min) + min);
};
/**
* return a random color
*/
/**
* return a random color
* @param {?=} min
* @param {?=} max
* @return {?}
*/
CaptchaComponent.prototype.randomColor = /**
* return a random color
* @param {?=} min
* @param {?=} max
* @return {?}
*/
function (min, max) {
if (min === void 0) {
min = 0;
}
if (max === void 0) {
max = 255;
}
/** @type {?} */
var r = this.randomNum(min, max);
/** @type {?} */
var g = this.randomNum(min, max);
/** @type {?} */
var b = this.randomNum(min, max);
return "rgb(" + r + ", " + g + ", " + b + ")";
};
CaptchaComponent.decorators = [
{ type: core.Component, args: [{
selector: 'captcha',
template: "<div class=\"captcha-container\" #captchaContainer (click)=\"onClick()\"></div>",
styles: [".captcha-container{display:inline-block;line-height:0}"]
}] }
];
/** @nocollapse */
CaptchaComponent.ctorParameters = function () { return []; };
CaptchaComponent.propDecorators = {
width: [{ type: core.Input }],
height: [{ type: core.Input }],
generateCode: [{ type: core.Output }],
container: [{ type: core.ViewChild, args: ['captchaContainer',] }]
};
return CaptchaComponent;
}());
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
var CaptchaModule = /** @class */ (function () {
function CaptchaModule() {
}
CaptchaModule.decorators = [
{ type: core.NgModule, args: [{
imports: [
common.CommonModule
],
declarations: [CaptchaComponent],
exports: [CaptchaComponent]
},] }
];
return CaptchaModule;
}());
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
exports.CaptchaModule = CaptchaModule;
exports.ɵa = CaptchaComponent;
Object.defineProperty(exports, '__esModule', { value: true });
})));
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ng-captcha.umd.js.map","sources":["ng://ng-captcha/lib/captcha.component.ts","ng://ng-captcha/lib/captcha.module.ts"],"sourcesContent":["import { Component, OnInit, ViewChild, Output, EventEmitter, Input } from '@angular/core';\n\n@Component({\n  selector: 'captcha',\n  templateUrl: './captcha.component.html',\n  styleUrls: ['./captcha.component.css']\n})\nexport class CaptchaComponent implements OnInit {\n\n  @Input() width\n  @Input() height\n  @Output() generateCode = new EventEmitter()\n  @ViewChild('captchaContainer') container\n  canvas = document.createElement('canvas')\n  letters = [\"0\", \"1\", \"2\", \"3\", \"4\", \"5\", \"6\", \"7\", \"8\", \"9\", \"a\", \"b\", \"c\", \"d\", \"e\", \"f\", \"g\", \"h\", \"i\", \"j\", \"k\", \"l\", \"m\", \"n\", \"o\", \"p\", \"q\", \"r\", \"s\", \"t\", \"u\", \"v\", \"w\", \"x\", \"y\", \"z\", \"A\", \"B\", \"C\", \"D\", \"E\", \"F\", \"G\", \"H\", \"I\", \"J\", \"K\", \"L\", \"M\", \"N\", \"O\", \"P\", \"Q\", \"R\", \"S\", \"T\", \"U\", \"V\", \"W\", \"X\", \"Y\", \"Z\"]\n  code = ''\n\n  constructor() { }\n\n  ngOnInit() {\n    this.init()\n    this.refresh()\n  }\n\n  onClick() {\n    this.refresh()\n  }\n\n  private init() {\n    this.canvas.width = this.width || 100\n    this.canvas.height = this.height || 50\n    this.canvas.style.cursor = 'pointer'\n    this.canvas.innerHTML = 'æ¨çæµè§å¨çæ¬ä¸æ¯æcanvas'\n    this.container.nativeElement.appendChild(this.canvas)\n  }\n\n  // generate code\n  private refresh() {\n    this.code = ''\n    const ctx = this.canvas.getContext('2d')\n    ctx.textBaseline = 'middle'\n    ctx.fillStyle = this.randomColor(180, 240)\n    ctx.fillRect(0, 0, this.canvas.width, this.canvas.height)\n\n    for (let i = 0; i < 4; i++) {\n      const letter = this.letters[this.randomNum(0, this.letters.length)]\n      this.code += letter\n      ctx.font = this.randomNum(this.canvas.height / 2, this.canvas.height) + 'px SimHei'\n      ctx.fillStyle = this.randomColor(50, 160)\n      ctx.shadowOffsetX = this.randomNum(-3, 3)\n      ctx.shadowOffsetY = this.randomNum(-3, 3)\n      ctx.shadowBlur = this.randomNum(-3, 3)\n      ctx.shadowColor = 'rgb(0, 0, 0, 0.3)'\n      const x = this.canvas.width / 5 * i\n      const y = this.canvas.height / 2\n      const deg = this.randomNum(-30, 30)\n      // setting rotate and origin point\n      ctx.translate(x, y)\n      ctx.rotate(deg * Math.PI / 180)\n      ctx.fillText(letter, 0, 0)\n      // reset rotate and origin point\n      ctx.rotate(-deg * Math.PI / 180)\n      ctx.translate(-x, -y)\n    }\n\n    // draw interfering line\n    for (let i = 0; i < 4; i++) {\n      ctx.strokeStyle = this.randomColor(40, 180)\n      ctx.beginPath()\n      ctx.moveTo(this.randomNum(0, this.canvas.width), this.randomNum(0, this.canvas.height))\n      ctx.lineTo(this.randomNum(0, this.canvas.width), this.randomNum(0, this.canvas.height))\n      ctx.stroke()\n    }\n\n    // draw interfering point\n    for (let i = 0; i < this.canvas.width / 4; i++) {\n      ctx.fillStyle = this.randomColor()\n      ctx.beginPath()\n      ctx.arc(this.randomNum(0, this.canvas.width), this.randomNum(0, this.canvas.height), 1, 0, 2 * Math.PI)\n      ctx.fill()\n    }\n\n    this.generateCode.emit(this.code.toLowerCase())\n  }\n\n  /**\n   * return a random integer\n   * @param min æå°å¼\n   * @param max æå¤§å¼\n   */\n  private randomNum(min, max) {\n    return Math.floor(Math.random() * (max - min) + min)\n  }\n\n  /**\n   * return a random color\n   */\n  private randomColor(min = 0, max = 255) {\n    const r = this.randomNum(min, max)\n    const g = this.randomNum(min, max)\n    const b = this.randomNum(min, max)\n    return `rgb(${r}, ${g}, ${b})`\n  }\n\n}\n","import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { CaptchaComponent } from './captcha.component';\n\n@NgModule({\n  imports: [\n    CommonModule\n  ],\n  declarations: [CaptchaComponent],\n  exports: [CaptchaComponent]\n})\nexport class CaptchaModule { }\n"],"names":["EventEmitter","Component","Input","Output","ViewChild","NgModule","CommonModule"],"mappings":"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"}