Your IP : 18.117.105.184


Current Path : /var/www/www-root/data/webdav/webdav/www/monolith-realty.ru/bitrix/js/ui/accessrights/src/
Upload File :
Current File : /var/www/www-root/data/webdav/webdav/www/monolith-realty.ru/bitrix/js/ui/accessrights/src/column.js

import {EventEmitter} from "main.core.events";
import {Dom, Event, Reflection, Tag} from 'main.core';

import Section from "./section";
import ColumnItem from "./columnitem";
import Role from "./item/role";
import Member from "./item/member";
import Title from "./item/title";
import UserGroupTitle from "./item/usergrouptitle";
import Toggler from "./item/toggler";
import VariableSelector from "./item/variableselector";
import MultiSelector from "./item/multivariable/multiselector";

type ColumnOptions = {
	grid: Grid;
	items: [];
	userGroup: [];
	accessCodes: [];
	section: Section;
	headSection: Section;
	newColumn: Column;
	openPopupEvent: string;
	popupContainer: HTMLElement;
};

export default class Column {
	constructor(options: ColumnOptions)
	{
		this.layout = {
			container: null
		};
		this.grid = options.grid ? options.grid : null;
		this.items = options.items ? options.items : [];
		this.userGroup = options.userGroup ? options.userGroup : null;
		this.accessCodes = options.accessCodes ? options.accessCodes : null;
		this.section = options.section ? options.section : null;
		this.headSection = options.headSection;
		this.newColumn = options.newColumn ? options.newColumn : null;
		this.openPopupEvent = options.grid.openPopupEvent ? options.grid.openPopupEvent : null;
		this.popupContainer = options.grid.popupContainer ? options.grid.popupContainer : null;
	}

	getItem(options): ColumnItem
	{
		options = options || {};

		let param = {};

		if (options.type === UserGroupTitle.TYPE)
		{
			param = {
				type: options.type,
				text: options.title,
				controller: options.controller
			}
		}

		if (options.type === Title.TYPE)
		{
			param = {
				id: options.id,
				type: options.type,
				hint: options.hint,
				text: options.title,
				controller: options.controller
			}
		}

		if (options.type === Toggler.TYPE)
		{
			param = {
				type: options.type,
				access: options.access
			}
		}

		if (options.type === VariableSelector.TYPE || options.type === MultiSelector.TYPE)
		{
			param = {
				type: options.type,
				text: options.title,
				variables: options.variables,
				access: options.access
			}
		}

		if (options.type === MultiSelector.TYPE)
		{
			param.allSelectedCode = options.allSelectedCode;
			param.enableSearch = options.enableSearch;
			param.showAvatars = options.showAvatars;
			param.compactView = options.compactView;
			param.hintTitle = options.hintTitle;
		}

		if (options.type === Role.TYPE)
		{
			param = {
				type: options.type,
				text: options.title
			}
		}

		if (options.type === Member.TYPE)
		{
			const accessCodes = [];

			for (const item in options.members)
			{
				accessCodes[item] = options.members[item].type;
			}

			param = {
				type: options.type,
				accessCodes: accessCodes
			}
		}

		param.column = this;
		param.userGroup = this.userGroup;
		param.openPopupEvent = this.openPopupEvent;
		param.popupContainer = this.popupContainer;
		param.currentValue = null;

		param.grid = this.grid;

		if (
			options.type === VariableSelector.TYPE
			|| options.type === MultiSelector.TYPE
			|| options.type === Toggler.TYPE
		)
		{
			const accessId = param.access.id.toString();
			const accessRights = param.userGroup?.accessRights ?? [];

			for (let i = 0; i < accessRights.length; i++)
			{
				if (accessId === accessRights[i].id.toString())
				{
					if (options.type === MultiSelector.TYPE)
					{
						param.currentValue = param.currentValue ?? [];
						param.currentValue.push(accessRights[i].value);
					}
					else
					{
						param.currentValue = accessRights[i].value;
					}
				}
			}
		}

		return new ColumnItem(param);
	}

	getUserGroup(): []
	{
		return this.userGroup;
	}

	remove(): void
	{
		if (Dom.hasClass(this.layout.container, 'ui-access-rights-column-new'))
		{
			this.resetClassNew();
		}

		Dom.addClass(this.layout.container,'ui-access-rights-column-remove')
		Dom.style(this.layout.container, 'width', this.layout.container.offsetWidth + 'px')

		Event.bind(this.layout.container, 'animationend', () => {
			Dom.style(this.layout.container, 'minWidth', '0px')
			Dom.style(this.layout.container, 'maxWidth', '0px')
		});


		setTimeout(() => {
			Dom.remove(this.layout.container);
		}, 500);
	}

	resetClassNew(): void
	{
		Dom.removeClass(this.layout.container,'ui-access-rights-column-new');
	}

	render(): HTMLElement
	{
		if (!this.layout.container)
		{
			const itemsFragment = document.createDocumentFragment();

			if (this.headSection)
			{
				this.userGroup.type = Role.TYPE;
				Dom.append(this.getItem(this.userGroup).render(), itemsFragment);

				this.userGroup.type = Member.TYPE;
				Dom.append(this.getItem(this.userGroup).render(), itemsFragment);
			}

			this.items.map(
				(data) => {
					const item = this.getItem(data);
					Dom.append(item.render(), itemsFragment);
				}
			);

			this.layout.container = Tag.render`<div class='ui-access-rights-column'></div>`;
			if (this.newColumn)
			{
				Dom.addClass('ui-access-rights-column-new', this.layout.container)
			}

			EventEmitter.subscribe('BX.UI.AccessRights:refresh', this.resetClassNew.bind(this));

			Dom.append(itemsFragment, this.layout.container);

			return this.layout.container;
		}
	}
}

const namespace = Reflection.namespace('BX.UI.AccessRights');
namespace.Column = Column;