You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

723 lines
14 KiB

/*
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(`<div class="p-4"><div class="spinner-border spinner-border-sm" role="status">
<span class="visually-hidden">Loading...</span>
</div> Loading...</div>`);
//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);
},
}
);