Your IP : 3.21.12.193


Current Path : /var/www/www-root/data/www/monolith-realty.ru/bitrix/js/landing/ui/tool/
Upload File :
Current File : /var/www/www-root/data/www/monolith-realty.ru/bitrix/js/landing/ui/tool/auto-font-scale.js

;(function() {
	"use strict";

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

	var bind = BX.Landing.Utils.bind;
	var slice = BX.Landing.Utils.slice;
	var onCustomEvent = BX.Landing.Utils.onCustomEvent;
	var lastWidth = BX.width(window);


	/**
	 * Checks than need adjust
	 * @return {boolean}
	 */
	function isNeedAdjust()
	{
		return BX.width(window) < 1100;
	}


	/**
	 * Checks that window resize
	 * @return {boolean}
	 */
	function isResized()
	{
		var result = lastWidth !== BX.width(window);
		lastWidth = BX.width(window);
		return result;
	}


	/**
	 * Implements interface for works with responsive texts
	 * @param {HTMLElement[]} elements
	 */
	BX.Landing.UI.Tool.autoFontScale = function(elements)
	{
		this.entries = elements.map(this.createEntry, this);
		bind(window, "resize", this.onResize.bind(this, false));
		bind(window, "orientationchange", this.onResize.bind(this, true));
		onCustomEvent("BX.Landing.Block:init", this.onAddBlock.bind(this));
		this.adjust(true);
	};


	BX.Landing.UI.Tool.autoFontScale.prototype = {
		onResize: function(forceAdjust)
		{
			this.adjust(forceAdjust);

			// Fallback for sliders
			clearTimeout(this.falbackTimeoutId);
			this.falbackTimeoutId = setTimeout(function() {
				this.adjust(true);
			}.bind(this), 250);
		},


		/**
		 * Adjusts text
		 * @param {boolean} [forceAdjust]
		 */
		adjust: function(forceAdjust)
		{
			if (forceAdjust === true || isResized())
			{
				var needAdjust = isNeedAdjust();
				this.entries.forEach(function(entry) {
					if (needAdjust)
					{
						entry.adjust();
					}
					else
					{
						entry.resetSize();
					}
				});
			}
		},


		/**
		 * Creates entry
		 * @param {HTMLElement} element
		 * @return {BX.Landing.UI.Tool.autoFontScaleEntry}
		 */
		createEntry: function(element)
		{
			return new BX.Landing.UI.Tool.autoFontScaleEntry(element);
		},


		/**
		 * Adds elements
		 * @param {HTMLElement[]} elements
		 */
		addElements: function(elements)
		{
			elements.forEach(function(element) {
				var containsElement = this.entries.some(function(entry) {
					return entry.element === element;
				});

				if (!containsElement)
				{
					this.entries.push(this.createEntry(element));
				}
			}, this);
		},


		/**
		 * Handles add block event
		 * @param {BX.Landing.Event.Block} event
		 */
		onAddBlock: function(event)
		{
			var elements = slice(event.block.querySelectorAll("h1, h2, h3, h4, h5, [data-auto-font-scale]"));
			this.addElements(elements);
		}
	}
})();