/** * Compiles information to add or edit a module * @param string The current GET/POST option * @param integer The unique id of the record to edit */ function edit() { // Initialize some variables $db =& JFactory::getDBO(); $user =& JFactory::getUser(); $client =& JApplicationHelper::getClientInfo(JRequest::getVar('client', '0', '', 'int')); $module = JRequest::getVar('module', '', '', 'cmd'); $id = JRequest::getVar('id', 0, 'method', 'int'); $cid = JRequest::getVar('cid', array($id), 'method', 'array'); JArrayHelper::toInteger($cid, array(0)); $model =& $this->getModel('module'); $model->setState('id', $cid['0']); $model->setState('clientId', $client->id); $lists = array(); $row =& JTable::getInstance('module'); // load the row from the db table $row->load((int) $cid['0']); // fail if checked out not by 'me' if ($row->isCheckedOut($user->get('id'))) { $this->setRedirect('index.php?option=com_advancedmodules&client=' . $client->id); return JError::raiseWarning(500, JText::sprintf('DESCBEINGEDITTED', JText::_('The module'), $row->title)); } $row->content = htmlspecialchars($row->content, ENT_COMPAT, 'UTF-8'); if ($cid['0']) { $row->checkout($user->get('id')); } // if a new record we must still prime the JTableModel object with a default // position and the order; also add an extra item to the order list to // place the 'new' record in last position if desired if ($cid['0'] == 0) { $row->position = 'left'; $row->showtitle = true; $row->published = 1; //$row->ordering = $l; $row->module = $module; } if ($client->id == 1) { $where = 'client_id = 1'; $lists['client_id'] = 1; $path = 'mod1_xml'; } else { $where = 'client_id = 0'; $lists['client_id'] = 0; $path = 'mod0_xml'; } $query = 'SELECT position, ordering, showtitle, title' . ' FROM #__modules' . ' WHERE ' . $where . ' ORDER BY ordering'; $db->setQuery($query); $orders = $db->loadObjectList(); if ($db->getErrorNum()) { echo $db->stderr(); return false; } $orders2 = array(); $l = 0; $r = 0; for ($i = 0, $n = count($orders); $i < $n; $i++) { $ord = 0; if (array_key_exists($orders[$i]->position, $orders2)) { $ord = count(array_keys($orders2[$orders[$i]->position])) + 1; } $orders2[$orders[$i]->position][] = JHTML::_('select.option', $ord, $ord . '::' . htmlspecialchars($orders[$i]->title)); } $color = 'FFFFFF'; if ($client->id != 1) { $parameters =& NNParameters::getParameters(); $config = JComponentHelper::getParams('com_advancedmodules'); $config = $parameters->getParams($config->_raw, JPATH_ADMINISTRATOR . DS . 'components' . DS . 'com_advancedmodules' . DS . 'config.xml'); $advanced_params = new stdClass(); $xmlfile = JPATH_ADMINISTRATOR . DS . 'components' . DS . 'com_advancedmodules' . DS . 'assignments.xml'; if (!$cid['0']) { $lists['assignments'] = new JParameter('', $xmlfile); // hide if empty $lists['hideempty'] = JHTML::_('select.booleanlist', 'advancedparams[hideempty]', 'class="inputbox"', 0, 'yes', 'no', 'advancedparamshideempty'); // tooltip $lists['tooltip'] = '<textarea class="text_area" rows="3" cols="40" name="advancedparams[tooltip]" id="advancedparamstooltip"></textarea>'; } else { // advanced params $query = 'SELECT params' . ' FROM #__advancedmodules' . ' WHERE moduleid = ' . (int) $row->id; $db->setQuery($query); $advanced_params = $db->loadResult(); if (!$advanced_params || strpos($advanced_params, 'assignto_') === false) { $advanced_params = $this->updateParams($row->id, $advanced_params); } $lists['assignments'] = new JParameter($advanced_params, $xmlfile); $advanced_params = $parameters->getParams($advanced_params); // hide if empty $lists['hideempty'] = JHTML::_('select.booleanlist', 'advancedparams[hideempty]', 'class="inputbox"', isset($advanced_params->hideempty) ? $advanced_params->hideempty : 0, 'yes', 'no', 'advancedparamshideempty'); // tooltip $lists['tooltip'] = '<textarea class="text_area" rows="3" cols="40" name="advancedparams[tooltip]" id="advancedparamstooltip">' . (isset($advanced_params->tooltip) ? $advanced_params->tooltip : '') . '</textarea>'; if (isset($advanced_params->color)) { $color = strtoupper(preg_replace('#[^a-z0-9]#si', '', $advanced_params->color)); } } require_once JPATH_SITE . DS . 'plugins' . DS . 'system' . DS . 'nonumberelements' . DS . 'elements' . DS . 'colorpicker.php'; $cp = new JElementColorPicker(); $node = new JSimpleXMLElement(''); $lists['color'] = $cp->fetchElement('color', $color, $node, 'advancedparams'); $lists['extra'] = ''; if ($config->show_extra) { if ($config->extra1) { $xml = new JSimpleXMLElement('extra', array()); $extraparams = array(); for ($i = 1; $i <= 5; $i++) { $var = 'extra' . $i; if ($config->{$var}) { $a = array(); $a['name'] = $var; $a['type'] = 'text'; $label = explode('\\|', $config->{$var}, 2); $a['label'] = $label['0']; if (isset($label['1'])) { $a['description'] = $label['1']; } $xml->addChild('extra1', $a); } if (isset($advanced_params->{$var})) { $extraparams[] = $var . '=' . $advanced_params->{$var}; } } $p = new JParameter(implode("\n", $extraparams)); $p->setXML($xml); if ($p->getNumParams()) { $lists['extra'] = $p->render('advancedparams'); } } } } if ($row->access == 99 || $row->client_id == 1 || $lists['client_id']) { $lists['access'] = 'Administrator'; $lists['showtitle'] = 'N/A <input type="hidden" name="showtitle" value="1" />'; $lists['selections'] = 'N/A'; } else { if ($client->id == '1') { $lists['access'] = 'N/A'; } else { $lists['access'] = JHTML::_('list.accesslevel', $row); } $lists['showtitle'] = JHTML::_('select.booleanlist', 'showtitle', 'class="inputbox"', $row->showtitle); } // build the html select list for published $lists['published'] = JHTML::_('select.booleanlist', 'published', 'class="inputbox"', $row->published); $row->description = ''; $lang =& JFactory::getLanguage(); if ($client->id != '1') { $lang->load(trim($row->module), JPATH_SITE); } else { $lang->load(trim($row->module)); } // xml file for module if ($row->module == 'custom') { $xmlfile = JApplicationHelper::getPath($path, 'mod_custom'); } else { $xmlfile = JApplicationHelper::getPath($path, $row->module); } $data = JApplicationHelper::parseXMLInstallFile($xmlfile); if ($data) { foreach ($data as $key => $value) { $row->{$key} = $value; } } // get params definitions $params = new JParameter($row->params, $xmlfile, 'module'); require_once JApplicationHelper::getPath('admin_html'); HTML_modules::edit($model, $row, $orders2, $lists, $params, $client); }
/** * Compiles information to add or edit a module * @param string The current GET/POST option * @param integer The unique id of the record to edit */ function edit() { // Initialize some variables $db =& JFactory::getDBO(); $user =& JFactory::getUser(); $client =& JApplicationHelper::getClientInfo(JRequest::getVar('client', '0', '', 'int')); $module = JRequest::getVar('module', '', '', 'cmd'); $id = JRequest::getVar('id', 0, 'method', 'int'); $cid = JRequest::getVar('cid', array($id), 'method', 'array'); JArrayHelper::toInteger($cid, array(0)); $model =& $this->getModel('module'); $model->setState('id', $cid[0]); $model->setState('clientId', $client->id); $lists = array(); $row =& JTable::getInstance('module'); // load the row from the db table $row->load((int) $cid[0]); // fail if checked out not by 'me' if ($row->isCheckedOut($user->get('id'))) { $this->setRedirect('index.php?option=com_modules&client=' . $client->id); return JError::raiseWarning(500, JText::sprintf('DESCBEINGEDITTED', JText::_('The module'), $row->title)); } $row->content = htmlspecialchars($row->content, ENT_COMPAT, 'UTF-8'); if ($cid[0]) { $row->checkout($user->get('id')); } // if a new record we must still prime the JTableModel object with a default // position and the order; also add an extra item to the order list to // place the 'new' record in last position if desired if ($cid[0] == 0) { $row->position = 'left'; $row->showtitle = true; $row->published = 1; //$row->ordering = $l; $row->module = $module; } if ($client->id == 1) { $where = 'client_id = 1'; $lists['client_id'] = 1; $path = 'mod1_xml'; } else { $where = 'client_id = 0'; $lists['client_id'] = 0; $path = 'mod0_xml'; } $query = 'SELECT position, ordering, showtitle, title' . ' FROM #__modules' . ' WHERE ' . $where . ' ORDER BY ordering'; $db->setQuery($query); $orders = $db->loadObjectList(); if ($db->getErrorNum()) { echo $db->stderr(); return false; } $orders2 = array(); $l = 0; $r = 0; for ($i = 0, $n = count($orders); $i < $n; $i++) { $ord = 0; if (array_key_exists($orders[$i]->position, $orders2)) { $ord = count(array_keys($orders2[$orders[$i]->position])) + 1; } $orders2[$orders[$i]->position][] = JHTML::_('select.option', $ord, $ord . '::' . addslashes($orders[$i]->title)); } // get selected pages for $lists['selections'] if ($cid[0]) { $query = 'SELECT menuid AS value' . ' FROM #__modules_menu' . ' WHERE moduleid = ' . (int) $row->id; $db->setQuery($query); $lookup = $db->loadObjectList(); if (empty($lookup)) { $lookup = array(JHTML::_('select.option', '-1')); $row->pages = 'none'; } elseif (count($lookup) == 1 && $lookup[0]->value == 0) { $row->pages = 'all'; } else { $row->pages = null; } } else { $lookup = array(JHTML::_('select.option', 0, JText::_('All'))); $row->pages = 'all'; } if ($row->access == 99 || $row->client_id == 1 || $lists['client_id']) { $lists['access'] = 'Administrator'; $lists['showtitle'] = 'N/A <input type="hidden" name="showtitle" value="1" />'; $lists['selections'] = 'N/A'; } else { if ($client->id == '1') { $lists['access'] = 'N/A'; $lists['selections'] = 'N/A'; } else { $lists['access'] = JHTML::_('list.accesslevel', $row); $selections = JHTML::_('menu.linkoptions'); $lists['selections'] = JHTML::_('select.genericlist', $selections, 'selections[]', 'class="inputbox" size="15" multiple="multiple"', 'value', 'text', $lookup, 'selections'); } $lists['showtitle'] = JHTML::_('select.booleanlist', 'showtitle', 'class="inputbox"', $row->showtitle); } // build the html select list for published $lists['published'] = JHTML::_('select.booleanlist', 'published', 'class="inputbox"', $row->published); $row->description = ''; $lang =& JFactory::getLanguage(); if ($client->id != '1') { $lang->load(trim($row->module), JPATH_SITE); } else { $lang->load(trim($row->module)); } // xml file for module if ($row->module == 'custom') { $xmlfile = JApplicationHelper::getPath($path, 'mod_custom'); } else { $xmlfile = JApplicationHelper::getPath($path, $row->module); } $data = JApplicationHelper::parseXMLInstallFile($xmlfile); if ($data) { foreach ($data as $key => $value) { $row->{$key} = $value; } } // get params definitions $params = new JParameter($row->params, $xmlfile, 'module'); require_once JApplicationHelper::getPath('admin_html'); HTML_modules::edit($model, $row, $orders2, $lists, $params, $client); }