Your IP : 18.119.123.154


Current Path : /var/www/www-root/data/www/www.monolith-realty.ru/bitrix/js/main/popup/src/compatibility/
Upload File :
Current File : /var/www/www-root/data/www/www.monolith-realty.ru/bitrix/js/main/popup/src/compatibility/button.js

import { Type, Dom } from 'main.core';

declare type ButtonOptions = {
	id?: string,
	text?: string,
	className?: string,
	events?: { [event: string]: (event) => {} }
};

/**
 * @memberOf BX.Main.Popup
 * @deprecated use BX.UI.Button
 */
export default class Button
{
	constructor(params: ButtonOptions)
	{
		this.popupWindow = null;

		this.params = params || {};

		this.text = this.params.text || '';
		this.id = this.params.id || '';
		this.className = this.params.className || '';
		this.events = this.params.events || {};

		this.contextEvents = {};
		for (let eventName in this.events)
		{
			if (Type.isFunction(this.events[eventName]))
			{
				this.contextEvents[eventName] = this.events[eventName].bind(this);
			}
		}

		this.buttonNode = Dom.create(
			'span',
			{
				props: {
					className: 'popup-window-button' + (this.className.length > 0 ? ' ' + this.className : ''),
					id: this.id
				},
				events: this.contextEvents,
				text: this.text
			}
		);
	}

	render(): Element
	{
		return this.buttonNode;
	}

	getId(): string
	{
		return this.id;
	}

	getContainer(): Element
	{
		return this.buttonNode;
	}

	getName(): string
	{
		return this.text;
	}

	setName(name: string)
	{
		this.text = name || '';
		if (this.buttonNode)
		{
			Dom.clean(this.buttonNode);
			Dom.adjust(this.buttonNode, { text: this.text });
		}
	}

	setClassName(className: string)
	{
		if (this.buttonNode)
		{
			if (Type.isString(this.className) && (this.className !== ''))
			{
				Dom.removeClass(this.buttonNode, this.className);
			}

			Dom.addClass(this.buttonNode, className);
		}

		this.className = className;
	}

	addClassName(className: string)
	{
		if (this.buttonNode)
		{
			Dom.addClass(this.buttonNode, className);
			this.className = this.buttonNode.className;
		}
	}

	removeClassName(className: string)
	{
		if (this.buttonNode)
		{
			Dom.removeClass(this.buttonNode, className);
			this.className = this.buttonNode.className;
		}
	}
}