.........

This commit is contained in:
DelLevin-Home
2026-02-05 21:12:23 +08:00
parent 9faa180627
commit d42acb6a02
10 changed files with 0 additions and 643 deletions

View File

@@ -1,142 +0,0 @@
<template>
<el-dialog v-model="visible" :title="!dataForm.id ? '新增' : '修改'" :close-on-click-modal="false" :close-on-press-escape="false">
<el-form :model="dataForm" :rules="rules" ref="dataFormRef" @keyup.enter="dataFormSubmitHandle()" label-width="120px">
<el-form-item label=" 提供商" prop="provider">
<el-input v-model="dataForm.provider" placeholder=" 提供商:阿里/腾讯/网易/百度/"></el-input>
</el-form-item>
<el-form-item label="名称" prop="name">
<el-input v-model="dataForm.name" placeholder="名称"></el-input>
</el-form-item>
<el-form-item label="备注" prop="remark">
<el-input v-model="dataForm.remark" placeholder="备注"></el-input>
</el-form-item>
<el-form-item label="续费方式" prop="renewalType">
<el-select v-model="dataForm.renewalType" placeholder="请选择续费方式" style="width: 240px">
<el-option v-for="item in renewalType" :key="item.dictValue" :label="item.dictLabel" :value="item.dictValue" />
</el-select>
</el-form-item>
<el-form-item label="续费日" prop="renewalDate">
<el-input-number v-model="dataForm.renewalDate" :min="1" :max="29" placeholder="具体续费日期 (1-29)" style="width: 100%" />
</el-form-item>
<el-form-item label="到期时间" prop="expireTime">
<el-date-picker v-model="dataForm.expireTime" type="datetime" placeholder="选择到期时间" format="YYYY-MM-DD HH:mm:ss" value-format="YYYY-MM-DD HH:mm:ss" style="width: 100%" />
</el-form-item>
<el-form-item label="其他信息" prop="otherInfo">
<el-input v-model="dataForm.otherInfo" placeholder="其他信息json形式"></el-input>
</el-form-item>
</el-form>
<template #footer>
<el-button @click="visible = false">取消</el-button>
<el-button type="primary" @click="dataFormSubmitHandle()">确定</el-button>
</template>
</el-dialog>
</template>
<script lang="ts" setup>
import { reactive, ref, computed } from "vue";
import baseService from "@/service/baseService";
import { ElMessage } from "element-plus";
import { useAppStore } from "@/store";
import { getDictDataList } from "@/utils/utils";
const store = useAppStore();
const renewalType = getDictDataList(store.state.dicts, "renewal_type");
const emit = defineEmits(["refreshDataList"]);
const visible = ref(false);
const dataFormRef = ref();
const dataForm = reactive({
id: "",
provider: "",
name: "",
remark: "",
otherInfo: "",
renewalType: "",
renewalDate: null as number | null,
expireTime: "",
createDate: "",
createUser: "",
updateDate: "",
updateUser: ""
});
const getRules = () => ({
provider: [{ required: true, message: "必填项不能为空", trigger: "blur" }],
name: [{ required: true, message: "必填项不能为空", trigger: "blur" }],
remark: [{ required: true, message: "必填项不能为空", trigger: "blur" }],
renewalType: [{ required: true, message: "必填项不能为空", trigger: "blur" }],
renewalDate:
dataForm.renewalType !== "1"
? [
{ required: true, message: "续费日不能为空", trigger: "blur" },
{ type: "number", min: 1, max: 29, message: "日期必须在1到29之间", trigger: "blur" }
]
: [{ type: "number", min: 1, max: 29, message: "日期必须在1到29之间", trigger: "blur" }],
expireTime: [{ required: true, message: "到期时间不能为空", trigger: "blur" }]
});
// 使用 computed 属性,使其响应式
const rules = computed(() => getRules());
const init = (id?: number) => {
visible.value = true;
dataForm.id = "";
// 重置表单数据
if (dataFormRef.value) {
dataFormRef.value.resetFields();
}
if (id) {
getInfo(id);
}
};
// 获取信息
const getInfo = (id: number) => {
baseService.get("/baitutools/dlrenewalremind/" + id).then((res) => {
const { data } = res; // 解构出 data 对象
// --- 新增处理逻辑 ---
if (data.hasOwnProperty("renewalDate")) {
if (typeof data.renewalDate === "string") {
const parsed = parseInt(data.renewalDate, 10);
data.renewalDate = isNaN(parsed) ? null : parsed;
} else if (typeof data.renewalDate === "number") {
data.renewalDate = data.renewalDate
} else {
data.renewalDate = null;
}
}
// 将处理后的 data 对象合并到 dataForm
Object.assign(dataForm, data);
});
};
// 表单提交
const dataFormSubmitHandle = () => {
dataFormRef.value.validate((valid: boolean) => {
if (!valid) {
return false;
}
(!dataForm.id ? baseService.post : baseService.put)("/baitutools/dlrenewalremind", dataForm).then((res) => {
ElMessage.success({
message: "成功",
duration: 500,
onClose: () => {
visible.value = false;
emit("refreshDataList");
}
});
});
});
};
defineExpose({
init
});
</script>

View File

@@ -1,63 +0,0 @@
<template>
<div class="mod-baitutools__dlrenewalremind">
<el-form :inline="true" :model="state.dataForm" @keyup.enter="state.getDataList()">
<el-form-item>
<el-input v-model="state.dataForm.keywordName" placeholder="名称" clearable></el-input>
</el-form-item>
<el-form-item>
<el-button @click="state.getDataList()">查询</el-button>
</el-form-item>
<el-form-item>
<el-button v-if="state.hasPermission('baitutools:dlrenewalremind:save')" type="primary" @click="addOrUpdateHandle()">新增</el-button>
</el-form-item>
<el-form-item>
<el-button v-if="state.hasPermission('baitutools:dlrenewalremind:delete')" type="danger" @click="state.deleteHandle()">删除</el-button>
</el-form-item>
</el-form>
<el-table v-loading="state.dataListLoading" :data="state.dataList" border @selection-change="state.dataListSelectionChangeHandle" style="width: 100%">
<el-table-column type="selection" header-align="center" align="center" width="50"></el-table-column>
<el-table-column prop="provider" label=" 提供商" header-align="center" align="center"></el-table-column>
<el-table-column prop="name" label="名称" header-align="center" align="center"></el-table-column>
<el-table-column prop="remark" label="备注" header-align="center" align="center"></el-table-column>
<el-table-column prop="otherInfo" label="其他信息" header-align="center" align="center"></el-table-column>
<el-table-column prop="renewalType" label="续费方式" header-align="center" align="center"></el-table-column>
<el-table-column prop="renewalDate" label="具体续费日期" width="130" header-align="center" align="center"></el-table-column>
<el-table-column prop="expireTime" label="到期时间" header-align="center" align="center"></el-table-column>
<el-table-column label="操作" fixed="right" header-align="center" align="center" width="150">
<template v-slot="scope">
<el-button v-if="state.hasPermission('baitutools:dlrenewalremind:update')" type="primary" link @click="addOrUpdateHandle(scope.row.id)">修改</el-button>
<el-button v-if="state.hasPermission('baitutools:dlrenewalremind:delete')" type="primary" link @click="state.deleteHandle(scope.row.id)">删除</el-button>
</template>
</el-table-column>
</el-table>
<el-pagination :current-page="state.page" :page-sizes="[10, 20, 50, 100]" :page-size="state.limit" :total="state.total" layout="total, sizes, prev, pager, next, jumper" @size-change="state.pageSizeChangeHandle" @current-change="state.pageCurrentChangeHandle"> </el-pagination>
<!-- 弹窗, 新增 / 修改 -->
<add-or-update ref="addOrUpdateRef" @refreshDataList="state.getDataList">确定</add-or-update>
</div>
</template>
<script lang="ts" setup>
import useView from "@/hooks/useView";
import { reactive, ref, toRefs } from "vue";
import AddOrUpdate from "./renewalremind-add-or-update.vue";
const view = reactive({
deleteIsBatch: true,
getDataListURL: "/baitutools/dlrenewalremind/page",
getDataListIsPage: true,
exportURL: "/baitutools/dlrenewalremind/export",
deleteURL: "/baitutools/dlrenewalremind",
dataForm: {
keywordName: "",
}
});
const state = reactive({ ...useView(view), ...toRefs(view) });
const addOrUpdateRef = ref();
const addOrUpdateHandle = (id?: number) => {
addOrUpdateRef.value.init(id);
};
</script>