Your IP : 13.58.147.19


Current Path : /var/www/www-root/data/www.catalog.monolith-realty.ru/bitrix/js/landing/ui/button/
Upload File :
Current File : /var/www/www-root/data/www.catalog.monolith-realty.ru/bitrix/js/landing/ui/button/font_action.js

;(function() {
	"use strict";

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


	/**
	 * Implements interface for works with font settings
	 *
	 * @extends {BX.Landing.UI.Button.EditorAction}
	 *
	 * @param {string} id - Action id
	 * @param {?object} [options]
	 *
	 * @constructor
	 */
	BX.Landing.UI.Button.FontAction = function(id, options)
	{
		BX.Landing.UI.Button.EditorAction.apply(this, arguments);
		this.layout.classList.add("landing-ui-button-editor-action-font");
		this.content = BX.create("div", {props: {className: "landing-ui-button-editor-action-font-popup-content"}});
		this.fontSize = new BX.Landing.UI.Field.Range({
			title: BX.Landing.Loc.getMessage("EDITOR_ACTION_FIELD_LABEL_FONT_SIZE"),
			items: Array.apply(null, {length: 160}).map(function(item, index) {
				return {value: index, name: index};
			}),
			jsDD: top.window.jsDD,
			property: "font-size",
			onDragStart: this.onDragStart.bind(this),
			onDragEnd: this.onDragEnd.bind(this),
			onChange: this.onChange.bind(this)
		});
		BX.Landing.UI.Button.FontAction.instances.push(this);
	};

	BX.Landing.UI.Button.FontAction.instances = [];

	BX.Landing.UI.Button.FontAction.hideAll = function()
	{
		BX.Landing.UI.Button.FontAction.instances.forEach(function(button) {
			if (button.popup)
			{
				button.popup.close();
			}
		});
	};

	BX.Landing.UI.Button.FontAction.prototype = {
		constructor: BX.Landing.UI.Button.FontAction,
		__proto__: BX.Landing.UI.Button.EditorAction.prototype,


		onDragStart: function()
		{
			this.popup.popupContainer.classList.add("landing-ui-fade");
		},

		onDragEnd: function()
		{
			this.popup.popupContainer.classList.remove("landing-ui-fade");
		},

		onChange: function(value, items, postfix, property)
		{
			if (property === "font-size")
			{
				var selection = this.contextDocument.defaultView.getSelection();
				var range = selection.getRangeAt(0);
				var editable = BX.Landing.UI.Panel.EditorPanel.getInstance().currentElement.contains(range.startContainer);

				if (selection.toString() && editable)
				{
					this.contextDocument.execCommand("fontSize", false, value);
					range = this.contextDocument.defaultView.getSelection().getRangeAt(0);
					var wrapper = range.startContainer.parentNode;
					wrapper.style.fontSize = value + "px";
				}
			}
		},


		/**
		 * Handles event on this button click
		 * @param {MouseEvent} event
		 */
		onClick: function(event)
		{
			event.preventDefault();
			event.stopPropagation();

			if (!this.popup)
			{
				this.popup = this.createPopup();
				this.popup.popupContainer.addEventListener("click", this.onPopupClick.bind(this));
				this.popup.popupContainer.classList.add("landing-ui-button-editor-action-font-popup");
				this.popup.contentContainer.appendChild(this.content);
				this.content.appendChild(this.fontSize.layout);
			}

			if (!this.popup.isShown())
			{
				this.popup.show();
				var position = BX.Landing.UI.Panel.EditorPanel.getInstance().isFixed() ? "fixed" : "relative";
				this.adjustPosition(position);
				BX.Landing.UI.Button.ColorAction.hideAll();

				var selection = this.contextDocument.defaultView.getSelection();
				var range = selection.getRangeAt(0);

				var editable = BX.Landing.UI.Panel.EditorPanel.getInstance().currentElement.contains(range.startContainer);

				if (editable)
				{
					var wrapper = range.startContainer.parentNode;
					var size = parseInt(getComputedStyle(wrapper).getPropertyValue("font-size"));
					this.fontSize.setValue(size, true);
				}
			}
			else
			{
				this.popup.close();
			}
		},


		onPopupClick: function(event)
		{
			event.stopPropagation();
		},


		/**
		 * @private
		 * @param {string} position
		 */
		adjustPosition: function(position)
		{
			BX.DOM.read(function() {
				var popupRect = this.popup.popupContainer.getBoundingClientRect();
				var parentRect = this.layout.parentNode.getBoundingClientRect();
				var offsetLeft = Math.abs(popupRect.width - parentRect.width);
				var props = {};

				props["left"] = parentRect.left + (offsetLeft / 2) + "px";

				if (position === "fixed")
				{
					var buttonRect = this.layout.getBoundingClientRect();
					props["top"] = buttonRect.bottom + "px";
					props["position"] = "fixed";
				}
				else
				{
					var buttonPos = BX.pos(this.layout);
					props["top"] = buttonPos.bottom + "px";
				}


				BX.DOM.write(function() {
					for (var prop in props)
					{
						this.popup.popupContainer.style[prop] = props[prop];
					}
				}.bind(this));
			}.bind(this));
		},

		createPopup: function()
		{
			return new BX.PopupWindow(
				"landing_font_editor_popup",
				this.layout,
				{
					autoHide: true,
					closeByEsc: true,
					noAllPaddings: true,
					width: 463,
					zIndex: -979
				}
			);
		}
	};
})();