UNPKG

@microblink/blinkid-in-browser-sdk

Version:

A simple ID scanning library for WebAssembly-enabled browsers.

128 lines (127 loc) 5.84 kB
/** * 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"; } }