Your IP : 3.145.40.120


Current Path : /var/www/www-root/data/www.catalog.monolith-realty.ru/bitrix/js/ui/label/dist/
Upload File :
Current File : /var/www/www-root/data/www.catalog.monolith-realty.ru/bitrix/js/ui/label/dist/label.bundle.js

/* eslint-disable */
this.BX = this.BX || {};
(function (exports,main_core,main_loader,ui_iconSet_api_core) {
	'use strict';

	/**
	 * @namespace {BX.UI}
	 */
	class LabelColor {}
	LabelColor.DEFAULT = 'ui-label-default';
	LabelColor.DANGER = 'ui-label-danger';
	LabelColor.SUCCESS = 'ui-label-success';
	LabelColor.WARNING = 'ui-label-warning';
	LabelColor.PRIMARY = 'ui-label-primary';
	LabelColor.SECONDARY = 'ui-label-secondary';
	LabelColor.LIGHT = 'ui-label-light';
	LabelColor.TAG_SECONDARY = 'ui-label-tag-secondary';
	LabelColor.TAG_LIGHT = 'ui-label-tag-light';
	LabelColor.LIGHT_BLUE = 'ui-label-lightblue';
	LabelColor.LIGHT_GREEN = 'ui-label-lightgreen';
	LabelColor.ORANGE = 'ui-label-orange';
	LabelColor.LIGHT_ORANGE = 'ui-label-lightorange';
	LabelColor.YELLOW = 'ui-label-yellow';
	LabelColor.LIGHT_YELLOW = 'ui-label-lightyellow';
	LabelColor.LIGHT_RED = 'ui-label-lightred';
	LabelColor.LAVENDER = 'ui-label-lavender';
	LabelColor.COPILOT_LIGHT = 'ui-label-copilot-light';
	LabelColor.COPILOT_LIGHT_REVERSE = 'ui-label-copilot-light-reverse';

	/**
	 * @namespace {BX.UI}
	 */
	class LabelSize {}
	LabelSize.MD = 'ui-label-md';
	LabelSize.SM = 'ui-label-sm';
	LabelSize.LG = 'ui-label-lg';

	let _ = t => t,
	  _t,
	  _t2,
	  _t3,
	  _t4,
	  _t5;
	class Label {
	  constructor(options) {
	    this.text = options.text;
	    this.color = options.color;
	    this.size = options.size;
	    this.link = options.link;
	    this.icon = options.icon;
	    this.fill = !!options.fill ? true : options.fill;
	    this.customClass = options.customClass;
	    this.classList = "ui-label";
	    this.status = options.status;
	    this.node = {
	      container: null,
	      status: null
	    };
	    this.setText(this.text);
	    this.setLink(this.link);
	    this.setColor(this.color);
	    this.setFill(this.fill);
	    this.setCustomClass(this.customClass);
	  }

	  //region COLOR
	  setColor(color) {
	    this.color = color;
	    this.setClassList();
	  }
	  getColor() {
	    return this.color;
	  }

	  // endregion

	  //region FILL
	  setFill(fill) {
	    this.fill = !!fill ? true : false;
	    this.setClassList();
	  }
	  getFill() {
	    return this.fill;
	  }

	  // endregion

	  //region SIZE
	  setSize(size) {
	    this.size = size;
	    this.setClassList();
	  }
	  getSize() {
	    return this.size;
	  }

	  // endregion

	  //region LINK
	  setLink(link) {
	    this.link = link;
	  }
	  getLink() {
	    return this.link;
	  }

	  // endregion

	  //region TEXT
	  setText(text) {
	    this.text = text;
	    if (main_core.Type.isStringFilled(text)) {
	      this.getTextContainer().textContent = text;
	    }
	  }
	  getText() {
	    return this.text;
	  }
	  getTextContainer() {
	    if (!this.textContainer) {
	      this.textContainer = main_core.Tag.render(_t || (_t = _`<span class="ui-label-inner">${0}</span>`), this.getText());
	    }
	    return this.textContainer;
	  }

	  // endregion

	  //region CUSTOM CLASS
	  setCustomClass(customClass) {
	    this.customClass = customClass;
	    this.updateClassList();
	  }
	  getCustomClass() {
	    return this.customClass;
	  }

	  // endregion

	  //region CLASS LIST
	  setClassList() {
	    this.classList = "ui-label";
	    if (typeof this.getColor() != "undefined") {
	      this.classList = this.classList + " " + this.color;
	    }
	    if (typeof this.getSize() != "undefined") {
	      this.classList = this.classList + " " + this.size;
	    }
	    if (typeof this.getCustomClass() != "undefined") {
	      this.classList = this.classList + " " + this.customClass;
	    }
	    if (this.fill) {
	      this.classList = this.classList + " ui-label-fill";
	    }
	    this.updateClassList();
	  }
	  getClassList() {
	    return this.classList;
	  }
	  updateClassList() {
	    if (!this.node.container) {
	      this.getContainer();
	    }
	    this.node.container.setAttribute("class", this.classList);
	  }
	  getIconAction() {
	    this.iconNode = main_core.Tag.render(_t2 || (_t2 = _`<div class="ui-label-icon"></div>`));
	    for (let key in this.icon) {
	      this.iconNode.addEventListener(key, this.icon[key]);
	    }
	    return this.iconNode;
	  }
	  getLoader() {
	    if (!this.loader) {
	      this.loader = new main_loader.Loader({
	        size: 12
	      });
	    }
	    return this.loader;
	  }
	  setStatus(status) {
	    if (status) {
	      this.status = status;
	    }
	    main_core.Dom.clean(this.getContainerStatus());
	    this.getContainerStatus().classList.remove('--icon');
	    if (this.status.toLocaleUpperCase() === 'LOADING') {
	      this.getLoader().show(this.getContainerStatus());
	    }
	    if (this.status.toLocaleUpperCase() === 'CHECK') {
	      let icon = new ui_iconSet_api_core.Icon({
	        icon: ui_iconSet_api_core.Main.CHECK,
	        size: 10
	      });
	      this.getContainerStatus().classList.add('--icon');
	      this.getContainerStatus().appendChild(icon.render());
	    }
	  }
	  getContainerStatus() {
	    if (!this.node.status) {
	      this.node.status = main_core.Tag.render(_t3 || (_t3 = _`
				<div class="ui-label-status"></div>
			`));
	    }
	    return this.node.status;
	  }

	  // endregion

	  getContainer() {
	    if (!this.node.container) {
	      if (this.getLink()) {
	        this.node.container = main_core.Tag.render(_t4 || (_t4 = _`<a href="${0}" class="${0}">
					${0}
					${0}
				</a>`), this.link, this.getClassList(), this.getContainerStatus(), this.getTextContainer());
	      } else {
	        this.node.container = main_core.Tag.render(_t5 || (_t5 = _`<div class="${0}">
					${0}
					${0}
				</div>`), this.getClassList(), this.getContainerStatus(), this.getTextContainer());
	      }
	      if (typeof this.icon === 'object') {
	        this.node.container.appendChild(this.getIconAction());
	      }
	    }
	    return this.node.container;
	  }
	  render() {
	    if (this.status) {
	      this.setStatus(this.status);
	    }
	    return this.getContainer();
	  }
	}
	Label.Color = LabelColor;
	Label.Size = LabelSize;

	exports.Label = Label;
	exports.LabelColor = LabelColor;
	exports.LabelSize = LabelSize;

}((this.BX.UI = this.BX.UI || {}),BX,BX,BX.UI.IconSet));
//# sourceMappingURL=label.bundle.js.map