index.vue 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220
  1. <template>
  2. <div class="p-2">
  3. <el-card shadow="never">
  4. <template #header>
  5. <el-row :gutter="10" class="mb8">
  6. <el-col :span="22"><span>物流公司信息列表</span> </el-col>
  7. <el-col :span="1.5">
  8. <el-button type="primary" plain icon="Plus" @click="handleAdd" >新增</el-button>
  9. </el-col>
  10. </el-row>
  11. </template>
  12. <el-table v-loading="loading" border :data="logisticsCompanyList" @selection-change="handleSelectionChange">
  13. <el-table-column type="selection" width="55" align="center" />
  14. <el-table-column label="物流公司编码" align="center" prop="logisticsCode" />
  15. <el-table-column label="物流公司名称" align="center" prop="logisticsName" />
  16. <el-table-column label="物流公司描述" align="center" prop="logisticsDescription" />
  17. <el-table-column label="是否显示" align="center" prop="isShow">
  18. <template #default="scope">
  19. <el-switch v-model="scope.row.isShow" active-value="0" inactive-value="1" @change="handleStatusChange(scope.row)"></el-switch>
  20. </template>
  21. </el-table-column>
  22. <el-table-column label="数据来源" align="center" prop="dataSource" />
  23. <el-table-column label="操作" align="center" class-name="small-padding fixed-width">
  24. <template #default="scope">
  25. <el-button link type="primary" icon="Edit" @click="handleUpdate(scope.row)">编辑</el-button>
  26. </template>
  27. </el-table-column>
  28. </el-table>
  29. <pagination v-show="total > 0" :total="total" v-model:page="queryParams.pageNum" v-model:limit="queryParams.pageSize" @pagination="getList" />
  30. </el-card>
  31. <!-- 添加或修改物流公司对话框 -->
  32. <el-dialog :title="dialog.title" v-model="dialog.visible" width="600px" append-to-body>
  33. <el-form ref="logisticsCompanyFormRef" :model="form" :rules="rules" label-width="110px">
  34. <el-form-item label="物流公司名称" prop="logisticsName">
  35. <el-input v-model="form.logisticsName" placeholder="请输入物流公司名称" />
  36. </el-form-item>
  37. <el-form-item label="物流公司描述" prop="logisticsDescription">
  38. <el-input v-model="form.logisticsDescription" type="textarea" placeholder="请输入内容" />
  39. </el-form-item>
  40. <el-form-item label="是否显示" prop="isShow">
  41. <el-radio-group v-model="form.isShow">
  42. <el-radio v-for="dict in sys_platform_yes_no" :key="dict.value" :value="dict.value">{{ dict.label }}</el-radio>
  43. </el-radio-group>
  44. </el-form-item>
  45. </el-form>
  46. <template #footer>
  47. <div class="dialog-footer">
  48. <el-button :loading="buttonLoading" type="primary" @click="submitForm">确 定</el-button>
  49. <el-button @click="cancel">取 消</el-button>
  50. </div>
  51. </template>
  52. </el-dialog>
  53. </div>
  54. </template>
  55. <script setup name="LogisticsCompany" lang="ts">
  56. import {
  57. listLogisticsCompany,
  58. getLogisticsCompany,
  59. delLogisticsCompany,
  60. addLogisticsCompany,
  61. updateLogisticsCompany,
  62. changeStatus
  63. } from '@/api/company/logisticsCompany';
  64. import { LogisticsCompanyVO, LogisticsCompanyQuery, LogisticsCompanyForm } from '@/api/company/logisticsCompany/types';
  65. const { proxy } = getCurrentInstance() as ComponentInternalInstance;
  66. const { sys_platform_yes_no } = toRefs<any>(proxy?.useDict('sys_platform_yes_no'));
  67. const logisticsCompanyList = ref<LogisticsCompanyVO[]>([]);
  68. const buttonLoading = ref(false);
  69. const loading = ref(true);
  70. const showSearch = ref(true);
  71. const ids = ref<Array<string | number>>([]);
  72. const single = ref(true);
  73. const multiple = ref(true);
  74. const total = ref(0);
  75. const queryFormRef = ref<ElFormInstance>();
  76. const logisticsCompanyFormRef = ref<ElFormInstance>();
  77. const dialog = reactive<DialogOption>({
  78. visible: false,
  79. title: ''
  80. });
  81. const initFormData: LogisticsCompanyForm = {
  82. id: undefined,
  83. logisticsCode: undefined,
  84. logisticsName: undefined,
  85. logisticsDescription: undefined,
  86. isShow: '0',
  87. dataSource: undefined,
  88. remark: undefined
  89. };
  90. const data = reactive<PageData<LogisticsCompanyForm, LogisticsCompanyQuery>>({
  91. form: { ...initFormData },
  92. queryParams: {
  93. pageNum: 1,
  94. pageSize: 10,
  95. logisticsCode: undefined,
  96. logisticsName: undefined,
  97. logisticsDescription: undefined,
  98. isShow: undefined,
  99. dataSource: undefined,
  100. platformCode: undefined,
  101. params: {}
  102. },
  103. rules: {
  104. logisticsName: [{ required: true, message: '物流公司名称不能为空', trigger: 'blur' }]
  105. }
  106. });
  107. const { queryParams, form, rules } = toRefs(data);
  108. /** 查询物流公司列表 */
  109. const getList = async () => {
  110. loading.value = true;
  111. const res = await listLogisticsCompany(queryParams.value);
  112. logisticsCompanyList.value = res.rows;
  113. total.value = res.total;
  114. loading.value = false;
  115. };
  116. /** 取消按钮 */
  117. const cancel = () => {
  118. reset();
  119. dialog.visible = false;
  120. };
  121. /** 表单重置 */
  122. const reset = () => {
  123. form.value = { ...initFormData };
  124. logisticsCompanyFormRef.value?.resetFields();
  125. };
  126. /** 搜索按钮操作 */
  127. const handleQuery = () => {
  128. queryParams.value.pageNum = 1;
  129. getList();
  130. };
  131. const handleStatusChange = async (row: LogisticsCompanyVO) => {
  132. const oldValue = row.isShow; // 保存旧值(0 或 1)
  133. try {
  134. await changeStatus(row.id, row.isShow); // 传新值
  135. proxy?.$modal.msgSuccess('操作成功');
  136. } catch {
  137. row.isShow = oldValue; // 失败回滚
  138. proxy?.$modal.msgError('操作失败,请重试');
  139. }
  140. };
  141. /** 多选框选中数据 */
  142. const handleSelectionChange = (selection: LogisticsCompanyVO[]) => {
  143. ids.value = selection.map((item) => item.id);
  144. single.value = selection.length != 1;
  145. multiple.value = !selection.length;
  146. };
  147. /** 新增按钮操作 */
  148. const handleAdd = () => {
  149. reset();
  150. dialog.visible = true;
  151. dialog.title = '添加物流公司';
  152. };
  153. /** 修改按钮操作 */
  154. const handleUpdate = async (row?: LogisticsCompanyVO) => {
  155. reset();
  156. const _id = row?.id || ids.value[0];
  157. const res = await getLogisticsCompany(_id);
  158. Object.assign(form.value, res.data);
  159. dialog.visible = true;
  160. dialog.title = '修改物流公司';
  161. };
  162. /** 提交按钮 */
  163. const submitForm = () => {
  164. logisticsCompanyFormRef.value?.validate(async (valid: boolean) => {
  165. if (valid) {
  166. buttonLoading.value = true;
  167. if (form.value.id) {
  168. await updateLogisticsCompany(form.value).finally(() => (buttonLoading.value = false));
  169. } else {
  170. await addLogisticsCompany(form.value).finally(() => (buttonLoading.value = false));
  171. }
  172. proxy?.$modal.msgSuccess('操作成功');
  173. dialog.visible = false;
  174. await getList();
  175. }
  176. });
  177. };
  178. /** 删除按钮操作 */
  179. const handleDelete = async (row?: LogisticsCompanyVO) => {
  180. const _ids = row?.id || ids.value;
  181. await proxy?.$modal.confirm('是否确认删除物流公司编号为"' + _ids + '"的数据项?').finally(() => (loading.value = false));
  182. await delLogisticsCompany(_ids);
  183. proxy?.$modal.msgSuccess('删除成功');
  184. await getList();
  185. };
  186. /** 导出按钮操作 */
  187. const handleExport = () => {
  188. proxy?.download(
  189. 'system/logisticsCompany/export',
  190. {
  191. ...queryParams.value
  192. },
  193. `logisticsCompany_${new Date().getTime()}.xlsx`
  194. );
  195. };
  196. onMounted(() => {
  197. getList();
  198. });
  199. </script>