暫無描述
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.

ProductLogic.php 16KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363
  1. <?php
  2. /**
  3. * 易优CMS
  4. * ============================================================================
  5. * 版权所有 2016-2028 海南赞赞网络科技有限公司,并保留所有权利。
  6. * 网站地址: http://www.eyoucms.com
  7. * ----------------------------------------------------------------------------
  8. * 如果商业用途务必到官方购买正版授权, 以免引起不必要的法律纠纷.
  9. * ============================================================================
  10. * Author: 小虎哥 <1105415366@qq.com>
  11. * Date: 2018-4-3
  12. */
  13. namespace app\admin\logic;
  14. use think\Db;
  15. use think\Model;
  16. /**
  17. * 产品逻辑定义
  18. * Class CatsLogic
  19. * @package admin\Logic
  20. */
  21. class ProductLogic extends Model
  22. {
  23. /**
  24. * 动态获取产品参数输入框 根据不同的数据返回不同的输入框类型
  25. * @param int $aid 产品id
  26. * @param int $typeid 产品栏目id
  27. */
  28. public function getAttrInput($aid, $typeid)
  29. {
  30. header("Content-type: text/html; charset=utf-8");
  31. $aid = intval($aid);
  32. $typeid = intval($typeid);
  33. $productAttribute = model('ProductAttribute');
  34. $attributeList = $productAttribute->where(['typeid'=>$typeid, 'is_del'=>0])->order('sort_order asc, attr_id asc')->select();
  35. $str = '';
  36. foreach($attributeList as $key => $val)
  37. {
  38. $attr_id = $val['attr_id'];
  39. $curAttrVal = $this->getProductAttrVal(NULL,$aid, $attr_id);
  40. //促使他 循环
  41. if(empty($curAttrVal))
  42. $curAttrVal[] = array('product_attr_id' =>'','aid' => '','attr_id' => '','attr_value' => '');
  43. foreach($curAttrVal as $k =>$v)
  44. {
  45. $str .= "<dl class='row attr_{$attr_id}'>";
  46. $addDelAttr = ''; // 加减符号
  47. $str .= "<dt class='tit pl5'><label for='attr_{$attr_id}'>$addDelAttr {$val['attr_name']}</label></dt>";
  48. // 单行文本框
  49. if($val['attr_input_type'] == 0)
  50. {
  51. $str .= "<dd class='opt'><input type='text' size='40' value='".($aid ? $v['attr_value'] : $val['attr_values'])."' name='attr_{$attr_id}[]' /><span class='err' tyle='color:#F00; display:none;'></span><p class='notic'></p></dd>";
  52. }
  53. // 下拉列表框(一行代表一个可选值)
  54. if($val['attr_input_type'] == 1)
  55. {
  56. $str .= "<dd class='opt'><select name='attr_{$attr_id}[]'><option value='0'>无</option>";
  57. $tmp_option_val = explode(PHP_EOL, $val['attr_values']);
  58. foreach($tmp_option_val as $k2=>$v2)
  59. {
  60. // 编辑的时候 有选中值
  61. $v2 = preg_replace("/\s/","",$v2);
  62. if($v['attr_value'] == $v2)
  63. $str .= "<option selected='selected' value='{$v2}'>{$v2}</option>";
  64. else
  65. $str .= "<option value='{$v2}'>{$v2}</option>";
  66. }
  67. $str .= "</select><span class='err' tyle='color:#F00; display:none;'></span><p class='notic'></p></dd>";
  68. }
  69. // 多行文本框
  70. if($val['attr_input_type'] == 2)
  71. {
  72. $str .= "<dd class='opt'><textarea cols='40' rows='3' name='attr_{$attr_id}[]'>".($aid ? $v['attr_value'] : $val['attr_values'])."</textarea><span class='err' tyle='color:#F00; display:none;'></span><p class='notic'></p></dd>";
  73. }
  74. // 富文本编辑器
  75. if($val['attr_input_type'] == 3)
  76. {
  77. $str .= "<dd class='opt'><textarea class='span12 ckeditor' id='attr_{$attr_id}' name='attr_{$attr_id}[]'>".($aid ? $v['attr_value'] : $val['attr_values'])."</textarea><span class='err' tyle='color:#F00; display:none;'></span><p class='notic'></p></dd>";
  78. $url = url('Ueditor/index', array('savepath'=>'allimg'));
  79. $str .= <<<EOF
  80. <script type="text/javascript">
  81. UE.getEditor("attr_{$attr_id}",{
  82. serverUrl :"{$url}",
  83. zIndex: 999,
  84. initialFrameWidth: "100%", //初化宽度
  85. initialFrameHeight: 300, //初化高度
  86. focus: false, //初始化时,是否让编辑器获得焦点true或false
  87. maximumWords: 99999,
  88. removeFormatAttributes: 'class,style,lang,width,height,align,hspace,valign',//允许的最大字符数 'fullscreen',
  89. pasteplain:false, //是否默认为纯文本粘贴。false为不使用纯文本粘贴,true为使用纯文本粘贴
  90. autoHeightEnabled: false,
  91. toolbars: ueditor_toolbars
  92. });
  93. </script>
  94. EOF;
  95. }
  96. $str .= "</dl>";
  97. }
  98. }
  99. return $str;
  100. }
  101. /**
  102. * 动态获取产品参数输入框 根据不同的数据返回不同的输入框类型
  103. * @param int $aid 产品id
  104. * @param int $typeid 产品栏目id
  105. */
  106. public function getShopAttrInput($aid, $typeid, $list_id)
  107. {
  108. header("Content-type: text/html; charset=utf-8");
  109. $aid = intval($aid);
  110. $typeid = intval($typeid);
  111. $list_id = intval($list_id);
  112. $where = [
  113. 'is_del' => 0
  114. ];
  115. if (!empty($list_id)) {
  116. $where['list_id'] = $list_id;
  117. $where['status'] = 1;
  118. }
  119. $attributeList = Db::name('ShopProductAttribute')->where($where)->order('sort_order asc, attr_id asc')->select();
  120. $str = '';
  121. foreach($attributeList as $key => $val) {
  122. $attr_id = $val['attr_id'];
  123. $curAttrVal = $this->getShopProductAttrVal(NULL, $aid, $attr_id);
  124. //促使他 循环
  125. if(empty($curAttrVal)) $curAttrVal[] = array('product_attr_id'=>'', 'aid'=>'', 'attr_id'=>'', 'attr_value'=>'');
  126. foreach($curAttrVal as $k =>$v) {
  127. $str .= "<dl class='row attr_{$attr_id}'>";
  128. $addDelAttr = ''; // 加减符号
  129. $str .= "<dt class='sort-e pl0'><input size='4' type='text' size='10' value='". $v['sort_order'] ."' name='new_attr_sort_order[{$attr_id}]' placeholder='100'></dt>";
  130. $str .= "<dt class='tit pl5'><input type='text' size='10' value='$addDelAttr {$val['attr_name']}' name='attr_{$attr_id}' readonly='readonly'/></dt>";
  131. // 单行文本框
  132. if($val['attr_input_type'] == 0) {
  133. $str .= "<dd class='opt pl5'><input type='text' size='40' value='".($aid ? $v['attr_value'] : $val['attr_values'])."' name='shop_attr_{$attr_id}[]' /><a class='text_a grey' href='javascript:void(0);' >&nbsp;&nbsp;删除</a></dd>";
  134. }
  135. // 下拉列表框(一行代表一个可选值)
  136. if($val['attr_input_type'] == 1) {
  137. // <option value='0'>无</option>
  138. $str .= "<dd class='opt pl5'><select name='shop_attr_{$attr_id}[]' style='width: 306px;'>"; $tmp_option_val = explode(PHP_EOL, $val['attr_values']); foreach($tmp_option_val as $k2=>$v2)
  139. {
  140. // 编辑的时候 有选中值
  141. // $v2 = preg_replace("/\s/","",$v2);
  142. if(trim($v['attr_value']) == trim($v2))
  143. $str .= "<option selected='selected' value='{$v2}'>{$v2}</option>";
  144. else
  145. $str .= "<option value='{$v2}'>{$v2}</option>";
  146. }
  147. $str .= "</select><a class='text_a grey' href='javascript:void(0);' >&nbsp;&nbsp;删除</a></dd>";
  148. }
  149. // 多行文本框
  150. if($val['attr_input_type'] == 2) {
  151. $str .= "<dd class='opt'><textarea cols='40' rows='3' name='shop_attr_{$attr_id}[]'>".($aid ? $v['attr_value'] : $val['attr_values'])."</textarea><span class='err' tyle='color:#F00; display:none;'></span><p class='notic'></p></dd>";
  152. }
  153. // 富文本编辑器
  154. if($val['attr_input_type'] == 3) {
  155. $str .= "<dd class='opt'><textarea class='span12 ckeditor' id='attr_{$attr_id}' name='shop_attr_{$attr_id}[]'>".($aid ? $v['attr_value'] : $val['attr_values'])."</textarea><span class='err' tyle='color:#F00; display:none;'></span><p class='notic'></p></dd>";
  156. $url = url('Ueditor/index', array('savepath'=>'allimg'));
  157. $str .= <<<EOF
  158. <script type="text/javascript">
  159. UE.getEditor("attr_{$attr_id}",{
  160. serverUrl :"{$url}",
  161. zIndex: 999,
  162. initialFrameWidth: "100%", //初化宽度
  163. initialFrameHeight: 300, //初化高度
  164. focus: false, //初始化时,是否让编辑器获得焦点true或false
  165. maximumWords: 99999,
  166. removeFormatAttributes: 'class,style,lang,width,height,align,hspace,valign',//允许的最大字符数 'fullscreen',
  167. pasteplain:false, //是否默认为纯文本粘贴。false为不使用纯文本粘贴,true为使用纯文本粘贴
  168. autoHeightEnabled: false,
  169. toolbars: ueditor_toolbars
  170. });
  171. </script>
  172. EOF;
  173. }
  174. $str .= "</dl>";
  175. }
  176. }
  177. return $str;
  178. }
  179. /**
  180. * 获取 product_attr 表中指定 aid 指定 attr_id 或者 指定 product_attr_id 的值 可是字符串 可是数组
  181. * @param int $product_attr_id product_attr表id
  182. * @param int $aid 产品id
  183. * @param int $attr_id 产品参数id
  184. * @return array 返回数组
  185. */
  186. public function getProductAttrVal($product_attr_id = 0 ,$aid = 0, $attr_id = 0)
  187. {
  188. $product_attr_id = intval($product_attr_id);
  189. $aid = intval($aid);
  190. $attr_id = intval($attr_id);
  191. $productAttr = Db::name('ProductAttr');
  192. if($product_attr_id > 0)
  193. return $productAttr->where(['product_attr_id'=>$product_attr_id])->select();
  194. if($aid > 0 && $attr_id > 0)
  195. return $productAttr->where(['aid'=>$aid,'attr_id'=>$attr_id])->select();
  196. }
  197. /**
  198. * 获取 shop_product_attr 表中指定 aid 指定 attr_id 或者 指定 product_attr_id 的值 可是字符串 可是数组
  199. * @param int $product_attr_id product_attr表id
  200. * @param int $aid 产品id
  201. * @param int $attr_id 产品参数id
  202. * @return array 返回数组
  203. */
  204. public function getShopProductAttrVal($product_attr_id = 0 ,$aid = 0, $attr_id = 0)
  205. {
  206. $product_attr_id = intval($product_attr_id);
  207. $aid = intval($aid);
  208. $attr_id = intval($attr_id);
  209. $ShopProductAttr = Db::name('ShopProductAttr');
  210. if($product_attr_id > 0) {
  211. return $ShopProductAttr->where(['product_attr_id'=>$product_attr_id])->order('sort_order asc')->select();
  212. }
  213. if($aid > 0 && $attr_id > 0) {
  214. return $ShopProductAttr->where(['aid'=>$aid,'attr_id'=>$attr_id])->order('sort_order asc')->select();
  215. }
  216. }
  217. /**
  218. * 给指定产品添加属性 或修改属性 更新到 product_attr
  219. * @param int $aid 产品id
  220. * @param int $typeid 产品栏目id
  221. */
  222. public function saveProductAttr($aid, $typeid, $postData = [])
  223. {
  224. $aid = intval($aid);
  225. $typeid = intval($typeid);
  226. $productAttr = Db::name('ProductAttr');
  227. // 属性类型被更改了 就先删除以前的属性类型 或者没有属性 则删除
  228. if($typeid == 0)
  229. {
  230. $productAttr->where('aid = '.$aid)->delete();
  231. return;
  232. }
  233. $productAttrList = $productAttr->where('aid = '.$aid)->select();
  234. $old_product_attr = array(); // 数据库中的的属性 以 attr_id _ 和值的 组合为键名
  235. foreach($productAttrList as $k => $v)
  236. {
  237. $old_product_attr[$v['attr_id'].'_'.$v['attr_value']] = $v;
  238. }
  239. // post 提交的属性 以 attr_id _ 和值的 组合为键名
  240. $post = input("post.");
  241. if (!isset($post['title'])) {
  242. $post = $postData;
  243. }
  244. foreach($post as $k => $v)
  245. {
  246. $attr_id = str_replace('attr_','',$k);
  247. if(!strstr($k, 'attr_'))
  248. continue;
  249. foreach ($v as $k2 => $v2)
  250. {
  251. //$v2 = str_replace('_', '', $v2); // 替换特殊字符
  252. //$v2 = str_replace('@', '', $v2); // 替换特殊字符
  253. $v2 = trim($v2);
  254. if(empty($v2))
  255. continue;
  256. $tmp_key = $attr_id."_".$v2;
  257. if(!array_key_exists($tmp_key , $old_product_attr)) // 数据库中不存在 说明要做删除操作
  258. {
  259. $adddata = array(
  260. 'aid' => $aid,
  261. 'attr_id' => $attr_id,
  262. 'attr_value' => $v2,
  263. 'add_time' => getTime(),
  264. 'update_time' => getTime(),
  265. );
  266. $productAttr->add($adddata);
  267. }
  268. unset($old_product_attr[$tmp_key]);
  269. }
  270. }
  271. // 没有被 unset($old_product_attr[$tmp_key]); 掉是 说明 数据库中存在 表单中没有提交过来则要删除操作
  272. foreach($old_product_attr as $k => $v)
  273. {
  274. $productAttr->where('product_attr_id = '.$v['product_attr_id'])->delete(); //
  275. }
  276. }
  277. /**
  278. * 给指定产品添加属性 或修改属性 更新到 shop_product_attr
  279. * @param int $aid 产品id
  280. * @param int $typeid 产品栏目id
  281. */
  282. public function saveShopProductAttr($aid, $typeid, $postData = [])
  283. {
  284. $aid = intval($aid);
  285. $typeid = intval($typeid);
  286. $ShopProductAttr = Db::name('ShopProductAttr');
  287. // 属性类型被更改了 就先删除以前的属性类型 或者没有属性 则删除
  288. if($typeid == 0) {
  289. $ShopProductAttr->where('aid = '.$aid)->delete();
  290. return false;
  291. }
  292. $productAttrList = $ShopProductAttr->where('aid = '.$aid)->select();
  293. $old_product_attr = array(); // 数据库中的的属性 以 attr_id _ 和值的 组合为键名
  294. foreach($productAttrList as $k => $v) {
  295. $old_product_attr[$v['attr_id'].'_'.$v['attr_value'].'_'.$v['sort_order']] = $v;
  296. }
  297. // post 提交的属性 以 attr_id _ 和值的 组合为键名
  298. $post = input("post.");
  299. if (!isset($post['title'])) {
  300. $post = $postData;
  301. }
  302. $sort_order = $post['new_attr_sort_order'];
  303. foreach($post as $k => $v) {
  304. $attr_id = str_replace('shop_attr_', '', $k);
  305. if(!strstr($k, 'shop_attr_')) continue;
  306. foreach ($v as $k2 => $v2) {
  307. $v2 = trim($v2);
  308. if(empty($v2)) continue;
  309. $tmp_key = $attr_id . "_" . $v2 . "_" . $sort_order[$attr_id];
  310. if(!array_key_exists($tmp_key, $old_product_attr)) {
  311. // 数据库中不存在 说明要做删除操作
  312. $adddata = array(
  313. 'aid' => $aid,
  314. 'attr_id' => $attr_id,
  315. 'attr_value' => $v2,
  316. 'sort_order' => $sort_order[$attr_id],
  317. 'add_time' => getTime(),
  318. 'update_time' => getTime(),
  319. );
  320. $ShopProductAttr->add($adddata);
  321. }
  322. unset($old_product_attr[$tmp_key]);
  323. }
  324. }
  325. // 没有被 unset($old_product_attr[$tmp_key]); 掉是 说明 数据库中存在 表单中没有提交过来则要删除操作
  326. foreach($old_product_attr as $k => $v) {
  327. $ShopProductAttr->where('product_attr_id = '.$v['product_attr_id'])->delete();
  328. }
  329. }
  330. }