go-captcha-angular
Version:
GoCaptcha for Angular, which implements click mode, slider mode, drag-drop mode and rotation mode.
112 lines • 22.6 kB
JavaScript
import { Component, Input, ViewEncapsulation } from '@angular/core';
import { defaultClickConfig, defaultData } from "./click-instance";
import { getDomXY, mergeTo } from "../../helper/helper";
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
import * as i2 from "../../icons/close-icon.component";
import * as i3 from "../../icons/refresh-icon.component";
import * as i4 from "../../icons/loading-icon.component";
export class ClickComponent {
constructor() {
this.localConfig = defaultClickConfig();
this.localData = defaultData();
this.localEvents = {};
this.dots = [];
}
set config(config) {
mergeTo(this.localConfig, config);
this.localConfig = config;
}
set data(data) {
mergeTo(this.localData, data);
this.localData = data;
}
set events(events) {
mergeTo(this.localEvents, events);
this.localEvents = events;
}
get hasDisplayWrapperState() {
return (this.localConfig.width || 0) > 0 || (this.localConfig.height || 0) > 0;
}
get hasDisplayImageState() {
return (this.localData.image && this.localData.image.length > 0) || (this.localData.thumb && this.localData.thumb.length > 0);
}
clickEvent(e) {
const dom = e.currentTarget;
const xy = getDomXY(dom);
const mouseX = e.pageX || e.clientX;
const mouseY = e.pageY || e.clientY;
const domX = xy.domX;
const domY = xy.domY;
const xPos = mouseX - domX;
const yPos = mouseY - domY;
const xx = parseInt(xPos.toString());
const yy = parseInt(yPos.toString());
const date = new Date();
const index = this.dots.length;
this.dots.push({ key: date.getTime(), index: index + 1, x: xx, y: yy });
this.localEvents.click && this.localEvents.click(xx, yy);
e.cancelBubble = true;
e.preventDefault();
return false;
}
confirmEvent(e) {
const dotsStr = JSON.stringify(this.dots);
let dots = [];
try {
dots = JSON.parse(dotsStr);
}
catch (e) {
console.warn("parse dots error", e);
}
this.localEvents.confirm && this.localEvents.confirm(dots, () => {
this.dots = [];
});
e.cancelBubble = true;
e.preventDefault();
return false;
}
closeEvent(e) {
this.close();
e.cancelBubble = true;
e.preventDefault();
return false;
}
refreshEvent(e) {
this.refresh();
e.cancelBubble = true;
e.preventDefault();
return false;
}
reset() {
this.dots = [];
}
clear() {
this.reset();
setTimeout(() => {
this.localData.image = '';
this.localData.thumb = '';
}, 0);
}
close() {
this.localEvents.close && this.localEvents.close();
this.reset();
}
refresh() {
this.localEvents.refresh && this.localEvents.refresh();
this.reset();
}
}
ClickComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ClickComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
ClickComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: ClickComponent, selector: "go-captcha-click", inputs: { config: "config", data: "data", events: "events" }, ngImport: i0, template: "<div\n class=\"go-captcha gc-wrapper\"\n [class]=\"{'gc-theme': localConfig.showTheme}\"\n [style]=\"{\n width: (localConfig.width || 0) + ( localConfig.horizontalPadding * 2) + (localConfig.showTheme ? 2 : 0) + 'px',\n paddingLeft: localConfig.horizontalPadding + 'px',\n paddingRight: localConfig.horizontalPadding + 'px',\n paddingTop: localConfig.verticalPadding + 'px',\n paddingBottom: localConfig.verticalPadding + 'px',\n display: hasDisplayWrapperState ? 'block' : 'none'\n }\"\n >\n <div class=\"gc-header\">\n <span>{{ localConfig.title }}</span>\n <img\n [class]=\"{'gc-hide': localData.thumb == ''}\"\n [style]=\"{\n width: localConfig.thumbWidth + 'px',\n height: localConfig.thumbHeight + 'px'\n }\"\n [attr.src]=\"localData.thumb\"\n alt=\"\"\n />\n </div>\n <div\n class=\"gc-body\"\n [style]=\"{\n width: localConfig.width + 'px',\n height: localConfig.height + 'px',\n }\"\n >\n <div class=\"gc-loading\">\n <loading-icon></loading-icon>\n </div>\n <img\n class=\"gc-picture\"\n [class]=\"{'gc-hide': localData.image == ''}\"\n [style]=\"{\n width: localConfig.width + 'px',\n height: localConfig.height + 'px',\n display: hasDisplayImageState ? 'block' : 'none'\n }\"\n [attr.src]=\"localData.image\"\n alt=\"\"\n (click)=\"clickEvent($event)\"\n />\n <div class=\"gc-dots\">\n <div\n class=\"gc-dot\"\n *ngFor=\"let dot of dots;\"\n [style]=\"{\n top: (dot.y - 11) + 'px',\n left: (dot.x - 11) + 'px',\n }\"\n >{{dot.index}}</div>\n </div>\n </div>\n <div class=\"gc-footer\">\n <div class=\"gc-icon-block gc-icon-block2\">\n <close-icon\n [width]=\"localConfig.iconSize\"\n [height]=\"localConfig.iconSize\"\n (click)=\"closeEvent($event)\"\n ></close-icon>\n <refresh-icon\n [width]=\"localConfig.iconSize\"\n [height]=\"localConfig.iconSize\"\n (click)=\"refreshEvent($event)\"\n ></refresh-icon>\n </div>\n <div class=\"gc-button-block\">\n <button\n [class]=\"{'disabled': !hasDisplayImageState}\"\n (click)=\"confirmEvent($event)\"\n >{{ localConfig.buttonText }}</button>\n </div>\n </div>\n</div>", styles: [".gc-icon-block2{flex:1}.gc-dots{position:absolute;inset:0}.gc-dots .gc-dot{position:absolute;z-index:2;width:22px;height:22px;color:var(--go-captcha-theme-dot-color);background:var(--go-captcha-theme-dot-bg-color);border:3px solid #f7f9fb;border-color:var(--go-captcha-theme-dot-border-color);display:flex;align-items:center;justify-content:center;border-radius:20px;cursor:default}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i2.CloseIconComponent, selector: "close-icon", inputs: ["width", "height"] }, { kind: "component", type: i3.RefreshIconComponent, selector: "refresh-icon", inputs: ["width", "height"] }, { kind: "component", type: i4.LoadingIconComponent, selector: "loading-icon", inputs: ["width", "height"] }], encapsulation: i0.ViewEncapsulation.None });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ClickComponent, decorators: [{
type: Component,
args: [{ selector: 'go-captcha-click', encapsulation: ViewEncapsulation.None, template: "<div\n class=\"go-captcha gc-wrapper\"\n [class]=\"{'gc-theme': localConfig.showTheme}\"\n [style]=\"{\n width: (localConfig.width || 0) + ( localConfig.horizontalPadding * 2) + (localConfig.showTheme ? 2 : 0) + 'px',\n paddingLeft: localConfig.horizontalPadding + 'px',\n paddingRight: localConfig.horizontalPadding + 'px',\n paddingTop: localConfig.verticalPadding + 'px',\n paddingBottom: localConfig.verticalPadding + 'px',\n display: hasDisplayWrapperState ? 'block' : 'none'\n }\"\n >\n <div class=\"gc-header\">\n <span>{{ localConfig.title }}</span>\n <img\n [class]=\"{'gc-hide': localData.thumb == ''}\"\n [style]=\"{\n width: localConfig.thumbWidth + 'px',\n height: localConfig.thumbHeight + 'px'\n }\"\n [attr.src]=\"localData.thumb\"\n alt=\"\"\n />\n </div>\n <div\n class=\"gc-body\"\n [style]=\"{\n width: localConfig.width + 'px',\n height: localConfig.height + 'px',\n }\"\n >\n <div class=\"gc-loading\">\n <loading-icon></loading-icon>\n </div>\n <img\n class=\"gc-picture\"\n [class]=\"{'gc-hide': localData.image == ''}\"\n [style]=\"{\n width: localConfig.width + 'px',\n height: localConfig.height + 'px',\n display: hasDisplayImageState ? 'block' : 'none'\n }\"\n [attr.src]=\"localData.image\"\n alt=\"\"\n (click)=\"clickEvent($event)\"\n />\n <div class=\"gc-dots\">\n <div\n class=\"gc-dot\"\n *ngFor=\"let dot of dots;\"\n [style]=\"{\n top: (dot.y - 11) + 'px',\n left: (dot.x - 11) + 'px',\n }\"\n >{{dot.index}}</div>\n </div>\n </div>\n <div class=\"gc-footer\">\n <div class=\"gc-icon-block gc-icon-block2\">\n <close-icon\n [width]=\"localConfig.iconSize\"\n [height]=\"localConfig.iconSize\"\n (click)=\"closeEvent($event)\"\n ></close-icon>\n <refresh-icon\n [width]=\"localConfig.iconSize\"\n [height]=\"localConfig.iconSize\"\n (click)=\"refreshEvent($event)\"\n ></refresh-icon>\n </div>\n <div class=\"gc-button-block\">\n <button\n [class]=\"{'disabled': !hasDisplayImageState}\"\n (click)=\"confirmEvent($event)\"\n >{{ localConfig.buttonText }}</button>\n </div>\n </div>\n</div>", styles: [".gc-icon-block2{flex:1}.gc-dots{position:absolute;inset:0}.gc-dots .gc-dot{position:absolute;z-index:2;width:22px;height:22px;color:var(--go-captcha-theme-dot-color);background:var(--go-captcha-theme-dot-bg-color);border:3px solid #f7f9fb;border-color:var(--go-captcha-theme-dot-border-color);display:flex;align-items:center;justify-content:center;border-radius:20px;cursor:default}\n"] }]
}], propDecorators: { config: [{
type: Input
}], data: [{
type: Input
}], events: [{
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"click.component.js","sourceRoot":"","sources":["../../../../../../projects/go-captcha-angular/src/lib/modules/click/click.component.ts","../../../../../../projects/go-captcha-angular/src/lib/modules/click/click.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input, ViewEncapsulation} from '@angular/core'\nimport {ClickConfig, ClickData, ClickDot, ClickEvent, defaultClickConfig, defaultData} from \"./click-instance\";\nimport {getDomXY, mergeTo} from \"../../helper/helper\";\n\n@Component({\n    selector: 'go-captcha-click',\n    templateUrl: 'click.component.html',\n    styleUrls: ['click.component.scss'],\n    encapsulation: ViewEncapsulation.None,\n})\nexport class ClickComponent {\n    localConfig?: ClickConfig = defaultClickConfig()\n    localData: ClickData = defaultData() as ClickData\n    localEvents?: ClickEvent = {}\n\n    dots: Array<ClickDot> = []\n\n    @Input()\n    set config(config: ClickConfig) {\n        mergeTo(this.localConfig, config)\n        this.localConfig = config\n    }\n\n    @Input()\n    set data(data: ClickData) {\n        mergeTo(this.localData, data)\n        this.localData = data\n    }\n\n    @Input()\n    set events(events: ClickEvent) {\n        mergeTo(this.localEvents, events)\n        this.localEvents = events\n    }\n\n    get hasDisplayWrapperState() {\n        return (this.localConfig.width || 0) > 0 || (this.localConfig.height || 0) > 0\n    }\n\n    get hasDisplayImageState() {\n        return (this.localData.image && this.localData.image.length > 0) || (this.localData.thumb && this.localData.thumb.length > 0)\n    }\n\n    clickEvent(e: Event|any){\n        const dom = e.currentTarget\n        const xy = getDomXY(dom)\n\n        const mouseX = e.pageX || e.clientX\n        const mouseY = e.pageY || e.clientY\n\n        const domX = xy.domX\n        const domY = xy.domY\n\n        const xPos = mouseX - domX;\n        const yPos = mouseY - domY;\n\n        const xx = parseInt(xPos.toString())\n        const yy = parseInt(yPos.toString())\n        const date = new Date()\n        const index = this.dots.length\n\n        this.dots.push({key: date.getTime(), index: index + 1, x: xx, y: yy})\n\n        this.localEvents.click && this.localEvents.click(xx, yy)\n        e.cancelBubble = true\n        e.preventDefault()\n        return false\n    }\n\n    confirmEvent(e: Event|any) {\n        const dotsStr = JSON.stringify(this.dots)\n        let dots: Array<ClickDot> = []\n        try {\n            dots = JSON.parse(dotsStr)\n        } catch (e) {\n            console.warn(\"parse dots error\", e)\n        }\n\n        this.localEvents.confirm && this.localEvents.confirm(dots, () => {\n            this.dots = []\n        })\n        e.cancelBubble = true\n        e.preventDefault()\n        return false\n    }\n\n    closeEvent(e: Event|any){\n        this.close()\n        e.cancelBubble = true\n        e.preventDefault()\n        return false\n    }\n\n    refreshEvent(e: Event|any) {\n        this.refresh()\n        e.cancelBubble = true\n        e.preventDefault()\n        return false\n    }\n\n    reset(){\n        this.dots = []\n    }\n\n    clear(){\n        this.reset()\n        setTimeout(()=> {\n            this.localData.image = ''\n            this.localData.thumb = ''\n        }, 0)\n    }\n\n    close() {\n        this.localEvents.close && this.localEvents.close()\n        this.reset()\n    }\n\n    refresh() {\n        this.localEvents.refresh && this.localEvents.refresh()\n        this.reset()\n    }\n}\n","<div\n  class=\"go-captcha gc-wrapper\"\n  [class]=\"{'gc-theme': localConfig.showTheme}\"\n  [style]=\"{\n    width:  (localConfig.width || 0) + ( localConfig.horizontalPadding * 2) + (localConfig.showTheme ? 2 : 0) + 'px',\n    paddingLeft: localConfig.horizontalPadding + 'px',\n    paddingRight: localConfig.horizontalPadding + 'px',\n    paddingTop: localConfig.verticalPadding + 'px',\n    paddingBottom: localConfig.verticalPadding + 'px',\n    display: hasDisplayWrapperState ? 'block' : 'none'\n  }\"\n  >\n  <div class=\"gc-header\">\n    <span>{{ localConfig.title }}</span>\n    <img\n      [class]=\"{'gc-hide': localData.thumb == ''}\"\n      [style]=\"{\n        width: localConfig.thumbWidth + 'px',\n        height: localConfig.thumbHeight + 'px'\n      }\"\n      [attr.src]=\"localData.thumb\"\n      alt=\"\"\n    />\n  </div>\n  <div\n    class=\"gc-body\"\n    [style]=\"{\n      width: localConfig.width + 'px',\n      height: localConfig.height + 'px',\n    }\"\n  >\n    <div class=\"gc-loading\">\n      <loading-icon></loading-icon>\n    </div>\n    <img\n      class=\"gc-picture\"\n      [class]=\"{'gc-hide': localData.image == ''}\"\n      [style]=\"{\n        width: localConfig.width + 'px',\n        height: localConfig.height + 'px',\n        display: hasDisplayImageState ? 'block' : 'none'\n      }\"\n      [attr.src]=\"localData.image\"\n      alt=\"\"\n      (click)=\"clickEvent($event)\"\n    />\n    <div class=\"gc-dots\">\n      <div\n        class=\"gc-dot\"\n        *ngFor=\"let dot of dots;\"\n        [style]=\"{\n          top: (dot.y - 11) + 'px',\n          left: (dot.x - 11) + 'px',\n        }\"\n      >{{dot.index}}</div>\n    </div>\n  </div>\n  <div class=\"gc-footer\">\n    <div class=\"gc-icon-block gc-icon-block2\">\n      <close-icon\n        [width]=\"localConfig.iconSize\"\n        [height]=\"localConfig.iconSize\"\n        (click)=\"closeEvent($event)\"\n      ></close-icon>\n      <refresh-icon\n        [width]=\"localConfig.iconSize\"\n        [height]=\"localConfig.iconSize\"\n        (click)=\"refreshEvent($event)\"\n      ></refresh-icon>\n    </div>\n    <div class=\"gc-button-block\">\n      <button\n        [class]=\"{'disabled': !hasDisplayImageState}\"\n        (click)=\"confirmEvent($event)\"\n      >{{ localConfig.buttonText }}</button>\n    </div>\n  </div>\n</div>"]}