cate.php 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377
  1. <?php
  2. class cate_m extends Model
  3. {
  4. var $sql_ext = " WHERE 1=1 ";
  5. var $catelist;
  6. var $rootlist;
  7. var $indexlist;
  8. var $sublist;
  9. var $html_ext="";
  10. var $langid = "zh";
  11. var $all_list;
  12. var $flist;//格式化后的数组
  13. function __construct()
  14. {
  15. parent::Model();
  16. }
  17. function langid($langid="zh")
  18. {
  19. $this->langid = $langid;
  20. }
  21. function cate_m()
  22. {
  23. $this->__construct();
  24. }
  25. function if_status($status=0)
  26. {
  27. $this->sql_ext .= " AND status='".$status."' ";
  28. }
  29. //取得分类
  30. function get_catelist($module_id=0,$condition="")
  31. {
  32. $sql = "SELECT * FROM ".$this->db->prefix."cate ".$this->sql_ext;
  33. $sql.= " AND langid='".$this->langid."' ";
  34. if($module_id)
  35. {
  36. $sql .= " AND module_id='".$module_id."' ";
  37. }
  38. if($condition)
  39. {
  40. $sql.= " AND ".$condition;
  41. }
  42. $sql .= " ORDER BY taxis ASC,module_id DESC,parentid ASC,id DESC ";
  43. $rslist = $this->db->get_all($sql);
  44. if(!$rslist)
  45. {
  46. return false;
  47. }
  48. foreach($rslist AS $key=>$value)
  49. {
  50. if(!$value["parentid"])
  51. {
  52. $this->rootlist[] = $value;
  53. }
  54. else
  55. {
  56. $this->sublist[] = $value;
  57. }
  58. }
  59. $this->catelist = $rslist;
  60. return true;
  61. }
  62. function catelist()
  63. {
  64. if(!$this->catelist) return false;
  65. return $this->catelist;
  66. }
  67. //取得所有分类
  68. function get_all()
  69. {
  70. $sql = "SELECT c.*,m.title,m.identifier m_sign FROM ".$this->db->prefix."cate c JOIN ".$this->db->prefix."module m ON(c.module_id=m.id) ";
  71. //$sql.= " WHERE c.langid='".$this->langid."' AND m.langid='".$this->langid."' ORDER BY m.taxis ASC,m.id DESC,c.taxis ASC,c.id DESC";
  72. $sql.= " WHERE c.langid='".$this->langid."' ORDER BY m.taxis ASC,m.id DESC,c.taxis ASC,c.id DESC";
  73. $rslist = $this->db->get_all($sql);
  74. $this->all_list = $rslist;
  75. return $rslist;
  76. }
  77. function get_list_idstring($cate_string)
  78. {
  79. $sql = "SELECT * FROM ".$this->db->prefix."cate WHERE id IN(".$cate_string.")";
  80. return $this->db->get_all($sql);
  81. }
  82. function format_list($parentid=0,$level=0)
  83. {
  84. if(!$this->all_list)
  85. {
  86. return false;
  87. }
  88. foreach($this->all_list AS $key=>$value)
  89. {
  90. if($value["parentid"] == $parentid)
  91. {
  92. $value["level"] = $level;
  93. $this->flist[] = $value;
  94. $this->format_list($value["id"],($level+1));
  95. }
  96. }
  97. return true;
  98. }
  99. function flist()
  100. {
  101. return $this->flist;
  102. }
  103. function html_select_array()
  104. {
  105. $rslist = array();
  106. if(!$this->rootlist || !is_array($this->rootlist) || count($this->rootlist)<1)
  107. {
  108. return false;
  109. }
  110. foreach($this->rootlist AS $key=>$value)
  111. {
  112. $value["space"] = $space ? $space : "";
  113. $rslist[] = $value;
  114. $this->_html_select_array($rslist,$value["id"],1);
  115. }
  116. return $rslist;
  117. }
  118. function _html_select_array(&$rslist,$parentid=0,$space_id=1)
  119. {
  120. if(!$this->catelist)
  121. {
  122. return false;
  123. }
  124. $space = "";
  125. for($i=0;$i<$space_id;$i++)
  126. {
  127. $space .= "  ";
  128. }
  129. foreach($this->catelist AS $key=>$value)
  130. {
  131. if($value["parentid"] == $parentid)
  132. {
  133. $value["space"] = $space;
  134. $rslist[] = $value;
  135. $this->_html_select_array($rslist,$value["id"],($space_id+1));
  136. }
  137. }
  138. return true;
  139. }
  140. //放在List操作中应用到的html表单
  141. function html_select($select_id="cateid",$selected=0,$lang="",$stop_pid=0)
  142. {
  143. $select = "<select name='".$select_id."' id='".$select_id."'>";
  144. if($lang)
  145. {
  146. $select.= "<option value='0'>".$lang."</option>";
  147. }
  148. if($this->rootlist && is_array($this->rootlist) && count($this->rootlist)>0)
  149. {
  150. foreach($this->rootlist AS $key=>$value)
  151. {
  152. $select .= "<option value='".$value["id"]."'";
  153. if($selected == $value["id"])
  154. {
  155. $select.= " selected";
  156. }
  157. $select .= ">".$space.$value["cate_name"];
  158. if(!$value["status"])
  159. {
  160. $select .= "【已停用】";
  161. }
  162. if($value["linkurl"])
  163. {
  164. $select .= "【已使用外链】";
  165. }
  166. $select .= "</option>";
  167. $this->html_ext = "";
  168. $this->_html_select($value["id"],$selected,1,$stop_pid);
  169. $select.= $this->html_ext;
  170. }
  171. }
  172. $select .= "</select>";
  173. return $select;
  174. }
  175. //根据当前分类取得子类HTML
  176. function _html_select($parentid=0,$selected=0,$space_id=1,$stop_pid=0)
  177. {
  178. if(!$this->catelist)
  179. {
  180. return false;
  181. }
  182. $space = "";
  183. for($i=0;$i<$space_id;$i++)
  184. {
  185. $space .= "&nbsp; &nbsp; ";
  186. }
  187. foreach($this->catelist AS $key=>$value)
  188. {
  189. if($value["parentid"] == $parentid)
  190. {
  191. $this->html_ext .= "<option value='".$value["id"]."'";
  192. if($value["id"] == $selected)
  193. {
  194. $this->html_ext .= " selected";
  195. }
  196. $this->html_ext .= ">".$space.$value["cate_name"];
  197. if(!$value["status"])
  198. {
  199. $this->html_ext .= "【已停用】";
  200. }
  201. if($value["linkurl"])
  202. {
  203. $this->html_ext .= "【已使用外链】";
  204. }
  205. $this->html_ext .= "</option>";
  206. if($parentid != $stop_pid || !$stop_pid)
  207. {
  208. $this->_html_select($value["id"],$selected,($space_id+1),$stop_pid);
  209. }
  210. }
  211. }
  212. return true;
  213. }
  214. //取得第一个分类信息
  215. function get_one($id)
  216. {
  217. $sql = "SELECT c.*,m.title,m.if_cate,m.if_list,m.if_msg FROM ".$this->db->prefix."cate c JOIN ".$this->db->prefix."module m ON(c.module_id=m.id) WHERE c.id='".$id."'";
  218. return $this->db->get_one($sql);
  219. }
  220. //检测标识串是否存在
  221. function chksign($val,$id=0)
  222. {
  223. $sql = "SELECT id FROM ".$this->db->prefix."cate WHERE identifier='".$val."' ";
  224. if($id)
  225. {
  226. $sql .= " AND id !='".$id."' ";
  227. }
  228. $sql.= "AND langid='".$this->langid."'";
  229. //$sql = "SELECT id FROM ".$this->db->prefix."cate WHERE identifier='".$val."'";
  230. $rs = $this->db->get_one($sql);
  231. if($rs)
  232. {
  233. return true;
  234. }
  235. else
  236. {
  237. return false;
  238. }
  239. }
  240. function save($data,$id=0)
  241. {
  242. if($id)
  243. {
  244. $this->db->update_array($data,"cate",array("id"=>$id));
  245. return true;
  246. }
  247. else
  248. {
  249. $insert_id = $this->db->insert_array($data,"cate");
  250. return $insert_id;
  251. }
  252. }
  253. function update_son_fields($fields,$id=0)
  254. {
  255. if(!$id) return false;
  256. $array = array();
  257. $array["fields"] = $fields;
  258. $this->db->update_array($array,"cate",array("parentid"=>$id));
  259. return true;
  260. }
  261. function set_status($id,$status=0)
  262. {
  263. $sql = "UPDATE ".$this->db->prefix."cate SET status='".$status."' WHERE id='".$id."'";
  264. return $this->db->query($sql);
  265. }
  266. //检测是否有子分类
  267. function chk_son($id)
  268. {
  269. $sql = "SELECT id FROM ".$this->db->prefix."cate WHERE parentid='".$id."'";
  270. return $this->db->get_one($sql);
  271. }
  272. //检测是否有内容
  273. function chk_msg($id)
  274. {
  275. $sql = "SELECT id FROM ".$this->db->prefix."list WHERE cate_id='".$id."'";
  276. return $this->db->get_one($sql);
  277. }
  278. function del($id)
  279. {
  280. $sql = "DELETE FROM ".$this->db->prefix."cate WHERE id='".$id."'";
  281. return $this->db->query($sql);
  282. }
  283. //取得第一个主题
  284. function get_cate2sub($idstring,$ordertype="")
  285. {
  286. $sql = "SELECT id,identifier,cate_id FROM ".$this->db->prefix."list WHERE status='1' AND cate_id IN(".$idstring.") ORDER BY istop DESC,taxis DESC ";
  287. if($ordertype)
  288. {
  289. $sql .= ", ";
  290. $sql .= str_replace(":"," ",$ordertype);
  291. }
  292. $sql.= ",id DESC LIMIT 1";
  293. return $this->db->get_one($sql);
  294. }
  295. function get_id_from_module($mid)
  296. {
  297. $sql = "SELECT id,identifier FROM ".$this->db->prefix."list WHERE status='1' AND module_id='".$mid."' ORDER BY istop DESC,taxis DESC ";
  298. $sql.= "post_date DESC,id DESC LIMIT 1";
  299. return $this->db->get_one($sql);
  300. }
  301. function min_max($mid,$langid="zh")
  302. {
  303. $sql = "SELECT min(c.id) min_id,max(c.id) max_id FROM ".$this->db->prefix."cate c ";
  304. $sql.= " JOIN ".$this->db->prefix."module m ON(c.module_id=m.id) ";
  305. $sql.= " WHERE c.status='1' AND c.module_id='".$mid."' AND c.langid='".$langid."' ";
  306. return $this->db->get_one($sql);
  307. }
  308. //取得子分类ID号
  309. function get_sonid_array(&$array,$id=0)
  310. {
  311. if(!$id)
  312. {
  313. return $array;
  314. }
  315. $sql = "SELECT id FROM ".$this->db->prefix."cate WHERE parentid='".$id."' AND status='1'";
  316. $rslist = $this->db->get_all($sql);
  317. if(!$rslist)
  318. {
  319. return $array;
  320. }
  321. foreach($rslist AS $key=>$value)
  322. {
  323. $array[] = $value["id"];
  324. $this->get_sonid_array($array,$value["id"]);
  325. }
  326. return $array;
  327. }
  328. function next_cid($cid,$mid=0,$langid="zh")
  329. {
  330. $sql = "SELECT id FROM ".$this->db->prefix."cate WHERE status='1' AND id>'".$cid."'";
  331. if($mid)
  332. {
  333. $sql.= " AND module_id='".$mid."' ";
  334. }
  335. $sql.= " AND langid='".$langid."' ";
  336. $sql.= " ORDER BY id ASC LIMIT 1";
  337. $rs = $this->db->get_one($sql);
  338. if($rs)
  339. {
  340. return $rs["id"];
  341. }
  342. else
  343. {
  344. return false;
  345. }
  346. }
  347. }
  348. ?>