403Webshell
Server IP : 80.87.202.40  /  Your IP : 216.73.216.169
Web Server : Apache
System : Linux rospirotorg.ru 5.14.0-539.el9.x86_64 #1 SMP PREEMPT_DYNAMIC Thu Dec 5 22:26:13 UTC 2024 x86_64
User : bitrix ( 600)
PHP Version : 8.2.27
Disable Function : NONE
MySQL : OFF |  cURL : ON |  WGET : ON |  Perl : ON |  Python : OFF |  Sudo : ON |  Pkexec : ON
Directory :  /home/bitrix/ext_www/rospirotorg.ru/bitrix/js/ui/accessrights/src/item/

Upload File :
current_dir [ Writeable] document_root [ Writeable]

 

Command :


[ Back ]     

Current File : /home/bitrix/ext_www/rospirotorg.ru/bitrix/js/ui/accessrights/src/item/role.js
import {EventEmitter} from "main.core.events";
import {Dom, Event, Text, Tag, Loc} from 'main.core';
import Base from "./base";

import {PopupWindowManager} from "main.popup";
import ColumnItemOptions from "../columnitem";

export default class Role extends Base
{
	static TYPE = 'role';

	constructor(options: ColumnItemOptions)
	{
		super(options);

		this.column = options.column;
	}

	bindEvents(): void
	{
		Event.bind(window, 'click', (event: Event) => {
			if (
				event.target === this.getRole()
				|| event.target.closest('.ui-access-rights-role')
			)
			{
				return;
			}

			this.updateRole();
			this.offRoleEditMode();
		});

		EventEmitter.subscribe(this.grid, 'onBeforeSave', () => {
			this.updateRole();
			this.offRoleEditMode();
		});
	}

	getRole(): HTMLElement
	{
		if (this.role)
		{
			return this.role;
		}

		EventEmitter.subscribe('BX.UI.AccessRights:preservation', this.updateRole.bind(this));
		EventEmitter.subscribe('BX.UI.AccessRights:preservation', this.offRoleEditMode.bind(this));

		this.roleInput = Tag.render`
				<input
					type='text'
					class='ui-access-rights-role-input'
					value='${Text.encode(this.text)}'
					placeholder='${Loc.getMessage('JS_UI_ACCESSRIGHTS_ROLE_NAME')}'
				/>
			`;

		Event.bind(this.roleInput, 'keydown', (event: Event) => {
			if (event.keyCode === 13)
			{
				this.updateRole();
				this.offRoleEditMode();
			}
		});

		Event.bind(this.roleInput, 'input', () => {
			this.grid.getButtonPanel().show();
		});

		this.roleValue = Tag.render`<div class='ui-access-rights-role-value'>${Text.encode(this.text)}</div>`;

		const editControl = Tag.render`<div class='ui-access-rights-role-edit'></div>`;
		Event.bind(editControl, 'click', this.onRoleEditMode.bind(this));

		const removeControl = Tag.render`<div class='ui-access-rights-role-remove'></div>`;
		Event.bind(removeControl, 'click', this.showPopupConfirm.bind(this));

		const roleControlWrapper = Tag.render`
				<div class='ui-access-rights-role-controls'>
					${editControl}
					${removeControl}
				</div>
			`;

		this.role = Tag.render`
				<div class='ui-access-rights-role'>
					${this.roleInput}
					${this.roleValue}
					${roleControlWrapper}
				</div>
			`;

		return this.role;
	}

	render(): HTMLElement
	{
		return this.getRole();
	}

	onRoleEditMode()
	{
		Dom.addClass(this.getRole(), 'ui-access-rights-role-edit-mode');
		this.roleInput.focus();
	}

	showPopupConfirm()
	{
		if (!this.popupConfirm)
		{
			/**@ToDO check role*/
			this.popupConfirm = PopupWindowManager.create(
				null,
				this.getRole(),
				{
					width: 250,
					overlay: true,
					contentPadding: 10,
					content: Loc.getMessage('JS_UI_ACCESSRIGHTS_POPUP_REMOVE_THIS_ROLE'),
					animation: 'fading-slide'
				}
			);

			this.popupConfirm.setButtons([
				new BX.UI.Button({
					text: Loc.getMessage('JS_UI_ACCESSRIGHTS_POPUP_REMOVE'),
					className: 'ui-btn ui-btn-sm ui-btn-primary',
					events: {
						click: () => {
							this.popupConfirm.close();
							EventEmitter.emit('BX.UI.AccessRights.ColumnItem:removeRole', this);
						}
					}
				}),
				new BX.UI.Button({
					text: Loc.getMessage('JS_UI_ACCESSRIGHTS_POPUP_CANCEL'),
					className: 'ui-btn ui-btn-sm ui-btn-link',
					events: {
						click: () => {
							this.popupConfirm.close();
						}
					}
				})
			]);
		}

		this.popupConfirm.show();
	}

	updateRole(): void
	{
		if (this.roleValue.innerHTML === this.roleInput.value || this.roleInput.value === '')
		{
			return;
		}

		this.text = this.roleInput.value;
		this.userGroup = this.column.getUserGroup();

		this.roleValue.innerText = this.roleInput.value;
		EventEmitter.emit('BX.UI.AccessRights.ColumnItem:updateRole', this);
	}

	offRoleEditMode(): void
	{
		Dom.removeClass(this.getRole(), 'ui-access-rights-role-edit-mode')
	}
}

Youez - 2016 - github.com/yon3zu
LinuXploit