You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
182 lines
9.0 KiB
182 lines
9.0 KiB
<?php
|
|
namespace Home\Model;
|
|
use Home\Model\BaseModel;
|
|
|
|
class ItemModel extends BaseModel {
|
|
|
|
public function export($item_id){
|
|
$item = D("Item")->where("item_id = '$item_id' ")->field(" item_type, item_name ,item_description,password ")->find();
|
|
//获取所有父目录id为0的页面
|
|
$pages = D("Page")->where("cat_id = '0' and item_id = '$item_id' ")->field(" page_title ,page_content,s_number,page_comments ")->order(" s_number asc ")->select();
|
|
//获取所有二级目录
|
|
$catalogs = D("Catalog")->where("item_id = '$item_id' and level = 2 ")->field("cat_id, cat_name ,level,s_number ")->order(" s_number asc ")->select();
|
|
if ($catalogs) {
|
|
foreach ($catalogs as $key => &$catalog) {
|
|
//该二级目录下的所有子页面
|
|
$temp = D("Page")->where("cat_id = '$catalog[cat_id]' ")->field(" page_title ,page_content,s_number,page_comments ")->order(" s_number asc ")->select();
|
|
$catalog['pages'] = $temp ? $temp: array();
|
|
//该二级目录下的所有子目录
|
|
$temp = D("catalog")->where("parent_cat_id = '$catalog[cat_id]' ")->field(" cat_id,cat_name ,level,s_number ")->order(" s_number asc ")->select();
|
|
$catalog['catalogs'] = $temp ? $temp: array();
|
|
if($catalog['catalogs']){
|
|
//获取所有三级目录的子页面
|
|
foreach ($catalog['catalogs'] as $key3 => &$catalog3) {
|
|
//该二级目录下的所有子页面
|
|
$temp = D("Page")->where("cat_id = '$catalog3[cat_id]' ")->field(" page_title ,page_content,s_number,page_comments ")->order(" s_number asc ")->select();
|
|
$catalog3['pages'] = $temp ? $temp: array();
|
|
unset($catalog3['cat_id']);
|
|
}
|
|
}
|
|
unset($catalog['cat_id']);
|
|
}
|
|
}
|
|
$item['pages'] = array(
|
|
"pages" =>$pages,
|
|
"catalogs" =>$catalogs,
|
|
);
|
|
unset($pages);
|
|
unset($catalogs);
|
|
$item['members'] = D("ItemMember")->where("item_id = '$item_id' ")->field(" member_group_id ,uid,username ")->select();
|
|
return json_encode($item);
|
|
|
|
}
|
|
public function import($json,$uid,$item_name= '',$item_description= '',$item_password = '',$item_domain = ''){
|
|
$userInfo = D("User")->userInfo($uid);
|
|
$item = json_decode($json ,1 );
|
|
unset($json);
|
|
if ($item) {
|
|
if ($item['item_domain']) {
|
|
$item2 = D("Item")->where("item_domain = '%s' ".array($item['item_domain']))->find();
|
|
if ($item2) {
|
|
//个性域名已经存在
|
|
return false;
|
|
}
|
|
if(!ctype_alnum($item_domain) || is_numeric($item_domain) ){
|
|
//echo '个性域名只能是字母或数字的组合';exit;
|
|
return false;
|
|
}
|
|
}else{
|
|
$item['item_domain'] = '';
|
|
}
|
|
$item_data = array(
|
|
"item_name"=>$item_name ? $item_name :$item['item_name'],
|
|
"item_domain"=>$item_domain ? $item_domain :$item['item_domain'],
|
|
"item_type"=>$item['item_type'],
|
|
"item_description"=>$item_description ? $item_description :$item['item_description'],
|
|
"password"=>$item_password ? $item_password :$item['password'],
|
|
"uid"=>$userInfo['uid'],
|
|
"username"=>$userInfo['username'],
|
|
"addtime"=>time(),
|
|
);
|
|
$item_id = D("Item")->add($item_data);
|
|
}
|
|
if ($item['pages']) {
|
|
//父页面们(一级目录)
|
|
if ($item['pages']['pages']) {
|
|
foreach ($item['pages']['pages'] as $key => &$value) {
|
|
$page_data = array(
|
|
"author_uid"=>$userInfo['uid'],
|
|
"author_username"=>$userInfo['username'],
|
|
"page_title" =>$value['page_title'],
|
|
"page_content" =>$value['page_content'],
|
|
"s_number" =>$value['s_number'],
|
|
"page_comments" =>$value['page_comments'],
|
|
"item_id" => $item_id,
|
|
"cat_id" => 0 ,
|
|
"addtime" =>time(),
|
|
);
|
|
D("Page")->add($page_data);
|
|
unset($page_data);
|
|
}
|
|
unset($item['pages']['pages']);
|
|
}
|
|
//二级目录
|
|
if ($item['pages']['catalogs']) {
|
|
foreach ($item['pages']['catalogs'] as $key => &$value) {
|
|
$catalog_data = array(
|
|
"cat_name" => $value['cat_name'],
|
|
"level" => $value['level'],
|
|
"s_number" => $value['s_number'],
|
|
"item_id" => $item_id,
|
|
"addtime" =>time(),
|
|
);
|
|
$cat_id = D("Catalog")->add($catalog_data);
|
|
//二级目录的页面们
|
|
if ($value['pages']) {
|
|
foreach ($value['pages'] as $key2 => &$value2) {
|
|
$page_data = array(
|
|
"author_uid"=>$userInfo['uid'],
|
|
"author_username"=>$userInfo['username'],
|
|
"page_title" =>$value2['page_title'],
|
|
"page_content" =>$value2['page_content'],
|
|
"s_number" =>$value2['s_number'],
|
|
"page_comments" =>$value2['page_comments'],
|
|
"item_id" => $item_id,
|
|
"cat_id" => $cat_id ,
|
|
"addtime" =>time(),
|
|
);
|
|
D("Page")->add($page_data);
|
|
unset($page_data);
|
|
unset($value2);
|
|
}
|
|
}
|
|
//判断是否存在三级目录
|
|
if ($value['catalogs']) {
|
|
foreach ($value['catalogs'] as $key3 => &$value3) {
|
|
$catalog_data = array(
|
|
"cat_name" => $value3['cat_name'],
|
|
"level" => $value3['level'],
|
|
"s_number" => $value3['s_number'],
|
|
"parent_cat_id" => $cat_id,
|
|
"item_id" => $item_id,
|
|
"addtime" =>time(),
|
|
);
|
|
$cat_id2 = D("Catalog")->add($catalog_data);
|
|
//三级目录的页面们
|
|
if ($value3['pages']) {
|
|
foreach ($value3['pages'] as $key4 => &$value4) {
|
|
$page_data = array(
|
|
"author_uid"=>$userInfo['uid'],
|
|
"author_username"=>$userInfo['username'],
|
|
"page_title" =>$value4['page_title'],
|
|
"page_content" =>$value4['page_content'],
|
|
"s_number" =>$value4['s_number'],
|
|
"page_comments" =>$value4['page_comments'],
|
|
"item_id" => $item_id,
|
|
"cat_id" => $cat_id2 ,
|
|
"addtime" =>time(),
|
|
);
|
|
D("Page")->add($page_data);
|
|
unset($page_data);
|
|
unset($value4);
|
|
}
|
|
}
|
|
unset($value3);
|
|
}
|
|
}
|
|
unset($value);
|
|
}
|
|
|
|
}
|
|
}
|
|
|
|
if ($item['members']) {
|
|
foreach ($item['members'] as $key => $value) {
|
|
$member_data = array(
|
|
"member_group_id"=>$value['member_group_id'],
|
|
"uid"=>$value['uid'],
|
|
"username"=>$value['username'],
|
|
"item_id"=>$item_id,
|
|
"addtime"=>time(),
|
|
);
|
|
D("ItemMember")->add($member_data);
|
|
}
|
|
}
|
|
return $item_id;
|
|
}
|
|
|
|
public function copy($item_id,$uid,$item_name= '',$item_description= '',$item_password = '',$item_domain){
|
|
return $this->import($this->export($item_id),$uid,$item_name,$item_description,$item_password,$item_domain);
|
|
}
|
|
|
|
}
|