Spade
Mini Shell
| Directory:~$ /home/lmsyaran/public_html/administrator/components/com_moojla/views/modules/ |
| [Home] [System Details] [Kill Me] |
<?php
/*----------------------------------------------------------------------------------|
www.vdm.io |----/
Lmskaran
/-------------------------------------------------------------------------------------------------------/
@version 1.0.77
@build 6th April, 2022
@created 22nd July, 2020
@package Moojla
@subpackage view.html.php
@author Lmskaran <http://Lmskaran.com>
@copyright Copyright (C) 2015. All Rights Reserved
@license GNU/GPL Version 2 or later -
http://www.gnu.org/licenses/gpl-2.0.html
____ _____ _____ __ __ __ __ ___ _____ __ __ ____
_____ _ _ ____ _ _ ____
(_ _)( _ )( _ )( \/ )( ) /__\ / __)( _ )( \/ )( _ \(
_ )( \( )( ___)( \( )(_ _)
.-_)( )(_)( )(_)( ) ( )(__ /(__)\ ( (__ )(_)( ) ( )___/
)(_)( ) ( )__) ) ( )(
\____) (_____)(_____)(_/\/\_)(____)(__)(__) \___)(_____)(_/\/\_)(__)
(_____)(_)\_)(____)(_)\_) (__)
/------------------------------------------------------------------------------------------------------*/
// No direct access to this file
defined('_JEXEC') or die('Restricted access');
/**
* Moojla View class for the Modules
*/
class MoojlaViewModules extends JViewLegacy
{
/**
* Modules view display method
* @return void
*/
function display($tpl = null)
{
if ($this->getLayout() !== 'modal')
{
// Include helper submenu
MoojlaHelper::addSubmenu('modules');
}
// Assign data to the view
$this->items = $this->get('Items');
$this->pagination = $this->get('Pagination');
$this->state = $this->get('State');
$this->user = JFactory::getUser();
// Load the filter form from xml.
$this->filterForm = $this->get('FilterForm');
// Load the active filters.
$this->activeFilters = $this->get('ActiveFilters');
// Add the list ordering clause.
$this->listOrder =
$this->escape($this->state->get('list.ordering',
'a.id'));
$this->listDirn =
$this->escape($this->state->get('list.direction',
'DESC'));
$this->saveOrder = $this->listOrder == 'a.ordering';
// set the return here value
$this->return_here = urlencode(base64_encode((string)
JUri::getInstance()));
// get global action permissions
$this->canDo = MoojlaHelper::getActions('module');
$this->canEdit = $this->canDo->get('core.edit');
$this->canState =
$this->canDo->get('core.edit.state');
$this->canCreate = $this->canDo->get('core.create');
$this->canDelete = $this->canDo->get('core.delete');
$this->canBatch = $this->canDo->get('core.batch');
// We don't need toolbar in the modal window.
if ($this->getLayout() !== 'modal')
{
$this->addToolbar();
$this->sidebar = JHtmlSidebar::render();
// load the batch html
if ($this->canCreate && $this->canEdit &&
$this->canState)
{
$this->batchDisplay = JHtmlBatch_::render();
}
}
// Check for errors.
if (count($errors = $this->get('Errors')))
{
throw new Exception(implode("\n", $errors), 500);
}
// Display the template
parent::display($tpl);
// Set the document
$this->setDocument();
}
/**
* Setting the toolbar
*/
protected function addToolBar()
{
JToolBarHelper::title(JText::_('COM_MOOJLA_MODULES'),
'image');
JHtmlSidebar::setAction('index.php?option=com_moojla&view=modules');
JFormHelper::addFieldPath(JPATH_COMPONENT . '/models/fields');
if ($this->canCreate)
{
JToolBarHelper::addNew('module.add');
}
// Only load if there are items
if (MoojlaHelper::checkArray($this->items))
{
if ($this->canEdit)
{
JToolBarHelper::editList('module.edit');
}
if ($this->canState)
{
JToolBarHelper::publishList('modules.publish');
JToolBarHelper::unpublishList('modules.unpublish');
JToolBarHelper::archiveList('modules.archive');
if ($this->canDo->get('core.admin'))
{
JToolBarHelper::checkin('modules.checkin');
}
}
// Add a batch button
if ($this->canBatch && $this->canCreate &&
$this->canEdit && $this->canState)
{
// Get the toolbar object instance
$bar = JToolBar::getInstance('toolbar');
// set the batch button name
$title = JText::_('JTOOLBAR_BATCH');
// Instantiate a new JLayoutFile instance and render the batch button
$layout = new JLayoutFile('joomla.toolbar.batch');
// add the button to the page
$dhtml = $layout->render(array('title' => $title));
$bar->appendButton('Custom', $dhtml, 'batch');
}
if ($this->state->get('filter.published') == -2
&& ($this->canState && $this->canDelete))
{
JToolbarHelper::deleteList('', 'modules.delete',
'JTOOLBAR_EMPTY_TRASH');
}
elseif ($this->canState && $this->canDelete)
{
JToolbarHelper::trash('modules.trash');
}
}
// set help url for this view if found
$help_url = MoojlaHelper::getHelpUrl('modules');
if (MoojlaHelper::checkString($help_url))
{
JToolbarHelper::help('COM_MOOJLA_HELP_MANAGER', false,
$help_url);
}
// add the options comp button
if ($this->canDo->get('core.admin') ||
$this->canDo->get('core.options'))
{
JToolBarHelper::preferences('com_moojla');
}
// Only load published batch if state and batch is allowed
if ($this->canState && $this->canBatch)
{
JHtmlBatch_::addListSelection(
JText::_('COM_MOOJLA_KEEP_ORIGINAL_STATE'),
'batch[published]',
JHtml::_('select.options',
JHtml::_('jgrid.publishedOptions', array('all' =>
false)), 'value', 'text', '', true)
);
}
// Only load Module Section Id batch if create, edit, and batch is
allowed
if ($this->canBatch && $this->canCreate &&
$this->canEdit)
{
// Set Module Section Id Selection
$this->module_section_idOptions =
JFormHelper::loadFieldType('modulesfiltermodulesectionid')->options;
// We do some sanitation for Module Section Id filter
if (MoojlaHelper::checkArray($this->module_section_idOptions)
&&
isset($this->module_section_idOptions[0]->value) &&
!MoojlaHelper::checkString($this->module_section_idOptions[0]->value))
{
unset($this->module_section_idOptions[0]);
}
// Module Section Id Batch Selection
JHtmlBatch_::addListSelection(
'- Keep Original
'.JText::_('COM_MOOJLA_MODULE_MODULE_SECTION_ID_LABEL').'
-',
'batch[module_section_id]',
JHtml::_('select.options',
$this->module_section_idOptions, 'value', 'text')
);
}
// Only load Modname batch if create, edit, and batch is allowed
if ($this->canBatch && $this->canCreate &&
$this->canEdit)
{
// Set Modname Selection
$this->modnameOptions =
JFormHelper::loadFieldType('modulesfiltermodname')->options;
// We do some sanitation for Modname filter
if (MoojlaHelper::checkArray($this->modnameOptions) &&
isset($this->modnameOptions[0]->value) &&
!MoojlaHelper::checkString($this->modnameOptions[0]->value))
{
unset($this->modnameOptions[0]);
}
// Modname Batch Selection
JHtmlBatch_::addListSelection(
'- Keep Original
'.JText::_('COM_MOOJLA_MODULE_MODNAME_LABEL').'
-',
'batch[modname]',
JHtml::_('select.options', $this->modnameOptions,
'value', 'text')
);
}
}
/**
* Method to set up the document properties
*
* @return void
*/
protected function setDocument()
{
if (!isset($this->document))
{
$this->document = JFactory::getDocument();
}
$this->document->setTitle(JText::_('COM_MOOJLA_MODULES'));
$this->document->addStyleSheet(JURI::root() .
"administrator/components/com_moojla/assets/css/modules.css",
(MoojlaHelper::jVersion()->isCompatible('3.8.0')) ?
array('version' => 'auto') : 'text/css');
}
/**
* Escapes a value for output in a view script.
*
* @param mixed $var The output to escape.
*
* @return mixed The escaped value.
*/
public function escape($var)
{
if(strlen($var) > 50)
{
// use the helper htmlEscape method instead and shorten the string
return MoojlaHelper::htmlEscape($var, $this->_charset, true);
}
// use the helper htmlEscape method instead.
return MoojlaHelper::htmlEscape($var, $this->_charset);
}
/**
* Returns an array of fields the table can be sorted by
*
* @return array Array containing the field name to sort by as the key
and display text as value
*/
protected function getSortFields()
{
return array(
'a.ordering' =>
JText::_('JGRID_HEADING_ORDERING'),
'a.published' => JText::_('JSTATUS'),
'a.module_section_id' =>
JText::_('COM_MOOJLA_MODULE_MODULE_SECTION_ID_LABEL'),
'a.name' =>
JText::_('COM_MOOJLA_MODULE_NAME_LABEL'),
'a.id' => JText::_('JGRID_HEADING_ID')
);
}
}