Nelze vybrat více než 25 témat Téma musí začínat písmenem nebo číslem, může obsahovat pomlčky („-“) a může být dlouhé až 35 znaků.

useOrderListItem.ts 4.6KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  1. /**
  2. * 订单列表业务逻辑
  3. */
  4. import { reactive, ref, watch, nextTick, onMounted } from "vue";
  5. import { request } from "@/utils/network/request.js";
  6. import { stringToJson } from "@/utils/network/encryption";
  7. import { onLoad, onUnload, onReachBottom, onPullDownRefresh } from "@dcloudio/uni-app";
  8. import { getItem, StorageKeys } from "@/utils/storage";
  9. import { hasLogin, msg, timesDiff } from "@/utils/utils";
  10. import { orderList } from "@/utils/network/api";
  11. import { PageData } from "@/datas/enum";
  12. export default function useOrderListItem(props) {
  13. //搜索关键字
  14. const searchKeyWords = ref('');
  15. //订单列表数据
  16. const ordersList = ref([]);
  17. const config = {
  18. emptyHint: {
  19. hint: '~ 暂无订单数据 ~',
  20. icon: '',
  21. mode: 'order'
  22. },
  23. contentTxt: {
  24. contentdown: '~上拉加载更多~',
  25. contentrefresh: '努力加载中...',
  26. contentnomore: '-- 我是有底线的 --'
  27. }
  28. }
  29. //请求参数
  30. const params = reactive({
  31. pageNum: PageData.NUM,
  32. pageSize: PageData.SIZE,
  33. total: 0,
  34. status: 'more',
  35. reload: false,
  36. })
  37. //搜索
  38. const doSearch = () => {
  39. // #ifdef MP-WEIXIN
  40. if (!searchKeyWords.value) {
  41. msg('请输入需要搜索的车牌号!');
  42. return;
  43. }
  44. // #endif
  45. refreshList(true);
  46. }
  47. //订单车牌号输入
  48. const onKeyInput = (event) => {
  49. searchKeyWords.value = event.target.value;
  50. if (searchKeyWords.value == '') {
  51. refreshList(true);
  52. }
  53. }
  54. /* 刷新列表 */
  55. const refreshList = (isLoading) => {
  56. params.pageNum = 1;
  57. params.total = 0;
  58. params.status = 'more';
  59. params.reload = false;
  60. getList();
  61. }
  62. /* 加载更多 */
  63. const loadMore = () => {
  64. if (params.total > ordersList.value.length) {
  65. params.status = 'loading';
  66. params.pageNum++;
  67. getList();
  68. } else {
  69. params.status = 'noMore';
  70. }
  71. }
  72. /* 获取列表数据 */
  73. const getList = async (isLoading = true) => {
  74. if (!hasLogin()) {
  75. uni.stopPullDownRefresh();
  76. uni.$emit('refreshFinish');
  77. return;
  78. }
  79. let res : any = null;
  80. let newsource = "WECHAT"
  81. // #ifdef MP-ALIPAY
  82. newsource = "ALI"
  83. // #endif
  84. const options = {
  85. type: 2,
  86. data: {
  87. "opId": getItem(StorageKeys.OpenId),
  88. "source": newsource,
  89. "vehiclePlate": searchKeyWords.value,
  90. "tabIndex": props.index + '',
  91. "pageNo": params.pageNum,
  92. "pageSize": params.pageSize,
  93. "promotionModes": 1,
  94. "isAfter": true
  95. },
  96. method: 'POST',
  97. // showLoading: isLoading ? (params.pageNum === 1 ? true : false) : false ,
  98. }
  99. console.log("订单列表查询", options)
  100. try {
  101. // res = await request(orderList, options);
  102. console.log('输出内容1111111')
  103. request(orderList, options).then((res) => {
  104. const data = stringToJson(res.bizContent);
  105. console.log("ordersList.value", ordersList.value)
  106. params.total = data.totalCount;
  107. if (params.pageNum === 1) {
  108. ordersList.value = [];
  109. }
  110. if (params.total > 0) {
  111. const curList = data.data || [];
  112. ordersList.value = params.reload ? curList : ordersList.value.concat(curList);
  113. params.reload = false;
  114. }
  115. if (params.total === ordersList.value.length) {
  116. params.reload = false;
  117. params.status = 'noMore';
  118. }
  119. if (params.pageNum === 1) {
  120. uni.stopPullDownRefresh();
  121. }
  122. // 订单发货后未激活 30天 以后 结束订单功能 insertTime >30 算出来距离今天是负数 updateTime<30(结束订单)
  123. for (var k = 0; k < ordersList.value.length; k++) {
  124. if (ordersList.value[k]['insertTime']) {
  125. if (timesDiff(ordersList.value[k]['insertTime'].replace("T", " ")).days > 30) {
  126. ordersList.value[k]['finishOrder'] = true //可以结束
  127. } else {
  128. ordersList.value[k]['finishOrder'] = false //不可以结束
  129. }
  130. }
  131. if (ordersList.value[k]['updateTime']) {
  132. if (timesDiff(ordersList.value[k]['updateTime'].replace("T", " ")).days <= 30) {
  133. ordersList.value[k]['isUseAgain'] = true //可以再次使用
  134. } else {
  135. ordersList.value[k]['isUseAgain'] = false //不可以再次使用
  136. }
  137. }
  138. }
  139. })
  140. .catch((err) => {
  141. console.log(err);
  142. });
  143. uni.$emit('refreshFinish');
  144. } catch (e) {
  145. console.log('输出内容222222', e)
  146. uni.stopPullDownRefresh();
  147. uni.$emit('refreshFinish');
  148. }
  149. }
  150. watch(() => props.index, () => {
  151. refreshList(true);
  152. });
  153. watch(() => props.refresh, (nv) => {
  154. if (nv) {
  155. refreshList(false);
  156. }
  157. });
  158. onMounted(() => {
  159. if (props.refresh) {
  160. refreshList(false);
  161. }
  162. })
  163. onPullDownRefresh(() => {
  164. refreshList(true);
  165. });
  166. onReachBottom(() => {
  167. loadMore();
  168. });
  169. return {
  170. config,
  171. params,
  172. ordersList,
  173. doSearch,
  174. onKeyInput,
  175. refreshList
  176. };
  177. }