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/landing/ui/field/color/src/layout/recent/

Upload File :
current_dir [ Writeable] document_root [ Writeable]

 

Command :


[ Back ]     

Current File : /home/bitrix/ext_www/rospirotorg.ru/bitrix/js/landing/ui/field/color/src/layout/recent/recent.js
import {Cache, Event, Tag, Dom, Type} from 'main.core';
import {EventEmitter} from 'main.core.events';

import {Backend} from 'landing.backend';

import isHex from '../../internal/is-hex';
import './css/recent.css';

export default class Recent extends EventEmitter
{
	static +USER_OPTION_NAME = 'color_field_recent_colors';
	static +MAX_ITEMS = 6;

	static items: [] = [];
	static itemsLoaded: boolean = false;

	constructor()
	{
		super();
		this.cache = new Cache.MemoryCache();
		this.setEventNamespace('BX.Landing.UI.Field.Color.Recent');
	}

	getLayout(): HTMLDivElement
	{
		this.initItems();

		return this.getLayoutContainer();
	}

	getLayoutContainer(): HTMLDivElement
	{
		return this.cache.remember('layout', () => {
			return Tag.render`<div class="landing-ui-field-color-recent"></div>`;
		});
	}

	initItems()
	{
		if (Recent.itemsLoaded)
		{
			this.buildItemsLayout();
		}
		else
		{
			Backend.getInstance()
				.action("Utils::getUserOption", {name: Recent.USER_OPTION_NAME})
				.then(result => {
					if (result && Type.isString(result.items))
					{
						Recent.items = [];
						result.items.split(',').forEach(item => {
							if (isHex((item)) && Recent.items.length < Recent.MAX_ITEMS)
							{
								Recent.items.push(item);
							}
						});
						Recent.itemsLoaded = true;

						this.buildItemsLayout();
					}
				});
			// todo: what if ajax error?
		}
	}

	buildItemsLayout(): Recent
	{
		Dom.clean(this.getLayoutContainer());
		Recent.items.forEach(item => {
			if (isHex(item))
			{
				let itemLayout = Tag.render`<div 
					class="landing-ui-field-color-recent-item" 
					style="background:${item}"
					data-value="${item}"
				></div>`;
				Event.bind(itemLayout, 'click', () => this.onItemClick(event));
				Dom.append(itemLayout, this.getLayoutContainer());
			}
		});

		return this;
	}

	onItemClick(event: MouseEvent)
	{
		this.emit('onChange', {hex: event.currentTarget.dataset.value});
	}

	addItem(hex: string): Recent
	{
		if (isHex(hex))
		{
			let pos = Recent.items.indexOf(hex);
			if (pos !== -1)
			{
				Recent.items.splice(pos, 1);
			}
			Recent.items.unshift(hex);
			if (Recent.items.length > Recent.MAX_ITEMS)
			{
				Recent.items.splice(Recent.MAX_ITEMS);
			}

			this.buildItemsLayout();
			this.saveItems();
		}

		return this;
	}

	saveItems(): Recent
	{
		if (Recent.items.length > 0)
		{
			BX.userOptions.save('landing', Recent.USER_OPTION_NAME, 'items', Recent.items);
		}

		return this;
	}
}

Youez - 2016 - github.com/yon3zu
LinuXploit