253 lines
6.7 KiB
Vue
253 lines
6.7 KiB
Vue
<template>
|
|
<div>
|
|
<el-card class="!border-none mb-4" shadow="never">
|
|
<el-form class="mb-[-16px] formdata" :model="queryParams" inline>
|
|
<el-form-item label="公司名称" prop="company_name">
|
|
<el-input
|
|
class="w-[280px]"
|
|
v-model="queryParams.company_name"
|
|
clearable
|
|
placeholder="请输入公司名称"
|
|
/>
|
|
</el-form-item>
|
|
<el-form-item label="区" prop="area" v-show="company_type_show">
|
|
<el-input
|
|
class="w-[280px]"
|
|
v-model="queryParams.area"
|
|
clearable
|
|
placeholder="请输入区"
|
|
/>
|
|
</el-form-item>
|
|
<el-form-item label="镇" prop="street" v-show="company_type_show">
|
|
<el-input
|
|
class="w-[280px]"
|
|
v-model="queryParams.street"
|
|
clearable
|
|
placeholder="请输入镇"
|
|
/>
|
|
</el-form-item>
|
|
<el-form-item
|
|
label="公司类型"
|
|
prop="company_type"
|
|
v-show="company_type_show"
|
|
>
|
|
<el-select
|
|
v-model="queryParams.company_type"
|
|
placeholder="请选择公司类型"
|
|
clearable
|
|
class="w-[280px]"
|
|
>
|
|
<el-option
|
|
v-for="(item, index) in datas.dictTypeLists"
|
|
:key="index"
|
|
:label="item.name"
|
|
:value="item.id"
|
|
></el-option>
|
|
</el-select>
|
|
</el-form-item>
|
|
<el-form-item label="片区经理" prop="area_manager">
|
|
<el-input
|
|
class="w-[280px]"
|
|
v-model="queryParams.area_manager"
|
|
clearable
|
|
placeholder="请输入片区经理"
|
|
/>
|
|
</el-form-item>
|
|
|
|
<el-form-item>
|
|
<el-button type="primary" @click="resetPage">查询</el-button>
|
|
<el-button @click="resetParams">重置</el-button>
|
|
</el-form-item>
|
|
</el-form>
|
|
</el-card>
|
|
<el-card class="!border-none" v-loading="pager.loading" shadow="never">
|
|
<div class="mt-4">
|
|
<el-table :data="pager.lists" @selection-change="handleSelectionChange">
|
|
<el-table-column
|
|
label="ID"
|
|
prop="id"
|
|
show-overflow-tooltip
|
|
width="80"
|
|
/>
|
|
<el-table-column
|
|
label="公司名称"
|
|
prop="company_name"
|
|
width="300"
|
|
show-overflow-tooltip
|
|
/>
|
|
<el-table-column
|
|
label="公司类型"
|
|
prop="company_type"
|
|
show-overflow-tooltip
|
|
/>
|
|
<el-table-column label="押金" prop="deposit" show-overflow-tooltip>
|
|
<template #default="{ row }">
|
|
<span class="text-success">{{ row.deposit }}</span>
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column label="区县" prop="area" show-overflow-tooltip />
|
|
<el-table-column label="乡镇" prop="street" show-overflow-tooltip />
|
|
<el-table-column
|
|
label="主联系人"
|
|
prop="master_name"
|
|
show-overflow-tooltip
|
|
/>
|
|
<el-table-column
|
|
label="联系方式"
|
|
prop="master_phone"
|
|
show-overflow-tooltip
|
|
/>
|
|
<el-table-column
|
|
label="片区经理"
|
|
prop="area_manager"
|
|
show-overflow-tooltip
|
|
/>
|
|
<el-table-column
|
|
label="操作"
|
|
align="center"
|
|
width="200"
|
|
fixed="right"
|
|
>
|
|
<template #default="{ row }">
|
|
<div style="display: flex">
|
|
<el-button type="primary" link @click="handleEdit(row)">
|
|
凭证录入
|
|
</el-button>
|
|
<el-button type="primary" link>
|
|
<router-link
|
|
:to="{
|
|
path: getRoutePath('finance.depositList'),
|
|
query: {
|
|
company_id: row.id,
|
|
},
|
|
}"
|
|
>凭证列表</router-link
|
|
>
|
|
</el-button>
|
|
</div>
|
|
</template>
|
|
</el-table-column>
|
|
</el-table>
|
|
</div>
|
|
<div class="flex mt-4 justify-end">
|
|
<pagination v-model="pager" @change="getLists" />
|
|
</div>
|
|
</el-card>
|
|
|
|
<edit-popup
|
|
v-if="showEdit"
|
|
ref="editRef"
|
|
:dict-data="dictData"
|
|
@success="getLists"
|
|
@close="showEdit = false"
|
|
/>
|
|
</div>
|
|
</template>
|
|
|
|
<script lang="ts" setup name="financeCompanyLists">
|
|
import { usePaging } from "@/hooks/usePaging";
|
|
import { useDictData } from "@/hooks/useDictOptions";
|
|
import useUserStore from "@/stores/modules/user";
|
|
import { apiCompanyLists } from "@/api/company";
|
|
import { timeFormat } from "@/utils/util";
|
|
import { dictDataLists } from "@/api/setting/dict";
|
|
import { getRoutePath } from "@/router";
|
|
import { dictContractTypeList } from "@/utils/dict.ts";
|
|
import EditPopup from "./component/voucher.vue";
|
|
|
|
const userStore = useUserStore();
|
|
// console.log(userStore.userInfo.company_id);
|
|
const route = useRoute();
|
|
const company_type_show = ref(true);
|
|
|
|
// 是否显示编辑框
|
|
const showEdit = ref(false);
|
|
const editRef = ref(null);
|
|
// 编辑
|
|
const handleEdit = async (data: any) => {
|
|
showEdit.value = true;
|
|
await nextTick();
|
|
editRef.value?.open("edit");
|
|
editRef.value?.setFormData(data);
|
|
};
|
|
|
|
// 创建合同与发送短信结束
|
|
// 查询条件
|
|
const queryParams = reactive({
|
|
company_name: "",
|
|
area: "",
|
|
street: "",
|
|
company_type: "",
|
|
area_manager: "",
|
|
// 是否签约
|
|
is_contract: "",
|
|
});
|
|
|
|
if (route.query.company_type) {
|
|
company_type_show.value = false;
|
|
queryParams["company_type"] = route.query.company_type?.toString() || "";
|
|
}
|
|
|
|
const datas = reactive({
|
|
dictTypeLists: [],
|
|
});
|
|
const getdictTypeLists = async () => {
|
|
const data = await dictDataLists({ type_id: 6 });
|
|
datas["dictTypeLists"] = data["lists"];
|
|
};
|
|
getdictTypeLists();
|
|
// 选中数据
|
|
const selectData = ref<any[]>([]);
|
|
|
|
// 表格选择后回调事件
|
|
const handleSelectionChange = (val: any[]) => {
|
|
selectData.value = val.map(({ id }) => id);
|
|
};
|
|
|
|
// 获取字典数据
|
|
const { dictData } = useDictData("");
|
|
|
|
// 分页相关
|
|
const { pager, getLists, resetParams, resetPage } = usePaging({
|
|
fetchFun: apiCompanyLists,
|
|
params: queryParams,
|
|
});
|
|
|
|
getLists();
|
|
</script>
|
|
<style lang="scss">
|
|
.btn {
|
|
position: absolute;
|
|
}
|
|
h1 {
|
|
text-align: center;
|
|
font-weight: bold;
|
|
font-size: 30px;
|
|
color: red;
|
|
margin-bottom: 10px;
|
|
}
|
|
|
|
.content {
|
|
font-size: 20px;
|
|
}
|
|
|
|
.info {
|
|
color: red;
|
|
font-weight: bold;
|
|
font-size: 18px;
|
|
display: inline-block;
|
|
margin: 0 5px;
|
|
}
|
|
|
|
.btn_menu {
|
|
margin-top: 10vh;
|
|
display: flex;
|
|
justify-content: space-around;
|
|
}
|
|
.formdata {
|
|
.el-form-item {
|
|
width: 20%;
|
|
}
|
|
}
|
|
</style>
|
|
|