|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Vvveb.ComponentsGroup['Server Components'] = ["components/products", "components/product", "components/categories", "components/manufacturers", "components/search", "components/user", "components/product_gallery", "components/cart", "components/checkout", "components/filters", "components/product", "components/slider"]; |
|
|
|
|
|
|
|
|
Vvveb.Components.add("components/product", { |
|
|
name: "Product", |
|
|
attributes: ["data-component-product"], |
|
|
|
|
|
image: "icons/map.svg", |
|
|
html: '<iframe frameborder="0" src="https://maps.google.com/maps?&z=1&t=q&output=embed"></iframe>', |
|
|
|
|
|
properties: [ |
|
|
{ |
|
|
name: "Id", |
|
|
key: "id", |
|
|
htmlAttr: "id", |
|
|
inputtype: TextInput |
|
|
}, |
|
|
{ |
|
|
name: "Select", |
|
|
key: "id", |
|
|
htmlAttr: "id", |
|
|
inputtype: SelectInput, |
|
|
data:{ |
|
|
options: [{ |
|
|
value: "", |
|
|
text: "None" |
|
|
}, { |
|
|
value: "pull-left", |
|
|
text: "Left" |
|
|
}, { |
|
|
value: "pull-right", |
|
|
text: "Right" |
|
|
}] |
|
|
}, |
|
|
}, |
|
|
{ |
|
|
name: "Select 2", |
|
|
key: "id", |
|
|
htmlAttr: "id", |
|
|
inputtype: SelectInput, |
|
|
data:{ |
|
|
options: [{ |
|
|
value: "", |
|
|
text: "nimic" |
|
|
}, { |
|
|
value: "pull-left", |
|
|
text: "gigi" |
|
|
}, { |
|
|
value: "pull-right", |
|
|
text: "vasile" |
|
|
}, { |
|
|
value: "pull-right", |
|
|
text: "sad34" |
|
|
}] |
|
|
}, |
|
|
}] |
|
|
}); |
|
|
|
|
|
|
|
|
Vvveb.Components.add("components/products", { |
|
|
name: "Products", |
|
|
attributes: ["data-component-products"], |
|
|
|
|
|
image: "icons/products.svg", |
|
|
html: '<div class="mb-3"><label>Your response:</label><textarea class="form-control"></textarea></div>', |
|
|
|
|
|
init: function (node) |
|
|
{ |
|
|
$('.mb-3[data-group]').hide(); |
|
|
if (node.dataset.type != undefined) |
|
|
{ |
|
|
$('.mb-3[data-group="'+ node.dataset.type + '"]').show(); |
|
|
} else |
|
|
{ |
|
|
$('.mb-3[data-group]:first').show(); |
|
|
} |
|
|
}, |
|
|
properties: [{ |
|
|
name: false, |
|
|
key: "type", |
|
|
inputtype: RadioButtonInput, |
|
|
htmlAttr:"data-type", |
|
|
data: { |
|
|
inline: true, |
|
|
extraclass:"btn-group-fullwidth", |
|
|
options: [{ |
|
|
value: "autocomplete", |
|
|
text: "Autocomplete", |
|
|
title: "Autocomplete", |
|
|
icon:"la la-search", |
|
|
checked:true, |
|
|
}, { |
|
|
value: "automatic", |
|
|
icon:"la la-cog", |
|
|
text: "Configuration", |
|
|
title: "Configuration", |
|
|
}], |
|
|
}, |
|
|
onChange : function(element, value, input) { |
|
|
|
|
|
$('.mb-3[data-group]').hide(); |
|
|
$('.mb-3[data-group="'+ input.value + '"]').show(); |
|
|
|
|
|
return element; |
|
|
}, |
|
|
init: function(node) { |
|
|
return node.dataset.type; |
|
|
}, |
|
|
},{ |
|
|
name: "Products", |
|
|
key: "products", |
|
|
group:"autocomplete", |
|
|
htmlAttr:"data-products", |
|
|
inputtype: AutocompleteList, |
|
|
data: { |
|
|
url: "/admin/?module=editor/editor&action=productsAutocomplete", |
|
|
}, |
|
|
},{ |
|
|
name: "Number of products", |
|
|
group:"automatic", |
|
|
key: "limit", |
|
|
htmlAttr:"data-limit", |
|
|
inputtype: NumberInput, |
|
|
data: { |
|
|
value: "8", |
|
|
min: "1", |
|
|
max: "1024", |
|
|
step: "1" |
|
|
}, |
|
|
getFromNode: function(node) { |
|
|
return 10 |
|
|
}, |
|
|
},{ |
|
|
name: "Start from page", |
|
|
group:"automatic", |
|
|
key: "page", |
|
|
htmlAttr:"data-page", |
|
|
data: { |
|
|
value: "1", |
|
|
min: "1", |
|
|
max: "1024", |
|
|
step: "1" |
|
|
}, |
|
|
inputtype: NumberInput, |
|
|
getFromNode: function(node) { |
|
|
return 0 |
|
|
}, |
|
|
},{ |
|
|
name: "Order by", |
|
|
group:"automatic", |
|
|
key: "order", |
|
|
htmlAttr:"data-order", |
|
|
inputtype: SelectInput, |
|
|
data: { |
|
|
options: [{ |
|
|
value: "price_asc", |
|
|
text: "Price Ascending" |
|
|
}, { |
|
|
value: "price_desc", |
|
|
text: "Price Descending" |
|
|
}, { |
|
|
value: "date_asc", |
|
|
text: "Date Ascending" |
|
|
}, { |
|
|
value: "date_desc", |
|
|
text: "Date Descending" |
|
|
}, { |
|
|
value: "sales_asc", |
|
|
text: "Sales Ascending" |
|
|
}, { |
|
|
value: "sales_desc", |
|
|
text: "Sales Descending" |
|
|
}] |
|
|
} |
|
|
},{ |
|
|
name: "Category", |
|
|
group:"automatic", |
|
|
key: "category", |
|
|
htmlAttr:"data-category", |
|
|
inputtype: AutocompleteList, |
|
|
data: { |
|
|
url: "/admin/?module=editor/editor&action=productsAutocomplete", |
|
|
}, |
|
|
|
|
|
},{ |
|
|
name: "Manufacturer", |
|
|
group:"automatic", |
|
|
key: "manufacturer", |
|
|
htmlAttr:"data-manufacturer", |
|
|
inputtype: AutocompleteList, |
|
|
data: { |
|
|
url: "/admin/?module=editor/editor&action=productsAutocomplete", |
|
|
} |
|
|
},{ |
|
|
name: "Manufacturer 2", |
|
|
group:"automatic", |
|
|
key: "manufacturer 2", |
|
|
htmlAttr:"data-manufacturer2", |
|
|
inputtype: AutocompleteList, |
|
|
data: { |
|
|
url: "/admin/?module=editor/editor&action=productsAutocomplete", |
|
|
}, |
|
|
}] |
|
|
}); |
|
|
|
|
|
Vvveb.Components.add("components/manufacturers", { |
|
|
name: "Manufacturers", |
|
|
classes: ["component_manufacturers"], |
|
|
image: "icons/categories.svg", |
|
|
html: '<div class="mb-3"><label>Your response:</label><textarea class="form-control"></textarea></div>', |
|
|
properties: [{ |
|
|
nolabel:false, |
|
|
inputtype: TextInput, |
|
|
data: {text:"Fields"} |
|
|
},{ |
|
|
name: "Name", |
|
|
key: "category", |
|
|
inputtype: TextInput |
|
|
},{ |
|
|
name: "Image", |
|
|
key: "category", |
|
|
inputtype: TextInput |
|
|
} |
|
|
] |
|
|
}); |
|
|
|
|
|
Vvveb.Components.add("components/categories", { |
|
|
name: "Categories", |
|
|
classes: ["component_categories"], |
|
|
image: "icons/categories.svg", |
|
|
html: '<div class="mb-3"><label>Your response:</label><textarea class="form-control"></textarea></div>', |
|
|
properties: [{ |
|
|
name: "Name", |
|
|
key: "name", |
|
|
htmlAttr: "src", |
|
|
inputtype: FileUploadInput |
|
|
}] |
|
|
}); |
|
|
Vvveb.Components.add("components/search", { |
|
|
name: "Search", |
|
|
classes: ["component_search"], |
|
|
image: "icons/search.svg", |
|
|
html: '<div class="mb-3"><label>Your response:</label><textarea class="form-control"></textarea></div>', |
|
|
properties: [{ |
|
|
name: "asdasdad", |
|
|
key: "src", |
|
|
htmlAttr: "src", |
|
|
inputtype: FileUploadInput |
|
|
}, { |
|
|
name: "34234234", |
|
|
key: "width", |
|
|
htmlAttr: "width", |
|
|
inputtype: TextInput |
|
|
}, { |
|
|
name: "d32d23", |
|
|
key: "height", |
|
|
htmlAttr: "height", |
|
|
inputtype: TextInput |
|
|
}] |
|
|
}); |
|
|
Vvveb.Components.add("components/user", { |
|
|
name: "User", |
|
|
classes: ["component_user"], |
|
|
image: "icons/user.svg", |
|
|
html: '<div class="mb-3"><label>Your response:</label><textarea class="form-control"></textarea></div>', |
|
|
properties: [{ |
|
|
name: "asdasdad", |
|
|
key: "src", |
|
|
htmlAttr: "src", |
|
|
inputtype: FileUploadInput |
|
|
}, { |
|
|
name: "34234234", |
|
|
key: "width", |
|
|
htmlAttr: "width", |
|
|
inputtype: TextInput |
|
|
}, { |
|
|
name: "d32d23", |
|
|
key: "height", |
|
|
htmlAttr: "height", |
|
|
inputtype: TextInput |
|
|
}] |
|
|
}); |
|
|
Vvveb.Components.add("components/product_gallery", { |
|
|
name: "Product gallery", |
|
|
classes: ["component_product_gallery"], |
|
|
image: "icons/product_gallery.svg", |
|
|
html: '<div class="mb-3"><label>Your response:</label><textarea class="form-control"></textarea></div>', |
|
|
properties: [{ |
|
|
name: "asdasdad", |
|
|
key: "src", |
|
|
htmlAttr: "src", |
|
|
inputtype: FileUploadInput |
|
|
}, { |
|
|
name: "34234234", |
|
|
key: "width", |
|
|
htmlAttr: "width", |
|
|
inputtype: TextInput |
|
|
}, { |
|
|
name: "d32d23", |
|
|
key: "height", |
|
|
htmlAttr: "height", |
|
|
inputtype: TextInput |
|
|
}] |
|
|
}); |
|
|
Vvveb.Components.add("components/cart", { |
|
|
name: "Cart", |
|
|
classes: ["component_cart"], |
|
|
image: "icons/cart.svg", |
|
|
html: '<div class="mb-3"><label>Your response:</label><textarea class="form-control"></textarea></div>', |
|
|
properties: [{ |
|
|
name: "asdasdad", |
|
|
key: "src", |
|
|
htmlAttr: "src", |
|
|
inputtype: FileUploadInput |
|
|
}, { |
|
|
name: "34234234", |
|
|
key: "width", |
|
|
htmlAttr: "width", |
|
|
inputtype: TextInput |
|
|
}, { |
|
|
name: "d32d23", |
|
|
key: "height", |
|
|
htmlAttr: "height", |
|
|
inputtype: TextInput |
|
|
}] |
|
|
}); |
|
|
Vvveb.Components.add("components/checkout", { |
|
|
name: "Checkout", |
|
|
classes: ["component_checkout"], |
|
|
image: "icons/checkout.svg", |
|
|
html: '<div class="mb-3"><label>Your response:</label><textarea class="form-control"></textarea></div>', |
|
|
properties: [{ |
|
|
name: "asdasdad", |
|
|
key: "src", |
|
|
htmlAttr: "src", |
|
|
inputtype: FileUploadInput |
|
|
}, { |
|
|
name: "34234234", |
|
|
key: "width", |
|
|
htmlAttr: "width", |
|
|
inputtype: TextInput |
|
|
}, { |
|
|
name: "d32d23", |
|
|
key: "height", |
|
|
htmlAttr: "height", |
|
|
inputtype: TextInput |
|
|
}] |
|
|
}); |
|
|
Vvveb.Components.add("components/filters", { |
|
|
name: "Filters", |
|
|
classes: ["component_filters"], |
|
|
image: "icons/filters.svg", |
|
|
html: '<div class="mb-3"><label>Your response:</label><textarea class="form-control"></textarea></div>', |
|
|
properties: [{ |
|
|
name: "asdasdad", |
|
|
key: "src", |
|
|
htmlAttr: "src", |
|
|
inputtype: FileUploadInput |
|
|
}, { |
|
|
name: "34234234", |
|
|
key: "width", |
|
|
htmlAttr: "width", |
|
|
inputtype: TextInput |
|
|
}, { |
|
|
name: "d32d23", |
|
|
key: "height", |
|
|
htmlAttr: "height", |
|
|
inputtype: TextInput |
|
|
}] |
|
|
}); |
|
|
Vvveb.Components.add("components/product", { |
|
|
name: "Product", |
|
|
classes: ["component_product"], |
|
|
image: "icons/product.svg", |
|
|
html: '<div class="mb-3"><label>Your response:</label><textarea class="form-control"></textarea></div>', |
|
|
properties: [{ |
|
|
name: "asdasdad", |
|
|
key: "src", |
|
|
htmlAttr: "src", |
|
|
inputtype: FileUploadInput |
|
|
}, { |
|
|
name: "34234234", |
|
|
key: "width", |
|
|
htmlAttr: "width", |
|
|
inputtype: TextInput |
|
|
}, { |
|
|
name: "d32d23", |
|
|
key: "height", |
|
|
htmlAttr: "height", |
|
|
inputtype: TextInput |
|
|
}] |
|
|
}); |
|
|
Vvveb.Components.add("components/slider", { |
|
|
name: "Slider", |
|
|
classes: ["component_slider"], |
|
|
image: "icons/slider.svg", |
|
|
html: '<div class="form-group"><label>Your response:</label><textarea class="form-control"></textarea></div>', |
|
|
properties: [{ |
|
|
name: "asdasdad", |
|
|
key: "src", |
|
|
htmlAttr: "src", |
|
|
inputtype: FileUploadInput |
|
|
}, { |
|
|
name: "34234234", |
|
|
key: "width", |
|
|
htmlAttr: "width", |
|
|
inputtype: TextInput |
|
|
}, { |
|
|
name: "d32d23", |
|
|
key: "height", |
|
|
htmlAttr: "height", |
|
|
inputtype: TextInput |
|
|
}] |
|
|
}); |
|
|
|