spec.php 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274
  1. <?php
  2. /**
  3. * 规格栏目管理
  4. *
  5. *
  6. *
  7. ***/
  8. defined('InShopNC') or exit('Access Invalid!');
  9. class specControl extends SystemControl {
  10. const EXPORT_SIZE = 5000;
  11. public function __construct(){
  12. parent::__construct();
  13. Language::read('spec');
  14. }
  15. /**
  16. * 规格管理
  17. */
  18. public function specOp(){
  19. $lang = Language::getLangContent();
  20. $model_spec = Model('spec');
  21. $page = new Page();
  22. $page->setEachNum(10);
  23. $page->setStyle('admin');
  24. $spec_list = $model_spec->specList(array('order'=>'sp_sort asc'), $page);
  25. Tpl::output('spec_list',$spec_list);
  26. Tpl::output('page',$page->show());
  27. Tpl::showpage('spec.index');
  28. }
  29. /**
  30. * 添加规格
  31. */
  32. public function spec_addOp(){
  33. $lang = Language::getLangContent();
  34. $model_spec = Model('spec');
  35. if (chksubmit()){
  36. $obj_validate = new Validate();
  37. $obj_validate->validateparam = array(
  38. array("input"=>$_POST["s_name"], "require"=>"true", "message"=>$lang['spec_add_name_no_null'])
  39. );
  40. $error = $obj_validate->validate();
  41. if ($error != ''){
  42. showMessage($error);
  43. }else {
  44. $spec = array();
  45. $spec['sp_name'] = $_POST['s_name'];
  46. $spec['sp_sort'] = intval($_POST['s_sort']);
  47. $spec['class_id'] = $_POST['class_id'];
  48. $spec['class_name'] = $_POST['class_name'];
  49. $return = $model_spec->addSpec($spec);
  50. if($return) {
  51. $url = array(
  52. array(
  53. 'url'=>'index.php?act=spec&op=spec_add',
  54. 'msg'=>$lang['spec_index_continue_to_dd']
  55. ),
  56. array(
  57. 'url'=>'index.php?act=spec&op=spec',
  58. 'msg'=>$lang['spec_index_return_type_list']
  59. )
  60. );
  61. $this->log(L('nc_add,spec_index_spec_name').'['.$_POST['s_name'].']',1);
  62. showMessage($lang['nc_common_save_succ'], $url);
  63. }else {
  64. $this->log(L('nc_add,spec_index_spec_name').'['.$_POST['s_name'].']',0);
  65. showMessage($lang['nc_common_save_fail']);
  66. }
  67. }
  68. }
  69. // 一级商品分类
  70. $gc_list = Model('goods_class')->getGoodsClassListByParentId(0);
  71. Tpl::output('gc_list', $gc_list);
  72. Tpl::showpage('spec.add');
  73. }
  74. /**
  75. * 编辑规格
  76. */
  77. public function spec_editOp() {
  78. $lang = Language::getLangContent();
  79. if(empty($_GET['sp_id'])) {
  80. showMessage($lang['param_error']);
  81. }
  82. /**
  83. * 规格模型
  84. */
  85. $model_spec = Model('spec');
  86. /**
  87. * 编辑保存
  88. */
  89. if (chksubmit()) {
  90. $obj_validate = new Validate();
  91. $obj_validate->validateparam = array(
  92. array("input"=>$_POST["s_name"], "require"=>"true", "message"=>$lang['spec_add_name_no_null'])
  93. );
  94. $error = $obj_validate->validate();
  95. if ($error != '') {
  96. showMessage($error);
  97. } else {
  98. //更新规格表
  99. $param = array();
  100. $param['sp_name'] = trim($_POST['s_name']);
  101. $param['sp_sort'] = intval($_POST['s_sort']);
  102. $param['class_id'] = $_POST['class_id'];
  103. $param['class_name'] = $_POST['class_name'];
  104. $return = $model_spec->specUpdate($param, array('sp_id'=>intval($_POST['s_id'])), 'spec');
  105. if ($return) {
  106. $url = array(
  107. array(
  108. 'url'=>'index.php?act=spec&op=spec',
  109. 'msg'=>$lang['spec_index_return_type_list']
  110. )
  111. );
  112. $this->log(L('nc_edit,spec_index_spec_name').'['.$_POST['s_name'].']',1);
  113. showMessage($lang['nc_common_save_succ'], $url);
  114. } else {
  115. $this->log(L('nc_edit,spec_index_spec_name').'['.$_POST['s_name'].']',0);
  116. showMessage($lang['nc_common_save_fail']);
  117. }
  118. }
  119. }
  120. //规格列表
  121. $spec_list = $model_spec->getSpecInfo(intval($_GET['sp_id']));
  122. if(!$spec_list){
  123. showMessage($lang['param_error']);
  124. }
  125. // 一级商品分类
  126. $gc_list = Model('goods_class')->getGoodsClassListByParentId(0);
  127. Tpl::output('gc_list', $gc_list);
  128. Tpl::output('sp_list',$spec_list);
  129. Tpl::showpage('spec.edit');
  130. }
  131. /**
  132. * 删除规格
  133. */
  134. public function spec_delOp(){
  135. $lang = Language::getLangContent();
  136. if(empty($_GET['del_id'])) {
  137. showMessage($lang['param_error']);
  138. }
  139. //规格模型
  140. $model_spec = Model('spec');
  141. if(is_array($_GET['del_id'])){
  142. $id = "'".implode("','", $_GET['del_id'])."'";
  143. }else{
  144. $id = intval($_GET['del_id']);
  145. }
  146. //规格列表
  147. $spec_list = $model_spec->specList(array('in_sp_id'=>$id));
  148. if(is_array($spec_list) && !empty($spec_list)){
  149. // 删除类型与规格关联表
  150. $return = $model_spec->delSpec('type_spec', array('in_sp_id'=>$id));
  151. if(!$return){
  152. showMessage($lang['nc_common_save_fail']);
  153. }
  154. //删除规格值表
  155. $return = $model_spec->delSpec('spec_value',array('in_sp_id'=>$id));
  156. if(!$return){
  157. showMessage($lang['nc_common_save_fail']);
  158. }
  159. //删除规格表
  160. $return = $model_spec->delSpec('spec',array('in_sp_id'=>$id));
  161. if(!$return){
  162. showMessage($lang['nc_common_save_fail']);
  163. }
  164. $this->log(L('nc_delete,spec_index_spec_name').'[ID:'.$id.']',1);
  165. showMessage($lang['nc_common_del_succ']);
  166. }else{
  167. $this->log(L('nc_delete,spec_index_spec_name').'[ID:'.$id.']',0);
  168. showMessage($lang['param_error']);
  169. }
  170. }
  171. /**
  172. * ajax操作
  173. */
  174. public function ajaxOp(){
  175. //规格模型
  176. $model_spec = Model('spec');
  177. switch ($_GET['branch']){
  178. case 'sort':
  179. // case 'name':
  180. $return = $model_spec->specUpdate(
  181. array($_GET['column']=>trim($_GET['value'])),
  182. array('sp_id'=>intval($_GET['id'])),
  183. 'spec'
  184. );
  185. if($return){
  186. $this->log(L('spec_index_spec_name,nc_sort').'[ID:'.intval($_GET['id']).']',1);
  187. echo 'true';exit;
  188. }else{
  189. echo 'false';exit;
  190. }
  191. break;
  192. }
  193. }
  194. /**
  195. * 规格导出
  196. */
  197. public function export_step1Op(){
  198. $model_spec = Model('spec');
  199. $page = new Page();
  200. $page->setEachNum(self::EXPORT_SIZE);
  201. $spec_list = $model_spec->specList(array('order'=>'sp_sort asc'), $page);
  202. if (!is_numeric($_GET['curpage'])){
  203. $count = $page->getTotalNum();
  204. $array = array();
  205. if ($count > self::EXPORT_SIZE ){ //显示下载链接
  206. $page = ceil($count/self::EXPORT_SIZE);
  207. for ($i=1;$i<=$page;$i++){
  208. $limit1 = ($i-1)*self::EXPORT_SIZE + 1;
  209. $limit2 = $i*self::EXPORT_SIZE > $count ? $count : $i*self::EXPORT_SIZE;
  210. $array[$i] = $limit1.' ~ '.$limit2 ;
  211. }
  212. Tpl::output('list',$array);
  213. Tpl::output('murl','index.php?act=spec&op=spec');
  214. Tpl::showpage('export.excel');
  215. }else{ //如果数量小,直接下载
  216. $this->createExcel($spec_list);
  217. }
  218. }else{ //下载
  219. $this->createExcel($spec_list);
  220. }
  221. }
  222. /**
  223. * 生成excel
  224. *
  225. * @param array $data
  226. */
  227. private function createExcel($data = array()){
  228. Language::read('export');
  229. import('libraries.excel');
  230. $excel_obj = new Excel();
  231. $excel_data = array();
  232. //设置样式
  233. $excel_obj->setStyle(array('id'=>'s_title','Font'=>array('FontName'=>'宋体','Size'=>'12','Bold'=>'1')));
  234. //header
  235. $excel_data[0][] = array('styleid'=>'s_title','data'=>L('exp_spec'));
  236. $excel_data[0][] = array('styleid'=>'s_title','data'=>L('exp_sp_content'));
  237. foreach ((array)$data as $k=>$v){
  238. $tmp = array();
  239. $tmp[] = array('data'=>$v['sp_name']);
  240. $tmp[] = array('data'=>$v['sp_value']);
  241. $excel_data[] = $tmp;
  242. }
  243. $excel_data = $excel_obj->charset($excel_data,CHARSET);
  244. $excel_obj->addArray($excel_data);
  245. $excel_obj->addWorksheet($excel_obj->charset(L('exp_spec'),CHARSET));
  246. $excel_obj->generateXML($excel_obj->charset(L('exp_spec'),CHARSET).$_GET['curpage'].'-'.date('Y-m-d-H',time()));
  247. }
  248. }