Your IP : 3.16.130.151


Current Path : /var/www/www-root/data/www/monolith-realty.ru/bitrix/js/landing/ui/panel/
Upload File :
Current File : /var/www/www-root/data/www/monolith-realty.ru/bitrix/js/landing/ui/panel/detail_page_panel.js

;(function() {
	"use strict";

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

	/**
	 * Implements interface for works with detail page panel
	 * Implements singleton patter
	 * @extends {BX.Landing.UI.Panel.URLList}
	 * @inheritDoc
	 * @constructor
	 */
	BX.Landing.UI.Panel.DetailPage = function(id, data)
	{
		BX.Landing.UI.Panel.URLList.apply(this, arguments);
		this.layout.classList.add("landing-ui-panel-detail-page");
		this.overlay.classList.add("landing-ui-panel-detail-page");

		this.cache = new BX.Cache.MemoryCache();

		document.body.appendChild(this.layout);
	};


	/**
	 * Stores instance of BX.Landing.UI.Panel.DetailPage
	 * @type {BX.Landing.UI.Panel.DetailPage}
	 */
	BX.Landing.UI.Panel.DetailPage.instance = null;


	/**
	 * Gets instance of BX.Landing.UI.Panel.DetailPage
	 * @return {BX.Landing.UI.Panel.DetailPage}
	 */
	BX.Landing.UI.Panel.DetailPage.getInstance = function()
	{
		if (!BX.Landing.UI.Panel.DetailPage.instance)
		{
			BX.Landing.UI.Panel.DetailPage.instance = (
				new BX.Landing.UI.Panel.DetailPage("detail_page_panel", {
					title: BX.Landing.Loc.getMessage("LANDING_BLOCK__DETAIL_PAGE_PANEL_TITLE")
				})
			);
		}

		return BX.Landing.UI.Panel.DetailPage.instance;
	};


	BX.Landing.UI.Panel.DetailPage.prototype = {
		constructor: BX.Landing.UI.Panel.DetailPage,
		__proto__: BX.Landing.UI.Panel.URLList.prototype,

		getSources: function()
		{
			return this.cache.remember('sources', function() {
				var rootWindow = BX.Landing.PageObject.getRootWindow();
				return rootWindow.BX.Landing.Main.getInstance().options.sources;
			});
		},

		onSourceClick: function(source)
		{
			this.sidebarButtons.forEach(function(button) {
				if (button.id === source.id)
				{
					button.activate();
					return;
				}

				button.deactivate();
			});

			this.content.innerHTML = "";
			this.showLoader();

			this.content.appendChild(BX.create('div', {
				props: {className: 'ui-alert ui-alert-warning landing-ui-panel-list-description'},
				children: [
					BX.create('span', {
						props: {className: 'ui-alert-message'},
						html: BX.Landing.Loc.getMessage('LANDING_BLOCK__DETAIL_PAGE_LIST_DESCRIPTION')
					})
				]
			}));

			BX.Landing.Backend.getInstance()
				.getDynamicTemplates(source.id)
				.then(function(templates) {
					templates.forEach(function(template) {
						this.appendCard(this.createTemplatePreview(template));
					}, this);

					this.loader.hide();
				}.bind(this));
		},

		createTemplatePreview: function(template)
		{
			return new BX.Landing.UI.Card.LandingPreviewCard({
				title: template.TITLE,
				description: template.DESCRIPTION,
				preview: template.PREVIEW2X,
				onClick: this.onTemplateClick.bind(this, template)
			});
		},

		onTemplateClick: function(template)
		{
			this.loader.show();

			var backend = BX.Landing.Backend.getInstance();

			backend
				.action(
					'Utils::checkMultiFeature',
					{code: ['create_page', 'publication_page']}
				)
				.then(function(response) {
					if (!response || response === 'false')
					{
						var rootWindow = BX.Landing.PageObject.getRootWindow();
						rootWindow.BX.Landing.PaymentAlertShow({
							message: BX.Landing.Loc.getMessage('LANDING_PUBLIC_PAGE_REACHED')
						});

						this.loader.hide();
					}
					else
					{
						backend
							.action('Landing::addByTemplate', {
								siteId: backend.getSiteId(),
								code: template.ID,
								fields: {
									ID: backend.getLandingId()
								}
							})
							.then(function(response) {
								this.loader.hide();
								this.onChange({type: 'landing', id: response, name: template.TITLE});

								var activeButton = this.sidebarButtons.getActive();
								if (activeButton)
								{
									var sourceId = activeButton.id;
									var env = BX.Landing.Env.getInstance();
									var envOptions = env.getOptions();

									var source = envOptions.sources.find(function(currentSource) {
										return currentSource.id === sourceId;
									});

									if (source)
									{
										source.default.detail = '#landing' + response;
									}

									env.setOptions(envOptions);
								}
							}.bind(this));
					}
				}.bind(this));
		},

		showSourcesButtons: function()
		{
			this.appendSidebarButton(
				new BX.Landing.UI.Button.SidebarButton('templates', {
					text: BX.Landing.Loc.getMessage('LANDING_BLOCK__DETAIL_PAGE_PANEL_TEMPLATES')
				})
			);

			this.getSources().forEach(function(source) {
				if (source.settings.detailPage)
				{
					this.appendSidebarButton(
						new BX.Landing.UI.Button.SidebarButton(source.id, {
							text: source.name,
							child: true,
							onClick: this.onSourceClick.bind(this, source)
						})
					);
				}
			}, this);
		},

		showSitesButtons: function()
		{
			this.appendSidebarButton(
				new BX.Landing.UI.Button.SidebarButton("my_sites", {
					text: BX.Landing.Loc.getMessage("LANDING_LINKS_PANEL_MY_SITES")
				})
			);

			return BX.Landing.Backend.getInstance()
				.getSites()
				.then(function(sites) {
					sites.forEach(function(site) {
						this.appendSidebarButton(
							new BX.Landing.UI.Button.SidebarButton(site.ID, {
								text: site.TITLE,
								onClick: this.onSiteClick.bind(this, site.ID, false),
								child: true
							})
						);
					}, this);
				}.bind(this));
		},

		showCreatePageButton: function()
		{
			this.appendSidebarButton(
				new BX.Landing.UI.Button.SidebarButton("feedback_button", {
					className: "landing-ui-button-sidebar-feedback",
					text: BX.Landing.Loc.getMessage("LANDING_BLOCK__DETAIL_PAGE_PANEL_ADD_PAGE_BUTTON"),
					onClick: function() {
						var options = BX.Landing.Main.getInstance().options;
						var urlMask = options.params.sef_url.site_show;
						var siteId = options.site_id;
						var url = urlMask.replace('#site_show#', siteId) + '#createPage';

						window.open(url, '_blank');
					}
				})
			);
		},

		buildSidebar: function()
		{
			return Promise.all([
				this.showSourcesButtons(),
				this.showSitesButtons()
					.then(function() {
						this.showCreatePageButton();
					}.bind(this))
			]);
		},

		show: function(options)
		{
			BX.Landing.UI.Panel.Content.prototype.show.call(this);

			this.clear();
			this.showLoader();

			this.buildSidebar();

			var button = this.sidebarButtons.find(function(button) {
				return button.id === options.source;
			});

			if (button)
			{
				button.layout.click();
			}

			return new Promise(function(resolve) {
				this.promiseResolve = resolve;
			}.bind(this));
		}
	};
})();