goodsInfo.blade.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276
  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/custom/Plugin/bootstrap-switch/bootstrap-switch.min.css" type="text/css" rel="stylesheet">
  5. <link href="/assets/global/vendor/ascolorpicker/asColorPicker.min.css" type="text/css" rel="stylesheet">
  6. <link href="/assets/global/vendor/dropify/dropify.min.css" type="text/css" rel="stylesheet">
  7. <style type="text/css">
  8. .text-help {
  9. padding-left: 1.0715rem;
  10. }
  11. </style>
  12. @endsection
  13. @section('content')
  14. <div class="page-content container">
  15. <div class="panel panel-bordered">
  16. <div class="panel-heading">
  17. <h1 class="panel-title">
  18. <i class="icon wb-shopping-cart" aria-hidden="true"></i>
  19. @isset($goods) 编辑商品 @else 添加商品 @endisset
  20. </h1>
  21. <div class="panel-actions">
  22. <a href="{{url('/shop')}}" class="btn btn-danger">返 回</a>
  23. </div>
  24. </div>
  25. @if (Session::has('successMsg'))
  26. <div class="alert alert-success alert-dismissible" role="alert">
  27. <button type="button" class="close" data-dismiss="alert" aria-label="Close">
  28. <span aria-hidden="true">×</span>
  29. </button>
  30. {{Session::get('successMsg')}}
  31. </div>
  32. @endif
  33. @if($errors->any())
  34. <div class="alert alert-danger alert-dismissible" role="alert">
  35. <button type="button" class="close" data-dismiss="alert" aria-label="Close">
  36. <span aria-hidden="true">×</span>
  37. </button>
  38. <strong>错误:</strong> {{$errors->first()}}
  39. </div>
  40. @endif
  41. @if (Session::has('errorMsg'))
  42. <div class="alert alert-success alert-dismissible" role="alert">
  43. <button type="button" class="close" data-dismiss="alert" aria-label="Close">
  44. <span aria-hidden="true">×</span>
  45. </button>
  46. {{Session::get('errorMsg')}}
  47. </div>
  48. @endif
  49. <div class="panel-body">
  50. <form action=@isset($goods){{url('/shop/edit?id='.$goods->id)}} @else {{url('/shop/add')}} @endisset"" method="post" enctype="multipart/form-data" class="form-horizontal" role="form">
  51. {{csrf_field()}}
  52. <div class="form-row">
  53. <div class="col-lg-6 col-md-12">
  54. <div class="form-group row">
  55. <label class="col-md-2 col-form-label">类型</label>
  56. <div class="col-md-10 d-flex align-items-center">
  57. <div class="radio-custom radio-primary radio-inline">
  58. <input type="radio" name="type" id="data_package" value="1"/>
  59. <label for="data_package">流量包</label>
  60. </div>
  61. <div class="radio-custom radio-primary radio-inline">
  62. <input type="radio" name="type" id="data_plan" value="2"/>
  63. <label for="data_plan">套餐</label>
  64. </div>
  65. </div>
  66. <span class="offset-md-2 text-help"> 套餐与账号有效期有关,流量包只扣可用流量,不影响有效期 </span>
  67. </div>
  68. <div class="form-group row">
  69. <label class="col-md-2 col-form-label" for="name">名称</label>
  70. <div class="col-md-4">
  71. <input type="text" class="form-control" name="name" id="name" required/>
  72. </div>
  73. </div>
  74. <div class="form-group row">
  75. <label class="col-md-2 col-form-label" for="price">售价</label>
  76. <div class="col-md-4 input-group">
  77. <input type="number" class="form-control" name="price" id="price" step="0.01" required/>
  78. <span class="input-group-text">元</span>
  79. </div>
  80. </div>
  81. <div class="form-group row">
  82. <label for="level" class="col-md-2 col-form-label">等级</label>
  83. <div class="col-md-4">
  84. <select data-plugin="selectpicker" data-style="btn-outline btn-primary" class="form-control" name="level" id="level">
  85. @foreach ($level_list as $level)
  86. <option value="{{$level->level}}">{{$level->name}}</option>
  87. @endforeach
  88. </select>
  89. </div>
  90. </div>
  91. <div class="form-group row package-renew">
  92. <label class="col-md-2 col-form-label" for="renew">流量重置价格</label>
  93. <div class="col-md-4 input-group">
  94. <input type="number" class="form-control" name="renew" id="renew" step="0.01" value="0"/>
  95. <span class="input-group-text">元</span>
  96. </div>
  97. </div>
  98. <div class="form-group row package-renew">
  99. <label class="col-md-2 col-form-label" for="period">重置周期</label>
  100. <div class="col-md-4 input-group">
  101. <input type="number" class="form-control" name="period" id="period" value="0"/>
  102. <span class="input-group-text">天</span>
  103. </div>
  104. <span class="text-help"> 套餐流量会每N天重置 </span>
  105. </div>
  106. <div class="form-group row">
  107. <label class="col-md-2 col-form-label" for="traffic">流量额度</label>
  108. <div class="col-md-4 input-group">
  109. <input type="number" class="form-control" name="traffic" id="traffic"/>
  110. <span class="input-group-text">MB</span>
  111. </div>
  112. </div>
  113. <div class="form-group row">
  114. <label class="col-md-2 col-form-label" for="invite_num">赠送邀请码数量</label>
  115. <div class="col-md-4 input-group">
  116. <input type="number" class="form-control" name="invite_num" id="invite_num" required/>
  117. <span class="input-group-text">枚</span>
  118. </div>
  119. </div>
  120. <div class="form-group row">
  121. <label class="col-md-2 col-form-label" for="limit_num">限购数量</label>
  122. <div class="col-md-4 input-group">
  123. <input type="number" class="form-control" name="limit_num" id="limit_num" required/>
  124. <span class="input-group-text">次</span>
  125. </div>
  126. <span class="text-help"> 每个用户可以购买该商品次数,为 0 时代表不限购 </span>
  127. </div>
  128. <div class="form-group row package-renew">
  129. <label class="col-md-2 col-form-label" for="days">有效期</label>
  130. <div class="col-md-4 input-group">
  131. <input type="number" class="form-control" name="days" id="days" value="0"/>
  132. <span class="input-group-text">天</span>
  133. </div>
  134. <span class="text-help"> 到期后会自动从总流量扣减对应的流量 </span>
  135. </div>
  136. <div class="form-group row">
  137. <label class="col-md-2 col-form-label" for="is_hot">热销</label>
  138. <div class="col-md-10">
  139. <input type="checkbox" data-toggle="switch" name="is_hot" id="is_hot" data-on-color="primary" data-off-color="default" data-on-text="是" data-off-text="否" data-size="small">
  140. </div>
  141. </div>
  142. <div class="form-group row">
  143. <label class="col-md-2 col-form-label" for="status">状态</label>
  144. <div class="col-md-10">
  145. <input type="checkbox" data-toggle="switch" name="status" id="status" data-on-color="primary" data-off-color="default" data-on-text="上架" data-off-text="下架" data-size="small">
  146. </div>
  147. </div>
  148. </div>
  149. <div class="col-lg-6 col-md-12">
  150. <div class="form-group row">
  151. <label class="col-md-2 col-form-label" for="sort">排序</label>
  152. <div class="col-md-4">
  153. <input type="number" class="form-control" name="sort" id="sort"/>
  154. </div>
  155. <span class="text-help"> 排序值越大排越前 </span>
  156. </div>
  157. <div class="form-group row">
  158. <label class="col-md-2 col-form-label" for="color">颜色</label>
  159. <div class="col-md-4">
  160. <input type="text" class="form-control" name="color" id="color" data-plugin="asColorPicker" data-mode="simple"/>
  161. </div>
  162. </div>
  163. <div class="form-group row">
  164. <label class="col-md-2 col-form-label" for="logo">商品图片</label>
  165. <div class="col-md-6">
  166. <input type="file" id="logo" name="logo" data-plugin="dropify" data-default-file=@if(isset($goods) && $goods->logo) "{{$goods->logo}}" @else "/assets/images/default.png" @endif/>
  167. </div>
  168. </div>
  169. <div class="form-group row">
  170. <label class="col-md-2 col-form-label" for="description">描述</label>
  171. <div class="col-md-8">
  172. <textarea class="form-control" rows="2" name="description" id="description" placeholder="商品的简单描述"></textarea>
  173. </div>
  174. </div>
  175. <div class="form-group row">
  176. <label class="col-md-2 col-form-label" for="info">自定义列表</label>
  177. <div class="col-md-8">
  178. <textarea class="form-control" rows="6" name="info" id="info" placeholder="商品的自定义列表添加"></textarea>
  179. </div>
  180. <span class="offset-md-2 text-help"> 每行内容请以<code>&lt;li&gt;</code> 开头
  181. <code>&lt;/li&gt;</code> 结尾</span>
  182. </div>
  183. <div class="form-actions col-12 text-right">
  184. <button type="submit" class="btn btn-success"><i class="icon wb-check"></i> 提 交</button>
  185. </div>
  186. </div>
  187. </div>
  188. </form>
  189. </div>
  190. </div>
  191. </div>
  192. @endsection
  193. @section('script')
  194. <script src="/assets/global/vendor/bootstrap-select/bootstrap-select.min.js" type="text/javascript"></script>
  195. <script src="/assets/global/vendor/ascolor/jquery-asColor.min.js" type="text/javascript"></script>
  196. <script src="/assets/global/vendor/asgradient/jquery-asGradient.min.js" type="text/javascript"></script>
  197. <script src="/assets/global/vendor/ascolorpicker/jquery-asColorPicker.min.js" type="text/javascript"></script>
  198. <script src="/assets/global/vendor/dropify/dropify.min.js" type="text/javascript"></script>
  199. <script src="/assets/global/js/Plugin/bootstrap-select.js" type="text/javascript"></script>
  200. <script src="/assets/custom/Plugin/bootstrap-switch/bootstrap-switch.min.js" type="text/javascript"></script>
  201. <script src="/assets/global/js/Plugin/ascolorpicker.js" type="text/javascript"></script>
  202. <script src="/assets/global/js/Plugin/dropify.js" type="text/javascript"></script>
  203. <script type="text/javascript">
  204. $('[data-toggle="switch"]').bootstrapSwitch();
  205. @isset($goods)
  206. $(document).ready(function () {
  207. const type = $("input[name='type']")
  208. $("#id").val('{{$goods->id}}')
  209. $("input[name='type'][value='{{$goods->type}}']").click()
  210. type.attr("disabled", true)
  211. $("#name").val('{{$goods->name}}')
  212. $("#price").val('{{$goods->price}}')
  213. $('#level').selectpicker('val', '{{$goods->level}}')
  214. @if ($goods->type == 2)
  215. $("#renew").val('{{$goods->renew}}')
  216. $("#period").val('{{$goods->period}}')
  217. $("#days").val('{{$goods->days}}').attr("disabled", true)
  218. @endif
  219. $("#traffic").val('{{$goods->traffic}}').attr("disabled", true)
  220. $("#invite_num").val('{{$goods->invite_num}}')
  221. $("#limit_num").val('{{$goods->limit_num}}')
  222. @if ($goods->is_hot)
  223. $("#is_hot").click()
  224. @endif
  225. @if ($goods->status)
  226. $("#status").click()
  227. @endif
  228. $("#sort").val('{{$goods->sort}}')
  229. $("#color").asColorPicker('val', '{{$goods->color}}')
  230. $("#description").val('{{$goods->description}}')
  231. $("#info").val('{!! $goods->info !!}')
  232. })
  233. @elseif(old('type'))
  234. $(document).ready(function () {
  235. const type = $("input[name='type']")
  236. $("#id").val('{{old('id')}}')
  237. $("input[name='type'][value='{{old('type')}}']").click()
  238. $("#name").val('{{old('name')}}')
  239. $("#price").val('{{old('price')}}')
  240. $('#level').selectpicker('val', '{{old('level')}}')
  241. @if (old('type') == 2)
  242. $("#renew").val('{{old('renew',0)}}')
  243. $("#period").val('{{old('period',0)}}')
  244. $("#days").val('{{old('days',0)}}')
  245. @endif
  246. $("#traffic").val('{{old('traffic')}}')
  247. $("#invite_num").val('{{old('invite_num')}}')
  248. $("#limit_num").val('{{old('limit_num')}}')
  249. @if (old('is_hot'))
  250. $("#is_hot").click()
  251. @endif
  252. @if (old('status'))
  253. $("#status").click()
  254. @endif
  255. $("#sort").val('{{old('sort')}}')
  256. $("#color").asColorPicker('val', '{{old('color')}}')
  257. $("#description").val('{{old('description')}}')
  258. $("#info").val('{{old('info')}}')
  259. })
  260. @endisset
  261. function itemControl(value) {
  262. if (value === 1) {
  263. $(".package-renew").hide();
  264. } else {
  265. $(".package-renew").show();
  266. }
  267. }
  268. // 选择商品类型
  269. $("input[name='type']").change(function () {
  270. itemControl(parseInt($(this).val()));
  271. });
  272. </script>
  273. @endsection