|
@@ -0,0 +1,210 @@
|
|
|
+<script lang="ts">
|
|
|
+// 声明额外的选项
|
|
|
+export default {
|
|
|
+ name: "Add"
|
|
|
+};
|
|
|
+</script>
|
|
|
+<script setup lang="ts">
|
|
|
+import { inject, onMounted, reactive, ref, Uploadfile, UploadImg, Editor, useRenderIcon, ElMessage, ElMessageBox, Upload, Close, http, getGroupUrl, RegularVerification, verification } from "@/utils/importUsed"
|
|
|
+// 接口列表实例
|
|
|
+let UrlList = reactive(null)
|
|
|
+// 获取当前板块接口列表
|
|
|
+onMounted(async () => {
|
|
|
+ UrlList = await getGroupUrl(["prizeSet"]);
|
|
|
+ listIdQuery();
|
|
|
+
|
|
|
+})
|
|
|
+// 组件传参对象
|
|
|
+const props = defineProps<{
|
|
|
+ submit: Function;
|
|
|
+ addVisible: {
|
|
|
+ type: Boolean;
|
|
|
+ default: false;
|
|
|
+ };
|
|
|
+ width: {
|
|
|
+ type: Number;
|
|
|
+ default: 50;
|
|
|
+ };
|
|
|
+ listId: {
|
|
|
+ type: Number;
|
|
|
+ default: 0;
|
|
|
+ },
|
|
|
+
|
|
|
+}>();
|
|
|
+// 表单数据
|
|
|
+let UpdateForm = ref({
|
|
|
+ listId: props.listId, //配置ID
|
|
|
+ prizePercent: "", //奖励比例
|
|
|
+ prizeAmount: "", //奖励固定金额
|
|
|
+ prizeSourceField: "", //奖励金额来源数据
|
|
|
+
|
|
|
+
|
|
|
+});
|
|
|
+// 表单实例
|
|
|
+const ruleFormRef = ref()
|
|
|
+
|
|
|
+// 传参选项数据
|
|
|
+// 配置ID选项数据
|
|
|
+const listIdOptionList = ref([]);
|
|
|
+
|
|
|
+// 选项卡参数(默认值为列表某项的id)
|
|
|
+const activeId = ref('1')
|
|
|
+// 提交函数
|
|
|
+const submit = async (formEl) => {
|
|
|
+ // 表单校验拦截
|
|
|
+ if (!formEl) return
|
|
|
+ await formEl.validate(async (valid, fields) => {
|
|
|
+ if (valid) {
|
|
|
+ //表单校验成功回调
|
|
|
+ console.log('submit!')
|
|
|
+
|
|
|
+
|
|
|
+ // 需动态生成接口
|
|
|
+ const { status, msg }: any = await http.Request({
|
|
|
+ method: UrlList.prizeSet.priaddPriListAmountSet.method,
|
|
|
+ url: UrlList.prizeSet.priaddPriListAmountSet.url,
|
|
|
+ params: UpdateForm.value
|
|
|
+ });
|
|
|
+ if (status === 1) {
|
|
|
+ //业务成功回调
|
|
|
+ ElMessage({
|
|
|
+ message: "新增成功",
|
|
|
+ type: "success"
|
|
|
+ });
|
|
|
+ UpdateForm.value = {
|
|
|
+ listId: props.listId, //配置ID
|
|
|
+ prizePercent: "", //奖励比例
|
|
|
+ prizeAmount: "", //奖励固定金额
|
|
|
+ prizeSourceField: "", //奖励金额来源数据
|
|
|
+
|
|
|
+ };
|
|
|
+ // 关闭新增弹窗;
|
|
|
+ closeVisible()
|
|
|
+ } else {
|
|
|
+ //业务失败回调
|
|
|
+ ElMessageBox.alert(msg, "提示", {
|
|
|
+ confirmButtonText: "关闭",
|
|
|
+ type: "warning"
|
|
|
+ });
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ //表单校验失败回调
|
|
|
+ ElMessage({
|
|
|
+ message: "请输入完整信息",
|
|
|
+ type: "error"
|
|
|
+ });
|
|
|
+ }
|
|
|
+ })
|
|
|
+};
|
|
|
+
|
|
|
+//获取配置ID数据
|
|
|
+const listIdQuery = async () => {
|
|
|
+ const { status, data }: any = await http.Request({ method: UrlList.prizeSet.prigetPriListDic.method, url: UrlList.prizeSet.prigetPriListDic.url, params: { } });
|
|
|
+ if (status === 1) {
|
|
|
+ listIdOptionList.value = data.records;
|
|
|
+ }
|
|
|
+};
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+// 表单校验规则
|
|
|
+const rules = reactive({
|
|
|
+ prizePercent: [
|
|
|
+ { required: true, message: '请输入奖励比例', trigger: 'blur' },
|
|
|
+ ],
|
|
|
+
|
|
|
+})
|
|
|
+// 关闭弹窗回调函数
|
|
|
+const closeFn: any = inject("closeAddVisible");
|
|
|
+const closeVisible = () => {
|
|
|
+ // 清空表单项;
|
|
|
+ UpdateForm.value = {
|
|
|
+ listId: props.listId, //配置ID
|
|
|
+ prizePercent: "", //奖励比例
|
|
|
+ prizeAmount: "", //奖励固定金额
|
|
|
+ prizeSourceField: "", //奖励金额来源数据
|
|
|
+
|
|
|
+ };
|
|
|
+ closeFn();
|
|
|
+};
|
|
|
+
|
|
|
+// 弹窗是否全屏
|
|
|
+const isFullscreen = ref(false)
|
|
|
+</script>
|
|
|
+
|
|
|
+<template lang="pug">
|
|
|
+.main
|
|
|
+ el-dialog(v-model='props.addVisible' width="50%" :fullscreen="isFullscreen" title="新增" draggable @close="closeVisible")
|
|
|
+ el-form(:model='UpdateForm' label-position="right" ref="ruleFormRef" :rules="rules" label-width="100px")
|
|
|
+ el-form-item(label="配置ID", prop="listId")
|
|
|
+ el-select(
|
|
|
+ v-model="UpdateForm.listId",
|
|
|
+ placeholder="请选择配置ID",
|
|
|
+ clearable,
|
|
|
+ )
|
|
|
+ el-option(:label="item.id", :value="item.prizeName" v-for="(item,index) in listIdOptionList")
|
|
|
+ el-form-item(label='奖励比例' prop="prizePercent")
|
|
|
+ el-input-number(v-model='UpdateForm.prizePercent' :min="0" :max="100000"
|
|
|
+ placeholder="请输入奖励比例")
|
|
|
+ el-form-item(label='奖励固定金额' prop="prizeAmount")
|
|
|
+ el-input-number(v-model='UpdateForm.prizeAmount' :min="0" :max="100000"
|
|
|
+ placeholder="请输入奖励固定金额")
|
|
|
+ el-form-item(label='奖励金额来源数据' prop="prizeSourceField")
|
|
|
+ el-input(v-model='UpdateForm.prizeSourceField' autocomplete='off'
|
|
|
+ placeholder="请输入奖励金额来源数据")
|
|
|
+
|
|
|
+ .flex.justify-end
|
|
|
+ el-button(
|
|
|
+ :icon="useRenderIcon(Close)",
|
|
|
+ @click="closeVisible"
|
|
|
+ ) 关闭
|
|
|
+ el-button(
|
|
|
+ type="primary",
|
|
|
+ :icon="useRenderIcon(Upload)",
|
|
|
+ @click="submit(ruleFormRef)"
|
|
|
+ ) 确认提交
|
|
|
+</template>
|
|
|
+
|
|
|
+<style scoped lang="scss">
|
|
|
+:deep(.el-dropdown-menu__item i) {
|
|
|
+ margin: 0;
|
|
|
+}
|
|
|
+
|
|
|
+:deep(.el-form-item__label) {
|
|
|
+ font-weight: 700;
|
|
|
+}
|
|
|
+
|
|
|
+:deep(.el-pagination) {
|
|
|
+ flex-flow: wrap;
|
|
|
+}
|
|
|
+
|
|
|
+:deep(.is-draggable) {
|
|
|
+ max-height: 80vh;
|
|
|
+ overflow: auto;
|
|
|
+}
|
|
|
+
|
|
|
+:deep(.el-dialog__header) {
|
|
|
+ position: sticky;
|
|
|
+ top: 0;
|
|
|
+ z-index: 2;
|
|
|
+ background: #fff;
|
|
|
+}
|
|
|
+
|
|
|
+.collapsedom {
|
|
|
+ padding: 0 20px;
|
|
|
+ background-color: #fff;
|
|
|
+}
|
|
|
+
|
|
|
+.ovh-x {
|
|
|
+ height: 40vh;
|
|
|
+ overflow-y: auto;
|
|
|
+}
|
|
|
+
|
|
|
+:deep(.el-descriptions__header) {
|
|
|
+ margin: 16px 0 !important;
|
|
|
+}
|
|
|
+
|
|
|
+.el-select {
|
|
|
+ width: 100%;
|
|
|
+}
|
|
|
+</style>
|