info.blade.php 17 KB

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