Current Path : /var/www/www-root/data/www.catalog.monolith-realty.ru/bitrix/js/ui/qrauthorization/src/ |
Current File : /var/www/www-root/data/www.catalog.monolith-realty.ru/bitrix/js/ui/qrauthorization/src/index.js |
import { ajax as Ajax, Dom, Type, Tag, Loc } from 'main.core'; import { Popup } from 'main.popup'; import { Loader } from 'main.loader'; import { PULL } from 'pull.client'; import 'main.qrcode'; import 'ui.icon-set.main'; import 'ui.design-tokens'; import 'ui.fonts.opensans'; import './css/style.css'; export class QrAuthorization { title; content; bottomText; qr; popupParam; constructor(options = {}) { this.title = options.title || null; this.content = options.content || null; this.bottomText = options.bottomText || Loc.getMessage('UI_QR_AUTHORIZE_TAKE_CODE'); this.showFishingWarning = options.showFishingWarning ?? false; this.showBottom = options.showBottom ?? true; this.helpLink = options.helpLink || null; this.qr = options.qr || null; this.popupParam = options.popupParam || null; this.intent = options.intent || 'calendar'; this.popup = null; this.loader = null; this.qrNode = null; this.successNode = null; this.loadingNode = null; this.isSubscribe = false; } createQrCodeImage() { Dom.clean(this.getQrNode()); if (Type.isString(this.qr)) { this.clean(); new QRCode(this.getQrNode(), { text: this.qr, width: 180, height: 180, }); return; } this.loading(); Ajax.runAction('mobile.deeplink.get', { data: { intent: this.intent, }, }).then((response) => { const link = response.data?.link; if (link) { this.clean(); new QRCode(this.getQrNode(), { text: link, width: 180, height: 180, }); if (!this.isSubscribe) { this.isSubscribe = true; this.subscribe(); } } }).catch(() => {}); } subscribe() { if (PULL) { PULL.subscribe({ type: 'BX.PullClient.SubscriptionType.Server', moduleId: 'mobile', command: 'onDeeplinkShouldRefresh', callback: (params) => { this.success(); }, }); } } getQrNode(): HTMLElement { if (!this.qrNode) { this.qrNode = Tag.render` <div class="ui-qr-authorization__popup-qr"></div> `; } return this.qrNode; } getPopup(): Popup { if (!this.popup) { const title = Type.isObject(this.title) ? this.title?.text : this.title; const titleSize = Type.isObject(this.title) ? this.title?.size : ''; const container = Tag.render` <div class="ui-qr-authorization__popup-wrapper"> <div class="ui-qr-authorization__popup-top ${this.content ? '' : '--direction-column'}"> <div class="ui-qr-authorization__popup-left ${title ? '' : '--flex'}"> ${title ? `<div class="ui-qr-authorization__popup-title --${titleSize}">${title}</div>` : ''} ${this.content ? `<div class="ui-qr-authorization__popup-text">${this.content}</div>` : ''} </div> <div class="ui-qr-authorization__popup-right ${this.title ? '' : '--no-margin'}" data-role="ui-qr-authorization__qr-node"></div> </div> ${this.renderFishingWarning()} ${this.renderBottom()} </div> `; const popupWidth = this.content ? 710 : 405; const popupParam = { className: this.popupParam?.className ?? 'ui-qr-authorization__popup ui-qr-authorization__popup-scope', width: this.popupParam?.width ?? popupWidth, content: container, closeByEsc: this.popupParam?.closeByEsc ? this.popupParam?.className : true, overlay: this.popupParam?.overlay ?? false, autoHide: this.popupParam?.autoHide ?? true, closeIcon: { top: '14px', right: '15px', }, events: { onPopupShow: () => { this.createQrCodeImage(); const qrTarget = this.getPopup().getContentContainer().querySelector('[data-role="ui-qr-authorization__qr-node"]'); if (qrTarget) { Dom.append(this.getQrNode(), qrTarget); } }, }, padding: 0, animation: 'fading-slide', }; this.popup = new Popup(popupParam); } return this.popup; } renderFishingWarning() { if (!this.showFishingWarning) { return ''; } return Tag.render` <div class="ui-qr-authorization__popup-warning"> <div class="ui-icon-set --shield-2-attention"></div> ${Loc.getMessage('UI_QR_AUTHORIZE_DONT_SHARE_QR_WARNING')} </div> `; } renderBottom(): HTMLElement | string { if (!this.showBottom) { return ''; } const bottomText = Type.isObject(this.bottomText) ? this.bottomText?.text : this.bottomText; const bottomTextSize = Type.isObject(this.bottomText) ? this.bottomText?.size : ''; return Tag.render` <div class="ui-qr-authorization__popup-bottom"> <div class="ui-qr-authorization__popup-bottom--title ${bottomTextSize ? '--' + bottomTextSize : ''}"> ${bottomText} </div> ${this.renderHelpLink()} </div> `; } renderHelpLink(): HTMLElement | string { if (!this.helpLink) { return ''; } return Tag.render` <a href="${this.helpLink}" class="ui-qr-authorization__popup-bottom--link"> ${Loc.getMessage('UI_QR_AUTHORIZE_HELP')} </a> `; } success() { this.clean(); Dom.addClass(this.getQrNode(), '--success'); Dom.append(this.getSuccessNode(), this.getQrNode()); } getSuccessNode(): HTMLElement { if (!this.successNode) { this.successNode = Tag.render` <div class="ui-qr-authorization__popup-qr-success"></div> `; } return this.successNode; } loading() { this.clean(); Dom.addClass(this.getQrNode(), '--loading'); Dom.append(this.getLoadingNode(), this.getQrNode()); this.showLoader(); } getLoadingNode(): HTMLElement { if (!this.loadingNode) { this.loadingNode = Tag.render` <div class="ui-qr-authorization__popup-qr-loading"></div> `; } return this.loadingNode; } getLoader(): Loader { if (!this.loader) { this.loader = new Loader({ target: this.getLoadingNode(), size: 150, }); } return this.loader; } showLoader(): void { void this.getLoader().show(); } hideLoader(): void { void this.getLoader().hide(); } clean() { Dom.removeClass(this.getQrNode(), ['--loading', '--success']); Dom.remove(this.getLoadingNode()); Dom.remove(this.getSuccessNode()); this.hideLoader(); } show() { if (!this.getPopup().isShown()) { this.loading(); this.getPopup().show(); } } close() { if (this.getPopup().isShown()) { this.clean(); this.getPopup().close(); } } }