You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
volunteer-pc/src/views/volunteer/gxhzs/gxhzsff/index.vue

383 lines
11 KiB

2 years ago
<template>
<div class="app-container" ref="main">
<div ref="search">
2 years ago
<MyInput
v-model="queryParams.certificateName"
@clickSearch="handleSearch"
/>
</div>
<el-table
v-loading="loading"
:data="tableData"
:height="tableHeigth + 'px'"
>
<el-table-column
label="序号"
align="center"
type="index"
prop="id"
width="55"
/>
2 years ago
<el-table-column label="证书名称" align="center" prop="certificateName" />
2 years ago
<el-table-column label="志愿者" align="center" prop="userName" />
<el-table-column label="兑换时间" align="center" prop="createTime" />
<el-table-column label="状态" align="center" prop="status">
<template slot-scope="scope">
2 years ago
{{ scope.row.status == 1 ? "已发放" : "未发放" }}
</template>
</el-table-column>
<el-table-column
label="操作"
align="center"
class-name="small-padding fixed-width"
>
<template slot-scope="scope">
2 years ago
<el-button size="mini" type="text" @click="handleInfo(scope.row)"
>查看</el-button
>
2 years ago
<el-button
size="mini"
type="text"
@click="handleFabu(scope.row)"
v-if="scope.row.status != 1"
>发放</el-button
>
</template>
</el-table-column>
</el-table>
<pagination
v-show="total > 0"
:total="total"
:page.sync="queryParams.pageNum"
:limit.sync="queryParams.pageSize"
@pagination="getList"
/>
<!-- 发布对话框 -->
<el-dialog :visible.sync="open" width="500px" append-to-body>
<div slot="title" class="dialog-title">
<span class="title-line"></span>
{{ title }}
</div>
<div class="info-box">
<div>
2 years ago
<div class="info-form-title">
<span></span>
证书信息
</div>
<div class="info-item">
2 years ago
<div class="item-lable">证书名称:</div>
2 years ago
<div class="item-value">{{ form.certificateName }}</div>
</div>
<div class="info-item">
2 years ago
<div class="item-lable">志愿者:</div>
2 years ago
<div class="item-value">{{ form.userName }}</div>
</div>
2 years ago
<div class="info-item">
<div class="item-lable">兑换时间:</div>
2 years ago
<div class="item-value">{{ form.createTime }}</div>
2 years ago
</div>
<div class="info-item">
<div class="item-lable">状态:</div>
<div class="item-value">
2 years ago
{{ form.status == 1 ? "已发放" : "未发放" }}
</div>
</div>
2 years ago
<div class="info-form-title">
<span></span>
收货信息
</div>
2 years ago
<div class="info-item">
<div class="item-lable">姓名:</div>
2 years ago
<div class="item-value">{{ form.userName }}</div>
2 years ago
</div>
<div class="info-item">
<div class="item-lable">手机号:</div>
2 years ago
<div class="item-value">{{ form.phonenumber }}</div>
2 years ago
</div>
<div class="info-item">
<div class="item-lable">详细地址:</div>
2 years ago
<div class="item-value">{{ form.address }}</div>
2 years ago
</div>
</div>
</div>
<div slot="footer" class="dialog-footer">
<el-button @click="cancel"> </el-button>
2 years ago
<el-button type="warning" @click="submitPaper()"
>发放纸制证书</el-button
>
<el-button type="primary" @click="submitElectron()"
>发放电子证书</el-button
>
</div>
</el-dialog>
2 years ago
<!-- 纸制证书 -->
<el-dialog :visible.sync="infoOpen" width="500px" append-to-body>
<div slot="title" class="dialog-title">
<span class="title-line"></span>
邮政信息
</div>
2 years ago
<el-form ref="form" :model="form" :rules="rules" label-width="80px">
2 years ago
<el-form-item label="快递公司" prop="courierCompanies">
<el-input
v-model="form.courierCompanies"
placeholder="请输入快递公司"
/>
2 years ago
</el-form-item>
2 years ago
<el-form-item label="快递单号" prop="trackingNumber">
2 years ago
<el-input
2 years ago
v-model="form.trackingNumber"
2 years ago
placeholder="请输入快递公司"
/>
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button type="primary" @click="submitForm"> </el-button>
</div>
</el-dialog>
2 years ago
<!-- 查看 -->
<el-dialog :visible.sync="infoShow" width="600px" append-to-body>
<div slot="title" class="dialog-title">
<span class="title-line"></span>
查看
</div>
<div class="conversionInfo">
<div class="basicInfo">
<div class="title">
<img src="@/assets/images/huodong.png" alt="" />
<span>证书详情</span>
</div>
<div class="info">
<div class="lists">
<div class="list-left">
<div>证书名称</div>
<div>{{ form.certificateName }}</div>
</div>
<div class="list-right">
<div>志愿者</div>
<div>{{ form.userName }}</div>
</div>
</div>
<div class="lists">
<div class="list-left">
<div>兑换时间</div>
<div>{{ form.createTime }}</div>
</div>
<div class="list-left">
<div>状态</div>
<div>{{ form.status == 1 ? "已发放" : "未发放" }}</div>
</div>
</div>
</div>
</div>
<div class="logisticsInfo" v-show="form.type == 2">
<div class="title">
<img src="@/assets/images/huodong.png" alt="" />
<span>纸制证书</span>
</div>
<div class="info">
<div class="lists">
<div class="list-left">
<div>快递公司</div>
<div>{{ form.courierCompanies }}</div>
</div>
<div class="list-right">
<div>快递单号</div>
<div>{{ form.trackingNumber }}</div>
</div>
</div>
</div>
</div>
<div class="logisticsInfo" v-show="form.type == 1">
<div class="title">
<img src="@/assets/images/huodong.png" alt="" />
<span>电子证书</span>
</div>
<div class="info"></div>
</div>
</div>
</el-dialog>
</div>
2 years ago
</template>
<script>
2 years ago
import {
dsbrecordsList,
dsbrecordsInfo,
issue,
} from "@/api/volunteer/gxhzs/hdzsff/index.js";
export default {
data() {
return {
2 years ago
infoShow: false,
infoOpen: false,
form: {},
2 years ago
rules: {
courierCompanies: [
{ required: true, message: "请输入快递公司", trigger: "blur" },
],
trackingNumber: [
{ required: true, message: "请输入快递公司", trigger: "blur" },
],
},
open: false,
title: "",
tableHeigth: 0,
loading: false,
tableData: [],
total: 1,
queryParams: {
2 years ago
certificateName: undefined,
creType: 2, //1:一次性证书发放,2个性化证书发放
pageNum: 1,
pageSize: 20,
},
};
},
created() {
// //给表格一个固定值
this.$nextTick(() => {
this.tableHeigth =
2 years ago
this.$refs.main.offsetHeight - this.$refs.search.offsetHeight - 80;
this.getList();
});
},
methods: {
2 years ago
/**搜索 */
handleSearch(keyWord) {
this.queryParams = {
certificateName: keyWord,
creType: 2, //1:一次性证书发放,2个性化证书发放
pageNum: 1,
pageSize: 10,
};
this.getList();
},
/**查详情 */
async handleInfo(row) {
let res = await this.getInfo(row.id);
this.form = res.data;
this.infoShow = true;
// console.log("详情", res);
},
async getInfo(id) {
let res = await dsbrecordsInfo(id);
return res;
},
2 years ago
//发放按钮
async handleFabu(row) {
this.reset();
let res = await this.getInfo(row.id);
this.form = res.data;
this.title = "发放查看";
this.open = true;
},
//点击制造或者电子验证收货信息是否完整
isComplete() {
if (!this.form.userName || !this.form.address || !this.form.phonenumber) {
this.$modal.msgError("请前往地址管理中添加详细地址!");
return false;
} else {
return true;
}
},
/**纸制 */
submitPaper() {
2 years ago
let isTrue = this.isComplete();
if (isTrue) {
this.infoOpen = true;
}
},
2 years ago
/**纸制提交 */
submitForm() {
this.$refs["form"].validate((valid) => {
let data = {
courierCompanies: this.form.courierCompanies,
id: this.form.id,
trackingNumber: this.form.trackingNumber,
type: 2, // 1:电子证书 2:纸制证书
};
this.subIssue(data);
});
},
//发放
subIssue(data) {
issue(data).then((res) => {
this.infoOpen = false;
this.open = false;
this.getList();
2 years ago
this.$modal.msgSuccess("发放成功");
});
},
2 years ago
/**电子 */
submitElectron() {
let _this = this;
this.$modal
.confirm(`您确定要发放“${this.form.certificateName}”证书吗?`)
.then(function () {
let data = {
id: _this.form.id,
type: 1, // 1:电子证书 2:纸制证书
};
_this.subIssue(data);
});
},
/**关闭 */
cancel() {
this.open = false;
this.reset();
},
/**重置 */
reset() {
this.form = {
id: null,
activityId: null,
certificateId: null,
uId: null,
content: null,
createId: null,
createBy: null,
createTime: null,
updateId: null,
updateBy: null,
updateTime: null,
remark: null,
userId: null,
deptId: null,
type: null,
};
},
/** 查询发放记录列表 */
getList() {
this.loading = true;
2 years ago
dsbrecordsList(this.queryParams).then((response) => {
this.tableData = response.rows;
this.total = response.total;
this.loading = false;
});
},
},
};
</script>
<style lang="scss" scoped>
@import "@/assets/styles/myTable.scss";
2 years ago
.info-form-title {
display: flex;
align-items: center;
margin-bottom: 20px;
font-size: 17px;
font-family: "Alibaba-PuHuiTi-Regular";
font-weight: 500;
color: #333;
font-weight: bold;
span {
width: 5px;
height: 17px;
margin-right: 6px;
background: #f8414d;
}
}
</style>