index.vue 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316
  1. <template>
  2. <!-- 分销申请审批 -->
  3. <div class="taskMessagePage flex-col">
  4. <s-header :name="$t('taskMessage.distributionApplicationApproval')" :noback="false"></s-header>
  5. <div class="taskMessageBox flex-col">
  6. <van-list v-model:loading="loading" v-model:error="error" :error-text="$t('common.reqFailClkReload')"
  7. :finished="finished" :finished-text="$t('common.noMoreTxt')" offset="300" :immediate-check="false" @load="onLoad">
  8. <div class="searchRow flex-row justify-between">
  9. <div class="flex-col">
  10. <div class="flex-row justify-between bd3">
  11. <div class="flex-col outer4 proportionIcon"></div>
  12. <span class="flex-col txt2">{{ $t('taskMessage.total') }}<span class="discountNumber">{{ alarmHistoryTotal
  13. }}</span>{{ $t('taskMessage.recordsInTotal') }}</span>
  14. </div>
  15. </div>
  16. <div class="l-flex-RC">
  17. <div @click="reviewedClk" class="label3 o-mr-30">{{
  18. $t('taskMessage.toViewAppro')
  19. }}</div>
  20. <div @click="noticeClk" class="main5 l-flex-RC">
  21. <img class="label2 o-mr-5" src="../../../assets/device/searchIcon.png" />
  22. </div>
  23. </div>
  24. </div>
  25. <div class="listBox">
  26. <div v-for="(item, index) in alarmHistoryList" :key="index" class="listItem">
  27. <div class="itemBox">
  28. <div class="itemRow">
  29. <span class="itemTitle">{{ $t('taskMessage.equipmentName') }}:&nbsp;</span>{{ item.equipmentName != null ?
  30. item.equipmentName : item.clientId.slice(-6) }}
  31. </div>
  32. <div class="itemRow">
  33. <span class="itemTitle">{{ $t('taskMessage.equipmentNo') }}:&nbsp;</span>{{ item.clientId }}
  34. </div>
  35. <!-- 机主的 -->
  36. <div class="itemRow">
  37. <span class="itemTitle">{{ $t('taskMessage.owner') }}:&nbsp;</span>{{ $t('taskMessage.machineOwner')
  38. }}<span class="itemTitle discount">{{ $t('taskMessage.proportion') }}:&nbsp;</span>{{ item.proportion }}%
  39. </div>
  40. <!-- 平台的 -->
  41. <div class="itemRow">
  42. <span class="itemTitle">{{ $t('taskMessage.platform') }}:&nbsp;</span>{{ $t('taskMessage.platformAccount')
  43. }}<span class="itemTitle discount">{{ $t('taskMessage.proportion') }}:&nbsp;</span>{{ item.adminProportion }}%
  44. </div>
  45. <!-- 分账方的 -->
  46. <div class="itemRow" v-if="item.type >= 1">
  47. <span class="itemTitle">{{ $t('taskMessage.partners') }}:&nbsp;</span>{{ item.agencyName
  48. }}<span class="itemTitle discount">{{ $t('taskMessage.proportion') }}:&nbsp;</span>{{
  49. item.agencyProportion
  50. }}%
  51. </div>
  52. <!-- 分账方4个 -->
  53. <div class="itemRow" v-if="item.type >= 2">
  54. <span class="itemTitle">{{ $t('taskMessage.partners') }}:&nbsp;</span>{{ item.merchantName
  55. }}<span class="itemTitle discount">{{ $t('taskMessage.proportion') }}:&nbsp;</span>{{
  56. item.merchantProportion
  57. }}%
  58. </div>
  59. <!-- 分账方5个以上 -->
  60. <div class="itemRow" v-if="item.type >= 3">
  61. <span class="itemTitle">{{ $t('taskMessage.partners') }}:&nbsp;</span>{{ item.personageName
  62. }}<span class="itemTitle discount">{{ $t('taskMessage.proportion') }}:&nbsp;</span>{{
  63. item.personageProportion
  64. }}%
  65. </div>
  66. <div class="itemRow">
  67. <span class="itemTitle">{{ $t('taskMessage.applicationTime') }}:&nbsp;</span>{{
  68. showDateTime(item.createDate)
  69. }}
  70. </div>
  71. <div class="itemRow" v-if="item.checkType !== '0'">
  72. <span class="itemTitle">{{ $t('taskMessage.approvalTime') }}:&nbsp;</span>{{
  73. showDateTime(item.modifyDate)
  74. }}
  75. </div>
  76. <div class="itemRow" style="display: flex; justify-content: flex-end"
  77. v-if="item.checkType === '0' && isOper">
  78. <van-button span="5" round type="primary" style="
  79. height: 2em;
  80. padding: 0 1em;
  81. margin: 0 0.5em;
  82. background: rgb(255 0 0 / 20%);
  83. color: #ff0000;
  84. border-color: #ff0000;
  85. " @click="changeStatusFun(item, 3)">
  86. {{ $t('taskMessage.fail') }}
  87. </van-button>
  88. <van-button span="5" round type="primary" style="
  89. height: 2em;
  90. padding: 0 1em;
  91. margin: 0 0.5em;
  92. background: rgb(25 137 250 / 20%);
  93. color: #1989fa;
  94. " @click="changeStatusFun(item, 1)">
  95. {{ $t('taskMessage.adopt') }}
  96. </van-button>
  97. </div>
  98. <div class="itemRow" style="display: flex; justify-content: flex-end" v-if="item.checkType !== '0'">
  99. <span v-if="item.checkType === '1'" style="color: #1989fa"> {{ $t('taskMessage.adopt') }}</span>
  100. <span v-if="item.checkType === '2'" style="color: #ff0000"> {{ $t('taskMessage.cancel') }}</span>
  101. <span v-if="item.checkType === '3'" style="color: #ff0000"> {{ $t('taskMessage.fail') }}</span>
  102. </div>
  103. </div>
  104. </div>
  105. </div>
  106. </van-list>
  107. </div>
  108. <!-- 筛选弹窗 -->
  109. <kDialog :dialogTitle="$t('taskMessage.equipmentInit.searchPop.title')"
  110. :confirmBtnTxt="$t('taskMessage.equipmentInit.searchPop.filterBtn')" ref="kDialogRef" @confirmclk="confirmClk">
  111. <template #content>
  112. <div class="cust_vantBorder">
  113. <van-field clearable v-model="searchForm.merchantName" :placeholder="$t('taskMessage.equipmentInit.searchPop.merchantNamePlace')
  114. " :label="$t('taskMessage.equipmentInit.searchPop.merchantName')" />
  115. <van-field @click-input="busiInpClk" readonly clearable v-model="searchForm.stateName"
  116. :placeholder="$t('taskMessage.equipmentInit.searchPop.statePlace')"
  117. :label="$t('taskMessage.equipmentInit.searchPop.state')">
  118. <template #right-icon>
  119. <div class="l-flex-RC">
  120. <van-icon v-if="searchForm.stateName" @click="searchForm.stateName = ''; searchForm.state = ''"
  121. class="o-mr-6" name="clear" />
  122. <van-icon @click="busiInpClk" name="arrow-down" />
  123. </div>
  124. </template>
  125. </van-field>
  126. </div>
  127. </template>
  128. </kDialog>
  129. <!-- 状态选择框 -->
  130. <van-popup v-model:show="busiPopShow" position="bottom">
  131. <van-picker :title="$t('taskMessage.equipmentInit.searchPop.statePlace')" :columns="busiPopList"
  132. :columns-field-names="busiPopFieldName" @confirm="busiPopConfirm" @cancel="busiPopShow = false" />
  133. </van-popup>
  134. </div>
  135. </template>
  136. <script>
  137. import { onMounted, reactive, ref } from "vue";
  138. import sHeader from "@/components/SimpleHeader";
  139. import {
  140. getTaskProportionList,
  141. changeProportionStatus,
  142. } from "@/service/taskMessage";
  143. import { showFailToast } from "vant";
  144. import { getLoginUser, styleUrl } from "@/common/js/utils";
  145. import dateUtil from "@/utils/dateUtil";
  146. import kDialog from "@/components/commom/kDialog/index.vue";
  147. import { useI18n } from "vue-i18n";
  148. export default {
  149. components: { sHeader, kDialog },
  150. setup() {
  151. const { t } = useI18n();
  152. // 筛选弹窗
  153. const busiPopList = reactive([
  154. {
  155. name: t('taskMessage.whole'),
  156. id: "1",
  157. },
  158. {
  159. name: t('taskMessage.unapproved'),
  160. id: "0",
  161. },
  162. ]);
  163. const busiPopFieldName = reactive({
  164. text: "name",
  165. value: "id",
  166. });
  167. const kDialogRef = ref(null);
  168. const busiPopShow = ref(false);
  169. // 筛选条件
  170. const searchForm = reactive({
  171. merchantName: "",
  172. state: "",
  173. stateName: '',
  174. });
  175. // 点击状态输入框
  176. const busiInpClk = () => {
  177. busiPopShow.value = true;
  178. };
  179. const busiPopConfirm = ({ selectedOptions }) => {
  180. busiPopShow.value = false;
  181. searchForm.state = selectedOptions[0].id;
  182. searchForm.stateName = selectedOptions[0].name;
  183. };
  184. // 点击筛选
  185. const noticeClk = () => {
  186. kDialogRef.value.openDialog();
  187. };
  188. // 点击查询按钮
  189. const confirmClk = () => {
  190. isClkReview.value = false;
  191. searchGetList();
  192. };
  193. // 是否点击待审核
  194. const isClkReview = ref(true);
  195. // 点击查看待审核
  196. const reviewedClk = () => {
  197. isClkReview.value = true;
  198. // 改为未审核状态
  199. searchParams.type = "0";
  200. searchGetList();
  201. };
  202. const user = getLoginUser();
  203. const loading = ref(false); // 加载状态
  204. const error = ref(false); // 错误状态
  205. const finished = ref(false); // 结束翻页状态
  206. const alarmHistoryList = ref([]); // 列表集合
  207. const alarmHistoryTotal = ref(0); // 列表总数
  208. let searchParams = reactive({
  209. adminId: "", // 当前登录账户的id
  210. type: "1", // 审核状态 未审核_0;全部_1
  211. current: 1, // 当前页
  212. size: 20, // 页大小
  213. username: "", // 商家名称
  214. });
  215. // 滚动加载
  216. const onLoad = () => {
  217. if (!finished.value) {
  218. searchParams.current = searchParams.current + 1;
  219. getList();
  220. }
  221. };
  222. // 查询列表
  223. const searchGetList = () => {
  224. alarmHistoryList.value = [];
  225. searchParams.current = 1;
  226. getList();
  227. };
  228. // 获取设备初始化审批列表数据
  229. const getList = async () => {
  230. // 把弹窗的筛选条件组合到请求参数里面
  231. if (!isClkReview.value) {
  232. searchParams.type = searchForm.state;
  233. }
  234. searchParams.userName = searchForm.merchantName;
  235. const { data } = await getTaskProportionList(
  236. Object.assign({}, searchParams)
  237. );
  238. if (data.code === "00000") {
  239. // 列表值叠加
  240. alarmHistoryList.value = alarmHistoryList.value.concat(
  241. data.data.records
  242. );
  243. alarmHistoryTotal.value = data.data.total;
  244. if (alarmHistoryList.value.length === data.data.total) {
  245. finished.value = true;
  246. }
  247. loading.value = false;
  248. console.log(alarmHistoryList);
  249. } else {
  250. showFailToast(data.message);
  251. }
  252. };
  253. // 是否有操作的权限
  254. const isOper = ref(true);
  255. // 初始化页面获取列表
  256. onMounted(async () => {
  257. // 加载样式
  258. styleUrl('taskMessage');
  259. if (user) {
  260. searchParams.adminId = user.id;
  261. searchGetList();
  262. // 如果是type大于1,那么不能有操作的权限
  263. if (user.type > 1) {
  264. isOper.value = false;
  265. }
  266. }
  267. });
  268. const showDateTime = (date) => {
  269. return date
  270. ? dateUtil.formateDate(new Date(date), "yyyy-MM-dd hh:mm:ss")
  271. : "";
  272. };
  273. const changeStatusFun = async (item, type) => {
  274. const { data } = await changeProportionStatus({
  275. id: item.id,
  276. type: type,
  277. });
  278. if (data.code === "00000") {
  279. showFailToast("操作成功");
  280. searchGetList();
  281. } else {
  282. showFailToast(data.message);
  283. }
  284. console.log(data);
  285. };
  286. return {
  287. loading,
  288. error,
  289. finished,
  290. onLoad,
  291. alarmHistoryList,
  292. alarmHistoryTotal,
  293. showDateTime,
  294. changeStatusFun,
  295. kDialogRef,
  296. noticeClk,
  297. confirmClk,
  298. busiInpClk,
  299. busiPopConfirm,
  300. busiPopShow,
  301. searchForm,
  302. busiPopList,
  303. busiPopFieldName,
  304. reviewedClk,
  305. isOper,
  306. };
  307. },
  308. };
  309. </script>
  310. <style lang="less" scoped>
  311. @import "../../../common/style/common.less";
  312. </style>