Your IP : 13.59.58.68


Current Path : /var/www/www-root/data/www/www.monolith-realty.ru/bitrix/js/ui/alerts/src/
Upload File :
Current File : /var/www/www-root/data/www/www.monolith-realty.ru/bitrix/js/ui/alerts/src/alert.js

// @flow

import {Dom, Tag, Type} from 'main.core';
import AlertColor from './alert-color';
import AlertSize from './alert-size';
import AlertIcon from './alert-icon';

import 'ui.design-tokens';

type AlertOptions = {
	text: string;
	color: AlertColor;
	size: AlertSize;
	icon: AlertIcon;
	customClass: string;
	closeBtn: boolean;
	animated: boolean;
	beforeMessageHtml: HTMLElement;
	afterMessageHtml: HTMLElement;
};

export default class Alert {

	static Color = AlertColor;
	static Size = AlertSize;
	static Icon = AlertIcon;

	text: string;
	color: string;
	size: string;
	icon: string;
	closeBtn: boolean;
	animated: boolean;
	customClass: string;
	beforeMessageHtml: HTMLElement;
	afterMessageHtml: HTMLElement;

	constructor(options: AlertOptions)
	{
		this.text = options.text;
		this.color = options.color;
		this.size = options.size;
		this.icon = options.icon;
		this.closeBtn = !!options.closeBtn ? true : options.closeBtn;
		this.animated = !!options.animated ? true : options.animated;
		this.customClass = options.customClass;
		this.beforeMessageHtml = Type.isElementNode(options.beforeMessageHtml) ? options.beforeMessageHtml : false ;
		this.afterMessageHtml = Type.isElementNode(options.afterMessageHtml) ? options.afterMessageHtml : false ;

		this.setText(this.text);
		this.setSize(this.size);
		this.setIcon(this.icon);
		this.setColor(this.color);
		this.setCloseBtn(this.closeBtn);
		this.setCustomClass(this.customClass);
	}

	//region COLOR
	setColor(color: string)
	{
		this.color = color;
		this.setClassList();
	}

	getColor()
	{
		return this.color;
	}

	// endregion

	//region SIZE
	setSize(size: string)
	{
		this.size = size;
		this.setClassList();
	}

	getSize()
	{
		return this.size;
	}

	// endregion

	//region ICON
	setIcon(icon: string)
	{
		this.icon = icon;
		this.setClassList();
	}

	getIcon()
	{
		return this.icon;
	}

	// endregion

	//region TEXT
	setText(text: string): this
	{
		if (Type.isStringFilled(text))
		{
			this.text = text;
			this.getTextContainer().innerHTML = text;
		}
	}

	getText()
	{
		return this.text;
	}

	getTextContainer()
	{
		if (!this.textContainer)
		{
			this.textContainer =  Dom.create('span', {
				props: {
					className: 'ui-alert-message'
				},
				html: this.text
			});
		}

		return this.textContainer;
	}

	// endregion

	// region CLOSE BTN
	setCloseBtn(closeBtn: boolean)
	{
		this.closeBtn = closeBtn;
	}

	getCloseBtn()
	{
		if (this.closeBtn != true)
		{
			return
		}

		if ((!this.closeNode) && (this.closeBtn === true))
		{
			this.closeNode = Dom.create("span", {
				props: {className: "ui-alert-close-btn"},
				events: {
					click: this.handleCloseBtnClick.bind(this)
				}
			})
		}

		return this.closeNode;
	}

	handleCloseBtnClick()
	{
		if (this.animated === true)
		{
			this.animateClosing();
		}
		else
		{
			Dom.remove(this.container);
		}
	}

	// endregion

	// region Custom HTML
	setBeforeMessageHtml(element: HTMLElement)
	{
		if (Type.isElementNode(element) && element !== false)
		{
			this.beforeMessageHtml = element;
		}
	}

	getBeforeMessageHtml(): HTMLElement
	{
		return this.beforeMessageHtml;
	}

	setAfterMessageHtml(element: HTMLElement)
	{
		if (Type.isElementNode(element) && element !== false)
		{
			this.afterMessageHtml = element;
		}
	}

	getAfterMessageHtml(): HTMLElement
	{
		return this.afterMessageHtml;
	}

	//endregion

	//region CUSTOM CLASS
	setCustomClass(customClass: string)
	{
		this.customClass = customClass;
		this.updateClassList();
	}

	getCustomClass()
	{
		return this.customClass;
	}

	// endregion

	//region CLASS LIST
	setClassList()
	{
		this.classList = "ui-alert";

		if (typeof this.getColor() != "undefined")
		{
			this.classList = this.classList + " " + this.color;
		}

		if (typeof this.getSize() != "undefined")
		{
			this.classList = this.classList + " " + this.size;
		}

		if (typeof this.getIcon() != "undefined")
		{
			this.classList = this.classList + " " + this.icon;
		}

		if (typeof this.getCustomClass() != "undefined")
		{
			this.classList = this.classList + " " + this.customClass;
		}

		this.updateClassList();
	}

	getClassList()
	{
		return this.classList;
	}

	updateClassList()
	{
		if (!this.container)
		{
			this.getContainer()
		}

		this.container.setAttribute("class", this.classList);
	}

	// endregion

	//region ANIMATION
	animateOpening()
	{
		this.container.style.overflow = "hidden";
		this.container.style.height = 0;
		this.container.style.paddingTop = 0;
		this.container.style.paddingBottom = 0;
		this.container.style.marginBottom = 0;
		this.container.style.opacity = 0;

		setTimeout(
			function () {
				this.container.style.height = this.container.scrollHeight + "px";
				this.container.style.height = "";
				this.container.style.paddingTop = "";
				this.container.style.paddingBottom = "";
				this.container.style.marginBottom = "";
				this.container.style.opacity = "";
			}.bind(this),
			10
		);

		setTimeout(
			function () {
				this.container.style.height = "";
			}.bind(this),
			200
		);
	}

	animateClosing()
	{
		this.container.style.overflow = "hidden";

		var alertWrapPos = Dom.getPosition(this.container);
		this.container.style.height = alertWrapPos.height + "px";

		setTimeout(
			function () {
				this.container.style.height = 0;
				this.container.style.paddingTop = 0;
				this.container.style.paddingBottom = 0;
				this.container.style.marginBottom = 0;
				this.container.style.opacity = 0;
			}.bind(this),
			10
		);

		setTimeout(
			function () {
				Dom.remove(this.container);
			}.bind(this),
			260
		);
	}

	//endregion

	show()
	{
		this.animateOpening()
	}

	hide()
	{
		this.animateClosing()
	}

	getContainer()
	{
		this.container = Tag.render`<div class="${this.getClassList()}">${this.getTextContainer()}</div>`;

		if (this.animated === true)
		{
			this.animateOpening();
		}

		if (this.closeBtn === true)
		{
			Dom.append(this.getCloseBtn(), this.container);
		}

		if (Type.isElementNode(this.beforeMessageHtml))
		{
			Dom.prepend(this.getBeforeMessageHtml(), this.getTextContainer());
		}

		if (Type.isElementNode(this.afterMessageHtml))
		{
			Dom.append(this.getAfterMessageHtml(), this.getTextContainer());
		}

		return this.container;
	}

	render(): HTMLElement
	{
		return this.getContainer();
	}

	renderTo(node: HTMLElement): HTMLElement | null
	{
		if (Type.isDomNode(node))
		{
			return node.appendChild(this.getContainer());
		}

		return null;
	}

	destroy(): void
	{
		Dom.remove(this.container);
		this.container = null;
		this.finished = false;
		this.textAfterContainer = null;
		this.textBeforeContainer = null;
		this.bar = null;


		for (const property in this)
		{
			if (this.hasOwnProperty(property))
			{
				delete this[property];
			}
		}

		Object.setPrototypeOf(this, null);
	}
}