Your IP : 3.22.74.25


Current Path : /var/www/www-root/data/webdav/webdav/www/monolith-realty.ru/bitrix/js/ui/buttons-panel/src/
Upload File :
Current File : /var/www/www-root/data/webdav/webdav/www/monolith-realty.ru/bitrix/js/ui/buttons-panel/src/panel.js

import { Dom, Tag, Type } from 'main.core';
import { Button, SplitButton } from 'ui.buttons';
import 'ui.fonts.opensans';
import './style.css';

export default class ButtonsPanel
{
	constructor(options)
	{
		options = Type.isPlainObject(options) ? options : {};
		this.target = Type.isDomNode(options.target) ? options.target : null;
		const buttons = Type.isArray(options.buttons) ? options.buttons : [];

		this.container = null;
		this.buttons = [];

		buttons.forEach(button => {
			if (button instanceof Button)
			{
				this.buttons.push(button);
			}
			else if (Type.isPlainObject(button))
			{
				if (button.splitButton)
				{
					this.buttons.push(new SplitButton(button));
				}
				else
				{
					this.buttons.push(new Button(button));
				}
			}
		});
	}

	#getContainer()
	{
		if (!this.container)
		{
			this.container = Tag.render`
				<div class="ui-button-panel__container ui-button-panel__scope"></div>
			`;
		}

		return this.container;
	}

	#getButtons()
	{
		return this.buttons;
	}

	collapse()
	{
		const buttons = Object.values(this.#getButtons());
		for (let i = buttons.length - 1; i >= 0; i--)
		{
			let button = buttons[i];
			if (!button.getIcon() && !Type.isStringFilled(button.getDataSet()['buttonCollapsedIcon']))
			{
				continue;
			}

			if (button.isCollapsed())
			{
				continue;
			}

			button.setCollapsed(true);

			if (!button.getIcon())
			{
				button.setIcon(button.getDataSet()['buttonCollapsedIcon']);
			}

			break;
		}
	}

	expand()
	{

	}

	#render()
	{
		Dom.append(this.#getContainer(), this.target);

		if (this.#getButtons().length > 0)
		{
			this.#getButtons().forEach(button => {
				Dom.append(button.getContainer(), this.#getContainer());
			})
		}
	}

	init()
	{
		this.#render();
	}
}