edit_product.php 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290
  1. <?php
  2. require_once('conn.php');
  3. require_once('functions.php');
  4. // Check login status
  5. checkLogin("信息管理");
  6. // Initialize variables
  7. $id = isset($_GET['id']) ? (int)$_GET['id'] : 0;
  8. $keys = isset($_GET['Keys']) ? urlencode($_GET['Keys']) : '';
  9. $page = isset($_GET['Page']) ? $_GET['Page'] : 1;
  10. $category_id = isset($_GET['category_id']) ? intval($_GET['category_id']) : 0;
  11. // Get the return URL
  12. $href_str = "products.php?keys=" . $keys . "&Page=" . $page;
  13. if ($category_id) {
  14. $href_str .= "&category_id=" . $category_id;
  15. }
  16. // Check if the product exists
  17. if ($id <= 0) {
  18. header("Location: " . $href_str);
  19. exit();
  20. }
  21. // Fetch product data
  22. $sql = "SELECT * FROM products WHERE id = " . (int)$id;
  23. $result = mysqli_query($conn, $sql);
  24. if (mysqli_num_rows($result) <= 0) {
  25. // Product not found, redirect
  26. header("Location: " . $href_str);
  27. exit();
  28. }
  29. $row = mysqli_fetch_assoc($result);
  30. $product_name = htmlspecialcharsFix($row['ProductName']);
  31. $product_img = htmlspecialcharsFix($row['ProductImg']);
  32. $unit = htmlspecialcharsFix($row['unit']);
  33. $moq = htmlspecialcharsFix($row['moq']);
  34. $nosale = $row['nosale'];
  35. $note = htmlspecialcharsFix($row['note']);
  36. $tips = htmlspecialcharsFix($row['tips']);
  37. $category_id = $row['category_id'] ? intval($row['category_id']) : 0;
  38. ?>
  39. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  40. <html xmlns="http://www.w3.org/1999/xhtml">
  41. <head>
  42. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  43. <title>编辑产品</title>
  44. <link rel="stylesheet" href="css/common.css" type="text/css" />
  45. <script language="javascript" src="js/jquery-1.7.2.min.js"></script>
  46. <script type="text/javascript" src="js/js.js"></script>
  47. <script type="text/javascript" src="js/SearchArea.js"></script>
  48. <script type="text/javascript" src="xheditor-1.1.9/xheditor-1.1.9-zh-cn.min.js"></script>
  49. <style>
  50. /* Styles for specification section */
  51. .specifications {
  52. margin-bottom: 10px;
  53. width: 100%;
  54. }
  55. .specitem {
  56. margin-bottom: 8px;
  57. padding: 8px 10px;
  58. /*background-color: #f9f9f9;*/
  59. border: 1px solid #e0e0e0;
  60. border-radius: 4px;
  61. clear: both;
  62. overflow: hidden;
  63. }
  64. .addspecitem, .delspecitem {
  65. display: inline-block;
  66. width: 20px;
  67. height: 20px;
  68. text-align: center;
  69. line-height: 18px;
  70. border-radius: 50%;
  71. font-weight: bold;
  72. cursor: pointer;
  73. margin-left: 10px;
  74. }
  75. .addspecitem {
  76. background-color: #5cb85c;
  77. color: white;
  78. }
  79. .delspecitem {
  80. background-color: #d9534f;
  81. color: white;
  82. }
  83. .spec-input {
  84. width: 160px;
  85. padding: 4px;
  86. margin-right: 10px;
  87. border: 1px solid #ccc;
  88. border-radius: 3px;
  89. }
  90. .spec-small-input {
  91. width: 80px;
  92. padding: 4px;
  93. margin-right: 10px;
  94. border: 1px solid #ccc;
  95. border-radius: 3px;
  96. }
  97. .spec-label {
  98. display: inline-block;
  99. margin-right: 5px;
  100. font-weight: normal;
  101. }
  102. .required {
  103. color: red;
  104. margin-left: 2px;
  105. }
  106. </style>
  107. </head>
  108. <body>
  109. <div id="man_zone">
  110. <form name="form1" method="post" action="save_product.php">
  111. <table width="100%" border="0" cellpadding="3" cellspacing="1" class="table1">
  112. <tbody>
  113. <tr>
  114. <th width="8%">产品名称</th>
  115. <td><input type="text" id="ProductName" name="ProductName" value="<?php echo $product_name; ?>" class="txt1" />
  116. <input type="hidden" name="id" value="<?php echo $id; ?>" />
  117. <input type="hidden" name="keys" value="<?php echo $keys; ?>" />
  118. <input type="hidden" name="page" value="<?php echo $page; ?>" />
  119. <input type="hidden" name="category_id" value="<?php echo $category_id; ?>" />
  120. </td>
  121. </tr>
  122. <tr>
  123. <th width="8%">产品分类</th>
  124. <td>
  125. <select name="category_id" id="category_id" class="select1">
  126. <option value="0">-- 请选择分类 --</option>
  127. <?php
  128. // Build category tree
  129. $category_data = buildCategoryTree($conn);
  130. $cat_tree = $category_data['tree'];
  131. // Output options
  132. outputCategoryOptions($cat_tree, $category_id);
  133. ?>
  134. </select>
  135. </td>
  136. </tr>
  137. <tr>
  138. <th width="8%">产品图片</th>
  139. <td><input type="text" id="ProductImg" name="ProductImg" placeholder="186x*186px" value="<?php echo $product_img; ?>" class="txt1" style="width:390px;float:left;" />
  140. <iframe src="uploadfile.php" frameborder="0" scrolling="no" style="width:400px;height:22px;float:left;margin-left:10px;"></iframe></td>
  141. </tr>
  142. <tr>
  143. <th width="8%">计价单位</th>
  144. <td><input type="text" id="unit" name="unit" value="<?php echo $unit; ?>" class="txt1"/></td>
  145. </tr>
  146. <!-- <tr>-->
  147. <!-- <th width="8%">起订数量</th>-->
  148. <!-- <td><input type="text" id="moq" name="moq" value="--><?php //echo $moq; ?><!--" class="txt1"/></td>-->
  149. <!-- </tr>-->
  150. <tr>
  151. <th width="8%">产品规格</th>
  152. <td>
  153. <div class="specifications">
  154. <?php
  155. // Fetch specifications for this product
  156. $spec_sql = "SELECT * FROM product_specifications WHERE product_id = " . (int)$id . " ORDER BY sort_order ASC";
  157. $spec_result = mysqli_query($conn, $spec_sql);
  158. if (mysqli_num_rows($spec_result) > 0) {
  159. while ($spec_row = mysqli_fetch_assoc($spec_result)) {
  160. ?>
  161. <div class="specitem">
  162. <span class="spec-label">规格名称<span class="required">*</span>:</span>
  163. <input type="text" class="spec-input" name="spec_name[]" placeholder="如: 红色、XL" value="<?php echo htmlspecialcharsFix($spec_row['spec_name']); ?>" required>
  164. <span class="spec-label">起订数量<span class="required">*</span>:</span>
  165. <input type="number" class="spec-small-input" name="spec_moq[]" value="<?php echo $spec_row['min_order_quantity']; ?>" required>
  166. <span class="spec-label">规格价格<span class="required">*</span>:</span>
  167. <input type="text" class="spec-small-input" name="spec_price[]" placeholder="价格" value="<?php echo $spec_row['price']; ?>" required>
  168. <span class="addspecitem">+</span>
  169. <span class="delspecitem">-</span>
  170. <!-- 隐藏字段,保留原始数据 -->
  171. <input type="hidden" name="spec_value[]" value="<?php echo htmlspecialcharsFix($spec_row['spec_value']); ?>">
  172. <input type="hidden" name="spec_code[]" value="<?php echo htmlspecialcharsFix($spec_row['spec_code']); ?>">
  173. <input type="hidden" name="spec_sort[]" value="<?php echo $spec_row['sort_order']; ?>">
  174. </div>
  175. <?php
  176. }
  177. } else {
  178. // No specifications found, show one empty form
  179. ?>
  180. <div class="specitem">
  181. <span class="spec-label">规格名称<span class="required">*</span>:</span>
  182. <input type="text" class="spec-input" name="spec_name[]" placeholder="如: 红色、XL" required>
  183. <span class="spec-label">起订数量<span class="required">*</span>:</span>
  184. <input type="number" class="spec-small-input" name="spec_moq[]" value="1" required>
  185. <span class="spec-label">规格价格<span class="required">*</span>:</span>
  186. <input type="text" class="spec-small-input" name="spec_price[]" placeholder="价格" required>
  187. <span class="addspecitem">+</span>
  188. <span class="delspecitem">-</span>
  189. <!-- 隐藏字段,仍然提交但不显示 -->
  190. <input type="hidden" name="spec_value[]" value="">
  191. <input type="hidden" name="spec_code[]" value="">
  192. <input type="hidden" name="spec_sort[]" value="0">
  193. </div>
  194. <?php
  195. }
  196. ?>
  197. </div>
  198. </td>
  199. </tr>
  200. <tr>
  201. <th width="8%">不报价地区</th>
  202. <td>
  203. <ul class="areadd">
  204. <?php
  205. if (!empty($nosale)) {
  206. // 确保nosale是逗号分隔的字符串格式
  207. $nosale_str = is_array($nosale) ? implode(',', $nosale) : $nosale;
  208. $area_sql = "SELECT id, countryName FROM country WHERE id IN(" . $nosale_str . ")";
  209. $area_result = mysqli_query($conn, $area_sql);
  210. while ($area_row = mysqli_fetch_assoc($area_result)) {
  211. ?>
  212. <li><input type="hidden" name="nosale[]" value="<?php echo $area_row['id']; ?>"><span class="cname"><?php echo htmlspecialcharsFix($area_row['countryName']); ?></span><span class="close"></span></li>
  213. <?php
  214. }
  215. }
  216. ?>
  217. </ul>
  218. <input type="text" id="AreaSearch" class="fastsearch">
  219. <div id="arealist" class="productlist"><ul></ul></div>
  220. </td>
  221. </tr>
  222. <tr>
  223. <th width="8%">不报价处理方式</th>
  224. <td><input type="text" id="note" name="note" value="<?php echo $note; ?>" class="txt1"/></td>
  225. </tr>
  226. <tr>
  227. <th width="8%">备注</th>
  228. <td><input type="text" id="tips" name="tips" value="<?php echo $tips; ?>" class="txt1"/></td>
  229. </tr>
  230. <tr>
  231. <th></th>
  232. <td colspan="2">
  233. <input type="submit" name="save" value="确定" class="btn1" />
  234. <input type="reset" name="reset" value="重置" class="btn1" />
  235. <input type="button" value="返回" class="btn1" onClick="location.href='<?php echo $href_str; ?>'" />
  236. </td>
  237. </tr>
  238. </tbody>
  239. </table>
  240. </form>
  241. </div>
  242. <script>
  243. $(document).ready(function(){
  244. // Add specification item
  245. $(document).on('click', '.addspecitem', function(){
  246. var newSpecItem = $(this).closest('.specitem').clone(true);
  247. newSpecItem.find('input[type="text"], input[type="hidden"]').val(''); // Clear values
  248. newSpecItem.find('input[name="spec_moq[]"]').val('1'); // Reset MOQ to 1
  249. newSpecItem.find('input[name="spec_sort[]"]').val('0'); // Reset sort to 0
  250. $(this).closest('.specifications').append(newSpecItem);
  251. });
  252. // Remove specification item
  253. $(document).on('click', '.delspecitem', function(){
  254. if($('.specitem').length > 1){
  255. $(this).closest('.specitem').remove();
  256. } else {
  257. alert('至少需要保留一个规格项');
  258. }
  259. });
  260. // Update unit display when unit field changes
  261. $('#unit').on('change keyup', function(){
  262. $('.unit').text($(this).val());
  263. });
  264. });
  265. </script>
  266. </body>
  267. </html>
  268. <?php mysqli_close($conn); ?>