123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274 |
- <?php
- /**
- * 规格栏目管理
- *
- *
- *
- ***/
- defined('InShopNC') or exit('Access Invalid!');
- class specControl extends SystemControl {
- const EXPORT_SIZE = 5000;
- public function __construct(){
- parent::__construct();
- Language::read('spec');
- }
- /**
- * 规格管理
- */
- public function specOp(){
- $lang = Language::getLangContent();
- $model_spec = Model('spec');
- $page = new Page();
- $page->setEachNum(10);
- $page->setStyle('admin');
- $spec_list = $model_spec->specList(array('order'=>'sp_sort asc'), $page);
- Tpl::output('spec_list',$spec_list);
- Tpl::output('page',$page->show());
- Tpl::showpage('spec.index');
- }
- /**
- * 添加规格
- */
- public function spec_addOp(){
- $lang = Language::getLangContent();
- $model_spec = Model('spec');
- if (chksubmit()){
- $obj_validate = new Validate();
- $obj_validate->validateparam = array(
- array("input"=>$_POST["s_name"], "require"=>"true", "message"=>$lang['spec_add_name_no_null'])
- );
- $error = $obj_validate->validate();
- if ($error != ''){
- showMessage($error);
- }else {
- $spec = array();
- $spec['sp_name'] = $_POST['s_name'];
- $spec['sp_sort'] = intval($_POST['s_sort']);
- $spec['class_id'] = $_POST['class_id'];
- $spec['class_name'] = $_POST['class_name'];
- $return = $model_spec->addSpec($spec);
- if($return) {
- $url = array(
- array(
- 'url'=>'index.php?act=spec&op=spec_add',
- 'msg'=>$lang['spec_index_continue_to_dd']
- ),
- array(
- 'url'=>'index.php?act=spec&op=spec',
- 'msg'=>$lang['spec_index_return_type_list']
- )
- );
- $this->log(L('nc_add,spec_index_spec_name').'['.$_POST['s_name'].']',1);
- showMessage($lang['nc_common_save_succ'], $url);
- }else {
- $this->log(L('nc_add,spec_index_spec_name').'['.$_POST['s_name'].']',0);
- showMessage($lang['nc_common_save_fail']);
- }
- }
- }
- // 一级商品分类
- $gc_list = Model('goods_class')->getGoodsClassListByParentId(0);
- Tpl::output('gc_list', $gc_list);
- Tpl::showpage('spec.add');
- }
- /**
- * 编辑规格
- */
- public function spec_editOp() {
- $lang = Language::getLangContent();
- if(empty($_GET['sp_id'])) {
- showMessage($lang['param_error']);
- }
- /**
- * 规格模型
- */
- $model_spec = Model('spec');
- /**
- * 编辑保存
- */
- if (chksubmit()) {
- $obj_validate = new Validate();
- $obj_validate->validateparam = array(
- array("input"=>$_POST["s_name"], "require"=>"true", "message"=>$lang['spec_add_name_no_null'])
- );
- $error = $obj_validate->validate();
- if ($error != '') {
- showMessage($error);
- } else {
- //更新规格表
- $param = array();
- $param['sp_name'] = trim($_POST['s_name']);
- $param['sp_sort'] = intval($_POST['s_sort']);
- $param['class_id'] = $_POST['class_id'];
- $param['class_name'] = $_POST['class_name'];
- $return = $model_spec->specUpdate($param, array('sp_id'=>intval($_POST['s_id'])), 'spec');
- if ($return) {
- $url = array(
- array(
- 'url'=>'index.php?act=spec&op=spec',
- 'msg'=>$lang['spec_index_return_type_list']
- )
- );
- $this->log(L('nc_edit,spec_index_spec_name').'['.$_POST['s_name'].']',1);
- showMessage($lang['nc_common_save_succ'], $url);
- } else {
- $this->log(L('nc_edit,spec_index_spec_name').'['.$_POST['s_name'].']',0);
- showMessage($lang['nc_common_save_fail']);
- }
- }
- }
- //规格列表
- $spec_list = $model_spec->getSpecInfo(intval($_GET['sp_id']));
- if(!$spec_list){
- showMessage($lang['param_error']);
- }
- // 一级商品分类
- $gc_list = Model('goods_class')->getGoodsClassListByParentId(0);
- Tpl::output('gc_list', $gc_list);
- Tpl::output('sp_list',$spec_list);
- Tpl::showpage('spec.edit');
- }
- /**
- * 删除规格
- */
- public function spec_delOp(){
- $lang = Language::getLangContent();
- if(empty($_GET['del_id'])) {
- showMessage($lang['param_error']);
- }
- //规格模型
- $model_spec = Model('spec');
- if(is_array($_GET['del_id'])){
- $id = "'".implode("','", $_GET['del_id'])."'";
- }else{
- $id = intval($_GET['del_id']);
- }
- //规格列表
- $spec_list = $model_spec->specList(array('in_sp_id'=>$id));
- if(is_array($spec_list) && !empty($spec_list)){
- // 删除类型与规格关联表
- $return = $model_spec->delSpec('type_spec', array('in_sp_id'=>$id));
- if(!$return){
- showMessage($lang['nc_common_save_fail']);
- }
- //删除规格值表
- $return = $model_spec->delSpec('spec_value',array('in_sp_id'=>$id));
- if(!$return){
- showMessage($lang['nc_common_save_fail']);
- }
- //删除规格表
- $return = $model_spec->delSpec('spec',array('in_sp_id'=>$id));
- if(!$return){
- showMessage($lang['nc_common_save_fail']);
- }
- $this->log(L('nc_delete,spec_index_spec_name').'[ID:'.$id.']',1);
- showMessage($lang['nc_common_del_succ']);
- }else{
- $this->log(L('nc_delete,spec_index_spec_name').'[ID:'.$id.']',0);
- showMessage($lang['param_error']);
- }
- }
- /**
- * ajax操作
- */
- public function ajaxOp(){
- //规格模型
- $model_spec = Model('spec');
- switch ($_GET['branch']){
- case 'sort':
- // case 'name':
- $return = $model_spec->specUpdate(
- array($_GET['column']=>trim($_GET['value'])),
- array('sp_id'=>intval($_GET['id'])),
- 'spec'
- );
- if($return){
- $this->log(L('spec_index_spec_name,nc_sort').'[ID:'.intval($_GET['id']).']',1);
- echo 'true';exit;
- }else{
- echo 'false';exit;
- }
- break;
- }
- }
- /**
- * 规格导出
- */
- public function export_step1Op(){
- $model_spec = Model('spec');
- $page = new Page();
- $page->setEachNum(self::EXPORT_SIZE);
- $spec_list = $model_spec->specList(array('order'=>'sp_sort asc'), $page);
- if (!is_numeric($_GET['curpage'])){
- $count = $page->getTotalNum();
- $array = array();
- if ($count > self::EXPORT_SIZE ){ //显示下载链接
- $page = ceil($count/self::EXPORT_SIZE);
- for ($i=1;$i<=$page;$i++){
- $limit1 = ($i-1)*self::EXPORT_SIZE + 1;
- $limit2 = $i*self::EXPORT_SIZE > $count ? $count : $i*self::EXPORT_SIZE;
- $array[$i] = $limit1.' ~ '.$limit2 ;
- }
- Tpl::output('list',$array);
- Tpl::output('murl','index.php?act=spec&op=spec');
- Tpl::showpage('export.excel');
- }else{ //如果数量小,直接下载
- $this->createExcel($spec_list);
- }
- }else{ //下载
- $this->createExcel($spec_list);
- }
- }
- /**
- * 生成excel
- *
- * @param array $data
- */
- private function createExcel($data = array()){
- Language::read('export');
- import('libraries.excel');
- $excel_obj = new Excel();
- $excel_data = array();
- //设置样式
- $excel_obj->setStyle(array('id'=>'s_title','Font'=>array('FontName'=>'宋体','Size'=>'12','Bold'=>'1')));
- //header
- $excel_data[0][] = array('styleid'=>'s_title','data'=>L('exp_spec'));
- $excel_data[0][] = array('styleid'=>'s_title','data'=>L('exp_sp_content'));
- foreach ((array)$data as $k=>$v){
- $tmp = array();
- $tmp[] = array('data'=>$v['sp_name']);
- $tmp[] = array('data'=>$v['sp_value']);
- $excel_data[] = $tmp;
- }
- $excel_data = $excel_obj->charset($excel_data,CHARSET);
- $excel_obj->addArray($excel_data);
- $excel_obj->addWorksheet($excel_obj->charset(L('exp_spec'),CHARSET));
- $excel_obj->generateXML($excel_obj->charset(L('exp_spec'),CHARSET).$_GET['curpage'].'-'.date('Y-m-d-H',time()));
- }
- }
|