📄 admin.modules.php
字号:
$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"
. "\n FROM #__modules"
. "\n WHERE ". $where
. "\n ORDER BY ordering"
;
$database->setQuery( $query );
if ( !($orders = $database->loadObjectList()) ) {
echo $database->stderr();
return false;
}
$query = "SELECT position, description"
. "\n FROM #__template_positions"
. "\n WHERE position <> ''"
;
$database->setQuery( $query );
// hard code options for now
$positions = $database->loadObjectList();
$orders2 = array();
$pos = array();
foreach ($positions as $position) {
$orders2[$position->position] = array();
$pos[] = mosHTML::makeOption( $position->position, $position->description );
}
$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][] = mosHTML::makeOption( $ord, $ord.'::'.addslashes( $orders[$i]->title ) );
}
// build the html select list
$pos_select = 'onchange="changeDynaList(\'ordering\',orders,document.adminForm.position.options[document.adminForm.position.selectedIndex].value, originalPos, originalOrder)"';
$active = ( $row->position ? $row->position : 'left' );
$lists['position'] = mosHTML::selectList( $pos, 'position', 'class="inputbox" size="1" '. $pos_select, 'value', 'text', $active );
// get selected pages for $lists['selections']
if ( $uid ) {
$query = 'SELECT menuid AS value FROM #__modules_menu WHERE moduleid='. $row->id;
$database->setQuery( $query );
$lookup = $database->loadObjectList();
} else {
$lookup = array( mosHTML::makeOption( 0, 'All' ) );
}
if ( $row->access == 99 || $row->client_id == 1 || $lists['client_id'] ) {
$lists['access'] = 'Administrator<input type="hidden" name="access" value="99" />';
$lists['showtitle'] = 'N/A <input type="hidden" name="showtitle" value="1" />';
$lists['selections'] = 'N/A';
} else {
if ( $client == 'admin' ) {
$lists['access'] = 'N/A';
$lists['selections'] = 'N/A';
} else {
$lists['access'] = mosAdminMenus::Access( $row );
$lists['selections'] = mosAdminMenus::MenuLinks( $lookup, 1, 1 );
}
$lists['showtitle'] = mosHTML::yesnoRadioList( 'showtitle', 'class="inputbox"', $row->showtitle );
}
// build the html select list for published
$lists['published'] = mosAdminMenus::Published( $row );
$row->description = '';
// XML library
require_once( $mosConfig_absolute_path . '/includes/domit/xml_domit_lite_include.php' );
// xml file for module
$xmlfile = $mainframe->getPath( $path, $row->module );
$xmlDoc =& new DOMIT_Lite_Document();
$xmlDoc->resolveErrors( true );
if ($xmlDoc->loadXML( $xmlfile, false, true )) {
$element = &$xmlDoc->documentElement;
if ($element->getTagName() == 'mosinstall' && $element->getAttribute( 'type' ) == 'module' ) {
$element = &$xmlDoc->getElementsByPath( 'description', 1 );
$row->description = $element ? trim( $element->getText() ) : '';
}
}
// get params definitions
$params =& new mosParameters( $row->params, $xmlfile, 'module' );
HTML_modules::editModule( $row, $orders2, $lists, $params, $option );
}
/**
* Deletes one or more modules
*
* Also deletes associated entries in the #__module_menu table.
* @param array An array of unique category id numbers
*/
function removeModule( &$cid, $option, $client ) {
global $database, $my, $adminLanguage;
if (count( $cid ) < 1) {
echo "<script> alert(\"". $adminLanguage->A_COMP_MAMB_DEL ."\"); window.history.go(-1);</script>\n";
exit;
}
$cids = implode( ',', $cid );
$database->setQuery( "SELECT id, module, title, iscore, params FROM #__modules WHERE id IN ($cids)" );
if (!($rows = $database->loadObjectList())) {
echo "<script> alert('".$database->getErrorMsg()."'); window.history.go(-1); </script>\n";
exit;
}
$err = array();
$cid = array();
foreach ($rows as $row) {
if ($row->module == '' || $row->iscore == 0) {
$cid[] = $row->id;
} else {
$err[] = $row->title;
}
// mod_mainmenu modules only deletable via Menu Manager
if ( $row->module == 'mod_mainmenu' ) {
if ( strstr( $row->params, 'mainmenu' ) ) {
echo "<script> alert(\"". $adminLanguage->A_COMP_MOD_SAVED_MOD ."\"); window.history.go(-1); </script>\n";
exit;
}
}
}
if (count( $cid )) {
$cids = implode( ',', $cid );
$database->setQuery( "DELETE FROM #__modules WHERE id IN ($cids)" );
if (!$database->query()) {
echo "<script> alert('".$database->getErrorMsg()."'); window.history.go(-1); </script>\n";
exit;
}
$database->setQuery( "DELETE from #__modules_menu WHERE moduleid IN ($cids)" );
if (!$database->query()) {
echo "<script> alert('".$database->getErrorMsg()."');</script>\n";
exit;
}
$mod = new mosModule( $database );
$mod->ordering = 0;
$mod->updateOrder( "position='left'" );
$mod->updateOrder( "position='right'" );
}
if (count( $err )) {
$cids = addslashes( implode( "', '", $err ) );
echo "<script>alert(\"". $adminLanguage->A_COMP_MOD_MODULES .": '". $cids ."' ". $adminLanguage->A_COMP_MOD_CANNOT ."\");</script>\n";
}
mosRedirect( 'index2.php?option='. $option .'&client='. $client );
}
/**
* Publishes or Unpublishes one or more modules
* @param array An array of unique record id numbers
* @param integer 0 if unpublishing, 1 if publishing
*/
function publishModule( $cid=null, $publish=1, $option, $client ) {
global $database, $my, $adminLanguage;
if (count( $cid ) < 1) {
$action = $publish ? 'publish' : 'unpublish';
echo "<script> alert(\"". $adminLanguage->A_COMP_MOD_SELECT_TO ." ". $action ."\"); window.history.go(-1);</script>\n";
exit;
}
$cids = implode( ',', $cid );
$query = "UPDATE #__modules SET published='$publish'"
. "\n WHERE id IN ($cids)"
. "\n AND (checked_out=0 OR (checked_out='$my->id'))"
;
$database->setQuery( $query );
if (!$database->query()) {
echo "<script> alert('".$database->getErrorMsg()."'); window.history.go(-1); </script>\n";
exit();
}
if (count( $cid ) == 1) {
$row = new mosModule( $database );
$row->checkin( $cid[0] );
}
mosRedirect( 'index2.php?option='. $option .'&client='. $client );
}
/**
* Cancels an edit operation
*/
function cancelModule( $option, $client ) {
global $database;
$row = new mosModule( $database );
// ignore array elements
$row->bind( $_POST, 'selections params' );
$row->checkin();
mosRedirect( 'index2.php?option='. $option .'&client='. $client );
}
/**
* Moves the order of a record
* @param integer The unique id of record
* @param integer The increment to reorder by
*/
function orderModule( $uid, $inc, $option ) {
global $database;
$client = mosGetParam( $_POST, 'client', '' );
$row = new mosModule( $database );
$row->load( $uid );
if ($client == 'admin') {
$where = "client_id='1'";
} else {
$where = "client_id='0'";
}
$row->move( $inc, "position='$row->position' AND ($where)" );
if ( $client ) {
$client = '&client=admin' ;
} else {
$client = '';
}
mosRedirect( 'index2.php?option='. $option .'&client='. $client );
}
/**
* changes the access level of a record
* @param integer The increment to reorder by
*/
function accessMenu( $uid, $access, $option, $client ) {
global $database;
switch ( $access ) {
case 'accesspublic':
$access = 0;
break;
case 'accessregistered':
$access = 1;
break;
case 'accessspecial':
$access = 2;
break;
}
$row = new mosModule( $database );
$row->load( $uid );
$row->access = $access;
if ( !$row->check() ) {
return $row->getError();
}
if ( !$row->store() ) {
return $row->getError();
}
mosRedirect( 'index2.php?option='. $option .'&client='. $client );
}
function saveOrder( &$cid, $client ) {
global $database;
$total = count( $cid );
$order = mosGetParam( $_POST, 'order', array(0) );
$row = new mosModule( $database );
$conditions = array();
// update ordering values
for( $i=0; $i < $total; $i++ ) {
$row->load( $cid[$i] );
if ($row->ordering != $order[$i]) {
$row->ordering = $order[$i];
if (!$row->store()) {
echo "<script> alert('".$database->getErrorMsg()."'); window.history.go(-1); </script>\n";
exit();
} // if
// remember to updateOrder this group
$condition = "position='$row->position' AND client_id='$row->client_id'";
$found = false;
foreach ( $conditions as $cond )
if ($cond[1]==$condition) {
$found = true;
break;
} // if
if (!$found) $conditions[] = array($row->id, $condition);
} // if
} // for
// execute updateOrder for each group
foreach ( $conditions as $cond ) {
$row->load( $cond[0] );
$row->updateOrder( $cond[1] );
} // foreach
$msg = $adminLanguage->A_COMP_MENUS_NEW_ORDER_SAVED;
mosRedirect( 'index2.php?option=com_modules&client='. $client, $msg );
} // saveOrder
?>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -