transductive_award.blade.php 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523
  1. @extends('layouts.base')
  2. @section('title', "直推奖")
  3. @section('content')
  4. <link rel="stylesheet" type="text/css" href="{{static_url('yunshop/goods/vue-goods1.css')}}"/>
  5. <style>
  6. .edit-i {
  7. display: none;
  8. }
  9. .el-table_1_column_2:hover .edit-i {
  10. font-weight: 900;
  11. padding: 0;
  12. margin: 0;
  13. display: inline-block;
  14. }
  15. .el-tabs__item, .is-top {
  16. font-size: 16px
  17. }
  18. .el-tabs__active-bar {
  19. height: 3px;
  20. }
  21. .list-title {
  22. display: flex;
  23. width: 100%;
  24. background: #f9f9f9;
  25. padding: 15px 10px;
  26. font-weight: 900;
  27. border: 1px solid #e9e9e9;
  28. }
  29. .list-title .list-title-1 {
  30. display: flex;
  31. align-items: center;
  32. justify-content: center;
  33. }
  34. .list-info {
  35. display: flex;
  36. padding: 10px;
  37. justify-content: left;
  38. background: #f9f9f9;
  39. }
  40. .list-con {
  41. display: flex;
  42. width: 100%;
  43. font-size: 12px;
  44. font-weight: 500;
  45. align-items: stretch;
  46. border-bottom: 1px solid rgb(233, 233, 233);
  47. }
  48. .list-con-goods {
  49. display: flex;
  50. align-items: center;
  51. justify-content: center;
  52. box-sizing: border-box;
  53. padding-left: 10px;
  54. border-top: 1px solid #e9e9e9;
  55. min-height: 90px
  56. }
  57. .list-con-goods-text {
  58. min-height: 70px;
  59. overflow: hidden;
  60. flex: 1;
  61. display: flex;
  62. flex-direction: column;
  63. justify-content: space-between;
  64. }
  65. .list-con-goods-price {
  66. border-right: 1px solid #e9e9e9;
  67. border-left: 1px solid #e9e9e9;
  68. min-width: 150px;
  69. min-height: 90px;
  70. text-align: left;
  71. padding: 20px;
  72. display: flex;
  73. flex-direction: column;
  74. }
  75. .list-con-goods-title {
  76. font-size: 14px;
  77. line-height: 20px;
  78. text-overflow: -o-ellipsis-lastline;
  79. overflow: hidden;
  80. text-overflow: ellipsis;
  81. display: -webkit-box;
  82. -webkit-line-clamp: 2;
  83. line-clamp: 2;
  84. -webkit-box-orient: vertical;
  85. }
  86. .list-con-goods-option {
  87. font-size: 12px;
  88. color: #999
  89. }
  90. .list-con-member-info {
  91. display: flex;
  92. padding: 0 2px;
  93. flex-direction: column;
  94. flex: 1;
  95. min-width: 120px;
  96. line-height: 28px;
  97. justify-content: center;
  98. text-align: left;
  99. font-size: 14px;
  100. border-top: 1px solid #e9e9e9;
  101. border-right: 1px solid #e9e9e9;
  102. }
  103. .list-member {
  104. padding: 10px;
  105. font-size: 12px;
  106. font-weight: 500;
  107. }
  108. .list-num {
  109. flex: 3;
  110. display: flex;
  111. align-items: center;
  112. border-right: 1px solid #e9e9e9;
  113. justify-content: center;
  114. }
  115. .list-gen {
  116. display: flex;
  117. align-items: center;
  118. justify-content: center;
  119. line-height: 28px;
  120. }
  121. .list-gen-txt {
  122. flex: 1;
  123. border-right: 1px solid #e9e9e9;
  124. border-bottom: 1px solid #e9e9e9;
  125. align-items: center;
  126. justify-content: center;
  127. display: flex;
  128. }
  129. .list-opt {
  130. flex: 1;
  131. display: flex;
  132. align-items: center;
  133. border-left: 1px solid #e9e9e9;
  134. justify-content: center;
  135. }
  136. /* 导航 */
  137. .el-radio-button .el-radio-button__inner, .el-radio-button:first-child .el-radio-button__inner {
  138. border-radius: 4px 4px 4px 4px;
  139. border-left: 0px;
  140. }
  141. .el-radio-button__inner {
  142. border: 0;
  143. }
  144. .el-radio-button:last-child .el-radio-button__inner {
  145. border-radius: 4px 4px 4px 4px;
  146. }
  147. .panel .active a {
  148. background-color: #29ba9c !important;
  149. border-radius: 18px !important;
  150. color: #fff;
  151. }
  152. .add-shopnav li a {
  153. display: inline-block;
  154. padding: 0 12px;
  155. line-height: 32px;
  156. color: #333;
  157. border: 1px solid #e5e5e5;
  158. background: #f8f8f8;
  159. min-width: 80px;
  160. text-align: center;
  161. }
  162. .panel a {
  163. border: none !important;
  164. background-color: #fff !important;
  165. }
  166. </style>
  167. <div class="all">
  168. <div id="app" v-cloak>
  169. <div class="vue-head">
  170. <div class="panel panel-info">
  171. <ul class="add-shopnav">
  172. <li @if(!\YunShop::request()->type || \YunShop::request()->type == 1) class="active" @endif >
  173. <a
  174. href="{{ yzWebUrl('plugin.agency.admin.award.index', ['type'=>1])}}">走货奖励</a></li>
  175. <li @if(\YunShop::request()->type == 2) class="active" @endif >
  176. <a
  177. href="{{ yzWebUrl('plugin.agency.admin.award.index', ['type'=>2])}}">直推代理商奖</a></li>
  178. <li @if(\YunShop::request()->type == 3) class="active" @endif>
  179. <a
  180. href="{{ yzWebUrl('plugin.agency.admin.award.index', ['type'=>3])}}">直推奖</a></li>
  181. <li @if(\YunShop::request()->type == 4) class="active" @endif>
  182. <a
  183. href="{{ yzWebUrl('plugin.agency.admin.award.index', ['type'=>4])}}">平级奖</a></li>
  184. </ul>
  185. </div>
  186. </div>
  187. <div class="vue-head">
  188. <div class="vue-main-title" style="margin-bottom:20px">
  189. <div class="vue-main-title-button">
  190. </div>
  191. </div>
  192. <div class="vue-search">
  193. <el-form :inline="true" :model="search_form" class="demo-form-inline">
  194. <el-form-item label="">
  195. <el-input v-model="search_form.member_info1" placeholder="会员ID/昵称/姓名/手机号"></el-input>
  196. </el-form-item>
  197. <el-form-item label="">
  198. <el-input v-model="search_form.order_sn" placeholder="订单编号"></el-input>
  199. </el-form-item>
  200. <el-form-item label="">
  201. <el-input v-model="search_form.member_info2" placeholder="发放会员ID/昵称/姓名/手机号"></el-input>
  202. </el-form-item>
  203. <el-form-item label="">
  204. <el-select v-model="search_form.award_status" clearable placeholder="状态"
  205. style="width:150px">
  206. <el-option label="状态" value="0"></el-option>
  207. <el-option label="未结算" value="1"></el-option>
  208. <el-option label="已结算" value="2"></el-option>
  209. <el-option label="失效" value="3"></el-option>
  210. </el-select>
  211. </el-form-item>
  212. <el-form-item label="">
  213. <el-select v-model="search_form.search_time" clearable placeholder="时间不限"
  214. style="width:150px">
  215. <el-option label="时间不限" value="0"></el-option>
  216. <el-option label="搜索时间" value="1"></el-option>
  217. </el-select>
  218. </el-form-item>
  219. <el-form-item label="">
  220. <el-date-picker
  221. v-model="times"
  222. type="datetimerange"
  223. value-format="yyyy-MM-dd HH:mm:ss"
  224. range-separator="至"
  225. start-placeholder="开始日期"
  226. end-placeholder="结束日期"
  227. style="margin-left:5px;"
  228. align="right">
  229. </el-date-picker>
  230. </el-form-item>
  231. <el-form-item label="">
  232. <el-button type="primary" @click="search(1)">搜索</el-button>
  233. </el-form-item>
  234. </el-form>
  235. </div>
  236. </div>
  237. <div class="vue-main">
  238. <div class="vue-main-form">
  239. <div class="vue-main-title" style="margin-bottom:20px">
  240. <div class="vue-main-title-left"></div>
  241. <div class="vue-main-title-content" style="flex:0 0 140px">直推奖列表</div>
  242. </div>
  243. <template style="margin-top:-10px;">
  244. <el-table
  245. :data="list"
  246. style="padding:0 10px"
  247. >
  248. <el-table-column
  249. prop="id"
  250. align="center"
  251. label="ID"
  252. >
  253. </el-table-column>
  254. <el-table-column
  255. prop="uid"
  256. align="center"
  257. label="时间"
  258. >
  259. <template slot-scope="scope">
  260. [[scope.row.created_at]]
  261. </template>
  262. </el-table-column>
  263. <el-table-column
  264. prop="order_sn"
  265. align="center"
  266. label="订单编号"
  267. >
  268. </el-table-column>
  269. <el-table-column
  270. align="center"
  271. label="会员"
  272. >
  273. <template slot-scope="scope">
  274. <div>
  275. <div class="vue-ellipsis">
  276. <el-image :src="scope.row.avatar1"
  277. style='width:30px;height:30px;padding:1px;border:1px solid #ccc'></el-image>
  278. </div>
  279. <div class="vue-ellipsis">[[scope.row.nickname1]]</div>
  280. </div>
  281. </template>
  282. </el-table-column>
  283. <el-table-column
  284. prop="price"
  285. align="center"
  286. label="订单金额"
  287. >
  288. </el-table-column>
  289. <el-table-column
  290. prop="award_amount"
  291. align="center"
  292. label="直推奖金额"
  293. >
  294. </el-table-column>
  295. <el-table-column
  296. align="center"
  297. label="发放代理商"
  298. >
  299. <template slot-scope="scope">
  300. <div>
  301. <div v-if="scope.row.nickname2" class="vue-ellipsis">
  302. <el-image :src="scope.row.avatar2"
  303. style='width:30px;height:30px;padding:1px;border:1px solid #ccc'></el-image>
  304. </div>
  305. <div class="vue-ellipsis">[[scope.row.nickname2?scope.row.nickname2:'平台']]</div>
  306. </div>
  307. </template>
  308. </el-table-column>
  309. <el-table-column
  310. prop="status_name"
  311. align="center"
  312. label="状态"
  313. >
  314. </el-table-column>
  315. </el-table>
  316. </template>
  317. </div>
  318. </div>
  319. <div class="vue-page" v-if="total>0">
  320. <el-row>
  321. <el-col align="right">
  322. <el-pagination layout="prev, pager, next,jumper" @current-change="search" :total="total"
  323. :page-size="per_page" :current-page="current_page" background
  324. ></el-pagination>
  325. </el-col>
  326. </el-row>
  327. </div>
  328. </div>
  329. </div>
  330. <script>
  331. var app = new Vue({
  332. el: "#app",
  333. delimiters: ['[[', ']]'],
  334. name: 'test',
  335. data() {
  336. return {
  337. listUrl: '{!! yzWebUrl('plugin.agency.admin.award.get-list', ['type'=>3]) !!}',//获取订单数据链接
  338. list: [],
  339. has_many_level: [],
  340. change_sort: '',
  341. times: [],
  342. data: "",
  343. expressCompanies: [],//快递公司
  344. extra_param: {},
  345. code: 'all',
  346. search_form: {
  347. member_id: "",
  348. },
  349. order_type: '',
  350. close_order_show: false,//关闭订单弹窗
  351. close_order_con: "",//关闭订单原因
  352. close_order_id: "",
  353. close_order1_show: false,//手动关闭订单弹窗
  354. close_order1_con: "",//手动关闭订单原因
  355. close_order1_id: "",
  356. cancel_send_show: false,// 取消发货弹窗
  357. cancel_send_con: "",//取消发货原因
  358. cancel_send_id: '',
  359. confirm_send_show: false,// 确认发货弹窗
  360. confirm_send_id: "",
  361. change_price_show: false,//修改价格弹窗
  362. change_price_id: "",
  363. change_all_money: 0.00,//价格修改
  364. all_money: 0.00,//买家实付
  365. order_model: {},
  366. dispatch_price: 0,//运费
  367. order_goods_model: [],
  368. address_info: {},
  369. send: {
  370. dispatch_type_id: 1,
  371. express_code: "",
  372. express_sn: "",
  373. },
  374. send_rules: {},
  375. more_send_show: false,
  376. order_goods_send_list: [],
  377. send_order_goods_ids: [],
  378. street: 0,
  379. province_list: [],
  380. city_list: [],
  381. district_list: [],
  382. street_list: [],
  383. areaLoading: false,
  384. rules: {},
  385. current_page: 1,
  386. total: 1,
  387. per_page: 1,
  388. readonly: false,
  389. }
  390. },
  391. created() {
  392. let result = this.viewReturn();
  393. this.__initial(result);
  394. this.search_form.member_id = this.getParam('member_id') ? this.getParam('member_id') : '';
  395. },
  396. mounted() {
  397. this.getData(1);
  398. },
  399. methods: {
  400. viewReturn() {
  401. return {!! $data?:'{}' !!};
  402. },
  403. __initial(data) {
  404. if (data.code) {
  405. this.code = data.code;
  406. }
  407. if (data.listUrl) {
  408. this.listUrl = data.listUrl;
  409. }
  410. if (data.extraParam) {
  411. this.extra_param = data.extraParam;
  412. }
  413. this.expressCompanies = data.expressCompanies;
  414. console.log(data);
  415. },
  416. getData(page) {
  417. let requestData = {
  418. page: page,
  419. code: this.code,
  420. search: JSON.parse(JSON.stringify(this.search_form)),
  421. };
  422. if (this.times && this.times.length > 0) {
  423. requestData.search.start_time = this.times[0];
  424. requestData.search.end_time = this.times[1];
  425. }
  426. console.log(requestData);
  427. let loading = this.$loading({
  428. target: document.querySelector(".content"),
  429. background: 'rgba(0, 0, 0, 0)'
  430. });
  431. this.$http.post(this.listUrl, requestData).then(function (response) {
  432. if (response.data.result) {
  433. this.list = response.data.data.data;
  434. this.current_page = response.data.data.current_page;
  435. this.total = response.data.data.total;
  436. this.per_page = response.data.data.per_page;
  437. loading.close();
  438. } else {
  439. this.$message({
  440. message: response.data.msg,
  441. type: 'error'
  442. });
  443. }
  444. loading.close();
  445. }, function (response) {
  446. this.$message({
  447. message: response.data.msg,
  448. type: 'error'
  449. });
  450. loading.close();
  451. });
  452. },
  453. search(val) {
  454. this.getData(val);
  455. },
  456. escapeHTML(a) {
  457. a = "" + a;
  458. return a.replace(/&amp;/g, "&").replace(/&lt;/g, "<").replace(/&gt;/g, ">").replace(/&quot;/g, "\"").replace(/&apos;/g, "'");
  459. },
  460. getParam(name) {
  461. var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)", "i");
  462. var r = window.location.search.substr(1).match(reg);
  463. if (r != null) return unescape(r[2]);
  464. return null;
  465. },
  466. currentChange(val) {
  467. this.loading = true;
  468. this.$http.post('{!! yzWebFullUrl('plugin.agency.admin.award.get-list', ['type'=>3]) !!}', {
  469. page: val,
  470. search: this.real_search_form
  471. }).then(function (response) {
  472. if (response.data.result) {
  473. this.list = response.data.data.data;
  474. this.current_page = response.data.data.current_page;
  475. this.total = response.data.data.total;
  476. this.per_page = response.data.data.per_page;
  477. loading.close();
  478. } else {
  479. this.$message({
  480. message: response.data.msg,
  481. type: 'error'
  482. });
  483. }
  484. loading.close();
  485. }, function (response) {
  486. console.log(response);
  487. this.loading = false;
  488. }
  489. );
  490. },
  491. },
  492. })
  493. </script>
  494. @endsection