<?php /** * @package Joomla.Component.Builder * * @created 30th April, 2015 * @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 */ use Joomla\CMS\Factory; use Joomla\CMS\Language\Text; use Joomla\CMS\HTML\HTMLHelper as Html; use Joomla\CMS\Layout\LayoutHelper; use Joomla\CMS\Router\Route; use VDM\Component\Componentbuilder\Administrator\Helper\ComponentbuilderHelper; /** @var Joomla\CMS\WebAsset\WebAssetManager $wa */ $wa = $this->getDocument()->getWebAssetManager(); $wa->useScript('keepalive')->useScript('form.validate'); Html::_('bootstrap.tooltip'); // No direct access to this file defined('_JEXEC') or die; ?> <script type="text/javascript"> // waiting spinner var outerDiv = document.querySelector('body'); var loadingDiv = document.createElement('div'); loadingDiv.id = 'loading'; loadingDiv.style.cssText = "background: rgba(255, 255, 255, .8) url('components/com_componentbuilder/assets/images/import.gif') 50% 15% no-repeat; top: " + (outerDiv.getBoundingClientRect().top + window.pageYOffset) + "px; left: " + (outerDiv.getBoundingClientRect().left + window.pageXOffset) + "px; width: " + outerDiv.offsetWidth + "px; height: " + outerDiv.offsetHeight + "px; position: fixed; opacity: 0.80; -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80); filter: alpha(opacity=80); display: none;"; outerDiv.appendChild(loadingDiv); loadingDiv.style.display = 'block'; // when page is ready remove and show window.addEventListener('load', function() { var componentLoader = document.getElementById('componentbuilder_loader'); if (componentLoader) componentLoader.style.display = 'block'; loadingDiv.style.display = 'none'; }); </script> <div id="componentbuilder_loader" style="display: none;"> <form action="<?php echo Route::_('index.php?option=com_componentbuilder&layout=edit&id='. (int) $this->item->id . $this->referral); ?>" method="post" name="adminForm" id="adminForm" class="form-validate" enctype="multipart/form-data"> <?php echo LayoutHelper::render('custom_admin_view.details_above', $this); ?> <div class="main-card"> <div class="row"> <div class="col-md-9"> <?php echo Html::_('uitab.startTabSet', 'custom_admin_viewTab', ['active' => 'details', 'recall' => true]); ?> <?php echo Html::_('uitab.addTab', 'custom_admin_viewTab', 'details', Text::_('COM_COMPONENTBUILDER_CUSTOM_ADMIN_VIEW_DETAILS', true)); ?> <div class="row"> <div class="col-md-6"> <?php echo LayoutHelper::render('custom_admin_view.details_left', $this); ?> </div> <div class="col-md-6"> <?php echo LayoutHelper::render('custom_admin_view.details_right', $this); ?> </div> </div> <div class="row"> <div class="col-md-12"> <?php echo LayoutHelper::render('custom_admin_view.details_fullwidth', $this); ?> </div> </div> <?php echo Html::_('uitab.endTab'); ?> <?php echo Html::_('uitab.addTab', 'custom_admin_viewTab', 'custom_buttons', Text::_('COM_COMPONENTBUILDER_CUSTOM_ADMIN_VIEW_CUSTOM_BUTTONS', true)); ?> <div class="row"> <div class="col-md-12"> <?php echo LayoutHelper::render('custom_admin_view.custom_buttons_left', $this); ?> </div> </div> <div class="row"> <div class="col-md-12"> <?php echo LayoutHelper::render('custom_admin_view.custom_buttons_fullwidth', $this); ?> </div> </div> <?php echo Html::_('uitab.endTab'); ?> <?php echo Html::_('uitab.addTab', 'custom_admin_viewTab', 'javascript_css', Text::_('COM_COMPONENTBUILDER_CUSTOM_ADMIN_VIEW_JAVASCRIPT_CSS', true)); ?> <div class="row"> </div> <div class="row"> <div class="col-md-12"> <?php echo LayoutHelper::render('custom_admin_view.javascript_css_fullwidth', $this); ?> </div> </div> <?php echo Html::_('uitab.endTab'); ?> <?php echo Html::_('uitab.addTab', 'custom_admin_viewTab', 'php', Text::_('COM_COMPONENTBUILDER_CUSTOM_ADMIN_VIEW_PHP', true)); ?> <div class="row"> </div> <div class="row"> <div class="col-md-12"> <?php echo LayoutHelper::render('custom_admin_view.php_fullwidth', $this); ?> </div> </div> <?php echo Html::_('uitab.endTab'); ?> <?php echo Html::_('uitab.addTab', 'custom_admin_viewTab', 'linked_components', Text::_('COM_COMPONENTBUILDER_CUSTOM_ADMIN_VIEW_LINKED_COMPONENTS', true)); ?> <div class="row"> </div> <div class="row"> <div class="col-md-12"> <?php echo LayoutHelper::render('custom_admin_view.linked_components_fullwidth', $this); ?> </div> </div> <?php echo Html::_('uitab.endTab'); ?> <?php $this->ignore_fieldsets = array('details','metadata','vdmmetadata','accesscontrol'); ?> <?php $this->tab_name = 'custom_admin_viewTab'; ?> <?php echo LayoutHelper::render('joomla.edit.params', $this); ?> <?php if ($this->canDo->get('core.edit.created_by') || $this->canDo->get('core.edit.created') || $this->canDo->get('core.edit.state') || ($this->canDo->get('core.delete') && $this->canDo->get('core.edit.state'))) : ?> <?php echo Html::_('uitab.addTab', 'custom_admin_viewTab', 'publishing', Text::_('COM_COMPONENTBUILDER_CUSTOM_ADMIN_VIEW_PUBLISHING', true)); ?> <div class="row"> <div class="col-md-6"> <?php echo LayoutHelper::render('custom_admin_view.publishing', $this); ?> </div> <div class="col-md-6"> <?php echo LayoutHelper::render('custom_admin_view.publlshing', $this); ?> </div> </div> <?php echo Html::_('uitab.endTab'); ?> <?php endif; ?> <?php if ($this->canDo->get('core.admin')) : ?> <?php echo Html::_('uitab.addTab', 'custom_admin_viewTab', 'permissions', Text::_('COM_COMPONENTBUILDER_CUSTOM_ADMIN_VIEW_PERMISSION', true)); ?> <div class="row"> <div class="col-md-12"> <fieldset class="adminform"> <div class="adminformlist"> <?php foreach ($this->form->getFieldset('accesscontrol') as $field): ?> <div> <?php echo $field->label; echo $field->input;?> </div> <div class="clearfix"></div> <?php endforeach; ?> </div> </fieldset> </div> </div> <?php echo Html::_('uitab.endTab'); ?> <?php endif; ?> <?php echo Html::_('uitab.endTabSet'); ?> <div> <input type="hidden" name="task" value="custom_admin_view.edit" /> <?php echo Html::_('form.token'); ?> </div> </div> <div class="col-md-3"><div class="m-md-3"> <?php echo LayoutHelper::render('custom_admin_view.details_rightside', $this); ?> </div></div> </div> </div> <div class="clearfix"></div> <?php echo LayoutHelper::render('custom_admin_view.details_under', $this); ?> </form> </div> <script type="text/javascript"> // #jform_add_php_view listeners for add_php_view_vvvvwae function jQuery('#jform_add_php_view').on('keyup',function() { var add_php_view_vvvvwae = jQuery("#jform_add_php_view input[type='radio']:checked").val(); vvvvwae(add_php_view_vvvvwae); }); jQuery('#adminForm').on('change', '#jform_add_php_view',function (e) { e.preventDefault(); var add_php_view_vvvvwae = jQuery("#jform_add_php_view input[type='radio']:checked").val(); vvvvwae(add_php_view_vvvvwae); }); // #jform_add_php_jview_display listeners for add_php_jview_display_vvvvwaf function jQuery('#jform_add_php_jview_display').on('keyup',function() { var add_php_jview_display_vvvvwaf = jQuery("#jform_add_php_jview_display input[type='radio']:checked").val(); vvvvwaf(add_php_jview_display_vvvvwaf); }); jQuery('#adminForm').on('change', '#jform_add_php_jview_display',function (e) { e.preventDefault(); var add_php_jview_display_vvvvwaf = jQuery("#jform_add_php_jview_display input[type='radio']:checked").val(); vvvvwaf(add_php_jview_display_vvvvwaf); }); // #jform_add_php_jview listeners for add_php_jview_vvvvwag function jQuery('#jform_add_php_jview').on('keyup',function() { var add_php_jview_vvvvwag = jQuery("#jform_add_php_jview input[type='radio']:checked").val(); vvvvwag(add_php_jview_vvvvwag); }); jQuery('#adminForm').on('change', '#jform_add_php_jview',function (e) { e.preventDefault(); var add_php_jview_vvvvwag = jQuery("#jform_add_php_jview input[type='radio']:checked").val(); vvvvwag(add_php_jview_vvvvwag); }); // #jform_add_php_document listeners for add_php_document_vvvvwah function jQuery('#jform_add_php_document').on('keyup',function() { var add_php_document_vvvvwah = jQuery("#jform_add_php_document input[type='radio']:checked").val(); vvvvwah(add_php_document_vvvvwah); }); jQuery('#adminForm').on('change', '#jform_add_php_document',function (e) { e.preventDefault(); var add_php_document_vvvvwah = jQuery("#jform_add_php_document input[type='radio']:checked").val(); vvvvwah(add_php_document_vvvvwah); }); // #jform_add_css_document listeners for add_css_document_vvvvwai function jQuery('#jform_add_css_document').on('keyup',function() { var add_css_document_vvvvwai = jQuery("#jform_add_css_document input[type='radio']:checked").val(); vvvvwai(add_css_document_vvvvwai); }); jQuery('#adminForm').on('change', '#jform_add_css_document',function (e) { e.preventDefault(); var add_css_document_vvvvwai = jQuery("#jform_add_css_document input[type='radio']:checked").val(); vvvvwai(add_css_document_vvvvwai); }); // #jform_add_javascript_file listeners for add_javascript_file_vvvvwaj function jQuery('#jform_add_javascript_file').on('keyup',function() { var add_javascript_file_vvvvwaj = jQuery("#jform_add_javascript_file input[type='radio']:checked").val(); vvvvwaj(add_javascript_file_vvvvwaj); }); jQuery('#adminForm').on('change', '#jform_add_javascript_file',function (e) { e.preventDefault(); var add_javascript_file_vvvvwaj = jQuery("#jform_add_javascript_file input[type='radio']:checked").val(); vvvvwaj(add_javascript_file_vvvvwaj); }); // #jform_add_js_document listeners for add_js_document_vvvvwak function jQuery('#jform_add_js_document').on('keyup',function() { var add_js_document_vvvvwak = jQuery("#jform_add_js_document input[type='radio']:checked").val(); vvvvwak(add_js_document_vvvvwak); }); jQuery('#adminForm').on('change', '#jform_add_js_document',function (e) { e.preventDefault(); var add_js_document_vvvvwak = jQuery("#jform_add_js_document input[type='radio']:checked").val(); vvvvwak(add_js_document_vvvvwak); }); // #jform_add_custom_button listeners for add_custom_button_vvvvwal function jQuery('#jform_add_custom_button').on('keyup',function() { var add_custom_button_vvvvwal = jQuery("#jform_add_custom_button input[type='radio']:checked").val(); vvvvwal(add_custom_button_vvvvwal); }); jQuery('#adminForm').on('change', '#jform_add_custom_button',function (e) { e.preventDefault(); var add_custom_button_vvvvwal = jQuery("#jform_add_custom_button input[type='radio']:checked").val(); vvvvwal(add_custom_button_vvvvwal); }); // #jform_add_css listeners for add_css_vvvvwam function jQuery('#jform_add_css').on('keyup',function() { var add_css_vvvvwam = jQuery("#jform_add_css input[type='radio']:checked").val(); vvvvwam(add_css_vvvvwam); }); jQuery('#adminForm').on('change', '#jform_add_css',function (e) { e.preventDefault(); var add_css_vvvvwam = jQuery("#jform_add_css input[type='radio']:checked").val(); vvvvwam(add_css_vvvvwam); }); // #jform_add_php_ajax listeners for add_php_ajax_vvvvwan function jQuery('#jform_add_php_ajax').on('keyup',function() { var add_php_ajax_vvvvwan = jQuery("#jform_add_php_ajax input[type='radio']:checked").val(); vvvvwan(add_php_ajax_vvvvwan); }); jQuery('#adminForm').on('change', '#jform_add_php_ajax',function (e) { e.preventDefault(); var add_php_ajax_vvvvwan = jQuery("#jform_add_php_ajax input[type='radio']:checked").val(); vvvvwan(add_php_ajax_vvvvwan); }); jQuery(function() { jQuery('#open-libraries').html('<a href="index.php?option=com_componentbuilder&view=libraries"><?php echo JText::_('COM_COMPONENTBUILDER_LIBRARIES'); ?></a>'); }); jQuery('#jform_snippet').closest('.input-append').addClass('jform_snippet_input_width'); jQuery('#jform_main_get').closest('.input-append').addClass('jform_main_get_input_width'); jQuery('#jform_dynamic_get').closest('.input-append').addClass('jform_dynamic_get_input_width'); jQuery(function() { jQuery("code").click(function() { jQuery(this).selText().addClass("selected"); }); }); jQuery('#adminForm').on('change', '#jform_libraries',function (e) { e.preventDefault(); getSnippets(); }); jQuery.fn.selText = function() { var obj = this[0]; if (jQuery.browser.msie) { var range = obj.offsetParent.createTextRange(); range.moveToElementText(obj); range.select(); } else if (jQuery.browser.mozilla || $.browser.opera) { var selection = obj.ownerDocument.defaultView.getSelection(); var range = obj.ownerDocument.createRange(); range.selectNodeContents(obj); selection.removeAllRanges(); selection.addRange(range); } else if (jQuery.browser.safari) { var selection = obj.ownerDocument.defaultView.getSelection(); selection.setBaseAndExtent(obj, 0, obj, 1); } return this; } jQuery('#adminForm').on('change', '#jform_snippet',function (e) { e.preventDefault(); // get type value var snippetId = jQuery("#jform_snippet option:selected").val(); getSnippetDetails(snippetId); }); jQuery(document).ready(function() { // get type value var snippetId = jQuery("#jform_snippet option:selected").val(); getSnippetDetails(snippetId); }); jQuery('#adminForm').on('change', '#jform_dynamic_get',function (e) { e.preventDefault(); // get type value var dynamicId = jQuery("#jform_dynamic_get option:selected").val(); getDynamicValues(dynamicId); }); jQuery(document).ready(function() { // get type value var dynamicId = jQuery("#jform_dynamic_get option:selected").val(); getDynamicValues(dynamicId); }); jQuery(document).ready(function() { // get type value getLayoutDetails(9999); getTemplateDetails(9999); }); // some lang strings var select_a_snippet = '<?php echo Text::_('COM_COMPONENTBUILDER_SELECT_A_SNIPPET'); ?>'; var create_a_snippet = '<?php echo Text::_('COM_COMPONENTBUILDER_CREATE_A_SNIPPET'); ?>'; document.addEventListener("DOMContentLoaded", function() { document.querySelectorAll(".loading-dots").forEach(function(loading_dots) { let x = 0; let intervalId = setInterval(function() { if (!loading_dots.classList.contains("loading-dots")) { clearInterval(intervalId); return; } let dots = ".".repeat(x % 8); loading_dots.textContent = dots; x++; }, 500); }); }); <?php $app = Factory::getApplication(); ?> function JRouter(link) { <?php if ($app->isClient('site')) { echo 'var url = "'. \Joomla\CMS\Uri\Uri::root() . '";'; } else { echo 'var url = "";'; } ?> return url+link; } jQuery(document).ready(function(){ jQuery(document).on('subform-row-add', function(event, row){ getIconImage(jQuery(row).find('.icomoon342')); }); }); function getIconImage(field) { // get the ID var id = jQuery(field).attr('id'); // remove old one jQuery('#image_'+id).remove(); // get value var value = jQuery('#'+id).val(); // build new one var span = '<span id="image_'+id+'" class="icon-'+value+'" style="position: absolute; top: 8px; right: -20px;"></span>'; // add the icon jQuery('#'+id+'_chzn').append(span); } </script>