@microblink/blinkid-in-browser-sdk
Version:
A simple ID scanning library for WebAssembly-enabled browsers.
128 lines (127 loc) • 5.84 kB
JavaScript
/**
* Copyright (c) Microblink Ltd. All rights reserved.
*/
import { Host, h, } from "@stencil/core";
import { setWebComponentParts, classNames, } from "../../../utils/generic.helpers";
export class MbApiProcessStatus {
constructor() {
this.visible = false;
this.state = undefined;
this.translationService = undefined;
}
componentDidLoad() {
setWebComponentParts(this.hostEl);
}
render() {
return (h(Host, { class: classNames({ visible: this.visible }) }, this.state === "LOADING" && (h("div", { class: "reticle-container" }, h("div", { class: "reticle is-classification" }, h("div", { class: "reticle__cursor" }, h("div", { class: "reticle__el" }), h("div", { class: "reticle__el" }), h("div", { class: "reticle__el" }), h("div", { class: "reticle__el" }))), h("p", { class: "message" }, this.translationService.i("process-api-message").toString()))), this.state === "SUCCESS" && (h("div", { class: "reticle-container" }, h("div", { class: "reticle is-done-all" }, h("div", { class: "reticle__cursor" }, h("div", { class: "reticle__el" }), h("div", { class: "reticle__el" }), h("div", { class: "reticle__el" }), h("div", { class: "reticle__el" })), h("img", { class: "reticle__done", src: "" })))), this.state === "ERROR" && (h("mb-modal", { visible: true, modalTitle: this.translationService
.i("feedback-scan-unsuccessful-title")
.toString(), content: this.translationService
.i("feedback-scan-unsuccessful")
.toString(), onClose: () => this.closeFromStart.emit() }, h("div", { slot: "actionButtons" }, h("button", { class: "primary modal-action-button", onClick: () => this.closeTryAgain.emit() }, this.translationService.i("process-api-retry").toString()))))));
}
static get is() { return "mb-api-process-status"; }
static get encapsulation() { return "shadow"; }
static get originalStyleUrls() {
return {
"$": ["mb-api-process-status.scss"]
};
}
static get styleUrls() {
return {
"$": ["mb-api-process-status.css"]
};
}
static get properties() {
return {
"visible": {
"type": "boolean",
"mutable": false,
"complexType": {
"original": "boolean",
"resolved": "boolean",
"references": {}
},
"required": false,
"optional": false,
"docs": {
"tags": [],
"text": "Element visibility, default is 'false'."
},
"attribute": "visible",
"reflect": false,
"defaultValue": "false"
},
"state": {
"type": "string",
"mutable": false,
"complexType": {
"original": "\"ERROR\" | \"LOADING\" | \"NONE\" | \"SUCCESS\"",
"resolved": "\"ERROR\" | \"LOADING\" | \"NONE\" | \"SUCCESS\"",
"references": {}
},
"required": false,
"optional": false,
"docs": {
"tags": [],
"text": "State value of API processing received from parent element ('loading' or 'success')."
},
"attribute": "state",
"reflect": false
},
"translationService": {
"type": "unknown",
"mutable": false,
"complexType": {
"original": "TranslationService",
"resolved": "TranslationService",
"references": {
"TranslationService": {
"location": "import",
"path": "../../../utils/translation.service"
}
}
},
"required": false,
"optional": false,
"docs": {
"tags": [],
"text": "Instance of TranslationService passed from parent component."
}
}
};
}
static get events() {
return [{
"method": "closeTryAgain",
"name": "closeTryAgain",
"bubbles": true,
"cancelable": true,
"composed": true,
"docs": {
"tags": [],
"text": "Emitted when user clicks on 'Retry' button."
},
"complexType": {
"original": "void",
"resolved": "void",
"references": {}
}
}, {
"method": "closeFromStart",
"name": "closeFromStart",
"bubbles": true,
"cancelable": true,
"composed": true,
"docs": {
"tags": [],
"text": "Emitted when user clicks on 'x' button."
},
"complexType": {
"original": "void",
"resolved": "void",
"references": {}
}
}];
}
static get elementRef() { return "hostEl"; }
}