admin.sections.php
来自「mambo的cms源代码」· PHP 代码 · 共 699 行 · 第 1/2 页
PHP
699 行
}
}
if (count( $cid )) {
$cids = implode( ',', $cid );
$database->setQuery( "DELETE FROM #__sections WHERE id IN ($cids)" );
if (!$database->query()) {
echo "<script> alert('".$database->getErrorMsg()."'); window.history.go(-1); </script>\n";
}
}
if (count( $err )) {
$cids = implode( ', ', $err );
$msg = $adminLanguage->A_COMP_SECT_SEC .": ". $cids ." ". $adminLanguage->A_COMP_SECT_CANNOT ;
mosRedirect( 'index2.php?option='. $option .'&scope='. $scope, $msg );
}
$names = implode( ', ', $name );
$msg = $adminLanguage->A_COMP_SECT_SEC .": ". $names ." ". $adminLanguage->A_COMP_SECT_SUCCESS_DEL ;
mosRedirect( 'index2.php?option='. $option .'&scope='. $scope, $msg );
}
/**
* Publishes or Unpublishes one or more categories
* @param database A database connector object
* @param string The name of the category section
* @param integer A unique category id (passed from an edit form)
* @param array An array of unique category id numbers
* @param integer 0 if unpublishing, 1 if publishing
* @param string The name of the current user
*/
function publishSections( $scope, $cid=null, $publish=1, $option ) {
global $database, $my, $adminLanguage;
if ( !is_array( $cid ) || count( $cid ) < 1 ) {
$action = $publish ? 'publish' : 'unpublish';
echo "<script> alert('$adminLanguage->A_COMP_SECT_TO $action'); window.history.go(-1);</script>\n";
exit;
}
$cids = implode( ',', $cid );
$count = count( $cid );
if ( $publish ) {
if ( !$count ){
echo "<script> alert('$adminLanguage->A_COMP_SECT_CANNOT_PUB $count'); window.history.go(-1);</script>\n";
return;
}
}
$database->setQuery( "UPDATE #__sections SET published='$publish'"
. "\n WHERE id IN ($cids) AND (checked_out=0 OR (checked_out='$my->id'))"
);
if (!$database->query()) {
echo "<script> alert('".$database->getErrorMsg()."'); window.history.go(-1); </script>\n";
exit();
}
if ( $count == 1 ) {
$row = new mosSection( $database );
$row->checkin( $cid[0] );
}
// check if section linked to menu items if unpublishing
if ( $publish == 0 ) {
$database->setQuery( "SELECT id FROM #__menu WHERE type='content_section' AND componentid IN ($cids)" );
$menus = $database->loadObjectList();
if ($menus) {
foreach ($menus as $menu) {
$database->setQuery( "UPDATE #__menu SET published=$publish WHERE id=$menu->id" );
$database->query();
}
}
}
mosRedirect( 'index2.php?option='. $option .'&scope='. $scope );
}
/**
* Cancels an edit operation
* @param database A database connector object
* @param string The name of the category section
* @param integer A unique category id
*/
function cancelSection( $option, $scope ) {
global $database;
$row = new mosSection( $database );
$row->bind( $_POST );
$row->checkin();
mosRedirect( 'index2.php?option='. $option .'&scope='. $scope );
}
/**
* Moves the order of a record
* @param integer The increment to reorder by
*/
function orderSection( $uid, $inc, $option, $scope ) {
global $database;
$row = new mosSection( $database );
$row->load( $uid );
$row->move( $inc, "scope='$row->scope'" );
mosRedirect( 'index2.php?option='. $option .'&scope='. $scope );
}
/**
* Form for copying item(s) to a specific menu
*/
function copySectionSelect( $option, $cid, $section ) {
global $database, $adminLanguage;
if (!is_array( $cid ) || count( $cid ) < 1) {
echo "<script> alert('$adminLanguage->A_COMP_CATEG_ITEM_MOVE'); window.history.go(-1);</script>\n";
exit;
}
## query to list selected categories
$cids = implode( ',', $cid );
$query = "SELECT a.name, a.id"
. "\n FROM #__categories AS a"
. "\n WHERE a.section IN ( ". $cids ." )"
;
$database->setQuery( $query );
$categories = $database->loadObjectList();
## query to list items from categories
$query = "SELECT a.title, a.id"
. "\n FROM #__content AS a"
. "\n WHERE a.sectionid IN ( ". $cids ." )"
. "\n ORDER BY a.sectionid, a.catid, a.title"
;
$database->setQuery( $query );
$contents = $database->loadObjectList();
sections_html::copySectionSelect( $option, $cid, $categories, $contents, $section );
}
/**
* Save the item(s) to the menu selected
*/
function copySectionSave( $sectionid ) {
global $database, $adminLanguage;
$title = mosGetParam( $_REQUEST, 'title', '' );
$contentid = mosGetParam( $_REQUEST, 'content', '' );
$categoryid = mosGetParam( $_REQUEST, 'category', '' );
// copy section
$section = new mosSection ( $database );
foreach( $sectionid as $id ) {
$section->load( $id );
$section->id = NULL;
$section->title = $title;
$section->name = $title;
if ( !$section->check() ) {
echo "<script> alert('".$section->getError()."'); window.history.go(-1); </script>\n";
exit();
}
if ( !$section->store() ) {
echo "<script> alert('".$section->getError()."'); window.history.go(-1); </script>\n";
exit();
}
$section->checkin();
$section->updateOrder( "section='". $section->id ."'" );
// stores original catid
$newsectids[]["old"] = $id;
// pulls new catid
$newsectids[]["new"] = $section->id;
}
$sectionMove = $section->id;
// copy categories
$category = new mosCategory ( $database );
foreach( $categoryid as $id ) {
$category->load( $id );
$category->id = NULL;
$category->section = $sectionMove;
foreach( $newsectids as $newsectid ) {
if ( $category->section == $newsectid["old"] ) {
$category->section = $newsectid["new"];
}
}
if (!$category->check()) {
echo "<script> alert('".$category->getError()."'); window.history.go(-1); </script>\n";
exit();
}
if (!$category->store()) {
echo "<script> alert('".$category->getError()."'); window.history.go(-1); </script>\n";
exit();
}
$category->checkin();
$category->updateOrder( "section='". $category->section ."'" );
// stores original catid
$newcatids[]["old"] = $id;
// pulls new catid
$newcatids[]["new"] = $category->id;
}
$content = new mosContent ( $database );
foreach( $contentid as $id) {
$content->load( $id );
$content->id = NULL;
$content->hits = 0;
foreach( $newsectids as $newsectid ) {
if ( $content->sectionid == $newsectid["old"] ) {
$content->sectionid = $newsectid["new"];
}
}
foreach( $newcatids as $newcatid ) {
if ( $content->catid == $newcatid["old"] ) {
$content->catid = $newcatid["new"];
}
}
if (!$content->check()) {
echo "<script> alert('".$content->getError()."'); window.history.go(-1); </script>\n";
exit();
}
if (!$content->store()) {
echo "<script> alert('".$content->getError()."'); window.history.go(-1); </script>\n";
exit();
}
$content->checkin();
}
$sectionOld = new mosSection ( $database );
$sectionOld->load( $sectionMove );
$msg = $adminLanguage->A_COMP_SECTION ." ". $sectionOld-> name ." ". $adminLanguage->A_COMP_SECT_AND_ALL ." ". $title;
mosRedirect( 'index2.php?option=com_sections&scope=content&mosmsg='. $msg );
}
/**
* changes the access level of a record
* @param integer The increment to reorder by
*/
function accessMenu( $uid, $access, $option ) {
global $database;
$row = new mosSection( $database );
$row->load( $uid );
$row->access = $access;
if ( !$row->check() ) {
return $row->getError();
}
if ( !$row->store() ) {
return $row->getError();
}
mosRedirect( 'index2.php?option='. $option .'&scope='. $row->scope );
}
function menuLink( $id ) {
global $database, $adminLanguage;
$section = new mosSection( $database );
$section->bind( $_POST );
$section->checkin();
$menu = mosGetParam( $_POST, 'menuselect', '' );
$name = mosGetParam( $_POST, 'link_name', '' );
$type = mosGetParam( $_POST, 'link_type', '' );
switch ( $type ) {
case 'content_section':
$link = 'index.php?option=com_content&task=section&id='. $id;
$menutype = 'Section Table';
break;
case 'content_blog_section':
$link = 'index.php?option=com_content&task=blogsection&id='. $id;
$menutype = 'Section Blog';
break;
case 'content_archive_section':
$link = 'index.php?option=com_content&task=archivesection&id='. $id;
$menutype = 'Section Blog Archive';
break;
}
$row = new mosMenu( $database );
$row->menutype = $menu;
$row->name = $name;
$row->type = $type;
$row->published = 1;
$row->componentid = $id;
$row->link = $link;
$row->ordering = 9999;
if (!$row->check()) {
echo "<script> alert('".$row->getError()."'); window.history.go(-1); </script>\n";
exit();
}
if (!$row->store()) {
echo "<script> alert('".$row->getError()."'); window.history.go(-1); </script>\n";
exit();
}
$row->checkin();
$row->updateOrder( 'scope="'. $row->scope .'"' );
$msg = $name ." ( ". $menutype ." ) ". $adminLanguage->A_COMP_SECT_IN_MENU .": ". $menu ." ". $adminLanguage->A_COMP_CONTENT_SUCCESS;
mosRedirect( 'index2.php?option=com_sections&scope=content&task=editA&hidemainmenu=1&id='. $id, $msg );
}
function saveOrder( &$cid ) {
global $database;
$total = count( $cid );
$order = mosGetParam( $_POST, 'order', array(0) );
$row = new mosSection( $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 = "scope='$row->scope'";
$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 = 'New ordering saved';
mosRedirect( 'index2.php?option=com_sections&scope=content', $msg );
} // saveOrder
?>
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?