Your IP : 3.133.137.40


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

;(function() {
	"use strict";

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


	/**
	 * Implements interface for works with image panel
	 *
	 * @extends {BX.Landing.UI.Panel.Content}
	 *
	 * @param {string} id
	 *
	 * @constructor
	 */
	BX.Landing.UI.Panel.Image = function(id)
	{
		BX.Landing.UI.Panel.Content.apply(this, arguments);
		this.layout.classList.add("landing-ui-panel-image");
		this.onChangeHandler = (function() {});
		this.headerButtonsField = this.createHeaderButtons();
		this.cards = new BX.Landing.Collection.BaseCollection();

		this.overlay.classList.add("landing-ui-panel-image");
		this.title.appendChild(this.headerButtonsField.layout);

		this.title.innerText = BX.Landing.Loc.getMessage("LANDING_IMAGE_LIBRARY_PANEL_TITLE");

		if (BX.Landing.Main.isEditorMode())
		{
			if (BX.Landing.Main.isExternalControlsEnabled() || window.parent && (window.parent !== top))
			{
				window.parent.document.body.appendChild(this.layout);
				return;
			}
		}

		this.overlay.parentNode.removeChild(this.overlay);
		document.body.appendChild(this.overlay);
		document.body.appendChild(this.layout);
	};


	/**
	 * Gets instance
	 * @returns {BX.Landing.UI.Panel.Image}
	 */
	BX.Landing.UI.Panel.Image.getInstance = function()
	{
		if (!BX.Landing.UI.Panel.Image.instance)
		{
			BX.Landing.UI.Panel.Image.instance = new BX.Landing.UI.Panel.Image("image_panel");
		}

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


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


	BX.Landing.UI.Panel.Image.prototype = {
		constructor: BX.Landing.UI.Panel.Image,
		__proto__: BX.Landing.UI.Panel.Content.prototype,


		onChangeView: function(value)
		{
			if (value === "unsplash")
			{
				this.showUnsplash();
			}

			if (value === "google")
			{
				this.showGoogle();
			}

			if (value === "disk")
			{
				this.showUploader();
			}
		},


		/**
		 * Shows uploader
		 */
		showUploader: function()
		{
			var uploader = this.cards.get("uploader");

			if (!uploader)
			{
				uploader = new BX.Landing.UI.Card.Uploader({
					id: "uploader"
				});
				this.appendCard(uploader);
				this.cards.add(uploader);
			}

			this.hideAll();
			uploader.show();
		},


		/**
		 * Shows google images
		 */
		showGoogle: function()
		{
			var google = this.cards.get("google");

			if (!google)
			{
				google = new BX.Landing.UI.Card.Google({
					id: "google",
					searchLabel: BX.Landing.Loc.getMessage("GOOGLE_SEARCH_FIELD_LABEL"),
					searchTips: [
						{name: "Nature", value: "Nature"},
						{name: "People", value: "People"},
						{name: "Buildings", value: "Buildings"},
						{name: "Sunset", value: "Sunset"}
					],
					description: BX.Landing.Loc.getMessage("LANDING_IMAGE_GOOGLE_DESCRIPTION"),
					onChange: this.onChange.bind(this),
					params: this.uploadParams
				});
				this.appendCard(google);
				this.cards.add(google);
			}

			this.hideAll();
			google.showPopular();
			google.show();
		},


		/**
		 * Shows unsplash library
		 */
		showUnsplash: function()
		{
			var unsplash = this.cards.get("unsplash");

			if (!unsplash)
			{
				unsplash = new BX.Landing.UI.Card.Unsplash({
					id: "unsplash",
					searchLabel: BX.Landing.Loc.getMessage("UNSPLASH_SEARCH_FIELD_LABEL"),
					searchTips: [
						{name: "Nature", value: "Nature"},
						{name: "People", value: "People"},
						{name: "Buildings", value: "Buildings"},
						{name: "Sunset", value: "Sunset"}
					],
					description: BX.Landing.Loc.getMessage("LANDING_IMAGE_UNSPLASH_DESCRIPTION"),
					onChange: this.onChange.bind(this)
				});
				this.appendCard(unsplash);
				this.cards.add(unsplash);
			}

			this.hideAll();
			unsplash.show();
		},


		/**
		 * Hides all
		 */
		hideAll: function()
		{
			this.cards.forEach(function(card) {
				card.layout.hidden = true;
			});
		},


		/**
		 * Creates header button
		 * @returns {BX.Landing.UI.Field.ButtonGroup}
		 */
		createHeaderButtons: function()
		{
			return new BX.Landing.UI.Field.ButtonGroup({
				items: [
					{name: BX.Landing.Loc.getMessage("LANDING_CONTENT_EDIT_IMAGE_HEADER_BUTTON_UNSPLASH"), value: "unsplash", active: true},
					{name: BX.Landing.Loc.getMessage("LANDING_CONTENT_EDIT_IMAGE_HEADER_BUTTON_GOOGLE"), value: "google"},
					{name: BX.Landing.Loc.getMessage("LANDING_CONTENT_EDIT_IMAGE_HEADER_BUTTON_FROM_DISK"), value: "disk"}
				],
				onChange: this.onChangeView.bind(this)
			});
		},


		/**
		 * Shows panel
		 * @param {string} view
		 * @param {?object} [params]
		 * @param {BX.Loader} loader
		 * @param {object} uploadParams
		 * @returns {Promise}
		 */
		show: function(view, params, loader, uploadParams)
		{
			this.uploadParams = uploadParams || {};
			this.externalLoader = loader;
			this.params = params;
			this.onChangeView(view);
			BX.Landing.UI.Panel.Content.prototype.show.call(this);
			return new Promise(function(resolve) {
				this.promiseResolve = resolve;
			}.bind(this));
		},


		/**
		 * Hides panel
		 */
		hide: function()
		{
			this.params = null;
			BX.Landing.UI.Panel.Content.prototype.hide.call(this);
		},


		/**
		 * Handles on change event
		 * @param {object} value
		 */
		onChange: function(value)
		{
			this.externalLoader.show();
			BX.Landing.Utils.urlToBlob(value.link)
				.then(function(/* File|Blob */blob) {
					blob.lastModifiedDate = new Date();
					blob.name = (value.name + '').split("?")[0];
					return blob;
				})
				.then(this.promiseResolve.bind(this));

			this.hide();
		}
	}
})();