addGoods.blade.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225
  1. @extends('admin.layouts')
  2. @section('css')
  3. <link href="/assets/global/vendor/bootstrap-select/bootstrap-select.min.css" type="text/css" rel="stylesheet">
  4. <link href="/assets/global/vendor/ascolorpicker/asColorPicker.min.css" type="text/css" rel="stylesheet">
  5. <link href="/assets/global/vendor/dropify/dropify.min.css" type="text/css" rel="stylesheet">
  6. <style type="text/css">
  7. .text-help {
  8. padding-left: 1.0715rem;
  9. }
  10. </style>
  11. @endsection
  12. @section('content')
  13. <div class="page-content container">
  14. <div class="panel panel-bordered">
  15. <div class="panel-heading">
  16. <h1 class="panel-title"><i class="icon wb-shopping-cart" aria-hidden="true"></i>添加商品</h1>
  17. </div>
  18. @if (Session::has('successMsg'))
  19. <div class="alert alert-success alert-dismissible">
  20. <button type="button" class="close" data-dismiss="alert" aria-label="Close"><span aria-hidden="true">×</span></button>
  21. {{Session::get('successMsg')}}
  22. </div>
  23. @endif
  24. @if($errors->any())
  25. <div class="alert alert-danger alert-dismissible">
  26. <button type="button" class="close" data-dismiss="alert" aria-label="Close"><span aria-hidden="true">×</span></button>
  27. <span> {{$errors->first()}} </span>
  28. </div>
  29. @endif
  30. <div class="alert alert-info alert-dismissible" role="alert">
  31. <button type="button" class="close" data-dismiss="alert" aria-label="Close"><span aria-hidden="true">×</span></button>
  32. <h4>面板关于商品的规则</h4>
  33. <ul>
  34. <li>警告:用户购买新套餐则会覆盖所有已购但未过期的旧套餐并删除这些旧套餐对应的流量,所以设置商品时请务必注意类型和有效期,流量包则可叠加</li>
  35. <li>套餐:仅展示12个上架的商品;流量:仅展示12个上架的商品</li>
  36. <li>注意:添加后无法更改授予等级、商品类型;套餐有效期90天起,因为套餐每月会重置流量</li>
  37. </ul>
  38. </div>
  39. <div class="panel-body">
  40. <form action="/shop/addGoods" method="post" enctype="multipart/form-data" class="form-horizontal" role="form">
  41. {{csrf_field()}}
  42. <div class="form-row">
  43. <div class="col-lg-6 col-md-12">
  44. <div class="form-group row">
  45. <label class="col-md-3 col-form-label" for="type">类型</label>
  46. <div class="col-md-9 d-flex align-items-center">
  47. <div class="radio-custom radio-primary radio-inline">
  48. <input type="radio" name="type" value="1" checked/>
  49. <label for="type">流量包</label>
  50. </div>
  51. <div class="radio-custom radio-primary radio-inline">
  52. <input type="radio" name="type" value="2"/>
  53. <label for="type">套餐</label>
  54. </div>
  55. <div class="radio-custom radio-primary radio-inline">
  56. <input type="radio" name="type" value="3"/>
  57. <label for="type">充值</label>
  58. </div>
  59. </div>
  60. <span class="offset-md-3 text-help"> 套餐与账号有效期有关,流量包只扣可用流量,不影响有效期 </span>
  61. </div>
  62. <div class="form-group row">
  63. <label class="col-md-3 col-form-label" for="name">名称</label>
  64. <div class="col-md-6">
  65. <input type="text" class="form-control" name="name" id="name" value="{{Request::old('name')}}" required/>
  66. </div>
  67. </div>
  68. <div class="form-group row package-money">
  69. <label class="col-md-3 col-form-label" for="traffic">流量额度</label>
  70. <div class="col-md-4 input-group">
  71. <input type="number" class="form-control" name="traffic" id="traffic" value="{{Request::old('traffic')? :1024}}" required/>
  72. <span class="input-group-text">MB</span>
  73. </div>
  74. <span class="text-help"> *提交后不可修改 </span>
  75. </div>
  76. <div class="form-group row">
  77. <label class="col-md-3 col-form-label" for="price">售价</label>
  78. <div class="col-md-4 input-group">
  79. <input type="number" class="form-control" name="price" id="price" value="{{Request::old('price')}}" step="0.01" required/>
  80. <span class="input-group-text">元</span>
  81. </div>
  82. </div>
  83. <div class="form-group row package-renew" style="display: none">
  84. <label class="col-md-3 col-form-label" for="renew">流量重置价格</label>
  85. <div class="col-md-4 input-group">
  86. <input type="number" class="form-control" name="renew" id="renew" value="{{Request::old('renew')? :0}}" step="0.01" required/>
  87. <span class="input-group-text">元</span>
  88. </div>
  89. <span class="offset-md-3 text-help"> 用户自行重置流量价格, <code>0</code> 时代表改该商品不提供重置功能 </span>
  90. </div>
  91. <div class="form-group row package-renew" style="display: none">
  92. <label class="col-md-3 col-form-label" for="period">重置周期</label>
  93. <div class="col-md-4 input-group">
  94. <input type="number" class="form-control" name="period" id="period" value="{{Request::old('period')? :30}}" required/>
  95. <span class="input-group-text">天</span>
  96. </div>
  97. <span class="offset-md-3 text-help"> 套餐流量会每N天重置 </span>
  98. </div>
  99. <div class="form-group row package-money">
  100. <label class="col-md-3 col-form-label" for="limit_num">限购数量</label>
  101. <div class="col-md-4 input-group">
  102. <input type="number" class="form-control" name="limit_num" id="limit_num" value="{{Request::old('limit_num')? :0}}" required/>
  103. <span class="input-group-text">次</span>
  104. </div>
  105. <span class="offset-md-3 text-help"> 每个用户可以购买该商品次数,为 <code>0</code> 时代表不限购 </span>
  106. </div>
  107. <div class="form-group row package-money">
  108. <label class="col-md-3 col-form-label" for="labels">标签</label>
  109. <div class="col-md-8">
  110. <select class="form-control show-tick" name="labels[]" id="labels" data-plugin="selectpicker" data-style="btn-outline btn-primary" multiple>
  111. @foreach($label_list as $label)
  112. <option value="{{$label->id}}">{{$label->name}}</option>
  113. @endforeach
  114. </select>
  115. </div>
  116. <span class="offset-md-3 text-help"> 自动给购买此商品的用户打上相应的标签 </span>
  117. </div>
  118. <div class="form-group row package-renew" style="display: none">
  119. <label class="col-md-3 col-form-label" for="days">有效期</label>
  120. <div class="col-md-3 input-group">
  121. <input type="number" class="form-control" name="days" id="days" value="{{Request::old('days')? :30}}" required/>
  122. <span class="input-group-text">天</span>
  123. </div>
  124. <span class="text-help"> *提交后不可修改 </span>
  125. </div>
  126. <div class="form-group row package-money">
  127. <label class="col-md-3 col-form-label" for="is_hot">热销</label>
  128. <div class="col-md-9 d-flex align-items-center">
  129. <div class="radio-custom radio-primary radio-inline">
  130. <input type="radio" name="is_hot" value="1"/>
  131. <label for="is_hot">是</label>
  132. </div>
  133. <div class="radio-custom radio-primary radio-inline">
  134. <input type="radio" name="is_hot" value="0" checked/>
  135. <label for="is_hot">否</label>
  136. </div>
  137. </div>
  138. </div>
  139. <div class="form-group row">
  140. <label class="col-md-3 col-form-label" for="status">状态</label>
  141. <div class="col-md-9 d-flex align-items-center">
  142. <div class="radio-custom radio-primary radio-inline">
  143. <input type="radio" name="status" value="1" checked/>
  144. <label for="status">上架</label>
  145. </div>
  146. <div class="radio-custom radio-primary radio-inline">
  147. <input type="radio" name="status" value="0"/>
  148. <label for="status">下架</label>
  149. </div>
  150. </div>
  151. </div>
  152. </div>
  153. <div class="col-lg-6 col-md-12 package-money">
  154. <div class="form-group row">
  155. <label class="col-md-3 col-form-label" for="sort">排序</label>
  156. <div class="col-md-3">
  157. <input type="number" class="form-control" name="sort" id="sort" value="{{Request::old('sort')? :0}}"/>
  158. </div>
  159. <span class="text-help"> 排序值越大排越前 </span>
  160. </div>
  161. <div class="form-group row">
  162. <label class="col-md-3 col-form-label" for="color">颜色</label>
  163. <div class="col-md-4">
  164. <input type="text" class="form-control" name="color" id="color" data-plugin="asColorPicker" data-mode="simple" value="{{Request::old('color')? :'#667AFA'}}"/>
  165. </div>
  166. </div>
  167. <div class="form-group row">
  168. <label class="col-md-3 col-form-label" for="logo">商品图片</label>
  169. <div class="col-md-9">
  170. <input type="file" id="logo" name="logo" data-plugin="dropify" data-default-file="/assets/images/noimage.png"/>
  171. </div>
  172. </div>
  173. <div class="form-group row">
  174. <label class="col-md-3 col-form-label" for="desc">描述</label>
  175. <div class="col-md-9">
  176. <textarea class="form-control" rows="2" name="desc" id="desc" placeholder="商品的简单描述">{{Request::old('desc')}}</textarea>
  177. </div>
  178. </div>
  179. <div class="form-group row">
  180. <label class="col-md-3 col-form-label" for="info">自定义列表</label>
  181. <div class="col-md-9">
  182. <textarea class="form-control" rows="6" name="info" id="info" placeholder="商品的自定义列表添加">{{Request::old('info')}}</textarea>
  183. </div>
  184. <span class="offset-md-3 text-help"> 每行内容请以<code>&lt;li&gt;</code> 开头 <code>&lt;/li&gt;</code> 结尾</span>
  185. </div>
  186. </div>
  187. <div class="form-actions col-12 text-right">
  188. <a href="/shop/goodsList" class="btn btn-danger"> 返 回</a>
  189. <button type="submit" class="btn btn-success"><i class="icon wb-check"></i> 提 交</button>
  190. </div>
  191. </div>
  192. </form>
  193. </div>
  194. </div>
  195. </div>
  196. @endsection
  197. @section('script')
  198. <script src="/assets/global/vendor/bootstrap-select/bootstrap-select.min.js" type="text/javascript"></script>
  199. <script src="/assets/global/vendor/ascolor/jquery-asColor.min.js" type="text/javascript"></script>
  200. <script src="/assets/global/vendor/asgradient/jquery-asGradient.min.js" type="text/javascript"></script>
  201. <script src="/assets/global/vendor/ascolorpicker/jquery-asColorPicker.min.js" type="text/javascript"></script>
  202. <script src="/assets/global/vendor/dropify/dropify.min.js" type="text/javascript"></script>
  203. <script src="/assets/global/js/Plugin/bootstrap-select.js" type="text/javascript"></script>
  204. <script src="/assets/global/js/Plugin/ascolorpicker.js" type="text/javascript"></script>
  205. <script src="/assets/global/js/Plugin/dropify.js" type="text/javascript"></script>
  206. <script type="text/javascript">
  207. // 选择商品类型
  208. $("input[name='type']").change(function () {
  209. const type = $(this).val();
  210. if (type === '3') {
  211. $(".package-money").hide();
  212. } else {
  213. $(".package-money").show();
  214. }
  215. if (type === '2') {
  216. $(".package-renew").show();
  217. } else {
  218. $(".package-renew").hide();
  219. }
  220. });
  221. </script>
  222. @endsection