Your IP : 3.137.186.186


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

;(function() {
	"use strict";

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

	var addClass = BX.Landing.Utils.addClass;
	var isArray = BX.Landing.Utils.isArray;
	var isPlainObject = BX.Landing.Utils.isPlainObject;
	var isFunction = BX.Landing.Utils.isFunction;
	var create = BX.Landing.Utils.create;
	var random = BX.Landing.Utils.random;
	var escapeHtml = BX.Landing.Utils.escapeHtml;
	var append = BX.Landing.Utils.append;
	var slice = BX.Landing.Utils.slice;
	var encodeDataValue = BX.Landing.Utils.encodeDataValue;
	var decodeDataValue = BX.Landing.Utils.decodeDataValue;
	var isNumber = BX.Landing.Utils.isNumber;
	var isBoolean = BX.Landing.Utils.isBoolean;
	var data = BX.Landing.Utils.data;
	var clone = BX.Landing.Utils.clone;


	/**
	 * Implements interface for works with checkboxes list field
	 * @extends {BX.Landing.UI.Field.BaseField}
	 * @param options
	 * @constructor
	 */
	BX.Landing.UI.Field.Checkbox = function(options)
	{
		BX.Landing.UI.Field.BaseField.apply(this, arguments);
		addClass(this.layout, "landing-ui-field-checkbox");

		this.onChangeHandler = isFunction(options.onChange) ? options.onChange : (function() {});
		this.items = isArray(options.items) ? options.items : [];
		this.value = isArray(options.value) ? options.value : null;
		this.depth = isNumber(options.depth) ? options.depth : 0;
		this.compact = isBoolean(options.compact) ? options.compact : false;
		this.multiple = options.multiple !== false;

		data(this.layout, "data-depth", this.depth);
		data(this.layout, "data-compact", this.compact);

		if (isArray(this.value))
		{
			this.value = this.value.map(function(value) {
				return decodeDataValue(value);
			})
		}

		if (!isArray(this.value))
		{
			this.value = this.items
				.filter(function(item) {
					return item.checked;
				})
				.map(function(item) {
					return decodeDataValue(item.value);
				});
		}

		this.content = this.value;

		this.items.forEach(this.addItem, this);
	};


	BX.Landing.UI.Field.Checkbox.prototype = {
		constructor: BX.Landing.UI.Field.Checkbox,
		__proto__: BX.Landing.UI.Field.BaseField.prototype,


		/**
		 * Adds item
		 * @param itemOptions
		 */
		addItem: function(itemOptions)
		{
			if (isPlainObject(itemOptions))
			{
				var itemId = ("checkbox_item_" + random());
				var item = create("div", {
					props: {
						className: "landing-ui-field-checkbox-item" + (itemOptions.disabled ? ' landing-ui-disabled' : '')
					},
					children: [
						create("input", {
							props: {className: "landing-ui-field-checkbox-item-checkbox"},
							attrs: {
								id: itemId,
								type: "checkbox",
								value: encodeDataValue(itemOptions.value),
								checked: this.value.find(function(itemVal) {
									// noinspection EqualityComparisonWithCoercionJS
									return itemVal == itemOptions.value;
								}) !== undefined
							},
							events: {change: this.onItemChange.bind(this)}
						}),
						create("label", {
							props: {className: "landing-ui-field-checkbox-item-label"},
							attrs: {"for": itemId, title: BX.Text.encode(itemOptions.name)},
							html: itemOptions.html ? itemOptions.html : escapeHtml(itemOptions.name)
						})
					]
				});

				append(item, this.input);
			}

			return item;
		},


		/**
		 * Handles item change
		 */
		onItemChange: function()
		{
			this.onChangeHandler(this);
			this.onValueChangeHandler(this);
			this.emit('onChange');
		},


		isChanged: function()
		{
			var content = clone(this.content).sort();
			var value = this.getValue().sort();

			return JSON.stringify(content) !== JSON.stringify(value);
		},


		setValue: function(value)
		{
			if (isArray(value))
			{
				slice(this.input.children).forEach(function(element) {
					element.querySelector("input").checked = false;
				});

				value.forEach(function(currentValue) {
					var element = slice(this.input.children).find(function(element) {
						// noinspection EqualityComparisonWithCoercionJS
						return decodeDataValue(element.querySelector("input").value) == currentValue;
					}, this);

					if (element)
					{
						element.querySelector("input").checked = true;
					}
				}, this);
			}
		},


		/**
		 * Gets field value
		 * @return {Array}
		 */
		getValue: function()
		{
			var values = slice(this.input.children)
				.filter(function(element) {
					return element.querySelector("input").checked;
				})
				.map(function(element) {
					return decodeDataValue(element.querySelector("input").value);
				});

			if (!this.multiple)
			{
				return values.length > 0 ? values[0] : false;
			}

			return values;
		}
	};
})();