add.html 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241
  1. {extend name="app/shop/view/base.html"/}
  2. {block name="resources"}
  3. <style type="text/css">
  4. .price-wrap{display: flex;top: 4px;position: relative;}
  5. .price-wrap > span {display: inline-block;margin: 0 5px;}
  6. .price-wrap > span.sepa{margin: 0 20px;}
  7. </style>
  8. {/block}
  9. {block name="main"}
  10. <div class="layui-form form-wrap">
  11. <div class="layui-form-item">
  12. <label class="layui-form-label"></label>
  13. <div class="layui-input-block">
  14. <button class="layui-btn" onclick="addGoods()">选择商品</button>
  15. </div>
  16. </div>
  17. <div class="layui-form-item">
  18. <label class="layui-form-label"><span class="required">*</span>商品名称:</label>
  19. <div class="layui-input-block">
  20. <input type="text" name="name" lay-verify="required|name" class="layui-input ns-len-mid" autocomplete="off" maxlength="14">
  21. </div>
  22. <div class="word-aux">
  23. <!-- <p>商品名称必须为3-14个字符</p> -->
  24. </div>
  25. </div>
  26. <div class="layui-form-item">
  27. <label class="layui-form-label"><span class="required">*</span>商品封面:</label>
  28. <div class="layui-input-block">
  29. <div class="upload-img-block">
  30. <div class="upload-img-box ">
  31. <div class="upload-default" id="ImgUpload">
  32. <div class="upload">
  33. <i class="iconfont iconshangchuan"></i>
  34. <p>选择商品</p>
  35. </div>
  36. </div>
  37. <div class="operation">
  38. <div>
  39. <i title="图片预览" class="iconfont iconreview js-preview" style="margin-right: 20px;"></i>
  40. <i title="删除图片" class="layui-icon layui-icon-delete js-delete"></i>
  41. </div>
  42. <div class="replace_img js-replace">点击替换</div>
  43. </div>
  44. <input type="hidden" name="goods_pic" value="" lay-verify="goodsPic"/>
  45. </div>
  46. <!-- <p id="ImgUpload" class="no-replace">替换</p>
  47. <input type="hidden" name="goods_pic" value="" lay-verify="goodsPic"/>
  48. <i class="del">x</i> -->
  49. </div>
  50. </div>
  51. <div class="word-aux">
  52. <p>建议尺寸:200像素 * 200像素,图片大小不得超过80K</p>
  53. </div>
  54. </div>
  55. <div class="layui-form-item">
  56. <label class="layui-form-label"><span class="required">*</span>价格形式:</label>
  57. <div class="layui-input-block">
  58. <div class="layui-input-inline">
  59. <input type="radio" name="price_type" value="1" title="一口价" checked>
  60. </div>
  61. <div class="layui-input-inline price-wrap">
  62. <span>价格</span>
  63. <input class="layui-input len-short input-num" type="number" min="0" name="price" value="0.00" lay-verify="required|flnum">
  64. <span>元</span>
  65. </div>
  66. </div>
  67. </div>
  68. <div class="layui-form-item">
  69. <label class="layui-form-label"></label>
  70. <div class="layui-input-block">
  71. <div class="layui-input-inline">
  72. <input type="radio" name="price_type" value="2" title="价格区间">
  73. </div>
  74. <div class="layui-input-inline price-wrap">
  75. <span>价格</span>
  76. <input class="layui-input len-short input-num" type="number" min="0" name="price" value="0.00" lay-verify="required|flnum">
  77. <span>元</span>
  78. <span class="sepa">-</span>
  79. <input class="layui-input len-short input-num" type="number" min="0" name="price2" value="0.00" lay-verify="required|flnum">
  80. <span>元</span>
  81. </div>
  82. </div>
  83. </div>
  84. <div class="layui-form-item">
  85. <label class="layui-form-label"></label>
  86. <div class="layui-input-block">
  87. <div class="layui-input-inline">
  88. <input type="radio" name="price_type" value="3" title="显示折扣价">
  89. </div>
  90. <div class="layui-input-inline price-wrap">
  91. <span>原价</span>
  92. <input class="layui-input len-short input-num" type="number" min="0" name="price" value="0.00" lay-verify="required|flnum">
  93. <span>元</span>
  94. <span class="sepa"></span>
  95. <span>现价</span>
  96. <input class="layui-input len-short input-num" type="number" min="0" name="price2" value="0.00" lay-verify="required|flnum">
  97. <span>元</span>
  98. </div>
  99. </div>
  100. </div>
  101. <div class="layui-form-item">
  102. <label class="layui-form-label"><span class="required">*</span>商品链接:</label>
  103. <div class="layui-input-block">
  104. <input type="text" name="url" lay-verify="required" class="layui-input len-mid" autocomplete="off">
  105. </div>
  106. <div class="word-aux">
  107. <p>请确保小程序页面路径可被访问,例如:pages/goods/detail?sku_id=sku_id</p>
  108. </div>
  109. </div>
  110. <div class="form-row">
  111. <button class="layui-btn" lay-submit lay-filter="save">添加</button>
  112. <button class="layui-btn layui-btn-primary" onclick="back()">返回</button>
  113. </div>
  114. </div>
  115. {/block}
  116. {block name="script"}
  117. <script type="text/javascript">
  118. var form,repeat_flag=false;
  119. layui.use(['form'], function() {
  120. form = layui.form;
  121. form.render();
  122. var upload = new Upload({
  123. elem: '#ImgUpload',
  124. multiple: true,
  125. });
  126. /**
  127. * 表单验证
  128. */
  129. form.verify({
  130. name: function(value){
  131. if (value.length < 3 || value.length > 14) {
  132. return '商品名称必须为3-14个字符';
  133. }
  134. },
  135. goodsPic: function(value){
  136. var patt = /[\S]+/;
  137. if (!patt.test(value)) {
  138. return '请上传商品封面!';
  139. }
  140. },
  141. });
  142. form.on('submit(save)', function(data){
  143. if (repeat_flag) return;
  144. repeat_flag = true;
  145. if (data.field.price_type == 1) {
  146. data.field.price = parseFloat($('[name="price_type"][value="1"]').parents('.layui-input-block').find('[name="price"]').val());
  147. data.field.price2 = 0;
  148. if (data.field.price <= 0) {
  149. layer.msg('请输入商品价格', {icon: 5, shift: 6});
  150. return;
  151. }
  152. } else if (data.field.price_type == 2) {
  153. data.field.price = parseFloat($('[name="price_type"][value="2"]').parents('.layui-input-block').find('[name="price"]').val());
  154. data.field.price2 = parseFloat($('[name="price_type"][value="2"]').parents('.layui-input-block').find('[name="price2"]').val());
  155. if (data.field.price <= 0 || data.field.price2 <= 0) {
  156. layer.msg('请输入商品价格', {icon: 5, shift: 6});
  157. return;
  158. }
  159. } else if (data.field.price_type == 3) {
  160. data.field.price = parseFloat($('[name="price_type"][value="3"]').parents('.layui-input-block').find('[name="price"]').val());
  161. data.field.price2 = parseFloat($('[name="price_type"][value="3"]').parents('.layui-input-block').find('[name="price2"]').val());
  162. if (data.field.price <= 0) {
  163. layer.msg('请输入原价', {icon: 5, shift: 6});
  164. return;
  165. }
  166. if (data.field.price2 <= 0) {
  167. layer.msg('请输入现价', {icon: 5, shift: 6});
  168. return;
  169. }
  170. if (data.field.price2 >= data.field.price) {
  171. layer.msg('现价不能小于或等于原价', {icon: 5, shift: 6});
  172. return;
  173. }
  174. }
  175. $.ajax({
  176. type: 'POST',
  177. url: ns.url("live://shop/goods/add"),
  178. data: data.field,
  179. dataType: 'JSON',
  180. success: function(res) {
  181. layer.msg(res.message);
  182. repeat_flag = false;
  183. if (res.code == 0) {
  184. location.href = ns.url("live://shop/goods/index");
  185. }
  186. }
  187. });
  188. });
  189. });
  190. function back() {
  191. location.href = ns.url("live://shop/goods/index");
  192. }
  193. /**
  194. * 添加商品
  195. */
  196. function addGoods(){
  197. goodsSelect(function (res) {
  198. if (res[0] != undefined) {
  199. var data = res[0],
  200. sku_id = data.sku_list[0].sku_id,
  201. images = data.goods_image.split(',');
  202. $('[name="name"]').val(data.goods_name);
  203. if (images[0] != undefined) {
  204. $("input[name='goods_pic']").val(imgHandle(images[0]));
  205. $("#ImgUpload").html("<div id='preview_imgUpload' class='preview_img'><img layer-src class='img_prev' src=" + ns.img(images[0]) + " ></div>");
  206. // $("#ImgUpload").html("<img src=" + ns.img(images[0]) + " >");
  207. // $("#ImgUpload").removeClass("no-replace").addClass("replace");
  208. loadImgMagnify();
  209. $('#ImgUpload').parents('.upload-img-box ').addClass('hover')
  210. }
  211. $('[name="url"]').val('pages/goods/detail?sku_id=' + sku_id);
  212. $('[name="price_type"][value="1"]').prop('checked', true);
  213. $('[name="price_type"][value="1"]').parents('.layui-input-block').find('[name="price"]').val(data.price);
  214. form.render();
  215. }
  216. }, [], {mode: "spu", min_num: 1, promotion: []});
  217. }
  218. function imgHandle(src){
  219. var arr = src.split("."),
  220. suffix = arr[arr.length - 1];
  221. arr.pop();
  222. arr[arr.length - 1] = arr[arr.length - 1] + "_SMALL";
  223. arr.push(suffix);
  224. src = arr.join(".");
  225. return src;
  226. }
  227. </script>
  228. {/block}