/* Copyright 2017 Ziadin Givan Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. https://github.com/givanz/VvvebJs */ var Input = { init: function(name) { }, onChange: function(event, node) { if (event.data && event.data.element) { event.data.element.trigger('propertyChange', [this.value, this]); } }, renderTemplate: function(name, data) { return tmpl("vvveb-input-" + name, data); }, setValue: function(value) { $('input', this.element).val(value); }, render: function(name, data) { this.element = $(this.renderTemplate(name, data)); //bind events if (this.events) for (var i in this.events) { ev = this.events[i][0]; fun = this[ this.events[i][1] ]; el = this.events[i][2]; this.element.on(ev, el, {element: this.element, input:this}, fun); } return this.element; } }; var TextInput = $.extend({}, Input, { events: [ //event, listener, child element ["blur", "onChange", "input"], ], init: function(data) { return this.render("textinput", data); }, } ); var TextareaInput = $.extend({}, Input, { events: [ ["keyup", "onChange", "textarea"], ], setValue: function(value) { $('textarea', this.element).val(value); }, init: function(data) { return this.render("textareainput", data); }, } ); var CheckboxInput = $.extend({}, Input, { onChange: function(event, node) { if (event.data && event.data.element) { event.data.element.trigger('propertyChange', [this.checked, this]); } }, events: [ ["change", "onChange", "input"], ], setValue: function(value) { if (value) { $('input', this.element).attr("checked", true); } else { $('input', this.element).attr("checked", false); } }, init: function(data) { return this.render("checkboxinput", data); }, } ); var SelectInput = $.extend({}, Input, { events: [ ["change", "onChange", "select"], ], setValue: function(value) { $('select', this.element).val(value); }, init: function(data) { return this.render("select", data); }, } ); var IconSelectInput = $.extend({}, Input, { events: [ ["change", "onChange", "select"], ], setValue: function(value) { $('select', this.element).val(value); }, init: function(data) { return this.render("icon-select", data); }, } ); var HtmlListSelectInput = $.extend({}, Input, { data:{}, cache:{}, events: [ //["click", "onChange", "li"], ["change", "onListChange", "select"], ["keyup", "searchElement", "input.search"], ["click", "clearSearch", "button.clear-backspace"], ], clearSearch : function(event) { let element = event.data.element; $("input.search", element).val("").keyup(); }, searchElement : function(event) { let element = event.data.element; searchText = this.value; delay(() => { $("li", element).hide().each(function () { $this = $(this); if (this.title.indexOf(searchText) > -1) $this.show(); }); }, 500); }, onElementClick: function(event) { let data = event.data.input.data; let svg = $(data.insertElement, this); let value = svg.get(0).outerHTML; event.data.element.trigger('propertyChange', [value, this]); }, onListChange: function(event) { let input = event.data.input; let element = event.data.element; let url = input.data.url.replace('{value}', this.value); $(".elements", element).html(`
Loading...
Loading...
`); //cache ajax requests if (input.cache[url] != undefined) { $(".elements", element).html(input.cache[url]); } else { //$(".elements", element).load(url); $.ajax({ url: url, cache: true, dataType: "html", success: function(data) { input.cache[url] = data; $(".elements", element).html(data); } }); } }, setValue: function(value) { $('select', this.element).val(value); }, init: function(data) { this.data = data; this.events.push(["click", "onElementClick", data.clickElement]); let template = this.render("html-list-select", data); //load first set $("select", template).change(); return template; }, } ); var LinkInput = $.extend({}, TextInput, { events: [ ["change", "onChange", "input"], ], init: function(data) { return this.render("textinput", data); }, } ); var DateInput = $.extend({}, TextInput, { events: [ ["change", "onChange", "input"], ], init: function(data) { return this.render("dateinput", data); }, } ); var RangeInput = $.extend({}, Input, { events: [ ["change", "onChange", "input"], ], onChange: function(event, node) { if (event.data && event.data.element) { $('[data-input-value]', this.parentNode).val(this.value); event.data.element.trigger('propertyChange', [this.value, this]); } }, setValue: function(value) { //$('[data-input-value]', this.element).text(value); return $('input', this.element).val(value); }, init: function(data) { return this.render("rangeinput", data); }, } ); var NumberInput = $.extend({}, Input, { events: [ ["change", "onChange", "input"], ], init: function(data) { return this.render("numberinput", data); }, } ); var CssUnitInput = $.extend({}, Input, { number:0, unit:"px", events: [ ["change", "onChange", "select"], ["change keyup", "onChange", "input"], ], onChange: function(event) { if (event.data && event.data.element) { let number = $("input", event.data.element).val(); let unit = $("select", event.data.element).val(); input = event.data.input; if (this.value != "") input[this.name] = this.value;// this.name = unit or number if (unit == "") unit = "px";//if unit is not set use default px let value = ""; if (unit == "auto") { $(event.data.element).addClass("auto"); value = unit; } else { $(event.data.element).removeClass("auto"); value = number + (unit ? unit : ""); } event.data.element.trigger('propertyChange', [value, this]); } }, setValue: function(value) { this.number = parseFloat(value); this.unit = value.replace(this.number, '').trim(); if (this.unit == "auto") $(this.element).addClass("auto"); $('input', this.element).val(this.number); $('select', this.element).val(this.unit); }, init: function(data) { return this.render("cssunitinput", data); }, } ); var ColorInput = $.extend({}, Input, { //html5 color input only supports setting values as hex colors even if the picker returns only rgb rgb2hex: function(value) { value = value.trim(); if (value && (rgb = value.match(/^rgba?[\s+]?\([\s+]?(\d+)[\s+]?,[\s+]?(\d+)[\s+]?,[\s+]?(\d+)[\s+]?/i))) { return (rgb && rgb.length === 4) ? "#" + ("0" + parseInt(rgb[1],10).toString(16)).slice(-2) + ("0" + parseInt(rgb[2],10).toString(16)).slice(-2) + ("0" + parseInt(rgb[3],10).toString(16)).slice(-2) : rgb; } return value; }, events: [ ["change", "onChange", "input"], ], setValue: function(value) { $('input', this.element).val(this.rgb2hex(value)); }, init: function(data) { return this.render("colorinput", data); }, } ); var ImageInput = $.extend({}, Input, { events: [ ["blur", "onChange", "input[type=text]"], ["change", "onUpload", "input[type=file]"], ], setValue: function(value) { //don't set blob value to avoid slowing down the page if (value.indexOf("data:image") == -1) { $('input[type="text"]', this.element).val(value); } }, onUpload: function(event, node) { if (this.files && this.files[0]) { var reader = new FileReader(); reader.onload = imageIsLoaded; reader.readAsDataURL(this.files[0]); //reader.readAsBinaryString(this.files[0]); file = this.files[0]; } function imageIsLoaded(e) { image = e.target.result; event.data.element.trigger('propertyChange', [image, this]); //return;//remove this line to enable php upload var formData = new FormData(); formData.append("file", file); $.ajax({ type: "POST", url: 'upload.php',//set your server side upload script url data: formData, processData: false, contentType: false, success: function (data) { console.log("File uploaded at: ", data); //if image is succesfully uploaded set image url event.data.element.trigger('propertyChange', [data, this]); //update src input $('input[type="text"]', event.data.element).val(data); }, error: function (data) { alert(data.responseText); } }); } }, init: function(data) { return this.render("imageinput", data); }, } ); var FileUploadInput = $.extend({}, TextInput, { events: [ ["blur", "onChange", "input"], ], init: function(data) { return this.render("textinput", data); }, } ); var RadioInput = $.extend({}, Input, { events: [ ["change", "onChange", "input"], ], setValue: function(value) { if (value && value != "") { $('input', this.element).removeAttr('checked'); var input = $("input[value=" + value + "]", this.element); input.attr("checked", "true").prop('checked', true); } }, init: function(data) { return this.render("radioinput", data); }, } ); var RadioButtonInput = $.extend({}, RadioInput, { init: function(data) { return this.render("radiobuttoninput", data); }, } ); var ToggleInput = $.extend({}, TextInput, { onChange: function(event, node) { if (event.data && event.data.element) { event.data.element.trigger('propertyChange', [this.checked?this.getAttribute("data-value-on"):this.getAttribute("data-value-off"), this]); } }, events: [ ["change", "onChange", "input"], ], init: function(data) { return this.render("toggle", data); }, } ); var ValueTextInput = $.extend({}, TextInput, { events: [ ["blur", "onChange", "input"], ], init: function(data) { return this.render("textinput", data); }, } ); var GridLayoutInput = $.extend({}, TextInput, { events: [ ["blur", "onChange", "input"], ], init: function(data) { return this.render("textinput", data); }, } ); var ProductsInput = $.extend({}, TextInput, { events: [ ["blur", "onChange", "input"], ], init: function(data) { return this.render("textinput", data); }, } ); var GridInput = $.extend({}, Input, { events: [ ["change", "onChange", "select" /*'select'*/], ["click", "onChange", "button" /*'select'*/], ], setValue: function(value) { $('select', this.element).val(value); }, init: function(data) { return this.render("grid", data); }, } ); var TextValueInput = $.extend({}, Input, { events: [ ["blur", "onChange", "input"], ["click", "onChange", "button" /*'select'*/], ], init: function(data) { return this.render("textvalue", data); }, } ); var ButtonInput = $.extend({}, Input, { events: [ ["click", "onChange", "button" /*'select'*/], ], setValue: function(value) { $('button', this.element).val(value); }, init: function(data) { return this.render("button", data); }, } ); var SectionInput = $.extend({}, Input, { events: [ ["click", "onChange", "button" /*'select'*/], ], setValue: function(value) { return false; }, init: function(data) { return this.render("sectioninput", data); }, } ); var ListInput = $.extend({}, Input, { events: [ ["change", "onChange", "select"], ], setValue: function(value) { $('select', this.element).val(value); }, init: function(data) { return this.render("listinput", data); }, } ); var AutocompleteInput = $.extend({}, Input, { events: [ ["autocomplete.change", "onAutocompleteChange", "input"], ], onAutocompleteChange: function(event, value, text) { if (event.data && event.data.element) { event.data.element.trigger('propertyChange', [value, this]); } }, init: function(data) { this.element = this.render("textinput", data); $('input', this.element).autocomplete(data.url);//using default parameters return this.element; } } ); var AutocompleteList = $.extend({}, Input, { events: [ ["autocompletelist.change", "onAutocompleteChange", "input"], ], onAutocompleteChange: function(event, value, text) { if (event.data && event.data.element) { event.data.element.trigger('propertyChange', [value, this]); } }, setValue: function(value) { $('input', this.element).data("autocompleteList").setValue(value); }, init: function(data) { this.element = this.render("textinput", data); $('input', this.element).autocompleteList(data);//using default parameters return this.element; } } ); var TagsInput = $.extend({}, Input, { events: [ ["tagsinput.change", "onTagsInputChange", "input"], ], onTagsInputChange: function(event, value, text) { if (event.data && event.data.element) { event.data.element.trigger('propertyChange', [value, this]); } }, setValue: function(value) { $('input', this.element).data("tagsInput").setValue(value); }, init: function(data) { this.element = this.render("tagsinput", data); $('input', this.element).tagsInput(data);//using default parameters return this.element; } } ); var NoticeInput = $.extend({}, Input, { events: [ ], init: function(data) { return this.render("noticeinput", data); }, } );