Your IP : 52.15.115.134


Current Path : /var/www/www-root/data/www/www.monolith-realty.ru/bitrix/js/landing/node/ul/dist/
Upload File :
Current File : /var/www/www-root/data/www/www.monolith-realty.ru/bitrix/js/landing/node/ul/dist/ul.bundle.js

this.BX = this.BX || {};
this.BX.Landing = this.BX.Landing || {};
(function (exports,main_core) {
	'use strict';

	class Ul {
	  constructor() {
	    this.popup = null;
	    this.nodeEditSubmit = null;
	    this.nodeEditLi = [];
	    this.content = [];

	    // get all LI with BIU tags
	    const ulLi = BX.findChildren(this.node, {
	      tag: 'li'
	    });
	    for (let i = 0, c = ulLi.length; i < c; i++) {
	      let liContent = '';
	      for (let j = 0, cc = ulLi[i].childNodes.length; j < cc; j++) {
	        if (ulLi[i].childNodes[j].nodeType === 1 && (ulLi[i].childNodes[j].tagName === 'B' || ulLi[i].childNodes[j].tagName === 'I' || ulLi[i].childNodes[j].tagName === 'U')) {
	          liContent += ulLi[i].childNodes[j].outerHTML;
	        } else if (ulLi[i].childNodes[j].nodeType === 3 && BX.util.trim(ulLi[i].childNodes[j].textContent) !== '') {
	          liContent += ' #VAL# ';
	        }
	      }
	      this.content.push({
	        content: BX.util.trim(ulLi[i].textContent),
	        original: liContent
	      });
	    }
	    BX.bind(this.node, 'click', BX.delegate(this.onClick, this));
	  }

	  /**
	   * Save content for Node.
	   * @returns {void}
	   */
	  saveContent() {
	    let wasChanged = false;
	    let isNull = true;
	    // change any li or not
	    for (let i = 0, c = this.nodeEditLi.length; i < c; i++) {
	      if (this.nodeEditLi[i] === null) {
	        wasChanged = true;
	        break;
	      } else {
	        const value = BX.util.trim(this.nodeEditLi[i].value);
	        isNull = false;
	        if (main_core.Type.isUndefined(this.content[i]) || this.content[i].content !== value) {
	          wasChanged = true;
	          break;
	        }
	      }
	    }

	    // save content
	    if (!isNull && wasChanged) {
	      BX.cleanNode(this.node);
	      this.content = [];
	      for (let i = 0, c = this.nodeEditLi.length; i < c; i++) {
	        if (this.nodeEditLi[i] === null) {
	          this.content.push(false);
	        } else {
	          const value = BX.util.trim(this.nodeEditLi[i].value);
	          const original = BX.data(this.nodeEditLi[i], 'original');
	          this.content.push({
	            content: value,
	            original
	          });
	          this.node.appendChild(BX.create('li', {
	            html: original.replace('#VAL#', BX.util.htmlspecialchars(value))
	          }));
	        }
	      }
	      this.markAsChanged();
	    }
	  }

	  /**
	   * Return element for add new li item.
	   * @returns {HTMLElement}
	   */
	  getAddLiButton(i) {
	    return BX.create('input', {
	      attrs: {
	        type: 'button',
	        value: '+'
	      },
	      dataset: {
	        i: i
	      },
	      events: {
	        click: BX.delegate(function () {
	          const button = BX.proxy_context;
	          const int = parseInt(BX.data(button, 'i'), 10);
	          const newLi = BX.create('input', {
	            dataset: {
	              original: this.content[i].original
	            },
	            attrs: {
	              type: 'text'
	            }
	          });
	          BX.insertAfter(BX.create('div', {
	            children: [newLi, this.getAddLiButton(int + 1), this.getRemoveLiButton(int + 1)]
	          }), button.parentNode);
	          this.nodeEditLi.splice(int + 1, 0, newLi);
	          BX.focus(newLi);
	        }, this)
	      }
	    });
	  }

	  /**
	   * Return element for remove li item.
	   * @returns {HTMLElement}
	   */
	  getRemoveLiButton(i) {
	    return BX.create('input', {
	      attrs: {
	        type: 'button',
	        value: '-'
	      },
	      dataset: {
	        i
	      },
	      events: {
	        click: BX.delegate(function () {
	          const button = BX.proxy_context;
	          this.nodeEditLi[BX.data(button, 'i')] = null;
	          BX.remove(button.parentNode);
	        }, this)
	      }
	    });
	  }

	  /**
	   * Return nodes for edit content.
	   * @param {Boolean} showButton False if not show save button.
	   * @returns {Array | HTMLElement}
	   */
	  getEditNodes(showButton) {
	    let li = [];
	    const editLi = [];
	    this.nodeEditLi = [];

	    // edit li
	    for (let i = 0, c = this.content.length; i < c; i++) {
	      li = BX.create('input', {
	        dataset: {
	          original: this.content[i].original
	        },
	        attrs: {
	          type: 'text',
	          value: BX.util.trim(this.content[i].content)
	        }
	      });
	      this.nodeEditLi.push(li);
	      editLi.push(BX.create('div', {
	        children: [li, this.getAddLiButton(i), this.getRemoveLiButton(i)]
	      }));
	    }

	    // save button
	    if (showButton !== false) {
	      this.nodeEditSubmit = BX.create('input', {
	        attrs: {
	          type: 'button',
	          value: 'Save'
	        },
	        events: {
	          click: function () {
	            this.saveContent();
	            this.popup.close();
	          }.bind(this)
	        }
	      });
	    }
	    if (showButton !== false) {
	      editLi.push(this.nodeEditSubmit);
	    }
	    return editLi;
	  }

	  /**
	   * Click on field - edit mode.
	   * @param {MouseEvent} e
	   * @returns {void}
	   */
	  onClick(e) {
	    this.popup = BX.PopupWindowManager.create('landing_node_img', BX.proxy_context, {
	      closeIcon: false,
	      autoHide: true,
	      closeByEsc: true,
	      contentColor: 'white',
	      angle: true,
	      offsetLeft: 15,
	      overlay: {
	        backgroundColor: '#cdcdcd',
	        opacity: '.1'
	      },
	      events: {
	        onPopupClose: function () {
	          this.popup.destroy();
	        }.bind(this)
	      }
	    });

	    // popup content
	    this.popup.setContent(BX.create('div', {
	      children: this.getEditNodes()
	    }));
	    this.popup.show();
	    return BX.PreventDefault(e);
	  }

	  /*
	   * Get tags for show Node in settings form.
	   * @returns {Array}
	   */
	  getSettingsForm() {
	    return [{
	      name: this.getName(),
	      node: BX.create('div', {
	        children: this.getEditNodes(false)
	      })
	    }];
	  }
	  getValue() {}
	  setValue() {}
	  getField() {
	    return new BX.Landing.UI.Field.BaseField({
	      selector: this.selector,
	      title: this.manifest.name
	    });
	  }
	}

	exports.Ul = Ul;

}((this.BX.Landing.Node = this.BX.Landing.Node || {}),BX));
//# sourceMappingURL=ul.bundle.js.map