Your IP : 3.135.196.144


Current Path : /var/www/www-root/data/www/info.monolith-realty.ru/bitrix/js/landing/ui/panel/
Upload File :
Current File : /var/www/www-root/data/www/info.monolith-realty.ru/bitrix/js/landing/ui/panel/base_panel.js

;(function() {
	"use strict";

	BX.namespace("BX.Landing.UI.Panel");


	/**
	 * Implements base interface for works with panel
	 *
	 * @param {?string} [id]
	 * @constructor
	 */
	BX.Landing.UI.Panel.BasePanel = function(id)
	{
		this.id = BX.type.isNotEmptyString(id) ? id : BX.Landing.UI.Panel.BasePanel.makeId();
		this.layout = BX.Landing.UI.Panel.BasePanel.createLayout(this.id);
		this.classShow = "landing-ui-show";
		this.classHide = "landing-ui-hide";
		this.forms = new BX.Landing.UI.Collection.FormCollection();
	};


	/**
	 * Makes panel id
	 * @return {string}
	 */
	BX.Landing.UI.Panel.BasePanel.makeId = function()
	{
		return "landing_ui_panel_" + (+new Date());
	};


	/**
	 * Creates panel layout
	 *
	 * @param {string} id - Panel id
	 * @return {HTMLElement}
	 */
	BX.Landing.UI.Panel.BasePanel.createLayout = function(id)
	{
		return BX.create("div", {
			props: {className: "landing-ui-panel landing-ui-hide"},
			attrs: {"data-id": id}
		});
	};


	BX.Landing.UI.Panel.BasePanel.prototype = {
		/**
		 * Shows panel
		 */
		show: function()
		{
			if (!this.isShown())
			{
				return BX.Landing.Utils.Show(this.layout);
			}

			return Promise.resolve();
		},


		/**
		 * Hides panel
		 */
		hide: function()
		{
			if (this.isShown())
			{
				return BX.Landing.Utils.Hide(this.layout);
			}

			return Promise.resolve();
		},


		/**
		 * Checks that panel is shown
		 * @return {boolean}
		 */
		isShown: function()
		{
			return (
				(this.layout.classList.contains(this.classShow) &&
				!this.layout.classList.contains(this.classHide)) ||
				(!this.layout.classList.contains(this.classShow) &&
				!this.layout.classList.contains(this.classHide))
			);
		},


		/**
		 * Sets layout content
		 * @param {?string|HTMLElement|HTMLElement[]} content
		 */
		setContent: function(content)
		{
			this.layout.innerHTML = "";

			if (BX.type.isNotEmptyString(content))
			{
				this.layout.innerHTML = content;
			}

			if (BX.type.isDomNode(content))
			{
				this.appendContent(content);
			}

			if (BX.type.isArray(content))
			{
				content.forEach(this.appendContent, this);
			}
		},


		/**
		 * Appends element
		 * @param {HTMLElement} content
		 */
		appendContent: function(content)
		{
			if (BX.type.isDomNode(content))
			{
				this.layout.appendChild(content);
			}
		},


		/**
		 * Prepends content
		 * @param {HTMLElement} content
		 */
		prependContent: function(content)
		{
			if (BX.type.isDomNode(content))
			{
				BX.prepend(content, this.layout);
			}
		},


		/**
		 * Removes this panel
		 */
		remove: function()
		{
			BX.remove(this.layout);
		},


		/**
		 * Appends form to panel body
		 * @param {BX.Landing.UI.Form.BaseForm} form
		 */
		appendForm: function(form)
		{
			this.layout.appendChild(form.getNode());
		},


		/**
		 * Clears body content
		 */
		clear: function()
		{
			this.layout.innerHTML = "";
		}
	};
})();