index.blade.php 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. @extends('base.base')
  2. @section('base')
  3. <meta name="csrf-token" content="{{ csrf_token() }}">
  4. <div class="container-fluid">
  5. <div class="row">
  6. <div class="col-12">
  7. <div class="card">
  8. <div class="card-header d-flex align-items-center justify-content-between">
  9. <h3 class="card-title mb-0">公用配置管理</h3>
  10. <small class="text-muted">编辑 5 档参数并一键保存</small>
  11. </div>
  12. <div class="card-body">
  13. @php
  14. $configData = $configs[0]['config'] ? $configs[0]['config'] : [
  15. "0" => ["FreeWinMax" => 1000, "TaxPercent" => 100, "RechargeMaxPercent" => 0, "RechargeMin" => 0, "RechargeMax" => 1],
  16. "1" => ["FreeWinMax" => 20, "TaxPercent" => 100, "RechargeMaxPercent" => 80, "RechargeMin" => 1, "RechargeMax" => 101],
  17. "2" => ["FreeWinMax" => 100, "TaxPercent" => 95, "RechargeMaxPercent" => 70, "RechargeMin" => 101, "RechargeMax" => 501],
  18. "3" => ["FreeWinMax" => 400, "TaxPercent" => 90, "RechargeMaxPercent" => 60, "RechargeMin" => 501, "RechargeMax" => 1001],
  19. "4" => ["FreeWinMax" => 8000, "TaxPercent" => 85, "RechargeMaxPercent" => 55, "RechargeMin" => 1001,"RechargeMax" => 10001],
  20. "5" => ["FreeWinMax" => 0,"TaxPercent" => 80, "RechargeMaxPercent" => 50, "RechargeMin" => 10001,"RechargeMax" => 99999999]
  21. ];
  22. @endphp
  23. <div class="table-responsive">
  24. <table class="table table-striped table-hover align-middle mb-0" style="min-width: 900px;">
  25. <thead class="thead-light">
  26. <tr>
  27. <th style="width:82px;">档位</th>
  28. <th style="width:180px;">充值区间下限 (RechargeMin)</th>
  29. <th style="width:180px;">充值区间上限 (RechargeMax)</th>
  30. <th style="width:180px;">固定值 (FreeWinMax)</th>
  31. <th style="width:180px;">充值最大百分比 (RechargeMaxPercent)</th>
  32. <th style="width:160px;">税收系数比例 (TaxPercent)</th>
  33. </tr>
  34. </thead>
  35. <tbody class="config-form">
  36. @foreach([0,1,2,3,4,5] as $level)
  37. <tr>
  38. <td>
  39. <span class="badge badge-primary">等级{{ $level }}</span>
  40. </td>
  41. <td>
  42. <input type="number" class="form-control form-control-sm"
  43. name="level[{{ $level }}][RechargeMin]"
  44. value="{{ $configData[$level]['RechargeMin'] ?? 0 }}" />
  45. </td>
  46. <td>
  47. <input type="number" class="form-control form-control-sm"
  48. name="level[{{ $level }}][RechargeMax]"
  49. value="{{ $configData[$level]['RechargeMax'] ?? 0 }}" />
  50. </td>
  51. <td>
  52. <input type="number" class="form-control form-control-sm"
  53. name="level[{{ $level }}][FreeWinMax]"
  54. value="{{ $configData[$level]['FreeWinMax'] ?? 0 }}" />
  55. </td>
  56. <td>
  57. <div class="input-group input-group-sm">
  58. <input type="number" class="form-control"
  59. name="level[{{ $level }}][RechargeMaxPercent]"
  60. value="{{ $configData[$level]['RechargeMaxPercent'] ?? 0 }}" />
  61. <div class="input-group-append"><span class="input-group-text">%</span></div>
  62. </div>
  63. </td>
  64. <td>
  65. <div class="input-group input-group-sm">
  66. <input type="number" class="form-control"
  67. name="level[{{ $level }}][TaxPercent]"
  68. value="{{ $configData[$level]['TaxPercent'] ?? 0 }}" />
  69. <div class="input-group-append"><span class="input-group-text">%</span></div>
  70. </div>
  71. </td>
  72. </tr>
  73. @endforeach
  74. </tbody>
  75. </table>
  76. </div>
  77. <div class="d-flex align-items-center mt-4">
  78. <button class="btn btn-gradient-primary btn-sm save-config">
  79. <i class="mdi mdi-content-save"></i> 保存配置
  80. </button>
  81. <span class="save-status ml-3"></span>
  82. </div>
  83. </div>
  84. </div>
  85. </div>
  86. </div>
  87. </div>
  88. <script>
  89. $(function() {
  90. $('.save-config').click(function(event) {
  91. const $form = $('.config-form');
  92. const $btn = $(this);
  93. const $status = $('.save-status');
  94. $btn.prop('disabled', true).html('<i class="fa fa-spinner fa-spin"></i> 保存中...');
  95. $status.html('').removeClass('text-success text-danger');
  96. let configObj = {"0":{},"1":{},"2":{},"3":{},"4":{},"5":{}};
  97. $form.find('input').each(function() {
  98. const name = this.name; // level[1][RechargeMin]
  99. const val = this.value;
  100. const m = name.match(/level\[(\d+)\]\[([^\]]+)\]/);
  101. if (m) {
  102. const lvl = m[1];
  103. const key = m[2];
  104. let num = (key === 'RechargeMaxPercent' || key === 'TaxPercent') ? parseInt(val || 0) : parseFloat(val || 0);
  105. if (isNaN(num)) num = 0;
  106. configObj[lvl][key] = num;
  107. }
  108. });
  109. $.post("{{ url('/admin/common-config/update') }}", {
  110. config: JSON.stringify(configObj),
  111. _token: "{{ csrf_token() }}"
  112. }).done(function(res){
  113. $btn.prop('disabled', false).html('<i class="mdi mdi-content-save"></i> 保存配置');
  114. if (res.status === 'success') {
  115. $status.text('更新成功').addClass('text-success');
  116. } else {
  117. $status.text(res.message || '更新失败').addClass('text-danger');
  118. }
  119. setTimeout(function(){ $status.fadeOut(function(){ $(this).text('').show().removeClass('text-success text-danger'); }); }, 3000);
  120. }).fail(function(){
  121. $btn.prop('disabled', false).html('<i class="mdi mdi-content-save"></i> 保存配置');
  122. $status.text('系统错误').addClass('text-danger');
  123. });
  124. });
  125. });
  126. </script>
  127. <style>
  128. .table thead th { white-space: nowrap; }
  129. .table tbody td { vertical-align: middle; }
  130. .input-group-text { min-width: 34px; justify-content: center; }
  131. .badge { font-size: .85rem; padding: .5em .6em; }
  132. </style>
  133. @endsection