Your IP : 3.145.202.60


Current Path : /var/www/www-root/data/www.catalog.monolith-realty.ru/bitrix/js/ui/qrauthorization/src/
Upload File :
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();
		}
	}
}