go-captcha-angular
Version:
GoCaptcha for Angular, which implements click mode, slider mode, drag-drop mode and rotation mode.
233 lines • 39 kB
JavaScript
import { Component, Input, ViewChild, ViewEncapsulation } from '@angular/core';
import { checkTargetFather, mergeTo } from "../../helper/helper";
import { defaultSlideRegionConfig } from "./slide-region-instance";
import * as i0 from "@angular/core";
import * as i1 from "../../icons/close-icon.component";
import * as i2 from "../../icons/refresh-icon.component";
import * as i3 from "../../icons/loading-icon.component";
export class SlideRegionComponent {
constructor() {
this.localConfig = defaultSlideRegionConfig();
this.localData = {
thumbX: 0,
thumbY: 0,
thumbWidth: 0,
thumbHeight: 0,
image: "",
thumb: ""
};
this.localEvents = {};
this.state = { x: this.localData.thumbX || 0, y: this.localData.thumbY || 0 };
this.isFreeze = false;
this.dsFn = (event) => event.preventDefault();
}
set config(config) {
mergeTo(this.localConfig, config);
this.localConfig = config;
}
set data(data) {
mergeTo(this.localData, data);
this.localData = data;
this.updateState();
}
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);
}
ngAfterViewInit() {
this.tileRef.nativeElement && this.tileRef.nativeElement.addEventListener('dragstart', this.dsFn);
}
ngOnDestroy() {
this.tileRef.nativeElement && this.tileRef.nativeElement.removeEventListener('dragstart', this.dsFn);
}
updateState() {
if (!this.isFreeze) {
this.state.x = (this.localData.thumbX || 0);
this.state.y = (this.localData.thumbY || 0);
}
}
dragEvent(e) {
if (!checkTargetFather(this.containerRef.nativeElement, e)) {
return;
}
const touch = e.touches && e.touches[0];
const offsetLeft = this.tileRef.nativeElement.offsetLeft;
const offsetTop = this.tileRef.nativeElement.offsetTop;
const width = this.containerRef.nativeElement.offsetWidth;
const height = this.containerRef.nativeElement.offsetHeight;
const tileWidth = this.tileRef.nativeElement.offsetWidth;
const tileHeight = this.tileRef.nativeElement.offsetHeight;
const maxWidth = width - tileWidth;
const maxHeight = height - tileHeight;
let isMoving = false;
let tmpLeaveDragEvent = null;
let startX = 0;
let startY = 0;
let tileLeft = 0;
let tileTop = 0;
if (touch) {
startX = touch.pageX - offsetLeft;
startY = touch.pageY - offsetTop;
}
else {
startX = e.clientX - offsetLeft;
startY = e.clientY - offsetTop;
}
const moveEvent = (e) => {
isMoving = true;
const mTouche = e.touches && e.touches[0];
let left = 0;
let top = 0;
if (mTouche) {
left = mTouche.pageX - startX;
top = mTouche.pageY - startY;
}
else {
left = e.clientX - startX;
top = e.clientY - startY;
}
if (left <= 0) {
left = 0;
}
if (top <= 0) {
top = 0;
}
if (left >= maxWidth) {
left = maxWidth;
}
if (top >= maxHeight) {
top = maxHeight;
}
this.state.x = left;
this.state.y = top;
tileLeft = left;
tileTop = top;
this.localEvents.move && this.localEvents.move(left, top);
e.cancelBubble = true;
e.preventDefault();
};
const upEvent = (e) => {
if (!checkTargetFather(this.containerRef.nativeElement, e)) {
return;
}
clearEvent();
if (!isMoving) {
return;
}
isMoving = false;
if (tileLeft < 0 || tileTop < 0) {
return;
}
this.localEvents.confirm && this.localEvents.confirm({ x: tileLeft, y: tileTop }, () => {
this.reset();
});
e.cancelBubble = true;
e.preventDefault();
};
const leaveDragBlockEvent = (e) => {
tmpLeaveDragEvent = e;
};
const enterDragBlockEvent = () => {
tmpLeaveDragEvent = null;
};
const leaveUpEvent = (_) => {
if (!tmpLeaveDragEvent) {
return;
}
upEvent(tmpLeaveDragEvent);
clearEvent();
};
const scope = this.localConfig.scope;
const dragDom = scope ? this.rootRef.nativeElement : this.dragBarRef.nativeElement;
const scopeDom = scope ? this.rootRef.nativeElement : document.body;
const clearEvent = () => {
scopeDom.removeEventListener("mousemove", moveEvent, false);
scopeDom.removeEventListener("touchmove", moveEvent, { passive: false });
dragDom.removeEventListener("mouseup", upEvent, false);
dragDom.removeEventListener("mouseenter", enterDragBlockEvent, false);
dragDom.removeEventListener("mouseleave", leaveDragBlockEvent, false);
dragDom.removeEventListener("touchend", upEvent, false);
scopeDom.removeEventListener("mouseleave", upEvent, false);
scopeDom.removeEventListener("mouseup", leaveUpEvent, false);
this.isFreeze = false;
};
this.isFreeze = true;
scopeDom.addEventListener("mousemove", moveEvent, false);
scopeDom.addEventListener("touchmove", moveEvent, { passive: false });
dragDom.addEventListener("mouseup", upEvent, false);
dragDom.addEventListener("mouseenter", enterDragBlockEvent, false);
dragDom.addEventListener("mouseleave", leaveDragBlockEvent, false);
dragDom.addEventListener("touchend", upEvent, false);
scopeDom.addEventListener("mouseleave", upEvent, false);
scopeDom.addEventListener("mouseup", leaveUpEvent, 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.state.x = this.localData.thumbX || 0;
this.state.y = this.localData.thumbY || 0;
}
clear() {
this.reset();
setTimeout(() => {
this.localData.image = '';
this.localData.thumb = '';
this.localData.thumbX = 0;
this.localData.thumbY = 0;
this.localData.thumbHeight = 0;
this.localData.thumbWidth = 0;
}, 0);
}
close() {
this.localEvents.close && this.localEvents.close();
this.reset();
}
refresh() {
this.localEvents.refresh && this.localEvents.refresh();
this.reset();
}
}
SlideRegionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: SlideRegionComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
SlideRegionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: SlideRegionComponent, selector: "go-captcha-slide-region", inputs: { config: "config", data: "data", events: "events" }, viewQueries: [{ propertyName: "rootRef", first: true, predicate: ["rootRef"], descendants: true }, { propertyName: "containerRef", first: true, predicate: ["containerRef"], descendants: true }, { propertyName: "dragBlockRef", first: true, predicate: ["dragBlockRef"], descendants: true }, { propertyName: "dragBarRef", first: true, predicate: ["dragBarRef"], descendants: true }, { propertyName: "tileRef", first: true, predicate: ["tileRef"], descendants: true }], 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 #rootRef\n>\n <div class=\"gc-header gc-header2\">\n <span>{{ localConfig.title }}</span>\n </div>\n <div\n class=\"gc-body\"\n #containerRef\n [style]=\"{width: localConfig.width + 'px', height: localConfig.height + 'px'}\"\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]=\"{display: hasDisplayImageState ? 'block' : 'none'}\"\n [attr.src]=\"localData.image\"\n alt=\"\"\n />\n <div\n class=\"gc-tile\"\n #tileRef\n [style]=\"{\n width: localData.thumbWidth + 'px',\n height: localData.thumbHeight + 'px',\n top: state.y + 'px',\n left: state.x + 'px'\n }\"\n (mousedown)=\"dragEvent($event)\"\n (touchstart)=\"dragEvent($event)\"\n >\n <img\n [class]=\"{'gc-hide': localData.thumb == ''}\"\n [style]=\"{display: hasDisplayImageState ? 'block' : 'none'}\"\n [attr.src]=\"localData.thumb\"\n alt=\"\"\n />\n </div>\n </div>\n <div class=\"gc-footer\">\n <div class=\"gc-icon-block\">\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>\n</div>", styles: [".go-captcha .gc-header2{text-align:center}.go-captcha .gc-tile{position:absolute;z-index:2;cursor:pointer}.go-captcha .gc-tile img{display:block;cursor:pointer;width:100%;height:100%}\n"], dependencies: [{ kind: "component", type: i1.CloseIconComponent, selector: "close-icon", inputs: ["width", "height"] }, { kind: "component", type: i2.RefreshIconComponent, selector: "refresh-icon", inputs: ["width", "height"] }, { kind: "component", type: i3.LoadingIconComponent, selector: "loading-icon", inputs: ["width", "height"] }], encapsulation: i0.ViewEncapsulation.None });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: SlideRegionComponent, decorators: [{
type: Component,
args: [{ selector: 'go-captcha-slide-region', 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 #rootRef\n>\n <div class=\"gc-header gc-header2\">\n <span>{{ localConfig.title }}</span>\n </div>\n <div\n class=\"gc-body\"\n #containerRef\n [style]=\"{width: localConfig.width + 'px', height: localConfig.height + 'px'}\"\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]=\"{display: hasDisplayImageState ? 'block' : 'none'}\"\n [attr.src]=\"localData.image\"\n alt=\"\"\n />\n <div\n class=\"gc-tile\"\n #tileRef\n [style]=\"{\n width: localData.thumbWidth + 'px',\n height: localData.thumbHeight + 'px',\n top: state.y + 'px',\n left: state.x + 'px'\n }\"\n (mousedown)=\"dragEvent($event)\"\n (touchstart)=\"dragEvent($event)\"\n >\n <img\n [class]=\"{'gc-hide': localData.thumb == ''}\"\n [style]=\"{display: hasDisplayImageState ? 'block' : 'none'}\"\n [attr.src]=\"localData.thumb\"\n alt=\"\"\n />\n </div>\n </div>\n <div class=\"gc-footer\">\n <div class=\"gc-icon-block\">\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>\n</div>", styles: [".go-captcha .gc-header2{text-align:center}.go-captcha .gc-tile{position:absolute;z-index:2;cursor:pointer}.go-captcha .gc-tile img{display:block;cursor:pointer;width:100%;height:100%}\n"] }]
}], propDecorators: { rootRef: [{
type: ViewChild,
args: ['rootRef', { static: false }]
}], containerRef: [{
type: ViewChild,
args: ['containerRef', { static: false }]
}], dragBlockRef: [{
type: ViewChild,
args: ['dragBlockRef', { static: false }]
}], dragBarRef: [{
type: ViewChild,
args: ['dragBarRef', { static: false }]
}], tileRef: [{
type: ViewChild,
args: ['tileRef', { static: false }]
}], config: [{
type: Input
}], data: [{
type: Input
}], events: [{
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slide-region.component.js","sourceRoot":"","sources":["../../../../../../projects/go-captcha-angular/src/lib/modules/slide-region/slide-region.component.ts","../../../../../../projects/go-captcha-angular/src/lib/modules/slide-region/slide-region.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, ElementRef, Input, ViewChild, ViewEncapsulation} from '@angular/core'\nimport {checkTargetFather, mergeTo} from \"../../helper/helper\";\nimport {defaultSlideRegionConfig, SlideRegionConfig, SlideRegionData, SlideRegionEvent} from \"./slide-region-instance\";\n\n@Component({\n    selector: 'go-captcha-slide-region',\n    templateUrl: 'slide-region.component.html',\n    styleUrls: ['slide-region.component.scss'],\n    encapsulation: ViewEncapsulation.None,\n})\nexport class SlideRegionComponent {\n    localConfig?: SlideRegionConfig = defaultSlideRegionConfig()\n    localData: SlideRegionData = {\n        thumbX: 0,\n        thumbY: 0,\n        thumbWidth: 0,\n        thumbHeight: 0,\n        image: \"\",\n        thumb: \"\"\n    } as SlideRegionData\n    localEvents?: SlideRegionEvent = {}\n\n    @ViewChild('rootRef', {static: false})\n    rootRef: ElementRef\n\n    @ViewChild('containerRef', {static: false})\n    containerRef: ElementRef\n\n    @ViewChild('dragBlockRef', {static: false})\n    dragBlockRef: ElementRef\n\n    @ViewChild('dragBarRef', {static: false})\n    dragBarRef: ElementRef\n\n    @ViewChild('tileRef', {static: false})\n    tileRef: ElementRef\n\n    state: {x: number, y: number} = {x: this.localData.thumbX || 0, y: this.localData.thumbY || 0}\n    isFreeze: boolean = false\n\n    @Input()\n    set config(config: SlideRegionConfig) {\n        mergeTo(this.localConfig, config)\n        this.localConfig = config\n    }\n\n    @Input()\n    set data(data: SlideRegionData) {\n        mergeTo(this.localData, data)\n        this.localData = data\n        this.updateState()\n    }\n\n    @Input()\n    set events(events: SlideRegionEvent) {\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    private dsFn = (event: any) => event.preventDefault()\n    ngAfterViewInit() {\n        this.tileRef.nativeElement && this.tileRef.nativeElement.addEventListener('dragstart', this.dsFn);\n    }\n\n    ngOnDestroy() {\n        this.tileRef.nativeElement && this.tileRef.nativeElement.removeEventListener('dragstart', this.dsFn);\n    }\n\n    updateState() {\n        if (!this.isFreeze) {\n            this.state.x = (this.localData.thumbX || 0)\n            this.state.y = (this.localData.thumbY || 0)\n        }\n    }\n\n    dragEvent(e: Event|any) {\n        if (!checkTargetFather(this.containerRef.nativeElement, e)) {\n            return\n        }\n\n        const touch = e.touches && e.touches[0];\n        const offsetLeft = this.tileRef.nativeElement.offsetLeft\n        const offsetTop = this.tileRef.nativeElement.offsetTop\n        const width = this.containerRef.nativeElement.offsetWidth\n        const height = this.containerRef.nativeElement.offsetHeight\n        const tileWidth = this.tileRef.nativeElement.offsetWidth\n        const tileHeight = this.tileRef.nativeElement.offsetHeight\n        const maxWidth = width - tileWidth\n        const maxHeight = height - tileHeight\n\n        let isMoving = false\n        let tmpLeaveDragEvent: Event|any = null\n        let startX = 0\n        let startY = 0\n        let tileLeft = 0\n        let tileTop = 0\n        if (touch) {\n            startX = touch.pageX - offsetLeft\n            startY = touch.pageY - offsetTop\n        } else {\n            startX = e.clientX - offsetLeft\n            startY = e.clientY - offsetTop\n        }\n\n        const moveEvent = (e: Event|any) => {\n            isMoving = true\n            const mTouche = e.touches && e.touches[0];\n\n            let left = 0;\n            let top = 0;\n            if (mTouche) {\n                left = mTouche.pageX - startX\n                top = mTouche.pageY - startY\n            } else {\n                left = e.clientX - startX\n                top = e.clientY - startY\n            }\n\n            if (left <= 0) {\n                left = 0\n            }\n\n            if (top <= 0) {\n                top = 0\n            }\n\n            if (left >= maxWidth) {\n                left = maxWidth\n            }\n\n            if (top >= maxHeight) {\n                top = maxHeight\n            }\n\n            this.state.x = left\n            this.state.y = top\n            tileLeft = left\n            tileTop = top\n            this.localEvents.move && this.localEvents.move(left, top)\n\n            e.cancelBubble = true\n            e.preventDefault()\n        }\n\n        const upEvent = (e: Event|any) => {\n            if (!checkTargetFather(this.containerRef.nativeElement, e)) {\n                return\n            }\n\n            clearEvent()\n            if (!isMoving) {\n                return\n            }\n            isMoving = false\n\n            if (tileLeft < 0 || tileTop < 0) {\n                return\n            }\n\n            this.localEvents.confirm && this.localEvents.confirm({x: tileLeft, y: tileTop}, () => {\n                this.reset()\n            })\n\n            e.cancelBubble = true\n            e.preventDefault()\n        }\n\n        const leaveDragBlockEvent = (e: Event|any) => {\n            tmpLeaveDragEvent = e\n        }\n\n        const enterDragBlockEvent = () => {\n            tmpLeaveDragEvent = null\n        }\n\n        const leaveUpEvent = (_: Event|any) => {\n            if(!tmpLeaveDragEvent) {\n                return\n            }\n\n            upEvent(tmpLeaveDragEvent)\n            clearEvent()\n        }\n\n        const scope = this.localConfig.scope\n        const dragDom = scope ? this.rootRef.nativeElement : this.dragBarRef.nativeElement\n        const scopeDom = scope ? this.rootRef.nativeElement : document.body\n\n        const clearEvent = () => {\n            scopeDom.removeEventListener(\"mousemove\", moveEvent, false)\n            scopeDom.removeEventListener(\"touchmove\", moveEvent, { passive: false })\n\n            dragDom.removeEventListener( \"mouseup\", upEvent, false)\n            dragDom.removeEventListener( \"mouseenter\", enterDragBlockEvent, false)\n            dragDom.removeEventListener( \"mouseleave\", leaveDragBlockEvent, false)\n            dragDom.removeEventListener(\"touchend\", upEvent, false)\n\n            scopeDom.removeEventListener(\"mouseleave\", upEvent, false)\n            scopeDom.removeEventListener(\"mouseup\", leaveUpEvent, false)\n\n            this.isFreeze = false\n        }\n        this.isFreeze = true\n\n        scopeDom.addEventListener(\"mousemove\", moveEvent, false)\n        scopeDom.addEventListener(\"touchmove\", moveEvent, { passive: false })\n\n        dragDom.addEventListener( \"mouseup\", upEvent, false)\n        dragDom.addEventListener( \"mouseenter\", enterDragBlockEvent, false)\n        dragDom.addEventListener( \"mouseleave\", leaveDragBlockEvent, false)\n        dragDom.addEventListener(\"touchend\", upEvent, false)\n\n        scopeDom.addEventListener(\"mouseleave\", upEvent, false)\n        scopeDom.addEventListener(\"mouseup\", leaveUpEvent, 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.state.x = this.localData.thumbX || 0\n        this.state.y = this.localData.thumbY || 0\n    }\n\n    clear(){\n        this.reset()\n        setTimeout(()=> {\n            this.localData.image = ''\n            this.localData.thumb = ''\n            this.localData.thumbX = 0\n            this.localData.thumbY = 0\n            this.localData.thumbHeight = 0\n            this.localData.thumbWidth = 0\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  #rootRef\n>\n  <div class=\"gc-header gc-header2\">\n    <span>{{ localConfig.title }}</span>\n  </div>\n  <div\n    class=\"gc-body\"\n    #containerRef\n    [style]=\"{width: localConfig.width + 'px', height: localConfig.height + 'px'}\"\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]=\"{display: hasDisplayImageState ? 'block' : 'none'}\"\n      [attr.src]=\"localData.image\"\n      alt=\"\"\n    />\n    <div\n      class=\"gc-tile\"\n      #tileRef\n      [style]=\"{\n        width: localData.thumbWidth + 'px',\n        height: localData.thumbHeight + 'px',\n        top: state.y + 'px',\n        left: state.x + 'px'\n      }\"\n      (mousedown)=\"dragEvent($event)\"\n      (touchstart)=\"dragEvent($event)\"\n    >\n      <img\n        [class]=\"{'gc-hide': localData.thumb == ''}\"\n        [style]=\"{display: hasDisplayImageState ? 'block' : 'none'}\"\n        [attr.src]=\"localData.thumb\"\n        alt=\"\"\n      />\n    </div>\n  </div>\n  <div class=\"gc-footer\">\n    <div class=\"gc-icon-block\">\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>\n</div>"]}