Component-Builder/media/js/site_view.js

490 lines
14 KiB
JavaScript
Raw Normal View History

/**
* @package Joomla.Component.Builder
*
* @created 30th April, 2015
2022-07-09 15:45:08 +00:00
* @author Llewellyn van der Merwe <https://dev.vdm.io>
* @git Joomla Component Builder <https://git.vdm.dev/joomla/Component-Builder>
* @copyright Copyright (C) 2015 Vast Development Method. All rights reserved.
* @license GNU General Public License version 2 or later; see LICENSE.txt
*/
2016-01-30 20:28:43 +00:00
// Initial Script
document.addEventListener('DOMContentLoaded', function()
2016-01-30 20:28:43 +00:00
{
var add_php_view_vvvvwao = jQuery("#jform_add_php_view input[type='radio']:checked").val();
vvvvwao(add_php_view_vvvvwao);
2016-01-30 20:28:43 +00:00
var add_php_jview_display_vvvvwap = jQuery("#jform_add_php_jview_display input[type='radio']:checked").val();
vvvvwap(add_php_jview_display_vvvvwap);
2016-01-30 20:28:43 +00:00
var add_php_jview_vvvvwaq = jQuery("#jform_add_php_jview input[type='radio']:checked").val();
vvvvwaq(add_php_jview_vvvvwaq);
2016-01-30 20:28:43 +00:00
var add_php_document_vvvvwar = jQuery("#jform_add_php_document input[type='radio']:checked").val();
vvvvwar(add_php_document_vvvvwar);
2016-01-30 20:28:43 +00:00
var add_css_document_vvvvwas = jQuery("#jform_add_css_document input[type='radio']:checked").val();
vvvvwas(add_css_document_vvvvwas);
2016-01-30 20:28:43 +00:00
var add_javascript_file_vvvvwat = jQuery("#jform_add_javascript_file input[type='radio']:checked").val();
vvvvwat(add_javascript_file_vvvvwat);
2016-01-30 20:28:43 +00:00
var add_js_document_vvvvwau = jQuery("#jform_add_js_document input[type='radio']:checked").val();
vvvvwau(add_js_document_vvvvwau);
2016-01-30 20:28:43 +00:00
var add_css_vvvvwav = jQuery("#jform_add_css input[type='radio']:checked").val();
vvvvwav(add_css_vvvvwav);
2016-01-30 20:28:43 +00:00
var add_php_ajax_vvvvwaw = jQuery("#jform_add_php_ajax input[type='radio']:checked").val();
vvvvwaw(add_php_ajax_vvvvwaw);
var add_custom_button_vvvvwax = jQuery("#jform_add_custom_button input[type='radio']:checked").val();
vvvvwax(add_custom_button_vvvvwax);
var button_position_vvvvway = jQuery("#jform_button_position").val();
vvvvway(button_position_vvvvway);
2016-01-30 20:28:43 +00:00
});
// the vvvvwao function
function vvvvwao(add_php_view_vvvvwao)
2016-01-30 20:28:43 +00:00
{
// set the function logic
if (add_php_view_vvvvwao == 1)
2016-01-30 20:28:43 +00:00
{
jQuery('#jform_php_view-lbl').closest('.control-group').show();
2016-01-30 20:28:43 +00:00
}
else
{
jQuery('#jform_php_view-lbl').closest('.control-group').hide();
2016-01-30 20:28:43 +00:00
}
}
// the vvvvwap function
function vvvvwap(add_php_jview_display_vvvvwap)
2016-01-30 20:28:43 +00:00
{
// set the function logic
if (add_php_jview_display_vvvvwap == 1)
2016-01-30 20:28:43 +00:00
{
jQuery('#jform_php_jview_display-lbl').closest('.control-group').show();
2016-01-30 20:28:43 +00:00
}
else
{
jQuery('#jform_php_jview_display-lbl').closest('.control-group').hide();
2016-01-30 20:28:43 +00:00
}
}
// the vvvvwaq function
function vvvvwaq(add_php_jview_vvvvwaq)
2016-01-30 20:28:43 +00:00
{
// set the function logic
if (add_php_jview_vvvvwaq == 1)
2016-01-30 20:28:43 +00:00
{
jQuery('#jform_php_jview-lbl').closest('.control-group').show();
2016-01-30 20:28:43 +00:00
}
else
{
jQuery('#jform_php_jview-lbl').closest('.control-group').hide();
2016-01-30 20:28:43 +00:00
}
}
// the vvvvwar function
function vvvvwar(add_php_document_vvvvwar)
2016-01-30 20:28:43 +00:00
{
// set the function logic
if (add_php_document_vvvvwar == 1)
2016-01-30 20:28:43 +00:00
{
jQuery('#jform_php_document-lbl').closest('.control-group').show();
2016-01-30 20:28:43 +00:00
}
else
{
jQuery('#jform_php_document-lbl').closest('.control-group').hide();
2016-01-30 20:28:43 +00:00
}
}
// the vvvvwas function
function vvvvwas(add_css_document_vvvvwas)
2016-01-30 20:28:43 +00:00
{
// set the function logic
if (add_css_document_vvvvwas == 1)
2016-01-30 20:28:43 +00:00
{
jQuery('#jform_css_document-lbl').closest('.control-group').show();
2016-01-30 20:28:43 +00:00
}
else
{
jQuery('#jform_css_document-lbl').closest('.control-group').hide();
2016-01-30 20:28:43 +00:00
}
}
// the vvvvwat function
function vvvvwat(add_javascript_file_vvvvwat)
2016-01-30 20:28:43 +00:00
{
// set the function logic
if (add_javascript_file_vvvvwat == 1)
{
jQuery('#jform_javascript_file-lbl').closest('.control-group').show();
}
else
{
jQuery('#jform_javascript_file-lbl').closest('.control-group').hide();
}
}
// the vvvvwau function
function vvvvwau(add_js_document_vvvvwau)
{
// set the function logic
if (add_js_document_vvvvwau == 1)
2016-01-30 20:28:43 +00:00
{
jQuery('#jform_js_document-lbl').closest('.control-group').show();
2016-01-30 20:28:43 +00:00
}
else
{
jQuery('#jform_js_document-lbl').closest('.control-group').hide();
2016-01-30 20:28:43 +00:00
}
}
// the vvvvwav function
function vvvvwav(add_css_vvvvwav)
2016-01-30 20:28:43 +00:00
{
// set the function logic
if (add_css_vvvvwav == 1)
2016-01-30 20:28:43 +00:00
{
jQuery('#jform_css-lbl').closest('.control-group').show();
2016-01-30 20:28:43 +00:00
}
else
{
jQuery('#jform_css-lbl').closest('.control-group').hide();
2016-01-30 20:28:43 +00:00
}
}
// the vvvvwaw function
function vvvvwaw(add_php_ajax_vvvvwaw)
2016-01-30 20:28:43 +00:00
{
// set the function logic
if (add_php_ajax_vvvvwaw == 1)
2016-01-30 20:28:43 +00:00
{
jQuery('#jform_ajax_input-lbl').closest('.control-group').show();
jQuery('#jform_php_ajaxmethod-lbl').closest('.control-group').show();
2016-01-30 20:28:43 +00:00
}
else
{
jQuery('#jform_ajax_input-lbl').closest('.control-group').hide();
jQuery('#jform_php_ajaxmethod-lbl').closest('.control-group').hide();
2016-01-30 20:28:43 +00:00
}
}
// the vvvvwax function
function vvvvwax(add_custom_button_vvvvwax)
2016-01-30 20:28:43 +00:00
{
// set the function logic
if (add_custom_button_vvvvwax == 1)
2016-01-30 20:28:43 +00:00
{
jQuery('#jform_custom_button-lbl').closest('.control-group').show();
jQuery('#jform_php_controller-lbl').closest('.control-group').show();
jQuery('#jform_php_model-lbl').closest('.control-group').show();
2016-01-30 20:28:43 +00:00
}
else
{
jQuery('#jform_custom_button-lbl').closest('.control-group').hide();
jQuery('#jform_php_controller-lbl').closest('.control-group').hide();
jQuery('#jform_php_model-lbl').closest('.control-group').hide();
2016-01-30 20:28:43 +00:00
}
}
// the vvvvway function
function vvvvway(button_position_vvvvway)
{
if (isSet(button_position_vvvvway) && button_position_vvvvway.constructor !== Array)
{
var temp_vvvvway = button_position_vvvvway;
var button_position_vvvvway = [];
button_position_vvvvway.push(temp_vvvvway);
}
else if (!isSet(button_position_vvvvway))
{
var button_position_vvvvway = [];
}
var button_position = button_position_vvvvway.some(button_position_vvvvway_SomeFunc);
// set this function logic
if (button_position)
{
jQuery('.note_custom_toolbar_placeholder').closest('.control-group').show();
}
else
{
jQuery('.note_custom_toolbar_placeholder').closest('.control-group').hide();
}
}
// the vvvvway Some function
function button_position_vvvvway_SomeFunc(button_position_vvvvway)
{
// set the function logic
if (button_position_vvvvway == 5)
{
return true;
}
return false;
}
2016-01-30 20:28:43 +00:00
// the isSet function
function isSet(val)
{
if ((val != undefined) && (val != null) && 0 !== val.length){
return true;
}
return false;
}
jQuery(document).ready(function()
{
// get the linked details
getLinked();
// check and load all the custom code edit buttons
getEditCustomCodeButtons();
});
function getCodeFrom_server(id, type, type_name, callingName) {
var url = "index.php?option=com_componentbuilder&task=ajax." + callingName + "&format=json&raw=true&vdm="+vastDevMod;
if (token.length > 0 && id > 0 && type.length > 0) {
url += '&' + token + '=1&' + type_name + '=' + type + '&id=' + id;
}
var getUrl = JRouter(url);
return fetch(getUrl, {
method: 'GET',
headers: {
'Content-Type': 'application/json'
}
}).then(function(response) {
if (response.ok) {
return response.json();
} else {
throw new Error('Network response was not ok');
}
}).then(function(data) {
return data;
}).catch(function(error) {
console.error('There was a problem with the fetch operation:', error);
});
}
function getLinked(){
getCodeFrom_server(1, 'type', 'type', 'getLinked').then(function(result) {
if(result){
jQuery('#display_linked_to').html(result);
}
});
}
2016-01-30 20:28:43 +00:00
function getSnippetDetails(id){
getCodeFrom_server(id, '_type', '_type', 'snippetDetails').then(function(result) {
2016-01-30 20:28:43 +00:00
if(result.snippet){
var description = '';
if (result.description.length > 0) {
2016-01-30 20:28:43 +00:00
description = '<p>'+result.description+'</p>';
}
var library = '';
if (result.library.length > 0) {
library = ' <b>('+result.library+')</b>';
}
var code = '<div id="snippet-code"><b>'+result.name+' ('+result.type+')</b> <a href="'+result.url+'" target="_blank" >see more details'+library+'</a><br /><em>'+result.heading+'</em><br /><textarea id="snippet" class="span12" rows="11">'+result.snippet+'</textarea></div>';
2016-01-30 20:28:43 +00:00
jQuery('#snippet-code').remove();
jQuery('.snippet-code').append(code);
// make sure the code block is active
jQuery("#snippet").focus(function() {
var jQuerythis = jQuery(this);
jQuerythis.select();
// Work around Chrome's little problem
jQuerythis.mouseup(function() {
// Prevent further mouseup intervention
jQuerythis.unbind("mouseup");
return false;
});
});
}
if(result.usage){
var usage = '<div id="snippet-usage"><p>'+result.usage+'</p></div>';
jQuery('#snippet-usage').remove();
jQuery('.snippet-usage').append(usage);
}
})
}
2016-01-30 20:28:43 +00:00
function getDynamicValues_server(dynamicId){
var getUrl = JRouter("index.php?option=com_componentbuilder&task=ajax.getDynamicValues&format=json");
2016-01-30 20:28:43 +00:00
if(token.length > 0 && dynamicId > 0){
var request = token+'=1&view=site_view&id='+dynamicId;
2016-01-30 20:28:43 +00:00
}
return jQuery.ajax({
type: 'GET',
url: getUrl,
dataType: 'jsonp',
data: request,
jsonp: 'callback'
});
}
function getDynamicValues(id){
getDynamicValues_server(id).done(function(result) {
if(result){
jQuery('#dynamic_values').remove();
jQuery('.dynamic_values').append('<div id="dynamic_values">'+result+'</div>');
// make sure the code bocks are active
jQuery("code").click(function() {
jQuery(this).selText().addClass("selected");
});
}
})
}
2016-01-30 20:28:43 +00:00
function getLayoutDetails_server(id){
var getUrl = JRouter("index.php?option=com_componentbuilder&task=ajax.getLayoutDetails&format=json&vdm="+vastDevMod);
2016-01-30 20:28:43 +00:00
if(token.length > 0 && id > 0){
var request = token+'=1&id='+id;
2016-01-30 20:28:43 +00:00
}
return jQuery.ajax({
type: 'GET',
url: getUrl,
dataType: 'jsonp',
data: request,
jsonp: 'callback'
});
}
function getLayoutDetails(id){
getLayoutDetails_server(id).done(function(result) {
if(result){
jQuery('#details').append(result);
// make sure the code bocks are active
jQuery("code").click(function() {
jQuery(this).selText().addClass("selected");
});
}
})
}
2016-01-30 20:28:43 +00:00
function getTemplateDetails(id){
getCodeFrom_server(id, 'type', 'type', 'templateDetails').then(function(result) {
2016-01-30 20:28:43 +00:00
if(result){
jQuery('#details').append(result);
// make sure the code bocks are active
jQuery("code").click(function() {
jQuery(this).selText().addClass("selected");
});
}
})
}
// set snippets that are on the page
var snippetIds = [];
var snippets = {};
var snippet = 0;
jQuery(document).ready(function($)
{
jQuery("#jform_snippet option").each(function()
{
var key = jQuery(this).val();
var text = jQuery(this).text();
snippets[key] = text;
snippetIds.push(key);
});
snippet = jQuery("#jform_snippet").val();
getSnippets();
});
function getSnippets(){
jQuery("#loading").show();
// clear the selection
jQuery('#jform_snippet').find('option').remove().end();
jQuery('#jform_snippet').trigger('liszt:updated');
// get libraries value if set
var libraries = jQuery("#jform_libraries").val();
if (libraries) {
getCodeFrom_server(1, JSON.stringify(libraries), 'libraries', 'getSnippets').then(function(result) {
setSnippets(result);
jQuery("#loading").hide();
if (typeof snippetButton !== 'undefined') {
// ensure button is correct
var snippet = jQuery('#jform_snippet').val();
snippetButton(snippet);
}
});
}
else
{
// load all snippets in none is selected
setSnippets(snippetIds);
jQuery("#loading").hide();
}
}
function setSnippets(array){
if (array) {
jQuery('#jform_snippet').append('<option value="">'+select_a_snippet+'</option>');
jQuery.each( array, function( i, id ) {
if (id in snippets) {
jQuery('#jform_snippet').append('<option value="'+id+'">'+snippets[id]+'</option>');
}
if (id == snippet) {
jQuery('#jform_snippet').val(id);
}
});
} else {
jQuery('#jform_snippet').append('<option value="">'+create_a_snippet+'</option>');
}
jQuery('#jform_snippet').trigger('liszt:updated');
}
function getEditCustomCodeButtons_server(id) {
var getUrl = JRouter("index.php?option=com_componentbuilder&task=ajax.getEditCustomCodeButtons&format=json&raw=true&vdm="+vastDevMod);
let requestParams = '';
if (token.length > 0 && id > 0) {
requestParams = token+'=1&id='+id+'&return_here='+return_here;
}
// Construct URL with parameters for GET request
const urlWithParams = getUrl + '&' + requestParams;
// Using the Fetch API for the GET request
return fetch(urlWithParams, {
method: 'GET',
headers: {
'Content-Type': 'application/json'
}
}).then(response => {
if (!response.ok) {
throw new Error('Network response was not ok');
}
return response.json();
});
}
function getEditCustomCodeButtons() {
// Get the id using pure JavaScript
const id = document.querySelector("#jform_id").value;
getEditCustomCodeButtons_server(id).then(function(result) {
if (typeof result === 'object') {
Object.entries(result).forEach(([field, buttons]) => {
// Creating the div element for buttons
const div = document.createElement('div');
div.className = 'control-group';
div.innerHTML = '<div class="control-label"><label>Add/Edit Customcode</label></div><div class="controls control-customcode-buttons-'+field+'"></div>';
// Insert the div before .control-wrapper-{field}
const insertBeforeElement = document.querySelector(".control-wrapper-"+field);
insertBeforeElement.parentNode.insertBefore(div, insertBeforeElement);
// Adding buttons to the div
Object.entries(buttons).forEach(([name, button]) => {
const controlsDiv = document.querySelector(".control-customcode-buttons-"+field);
controlsDiv.innerHTML += button;
});
});
}
}).catch(error => {
console.error('Error:', error);
});
}