Your IP : 18.118.140.96


Current Path : /var/www/www-root/data/www/monolith-realty.ru/bitrix/js/ui/tilegrid/
Upload File :
Current File : /var/www/www-root/data/www/monolith-realty.ru/bitrix/js/ui/tilegrid/item.js

;(function() {

'use strict';

BX.namespace('BX.TileGrid');

BX.TileGrid.Item = function(options)
{
	this.id = options.id;
	this.isDraggable = options.isDraggable || false;
	this.isDroppable = options.isDroppable || false;
	this.name = options.name;
	this.type = options.type;
	this.layout = {
		container: null,
		checkbox: null
	};
	this.gridTile = null;
	this.dblClickDelay = 180;
};

BX.TileGrid.Item.prototype =
{
	bindEvents: function()
	{
		BX.addCustomEvent(window, 'BX.TileGrid.Grid:lastSelectedItem', function()
		{

		});
	},

	getId: function()
	{
		return this.id;
	},

	render: function()
	{
		var clickTimer = null;
		var preventClick = false;

		this.layout.container = BX.create('div', {
			attrs: {
				className: this.gridTile.itemHeight ? 'ui-grid-tile-item ui-grid-tile-item-fixed-height' : 'ui-grid-tile-item'
			},
			style: {
				height: this.gridTile.itemHeight ? this.gridTile.itemHeight + 'px' : null,
				margin: this.gridTile.getTileMargin() ? this.gridTile.getTileMargin() + 'px' : null
			},
			dataset: {
				id: this.id
			},
			children: [
				this.gridTile.checkBoxing ? this.getCheckBox() : null,
				this.layout.content = BX.create('div', {
					attrs: {
						className: 'ui-grid-tile-item-content'
					},
					children: [
						this.getContent()
					]
				})
			],
			events: {
				dblclick: function(event)
				{
					clickTimer && clearTimeout(clickTimer);
					preventClick = true;
					this.handleDblClick.call(this, event);
					this.gridTile.resetSetMultiSelectMode();
					this.gridTile.resetSelectAllItems();
					this.gridTile.resetFromToItems();
				}.bind(this),
				click: function(event)
				{
					clickTimer = setTimeout(function () {
						if(!preventClick)
						{
							this.handleClick.call(this, event);
						}
						preventClick = false;
					}.bind(this), this.dblClickDelay);
				}.bind(this)
			}
		});

		if (this.isDraggable)
		{
			this.gridTile.dragger.registerItem(this.layout.container);
		}
		if (this.isDroppable)
		{
			this.gridTile.dragger.registerDrop(this.layout.container);
		}

		return this.layout.container
	},

	isVisibleItem: function()
	{
		var rect = this.layout.container.getBoundingClientRect();
		var rectBody = document.body.getBoundingClientRect();

		if (rect.top < 0 || rect.bottom < 0)
		{
			return false;
		}

		return rectBody.height > rect.top && rectBody.height >= rect.bottom;
	},

	afterRender: function()
	{

	},

	handleClick: function(event)
	{
		this.focusItem();
		this.resetFocusItem();

		var grid = this.gridTile;

		if(grid.isKeyControlKey())
		{
			grid.setMultiSelectMode();
			grid.checkItem(grid.getFirstCurrentItem())
		}

		if(!grid.isLastSelectedItem())
		{
			if(!grid.isMultiSelectMode())
			{
				grid.unSelectItem(grid.getCurrentItem())
			}
		}

		if(!grid.getFirstCurrentItem())
		{
			grid.setFirstCurrentItem(this);
		}

		if(grid.isKeyPressedShift())
		{
			grid.selectFromToItems(grid.getFirstCurrentItem(), this);
			return;
		}

		if(grid.isMultiSelectMode() || grid.isKeyPressedSelectAll())
		{
			if(!this.checked)
			{
				grid.checkItem(this);
				grid.selectItem(this);
				grid.setCurrentItem(this);
				grid.setFirstCurrentItem(this);
			}
			else
			{
				grid.unCheckItem(this);
				grid.unSelectItem(this);

				if(grid.isLastSelectedItem())
					grid.resetSetMultiSelectMode();

			}

			return;
		}

		if(this.selected)
		{
			grid.unSelectItem(this)
		}
		else
		{
			grid.selectItem(this);
			grid.unCheckItem(this);
			grid.setCurrentItem(this);
			grid.setFirstCurrentItem(this);

			if(grid.isLastSelectedItem())
				grid.resetSetMultiSelectMode();
		}
	},

	handleDblClick: function(event)
	{},

	handleEnter: function()
	{},

	getContainer: function()
	{
		return this.layout.container;
	},

	getCheckBox: function()
	{
		return this.layout.checkbox = BX.create('div', {
			props: {
				className: 'ui-grid-tile-item-checkbox'
			},
			events: {
				click: function(event)
				{
					if(this.gridTile.isLastSelectedItem())
						this.gridTile.resetSetMultiSelectMode();

					if(this !== this.gridTile.getCurrentItem() && this.gridTile.isMultiSelectMode())
					{
						this.gridTile.checkItem(this.gridTile.getCurrentItem());
						this.gridTile.selectItem(this.gridTile.getCurrentItem());

					}

					this.gridTile.checkItem(this);
					this.gridTile.selectItem(this);
					this.gridTile.setCurrentItem(this);
					this.gridTile.setFirstCurrentItem(this);

					if(!this.gridTile.isLastSelectedItem())
					{
						if(this.gridTile.isMultiSelectMode())
							this.gridTile.checkItem(this.gridTile.getFirstCurrentItem());
					}

					this.focusItem();
					this.resetFocusItem();
					event.stopPropagation();
				}.bind(this)
			}
		})
	},

	getContent: function() {
		return null
	},

	focusItem: function()
	{
		this.layout.container.setAttribute('tabindex', '1');
		this.layout.container.focus();
	},

	resetFocusItem: function()
	{
		this.layout.container.removeAttribute('tabindex')
	},

	removeNode: function(withAnimation)
	{
		withAnimation = withAnimation !== false;
		var itemContainer = this.layout.container;

		if(!itemContainer.parentNode)
			return;

		if(!withAnimation)
		{
			itemContainer.parentNode.removeChild(itemContainer);
			return;
		}

		itemContainer.classList.add('ui-grid-tile-item-to-fade');
		itemContainer.style.width = itemContainer.offsetWidth + 'px';

		BX.bind(itemContainer, 'transitionend', function()
		{
			itemContainer.classList.add('ui-grid-tile-item-to-remove');
		});

		setTimeout(function()
		{
			itemContainer.parentNode.removeChild(itemContainer);
		}, 500);
	},

	animateNode: function()
	{
		var itemContainer = this.layout.container;
		itemContainer.classList.add('ui-grid-tile-item-to-receive');

		setTimeout(function()
		{
			itemContainer.classList.remove('ui-grid-tile-item-to-receive');
		},500);
	}
}

})();