index.vue 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282
  1. <template>
  2. <div class="rules">
  3. <table border="1" v-if="type == 'onLine' || !type">
  4. <tr>
  5. <th colspan="3">乐团&VIP&网管线上课</th>
  6. <th>以课程12:00:00-13:00:00为例</th>
  7. <th>扣费规则</th>
  8. </tr>
  9. <tr>
  10. <td rowspan="5">签到</td>
  11. <td>可签到时间范围</td>
  12. <td>课程<span class="r">开始前</span>20分钟至课程<span class="r">结束前</span>进入教室</td>
  13. <td>11:40:00-12:59:59</td>
  14. <td></td>
  15. </tr>
  16. <tr>
  17. <td>正常签到</td>
  18. <td>课程<span class="r">开始前</span>分钟至课程<span class="r">开始前</span>1分钟进入教室</td>
  19. <td>11:40:00-11:58:59</td>
  20. <td></td>
  21. </tr>
  22. <tr>
  23. <td>迟到</td>
  24. <td>课程<span class="r">开始前</span>1分钟至课程<span class="r">开始后</span>3分钟进入教室</td>
  25. <td>11:58:59-12:02:59</td>
  26. <td>-50%</td>
  27. </tr>
  28. <tr>
  29. <td>旷课</td>
  30. <td>课程开始后3分钟至课程<span class="r">结束前</span>进入教室</td>
  31. <td>12:03:00-12:59:59</td>
  32. <td>-100%</td>
  33. </tr>
  34. <tr>
  35. <td>未签到</td>
  36. <td>未进入网络教室</td>
  37. <td></td>
  38. <td>-100%</td>
  39. </tr>
  40. <tr>
  41. <td rowspan="5">签退</td>
  42. <td>可签退时间范围</td>
  43. <td>课程<span class="r">开始前</span>分钟至课程<span class="r">结束后</span>15分钟(课程结束后15分钟网络教室自动关闭)</td>
  44. <td>11:40:00-13:15:00</td>
  45. <td></td>
  46. </tr>
  47. <tr>
  48. <td>正常签退</td>
  49. <td>课程<span class="r">结束后</span>退出教室</td>
  50. <td>13:00:00-13:15:00</td>
  51. <td></td>
  52. </tr>
  53. <tr>
  54. <td>早退</td>
  55. <td>课程<span class="r">开始前</span>分钟至课程<span class="r">结束前</span>3分钟退出教室</td>
  56. <td>11:40:00-12:56:59</td>
  57. <td>-100%</td>
  58. </tr>
  59. <tr>
  60. <td>异常签退</td>
  61. <td>课程<span class="r">结束前</span>3分钟至课程<span class="r">结束前</span>退出教室</td>
  62. <td>12:57:00-12:59:59</td>
  63. <td>-50%</td>
  64. </tr>
  65. </table>
  66. <table border="1" v-if="type == 'offLine' || !type">
  67. <tr>
  68. <th colspan="3">乐团线下课</th>
  69. <th>以课程12:00:00-13:00:00为例</th>
  70. <th>扣费规则</th>
  71. </tr>
  72. <tr>
  73. <td rowspan="7">签到</td>
  74. <td>可签到时间范围</td>
  75. <td>课程<span class="r">开始前</span>1小时至课程<span class="r">结束前</span></td>
  76. <td>11:00:00-13:00:00</td>
  77. <td></td>
  78. </tr>
  79. <tr>
  80. <td>正常签到</td>
  81. <td>课程<span class="r">开始前</span>1小时至课程<span class="r">开始前</span>20分钟签到,GPS定位点在教学点1000米<span class="r">内</span></td>
  82. <td>10:00:00-11:39:59</td>
  83. <td></td>
  84. </tr>
  85. <tr>
  86. <td rowspan="2">异常签到</td>
  87. <td>课程<span class="r">开始前</span>1小时至课程<span class="r">开始前</span>20分钟签到,GPS定位点在教学点1000米<span class="r">外</span></td>
  88. <td></td>
  89. <td>-50</td>
  90. </tr>
  91. <tr>
  92. <td>课程<span class="r">开始前</span>20分钟后至课程<span class="r">开始前</span>签到</td>
  93. <td>11:40:00-11:59:59</td>
  94. <td>-50</td>
  95. </tr>
  96. <tr>
  97. <td>迟到</td>
  98. <td>课程<span class="r">开始后</span>30分钟内签到</td>
  99. <td>12:00:00-12:29:59</td>
  100. <td>-50%</td>
  101. </tr>
  102. <tr>
  103. <td>旷课</td>
  104. <td>课程<span class="r">开始后</span>30分钟至课程<span class="r">结束前</span>签到</td>
  105. <td>12:30:00-12:59:59</td>
  106. <td>-100%</td>
  107. </tr>
  108. <tr>
  109. <td>未签到</td>
  110. <td>未进行【签到】操作</td>
  111. <td>12:30:00-12:59:59</td>
  112. <td>-100%</td>
  113. </tr>
  114. <!-- -->
  115. <tr>
  116. <td rowspan="3">点名</td>
  117. <td>可点名时间范围</td>
  118. <td>课程<span class="r">开始前</span>1小时至课程<span class="r">结束后</span>6小时(当天24点前)(需先进行【签到】操作)</td>
  119. <td>11:00:00-18:59:59</td>
  120. <td></td>
  121. </tr>
  122. <tr>
  123. <td>正常点名</td>
  124. <td>进行了【点名】操作</td>
  125. <td></td>
  126. <td></td>
  127. </tr>
  128. <tr>
  129. <td>未点名</td>
  130. <td>未进行【点名】操作</td>
  131. <td></td>
  132. <td></td>
  133. </tr>
  134. <!-- -->
  135. <tr>
  136. <td rowspan="6">签退</td>
  137. <td>可签退时间范围</td>
  138. <td>课程<span class="r">结束后</span>到课程当天24点前</td>
  139. <td>13:00:00-23:59:59</td>
  140. <td></td>
  141. </tr>
  142. <tr>
  143. <td>正常签退</td>
  144. <td>课程<span class="r">结束后</span>至课程<span class="r">结束后</span>6小时,且GPS定位在教学点1000米<span class="r">外</span></td>
  145. <td>13:00:00-18:59:59</td>
  146. <td></td>
  147. </tr>
  148. <tr>
  149. <td>早退</td>
  150. <td>课程<span class="r">结束前</span>3分钟签退至课程<span class="r">结束前</span>签退</td>
  151. <td>12:56:59-12:59:59</td>
  152. <td>-100%</td>
  153. </tr>
  154. <tr>
  155. <td rowspan="2">异常签退</td>
  156. <td>课程<span class="r">结束6小时后</span>至课程<span class="r">当天</span>24点前</td>
  157. <td>19:00:00-23:59:59</td>
  158. <td rowspan="2">正常点名-50 <br />未点名-50%</td>
  159. </tr>
  160. <tr>
  161. <td>GPS定位点在教学点范围之外</td>
  162. <td></td>
  163. </tr>
  164. <tr>
  165. <td>未签退</td>
  166. <td>未进行【签退】操作</td>
  167. <td></td>
  168. <td>-100%</td>
  169. </tr>
  170. <tr>
  171. <td colspan="3"><span class="r">签到签退时间都在正常范围内,但同时GPS定位在教学点1000米外</span></td>
  172. <td></td>
  173. <td>-100%</td>
  174. </tr>
  175. </table>
  176. <table border="1" v-if="type == 'vipOffLine' || !type">
  177. <tr>
  178. <th colspan="3">VIP线下课</th>
  179. <th>以课程12:00:00-13:00:00为例</th>
  180. <th>扣费规则</th>
  181. </tr>
  182. <tr>
  183. <td rowspan="4">签到&签退</td>
  184. <td>可签到时间范围</td>
  185. <td>课程开始前20分钟至课程结束后20分钟</td>
  186. <td>11:40:00-13:19:59</td>
  187. <td></td>
  188. </tr>
  189. <tr>
  190. <td>正常签到签退</td>
  191. <td>操作了【点名】,GPS定位在教学点1000米<span class="r">内</span></td>
  192. <td></td>
  193. <td></td>
  194. </tr>
  195. <tr>
  196. <td>异常签到签退</td>
  197. <td>操作了【点名】,GPS定位在教学点1000米<span class="r">外</span></td>
  198. <td></td>
  199. <td>-100%</td>
  200. </tr>
  201. <tr>
  202. <td>未签到签退</td>
  203. <td>未进行【点名】</td>
  204. <td></td>
  205. <td>-100%</td>
  206. </tr>
  207. <tr>
  208. <td colspan="3"><span class="r">签到签退时间都在正常范围内,但同时GPS定位在教学点1000米外</span></td>
  209. <td></td>
  210. <td>-100%</td>
  211. </tr>
  212. </table>
  213. </div>
  214. </template>
  215. <script>
  216. import { sysConfigList } from './api'
  217. import setLoading from '@/utils/loading'
  218. export default {
  219. data() {
  220. let query = this.$route.query
  221. return {
  222. type: query.type || null,
  223. dataList: {}
  224. }
  225. },
  226. mounted() {
  227. this.__init()
  228. },
  229. methods: {
  230. async __init() {
  231. setLoading(true)
  232. await sysConfigList().then(res => {
  233. const result = res.data
  234. if(result.code == 200) {
  235. const { data } = result
  236. const dataList = this.dataList
  237. data.forEach(item => {
  238. switch(item.paramName) {
  239. case 'advance_sign_in_minutes':
  240. // 老师正常打卡时间,为课程当天,距离开课时间前{}分钟
  241. dataList.advance_sign_in_minutes = item.paranValue
  242. break;
  243. }
  244. });
  245. console.log(this.dataList)
  246. }
  247. })
  248. setLoading(false)
  249. }
  250. }
  251. }
  252. </script>
  253. <style lang="less" scoped>
  254. .rules {
  255. background: #ffffff;
  256. }
  257. table {
  258. border: 0;
  259. font-size: 12px;
  260. border-color: #cccccc;
  261. th {
  262. text-align: center;
  263. }
  264. th, td {
  265. padding: 5px;
  266. }
  267. tr:nth-child(even) {
  268. background-color: #f1f1f1;
  269. }
  270. }
  271. table + table {
  272. margin-top: .15rem;
  273. }
  274. .r {
  275. color: red;
  276. }
  277. </style>