多语言优化
This commit is contained in:
@@ -39,6 +39,7 @@
|
|||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import { computed } from 'vue'
|
import { computed } from 'vue'
|
||||||
import { useDictStore } from '@/store/modules/dict'
|
import { useDictStore } from '@/store/modules/dict'
|
||||||
|
import { useI18n } from 'vue-i18n'
|
||||||
|
|
||||||
defineOptions({ name: 'SaCheckbox', inheritAttrs: false })
|
defineOptions({ name: 'SaCheckbox', inheritAttrs: false })
|
||||||
|
|
||||||
@@ -69,6 +70,7 @@
|
|||||||
const modelValue = defineModel<(string | number)[]>()
|
const modelValue = defineModel<(string | number)[]>()
|
||||||
|
|
||||||
const dictStore = useDictStore()
|
const dictStore = useDictStore()
|
||||||
|
const { t, te, locale } = useI18n()
|
||||||
|
|
||||||
const canConvertToNumberStrict = (value: any) => {
|
const canConvertToNumberStrict = (value: any) => {
|
||||||
if (value == null) return false
|
if (value == null) return false
|
||||||
@@ -81,9 +83,20 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
const options = computed(() => {
|
const options = computed(() => {
|
||||||
|
// 让字典选项在切换语言时可响应更新
|
||||||
|
locale.value
|
||||||
|
|
||||||
const list = dictStore.getByCode(props.dict) || []
|
const list = dictStore.getByCode(props.dict) || []
|
||||||
|
|
||||||
if (!props.valueType) return list
|
if (!props.valueType) {
|
||||||
|
return list.map((item) => {
|
||||||
|
const key = `dict.${props.dict}.${item.value}`
|
||||||
|
return {
|
||||||
|
...item,
|
||||||
|
label: te(key) ? t(key) : item.label
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
return list.map((item) => {
|
return list.map((item) => {
|
||||||
let newValue = item.value
|
let newValue = item.value
|
||||||
@@ -101,7 +114,11 @@
|
|||||||
|
|
||||||
return {
|
return {
|
||||||
...item,
|
...item,
|
||||||
value: newValue
|
value: newValue,
|
||||||
|
label: (() => {
|
||||||
|
const key = `dict.${props.dict}.${newValue}`
|
||||||
|
return te(key) ? t(key) : item.label
|
||||||
|
})()
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -14,12 +14,12 @@
|
|||||||
:round="round"
|
:round="round"
|
||||||
class="mr-1 last:mr-0"
|
class="mr-1 last:mr-0"
|
||||||
>
|
>
|
||||||
{{ getData(item)?.label || item }}
|
{{ getDisplayLabel(item) }}
|
||||||
</ElTag>
|
</ElTag>
|
||||||
</template>
|
</template>
|
||||||
<template v-else>
|
<template v-else>
|
||||||
<span v-for="(item, index) in normalizedValues" :key="index">
|
<span v-for="(item, index) in normalizedValues" :key="index">
|
||||||
{{ getData(item)?.label || item }}{{ index < normalizedValues.length - 1 ? '、' : '' }}
|
{{ getDisplayLabel(item) }}{{ index < normalizedValues.length - 1 ? '、' : '' }}
|
||||||
</span>
|
</span>
|
||||||
</template>
|
</template>
|
||||||
</div>
|
</div>
|
||||||
@@ -27,6 +27,7 @@
|
|||||||
|
|
||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import { useDictStore } from '@/store/modules/dict'
|
import { useDictStore } from '@/store/modules/dict'
|
||||||
|
import { useI18n } from 'vue-i18n'
|
||||||
|
|
||||||
defineOptions({ name: 'SaDict' })
|
defineOptions({ name: 'SaDict' })
|
||||||
|
|
||||||
@@ -50,6 +51,7 @@
|
|||||||
})
|
})
|
||||||
|
|
||||||
const dictStore = useDictStore()
|
const dictStore = useDictStore()
|
||||||
|
const { t, te, locale } = useI18n()
|
||||||
|
|
||||||
// 统一处理 value,转换为数组格式
|
// 统一处理 value,转换为数组格式
|
||||||
const normalizedValues = computed(() => {
|
const normalizedValues = computed(() => {
|
||||||
@@ -64,6 +66,16 @@
|
|||||||
// 根据值获取字典数据
|
// 根据值获取字典数据
|
||||||
const getData = (value: string) => dictStore.getDataByValue(props.dict, value)
|
const getData = (value: string) => dictStore.getDataByValue(props.dict, value)
|
||||||
|
|
||||||
|
const getDisplayLabel = (value: string) => {
|
||||||
|
// 让显示在切换语言时可响应更新
|
||||||
|
locale.value
|
||||||
|
|
||||||
|
const key = `dict.${props.dict}.${value}`
|
||||||
|
if (te(key)) return t(key)
|
||||||
|
|
||||||
|
return getData(value)?.label || value
|
||||||
|
}
|
||||||
|
|
||||||
const getColor = (color: string | undefined, type: 'bg' | 'border' | 'text') => {
|
const getColor = (color: string | undefined, type: 'bg' | 'border' | 'text') => {
|
||||||
// 如果没有指定颜色,使用默认主色调
|
// 如果没有指定颜色,使用默认主色调
|
||||||
if (!color) {
|
if (!color) {
|
||||||
|
|||||||
@@ -45,6 +45,7 @@
|
|||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import { computed } from 'vue'
|
import { computed } from 'vue'
|
||||||
import { useDictStore } from '@/store/modules/dict'
|
import { useDictStore } from '@/store/modules/dict'
|
||||||
|
import { useI18n } from 'vue-i18n'
|
||||||
|
|
||||||
defineOptions({ name: 'SaRadio', inheritAttrs: false })
|
defineOptions({ name: 'SaRadio', inheritAttrs: false })
|
||||||
|
|
||||||
@@ -82,6 +83,7 @@
|
|||||||
const modelValue = defineModel<string | number | undefined>()
|
const modelValue = defineModel<string | number | undefined>()
|
||||||
|
|
||||||
const dictStore = useDictStore()
|
const dictStore = useDictStore()
|
||||||
|
const { t, te, locale } = useI18n()
|
||||||
|
|
||||||
// 判断能否转成数字
|
// 判断能否转成数字
|
||||||
const canConvertToNumberStrict = (value: any) => {
|
const canConvertToNumberStrict = (value: any) => {
|
||||||
@@ -97,10 +99,21 @@
|
|||||||
|
|
||||||
// 核心逻辑:在 computed 中处理数据类型转换
|
// 核心逻辑:在 computed 中处理数据类型转换
|
||||||
const options = computed(() => {
|
const options = computed(() => {
|
||||||
|
// 让字典选项在切换语言时可响应更新
|
||||||
|
locale.value
|
||||||
|
|
||||||
const list = dictStore.getByCode(props.dict) || []
|
const list = dictStore.getByCode(props.dict) || []
|
||||||
|
|
||||||
// 如果没有指定 valueType,直接返回原始字典
|
// 如果没有指定 valueType,直接返回原始字典
|
||||||
if (!props.valueType) return list
|
if (!props.valueType) {
|
||||||
|
return list.map((item) => {
|
||||||
|
const key = `dict.${props.dict}.${item.value}`
|
||||||
|
return {
|
||||||
|
...item,
|
||||||
|
label: te(key) ? t(key) : item.label
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
// 如果指定了类型,进行映射转换
|
// 如果指定了类型,进行映射转换
|
||||||
return list.map((item) => {
|
return list.map((item) => {
|
||||||
@@ -119,7 +132,11 @@
|
|||||||
|
|
||||||
return {
|
return {
|
||||||
...item,
|
...item,
|
||||||
value: newValue
|
value: newValue,
|
||||||
|
label: (() => {
|
||||||
|
const key = `dict.${props.dict}.${newValue}`
|
||||||
|
return te(key) ? t(key) : item.label
|
||||||
|
})()
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -37,6 +37,7 @@
|
|||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import { computed } from 'vue'
|
import { computed } from 'vue'
|
||||||
import { useDictStore } from '@/store/modules/dict'
|
import { useDictStore } from '@/store/modules/dict'
|
||||||
|
import { useI18n } from 'vue-i18n'
|
||||||
|
|
||||||
defineOptions({ name: 'SaSelect', inheritAttrs: false })
|
defineOptions({ name: 'SaSelect', inheritAttrs: false })
|
||||||
|
|
||||||
@@ -75,6 +76,7 @@
|
|||||||
const modelValue = defineModel<string | number | Array<string | number>>()
|
const modelValue = defineModel<string | number | Array<string | number>>()
|
||||||
|
|
||||||
const dictStore = useDictStore()
|
const dictStore = useDictStore()
|
||||||
|
const { t, te, locale } = useI18n()
|
||||||
|
|
||||||
// 判断能否转成数字
|
// 判断能否转成数字
|
||||||
const canConvertToNumberStrict = (value: any) => {
|
const canConvertToNumberStrict = (value: any) => {
|
||||||
@@ -90,10 +92,21 @@
|
|||||||
|
|
||||||
// 计算属性:获取字典数据并处理类型转换
|
// 计算属性:获取字典数据并处理类型转换
|
||||||
const options = computed(() => {
|
const options = computed(() => {
|
||||||
|
// 让字典选项在切换语言时可响应更新
|
||||||
|
locale.value
|
||||||
|
|
||||||
const list = dictStore.getByCode(props.dict) || []
|
const list = dictStore.getByCode(props.dict) || []
|
||||||
|
|
||||||
// 1. 如果没有指定 valueType,直接返回
|
// 1. 如果没有指定 valueType,直接返回
|
||||||
if (!props.valueType) return list
|
if (!props.valueType) {
|
||||||
|
return list.map((item) => {
|
||||||
|
const key = `dict.${props.dict}.${item.value}`
|
||||||
|
return {
|
||||||
|
...item,
|
||||||
|
label: te(key) ? t(key) : item.label
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
// 2. 如果指定了类型,进行映射转换
|
// 2. 如果指定了类型,进行映射转换
|
||||||
return list.map((item) => {
|
return list.map((item) => {
|
||||||
@@ -111,7 +124,11 @@
|
|||||||
|
|
||||||
return {
|
return {
|
||||||
...item,
|
...item,
|
||||||
value: newValue
|
value: newValue,
|
||||||
|
label: (() => {
|
||||||
|
const key = `dict.${props.dict}.${newValue}`
|
||||||
|
return te(key) ? t(key) : item.label
|
||||||
|
})()
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -47,6 +47,17 @@
|
|||||||
"labelName": "Name",
|
"labelName": "Name",
|
||||||
"close": "Close"
|
"close": "Close"
|
||||||
},
|
},
|
||||||
|
"dict": {
|
||||||
|
"data_status": {
|
||||||
|
"1": "Normal",
|
||||||
|
"2": "Disabled"
|
||||||
|
},
|
||||||
|
"gender": {
|
||||||
|
"1": "Male",
|
||||||
|
"2": "Female",
|
||||||
|
"3": "Unknown"
|
||||||
|
}
|
||||||
|
},
|
||||||
"search": {
|
"search": {
|
||||||
"placeholder": "Search page",
|
"placeholder": "Search page",
|
||||||
"historyTitle": "Search history",
|
"historyTitle": "Search history",
|
||||||
|
|||||||
@@ -31,7 +31,10 @@
|
|||||||
"rollNumber": "Roll Sum",
|
"rollNumber": "Roll Sum",
|
||||||
"placeholderRollNumber": "Sum of 5 dice (5–30)",
|
"placeholderRollNumber": "Sum of 5 dice (5–30)",
|
||||||
"rewardConfig": "Reward Config",
|
"rewardConfig": "Reward Config",
|
||||||
"placeholderRewardConfig": "Select reward config (by UI text)"
|
"placeholderRewardConfig": "Select reward config (by UI text)",
|
||||||
|
"addSuccess": "Added successfully",
|
||||||
|
"editSuccess": "Updated successfully",
|
||||||
|
"validateFailed": "Validation failed, please check required fields and format"
|
||||||
},
|
},
|
||||||
"search": {
|
"search": {
|
||||||
"player": "Player",
|
"player": "Player",
|
||||||
|
|||||||
@@ -33,5 +33,34 @@
|
|||||||
"rollNumber": "Roll Number",
|
"rollNumber": "Roll Number",
|
||||||
"rewardConfig": "Reward Config",
|
"rewardConfig": "Reward Config",
|
||||||
"createTime": "Create Time"
|
"createTime": "Create Time"
|
||||||
|
},
|
||||||
|
"form": {
|
||||||
|
"titleAdd": "Add Player Draw Record (Test)",
|
||||||
|
"titleEdit": "Edit Player Draw Record (Test)",
|
||||||
|
"labelLotteryConfigId": "Lottery Config ID",
|
||||||
|
"placeholderLotteryConfigId": "Please enter lottery config id",
|
||||||
|
"placeholderWinCoin": "Win coin",
|
||||||
|
"placeholderRewardTier": "Please select tier (will auto fill reward config id)",
|
||||||
|
"rewardConfigId": "Reward Config ID",
|
||||||
|
"placeholderRewardConfigId": "Auto fill by tier or enter manually",
|
||||||
|
"placeholderStartIndex": "Please enter start index",
|
||||||
|
"labelTargetIndex": "Target Index",
|
||||||
|
"placeholderTargetIndex": "Please enter target index",
|
||||||
|
"placeholderRollNumber": "Please enter roll number",
|
||||||
|
"labelRollArray": "Roll Array [1,2,3,4,5,6]",
|
||||||
|
"placeholderRollArray": "Please enter roll array [1,2,3,4,5,6]",
|
||||||
|
"labelStatus": "Status (0=fail, 1=success)",
|
||||||
|
"placeholderSuperWinCoin": "Please enter super win coin",
|
||||||
|
"placeholderRewardWinCoin": "Please enter reward win coin",
|
||||||
|
"labelAdminId": "Admin ID",
|
||||||
|
"placeholderAdminId": "Please enter admin id",
|
||||||
|
"ruleLotteryConfigIdRequired": "Lottery config id is required",
|
||||||
|
"ruleDrawTypeRequired": "Draw type is required",
|
||||||
|
"ruleIsBigWinRequired": "Is big win is required",
|
||||||
|
"ruleDirectionRequired": "Direction is required",
|
||||||
|
"ruleRewardConfigIdRequired": "Reward config id is required",
|
||||||
|
"ruleStatusRequired": "Status is required",
|
||||||
|
"addSuccess": "Added successfully",
|
||||||
|
"editSuccess": "Updated successfully"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -30,6 +30,7 @@
|
|||||||
"t5Weight": "T5 Pool Weight (%)",
|
"t5Weight": "T5 Pool Weight (%)",
|
||||||
"weightsSumHint": "Total pool weights: ",
|
"weightsSumHint": "Total pool weights: ",
|
||||||
"weightsSumUnit": "% / 100% (must equal 100%)",
|
"weightsSumUnit": "% / 100% (must equal 100%)",
|
||||||
|
"ruleWeightsSumMustBe100": "Total pool weights must equal 100%",
|
||||||
"walletTitle": "Player Wallet Operation",
|
"walletTitle": "Player Wallet Operation",
|
||||||
"walletPlayer": "Player",
|
"walletPlayer": "Player",
|
||||||
"walletBalance": "Balance",
|
"walletBalance": "Balance",
|
||||||
|
|||||||
@@ -12,7 +12,9 @@
|
|||||||
"placeholderFreeDrawCount": "Please enter free draw count",
|
"placeholderFreeDrawCount": "Please enter free draw count",
|
||||||
"totalDrawCount": "Total Draw Count",
|
"totalDrawCount": "Total Draw Count",
|
||||||
"placeholderTotalDrawCount": "Auto sum",
|
"placeholderTotalDrawCount": "Auto sum",
|
||||||
"placeholderRemark": "Remark (required)"
|
"placeholderRemark": "Remark (required)",
|
||||||
|
"addSuccess": "Added successfully",
|
||||||
|
"editSuccess": "Updated successfully"
|
||||||
},
|
},
|
||||||
"search": {
|
"search": {
|
||||||
"player": "Player",
|
"player": "Player",
|
||||||
|
|||||||
@@ -17,7 +17,9 @@
|
|||||||
"placeholderWalletBefore": "Auto from selected user",
|
"placeholderWalletBefore": "Auto from selected user",
|
||||||
"walletAfter": "After",
|
"walletAfter": "After",
|
||||||
"placeholderWalletAfter": "Auto calculated",
|
"placeholderWalletAfter": "Auto calculated",
|
||||||
"placeholderRemark": "Optional"
|
"placeholderRemark": "Optional",
|
||||||
|
"addSuccess": "Added successfully",
|
||||||
|
"editSuccess": "Updated successfully"
|
||||||
},
|
},
|
||||||
"search": {
|
"search": {
|
||||||
"type": "Type",
|
"type": "Type",
|
||||||
|
|||||||
@@ -19,5 +19,34 @@
|
|||||||
"realEv": "Real EV",
|
"realEv": "Real EV",
|
||||||
"remark": "Remark",
|
"remark": "Remark",
|
||||||
"weight": "Weight"
|
"weight": "Weight"
|
||||||
|
},
|
||||||
|
"form": {
|
||||||
|
"titleAdd": "Add Reward Config",
|
||||||
|
"titleEdit": "Edit Reward Config",
|
||||||
|
"labelDicePoints": "Dice Points",
|
||||||
|
"placeholderDicePoints": "Please enter dice points",
|
||||||
|
"labelUiText": "Display Text",
|
||||||
|
"placeholderUiText": "Please enter display text (Chinese)",
|
||||||
|
"labelUiTextEn": "Display Text (EN)",
|
||||||
|
"placeholderUiTextEn": "Please enter display text (English)",
|
||||||
|
"labelRealEv": "Real EV",
|
||||||
|
"placeholderRealEv": "Please enter real EV",
|
||||||
|
"labelTier": "Tier",
|
||||||
|
"placeholderTier": "Please select tier",
|
||||||
|
"tierBigWin": "BIGWIN (Super Prize)",
|
||||||
|
"labelBigWinWeight": "Big Win Weight",
|
||||||
|
"placeholderBigWinWeight": "0~10000, 10000=100% win",
|
||||||
|
"bigWinWeightDisabledTip": "For points 5 and 30, big win is guaranteed. Weight is fixed to 10000.",
|
||||||
|
"bigWinWeightTip": "10000=100% win, 0=0% win; only effective for points 10/15/20/25",
|
||||||
|
"labelRemark": "Remark",
|
||||||
|
"placeholderRemark": "Please enter remark",
|
||||||
|
"ruleDicePointsRequired": "Dice points is required",
|
||||||
|
"ruleUiTextRequired": "Display text is required",
|
||||||
|
"ruleUiTextEnMax": "Display text (EN) must be less than 255 characters",
|
||||||
|
"ruleRealEvRequired": "Real EV is required",
|
||||||
|
"ruleTierRequired": "Tier is required",
|
||||||
|
"ruleBigWinWeightRange": "Big win weight must be between 0 and 10000",
|
||||||
|
"addSuccess": "Added successfully",
|
||||||
|
"editSuccess": "Updated successfully"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -14,5 +14,18 @@
|
|||||||
"statusFail": "Failed",
|
"statusFail": "Failed",
|
||||||
"statusDone": "Done",
|
"statusDone": "Done",
|
||||||
"statusTesting": "Testing"
|
"statusTesting": "Testing"
|
||||||
|
},
|
||||||
|
"form": {
|
||||||
|
"titleAdd": "Add Reward Config Weight Test Record",
|
||||||
|
"titleEdit": "Edit Reward Config Weight Test Record",
|
||||||
|
"labelTestCount": "Test Count: 100/500/1000",
|
||||||
|
"placeholderTestCount": "Please enter test count: 100/500/1000",
|
||||||
|
"labelWeightSnapshot": "Weight Snapshot: save id,grid_number,tier,weight by tier",
|
||||||
|
"placeholderWeightSnapshot": "Please enter weight snapshot: id,grid_number,tier,weight by tier",
|
||||||
|
"labelResultCounts": "Result Counts: grid_number => count",
|
||||||
|
"placeholderResultCounts": "Please enter result counts: grid_number => count",
|
||||||
|
"ruleTestCountRequired": "Test count is required",
|
||||||
|
"addSuccess": "Added successfully",
|
||||||
|
"editSuccess": "Updated successfully"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -14,5 +14,13 @@
|
|||||||
"fileType": "File Type",
|
"fileType": "File Type",
|
||||||
"fileSize": "File Size",
|
"fileSize": "File Size",
|
||||||
"uploadTime": "Upload Time"
|
"uploadTime": "Upload Time"
|
||||||
|
},
|
||||||
|
"form": {
|
||||||
|
"titleAdd": "Add File",
|
||||||
|
"titleEdit": "Edit File",
|
||||||
|
"labelFileName": "File Name",
|
||||||
|
"placeholderFileName": "Please enter file name",
|
||||||
|
"ruleFileNameRequired": "Please enter file name",
|
||||||
|
"editSuccess": "Updated successfully"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -17,5 +17,49 @@
|
|||||||
"sort": "Sort",
|
"sort": "Sort",
|
||||||
"status": "Status",
|
"status": "Status",
|
||||||
"createTime": "Create Time"
|
"createTime": "Create Time"
|
||||||
|
},
|
||||||
|
"form": {
|
||||||
|
"titleAdd": "Add Menu",
|
||||||
|
"titleEdit": "Edit Menu",
|
||||||
|
"labelMenuType": "Menu Type",
|
||||||
|
"labelParentMenu": "Parent Menu",
|
||||||
|
"labelMenuName": "Menu Name",
|
||||||
|
"labelRoutePath": "Route Path",
|
||||||
|
"labelRoutePathTip": "Top-level: absolute path starting with / (e.g. /dashboard). Sub-level: relative path (e.g. console, user).",
|
||||||
|
"placeholderRoutePath": "e.g. /dashboard or console",
|
||||||
|
"labelComponentName": "Component Name",
|
||||||
|
"placeholderComponentName": "e.g. User",
|
||||||
|
"labelComponentPath": "Component Path",
|
||||||
|
"labelComponentPathTip": "Fill component path under views. For directory menu, leave empty.",
|
||||||
|
"placeholderComponentPath": "e.g. /system/user or leave empty",
|
||||||
|
"labelMenuIcon": "Menu Icon",
|
||||||
|
"labelPermSlug": "Permission Slug",
|
||||||
|
"placeholderPermSlug": "Please enter permission slug",
|
||||||
|
"labelLinkUrl": "External Link",
|
||||||
|
"placeholderLinkUrl": "e.g. https://saithink.top",
|
||||||
|
"labelSort": "Sort",
|
||||||
|
"labelSortTip": "Larger number comes first",
|
||||||
|
"placeholderSort": "Please enter sort",
|
||||||
|
"labelStatus": "Status",
|
||||||
|
"labelStatusTip": "After disabled, this menu item will be unavailable",
|
||||||
|
"labelIsIframe": "Embedded",
|
||||||
|
"labelIsIframeTip": "Only effective in external link mode",
|
||||||
|
"labelIsKeepAlive": "Keep Alive",
|
||||||
|
"labelIsKeepAliveTip": "Switching tabs won't refresh",
|
||||||
|
"labelIsHidden": "Hidden",
|
||||||
|
"labelIsHiddenTip": "Hidden in menu but accessible via route",
|
||||||
|
"labelIsFixedTab": "Fixed Tab",
|
||||||
|
"labelIsFixedTabTip": "Fixed in tabs bar",
|
||||||
|
"labelIsFullPage": "Full Page",
|
||||||
|
"labelIsFullPageTip": "Do not inherit side menu and top bar",
|
||||||
|
"noParentMenu": "No parent menu",
|
||||||
|
"ruleParentMenuRequired": "Please select parent menu",
|
||||||
|
"ruleMenuNameRequired": "Please enter menu name",
|
||||||
|
"ruleRoutePathRequired": "Please enter route path",
|
||||||
|
"ruleComponentNameRequired": "Please enter component name",
|
||||||
|
"rulePermSlugRequired": "Please enter permission slug",
|
||||||
|
"ruleLinkUrlRequired": "Please enter external link",
|
||||||
|
"addSuccess": "Added successfully",
|
||||||
|
"editSuccess": "Updated successfully"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -13,5 +13,22 @@
|
|||||||
"sort": "Sort",
|
"sort": "Sort",
|
||||||
"status": "Status",
|
"status": "Status",
|
||||||
"createTime": "Create Time"
|
"createTime": "Create Time"
|
||||||
|
},
|
||||||
|
"form": {
|
||||||
|
"titleAdd": "Add Post",
|
||||||
|
"titleEdit": "Edit Post",
|
||||||
|
"labelName": "Post Name",
|
||||||
|
"labelCode": "Post Code",
|
||||||
|
"labelRemark": "Description",
|
||||||
|
"labelSort": "Sort",
|
||||||
|
"labelStatus": "Enabled",
|
||||||
|
"placeholderName": "Please enter post name",
|
||||||
|
"placeholderCode": "Please enter post code",
|
||||||
|
"placeholderRemark": "Please enter description",
|
||||||
|
"placeholderSort": "Please enter sort",
|
||||||
|
"ruleNameRequired": "Please enter post name",
|
||||||
|
"ruleCodeRequired": "Please enter post code",
|
||||||
|
"addSuccess": "Added successfully",
|
||||||
|
"editSuccess": "Updated successfully"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -14,5 +14,25 @@
|
|||||||
"roleRemark": "Role Description",
|
"roleRemark": "Role Description",
|
||||||
"status": "Status",
|
"status": "Status",
|
||||||
"createTime": "Create Time"
|
"createTime": "Create Time"
|
||||||
|
},
|
||||||
|
"form": {
|
||||||
|
"titleAdd": "Add Role",
|
||||||
|
"titleEdit": "Edit Role",
|
||||||
|
"labelName": "Role Name",
|
||||||
|
"labelCode": "Role Code",
|
||||||
|
"labelLevel": "Role Level",
|
||||||
|
"levelTip": "Controls role permission level, cannot operate roles with higher level than your own",
|
||||||
|
"labelRemark": "Description",
|
||||||
|
"labelSort": "Sort",
|
||||||
|
"labelStatus": "Enabled",
|
||||||
|
"placeholderName": "Please enter role name",
|
||||||
|
"placeholderCode": "Please enter role code",
|
||||||
|
"placeholderRemark": "Please enter role description",
|
||||||
|
"placeholderSort": "Please enter sort",
|
||||||
|
"ruleNameRequired": "Please enter role name",
|
||||||
|
"ruleCodeRequired": "Please enter role code",
|
||||||
|
"ruleLevelRequired": "Please enter role level",
|
||||||
|
"addSuccess": "Added successfully",
|
||||||
|
"editSuccess": "Updated successfully"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -17,5 +17,35 @@
|
|||||||
"status": "Status",
|
"status": "Status",
|
||||||
"createTime": "Create Time",
|
"createTime": "Create Time",
|
||||||
"updateTime": "Update Time"
|
"updateTime": "Update Time"
|
||||||
|
},
|
||||||
|
"form": {
|
||||||
|
"titleAdd": "Add User",
|
||||||
|
"titleEdit": "Edit User",
|
||||||
|
"labelAvatar": "Avatar",
|
||||||
|
"labelUsername": "Username",
|
||||||
|
"labelRealname": "Real Name",
|
||||||
|
"labelPassword": "Password",
|
||||||
|
"labelPasswordConfirm": "Confirm Password",
|
||||||
|
"labelEmail": "Email",
|
||||||
|
"labelPhone": "Phone",
|
||||||
|
"labelDept": "Department",
|
||||||
|
"labelRole": "Role",
|
||||||
|
"labelPost": "Post",
|
||||||
|
"labelGender": "Gender",
|
||||||
|
"labelStatus": "Status",
|
||||||
|
"labelRemark": "Remark",
|
||||||
|
"placeholderEmail": "Please enter email",
|
||||||
|
"placeholderPhone": "Please enter phone",
|
||||||
|
"placeholderRemark": "Please enter remark",
|
||||||
|
"rulePasswordNotMatch": "Passwords do not match",
|
||||||
|
"ruleUsernameRequired": "Please enter username",
|
||||||
|
"ruleUsernameLength": "Length must be between 2 and 20 characters",
|
||||||
|
"rulePasswordRequired": "Please enter password",
|
||||||
|
"rulePasswordLength": "Length must be between 6 and 20 characters",
|
||||||
|
"rulePasswordConfirmRequired": "Please enter confirm password",
|
||||||
|
"ruleDeptRequired": "Please select department",
|
||||||
|
"ruleRoleRequired": "Please select role",
|
||||||
|
"addSuccess": "Added successfully",
|
||||||
|
"editSuccess": "Updated successfully"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -17,5 +17,46 @@
|
|||||||
"executeTime": "Execute Time",
|
"executeTime": "Execute Time",
|
||||||
"parameter": "Parameter",
|
"parameter": "Parameter",
|
||||||
"executeStatus": "Status"
|
"executeStatus": "Status"
|
||||||
|
},
|
||||||
|
"form": {
|
||||||
|
"titleAdd": "Add Scheduled Task",
|
||||||
|
"titleEdit": "Edit Scheduled Task",
|
||||||
|
"labelName": "Task Name",
|
||||||
|
"labelType": "Task Type",
|
||||||
|
"labelTaskStyle": "Schedule Rule",
|
||||||
|
"labelTarget": "Target",
|
||||||
|
"labelParams": "Parameters",
|
||||||
|
"labelStatus": "Status",
|
||||||
|
"labelRemark": "Remark",
|
||||||
|
"placeholderName": "Please enter task name",
|
||||||
|
"placeholderTarget": "Please enter target",
|
||||||
|
"placeholderParams": "Please enter parameters",
|
||||||
|
"placeholderRemark": "Please enter remark",
|
||||||
|
"taskStyleEveryDay": "Every day",
|
||||||
|
"taskStyleEveryHour": "Every hour",
|
||||||
|
"taskStyleNHours": "N hours",
|
||||||
|
"taskStyleNMinutes": "N minutes",
|
||||||
|
"taskStyleNSeconds": "N seconds",
|
||||||
|
"taskStyleEveryWeek": "Every week",
|
||||||
|
"taskStyleEveryMonth": "Every month",
|
||||||
|
"taskStyleEveryYear": "Every year",
|
||||||
|
"weekMon": "Mon",
|
||||||
|
"weekTue": "Tue",
|
||||||
|
"weekWed": "Wed",
|
||||||
|
"weekThu": "Thu",
|
||||||
|
"weekFri": "Fri",
|
||||||
|
"weekSat": "Sat",
|
||||||
|
"weekSun": "Sun",
|
||||||
|
"unitMonth": "Month",
|
||||||
|
"unitDay": "Day",
|
||||||
|
"unitHour": "Hour",
|
||||||
|
"unitMinute": "Minute",
|
||||||
|
"unitSecond": "Second",
|
||||||
|
"ruleNameRequired": "Task name is required",
|
||||||
|
"ruleTypeRequired": "Task type is required",
|
||||||
|
"ruleTaskStyleRequired": "Schedule rule is required",
|
||||||
|
"ruleTargetRequired": "Target is required",
|
||||||
|
"addSuccess": "Added successfully",
|
||||||
|
"editSuccess": "Updated successfully"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -47,6 +47,17 @@
|
|||||||
"labelName": "名称",
|
"labelName": "名称",
|
||||||
"close": "关闭"
|
"close": "关闭"
|
||||||
},
|
},
|
||||||
|
"dict": {
|
||||||
|
"data_status": {
|
||||||
|
"1": "正常",
|
||||||
|
"2": "停用"
|
||||||
|
},
|
||||||
|
"gender": {
|
||||||
|
"1": "男",
|
||||||
|
"2": "女",
|
||||||
|
"3": "未知"
|
||||||
|
}
|
||||||
|
},
|
||||||
"search": {
|
"search": {
|
||||||
"placeholder": "搜索页面",
|
"placeholder": "搜索页面",
|
||||||
"historyTitle": "搜索历史",
|
"historyTitle": "搜索历史",
|
||||||
|
|||||||
@@ -31,7 +31,10 @@
|
|||||||
"rollNumber": "摇取点数和",
|
"rollNumber": "摇取点数和",
|
||||||
"placeholderRollNumber": "5 个色子点数之和(5~30)",
|
"placeholderRollNumber": "5 个色子点数之和(5~30)",
|
||||||
"rewardConfig": "奖励配置",
|
"rewardConfig": "奖励配置",
|
||||||
"placeholderRewardConfig": "请选择奖励配置(显示前端文本)"
|
"placeholderRewardConfig": "请选择奖励配置(显示前端文本)",
|
||||||
|
"addSuccess": "新增成功",
|
||||||
|
"editSuccess": "修改成功",
|
||||||
|
"validateFailed": "表单验证失败,请检查必填项与格式"
|
||||||
},
|
},
|
||||||
"search": {
|
"search": {
|
||||||
"player": "玩家",
|
"player": "玩家",
|
||||||
|
|||||||
@@ -33,5 +33,34 @@
|
|||||||
"rollNumber": "摇取点数和",
|
"rollNumber": "摇取点数和",
|
||||||
"rewardConfig": "奖励配置",
|
"rewardConfig": "奖励配置",
|
||||||
"createTime": "创建时间"
|
"createTime": "创建时间"
|
||||||
|
},
|
||||||
|
"form": {
|
||||||
|
"titleAdd": "新增玩家抽奖记录(测试数据)",
|
||||||
|
"titleEdit": "编辑玩家抽奖记录(测试数据)",
|
||||||
|
"labelLotteryConfigId": "彩金池配置id",
|
||||||
|
"placeholderLotteryConfigId": "请输入彩金池配置id",
|
||||||
|
"placeholderWinCoin": "赢取平台币",
|
||||||
|
"placeholderRewardTier": "请选择档位(选后自动带出奖励配置ID)",
|
||||||
|
"rewardConfigId": "奖励配置id",
|
||||||
|
"placeholderRewardConfigId": "可选中奖档位自动带出或手动输入",
|
||||||
|
"placeholderStartIndex": "请输入起始索引",
|
||||||
|
"labelTargetIndex": "结束索引",
|
||||||
|
"placeholderTargetIndex": "请输入结束索引",
|
||||||
|
"placeholderRollNumber": "请输入摇取点数和",
|
||||||
|
"labelRollArray": "摇取点数:[1,2,3,4,5,6]",
|
||||||
|
"placeholderRollArray": "请输入摇取点数:[1,2,3,4,5,6]",
|
||||||
|
"labelStatus": "状态:0=失败,1=成功",
|
||||||
|
"placeholderSuperWinCoin": "请输入中大奖平台币",
|
||||||
|
"placeholderRewardWinCoin": "请输入摇色子中奖平台币",
|
||||||
|
"labelAdminId": "所属管理员",
|
||||||
|
"placeholderAdminId": "请输入所属管理员",
|
||||||
|
"ruleLotteryConfigIdRequired": "彩金池配置id必需填写",
|
||||||
|
"ruleDrawTypeRequired": "抽奖类型必需填写",
|
||||||
|
"ruleIsBigWinRequired": "是否中大奖必需填写",
|
||||||
|
"ruleDirectionRequired": "方向必需填写",
|
||||||
|
"ruleRewardConfigIdRequired": "奖励配置id必需填写",
|
||||||
|
"ruleStatusRequired": "状态必需填写",
|
||||||
|
"addSuccess": "新增成功",
|
||||||
|
"editSuccess": "修改成功"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -30,6 +30,7 @@
|
|||||||
"t5Weight": "T5池权重(%)",
|
"t5Weight": "T5池权重(%)",
|
||||||
"weightsSumHint": "五个池权重总和:",
|
"weightsSumHint": "五个池权重总和:",
|
||||||
"weightsSumUnit": "% / 100%(必须为100%)",
|
"weightsSumUnit": "% / 100%(必须为100%)",
|
||||||
|
"ruleWeightsSumMustBe100": "五个池权重总和必须为100%",
|
||||||
"walletTitle": "玩家钱包操作",
|
"walletTitle": "玩家钱包操作",
|
||||||
"walletPlayer": "玩家",
|
"walletPlayer": "玩家",
|
||||||
"walletBalance": "钱包余额",
|
"walletBalance": "钱包余额",
|
||||||
|
|||||||
@@ -12,7 +12,9 @@
|
|||||||
"placeholderFreeDrawCount": "请输入赠送抽奖次数",
|
"placeholderFreeDrawCount": "请输入赠送抽奖次数",
|
||||||
"totalDrawCount": "总抽奖次数",
|
"totalDrawCount": "总抽奖次数",
|
||||||
"placeholderTotalDrawCount": "自动求和",
|
"placeholderTotalDrawCount": "自动求和",
|
||||||
"placeholderRemark": "请输入备注(必填)"
|
"placeholderRemark": "请输入备注(必填)",
|
||||||
|
"addSuccess": "新增成功",
|
||||||
|
"editSuccess": "修改成功"
|
||||||
},
|
},
|
||||||
"search": {
|
"search": {
|
||||||
"player": "玩家",
|
"player": "玩家",
|
||||||
|
|||||||
@@ -17,7 +17,9 @@
|
|||||||
"placeholderWalletBefore": "选择用户后自动带出当前平台币",
|
"placeholderWalletBefore": "选择用户后自动带出当前平台币",
|
||||||
"walletAfter": "钱包操作后",
|
"walletAfter": "钱包操作后",
|
||||||
"placeholderWalletAfter": "根据平台币变化自动计算",
|
"placeholderWalletAfter": "根据平台币变化自动计算",
|
||||||
"placeholderRemark": "选填"
|
"placeholderRemark": "选填",
|
||||||
|
"addSuccess": "新增成功",
|
||||||
|
"editSuccess": "修改成功"
|
||||||
},
|
},
|
||||||
"search": {
|
"search": {
|
||||||
"type": "类型",
|
"type": "类型",
|
||||||
|
|||||||
@@ -19,5 +19,34 @@
|
|||||||
"realEv": "实际中奖金额",
|
"realEv": "实际中奖金额",
|
||||||
"remark": "备注",
|
"remark": "备注",
|
||||||
"weight": "权重(1-10000)"
|
"weight": "权重(1-10000)"
|
||||||
|
},
|
||||||
|
"form": {
|
||||||
|
"titleAdd": "新增奖励配置",
|
||||||
|
"titleEdit": "编辑奖励配置",
|
||||||
|
"labelDicePoints": "色子点数",
|
||||||
|
"placeholderDicePoints": "请输入色子点数",
|
||||||
|
"labelUiText": "前端显示文本",
|
||||||
|
"placeholderUiText": "请输入前端显示文本(中文)",
|
||||||
|
"labelUiTextEn": "前端显示文本(英文)",
|
||||||
|
"placeholderUiTextEn": "请输入前端显示文本(英文)",
|
||||||
|
"labelRealEv": "真实资金结算",
|
||||||
|
"placeholderRealEv": "请输入真实资金结算",
|
||||||
|
"labelTier": "所属档位",
|
||||||
|
"placeholderTier": "请选择所属档位",
|
||||||
|
"tierBigWin": "BIGWIN(超级大奖)",
|
||||||
|
"labelBigWinWeight": "大奖权重",
|
||||||
|
"placeholderBigWinWeight": "0~10000,10000=100%中奖",
|
||||||
|
"bigWinWeightDisabledTip": "点数 5、30 摇到必中大奖,权重固定 10000",
|
||||||
|
"bigWinWeightTip": "10000=100% 中奖,0=0% 中奖;仅对点数 10/15/20/25 生效",
|
||||||
|
"labelRemark": "备注",
|
||||||
|
"placeholderRemark": "请输入备注",
|
||||||
|
"ruleDicePointsRequired": "色子点数必需填写",
|
||||||
|
"ruleUiTextRequired": "前端显示文本必需填写",
|
||||||
|
"ruleUiTextEnMax": "前端显示文本(英文)长度需小于 255 字符",
|
||||||
|
"ruleRealEvRequired": "真实资金结算必需填写",
|
||||||
|
"ruleTierRequired": "所属档位必需填写",
|
||||||
|
"ruleBigWinWeightRange": "大奖权重 0~10000",
|
||||||
|
"addSuccess": "新增成功",
|
||||||
|
"editSuccess": "修改成功"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -14,5 +14,18 @@
|
|||||||
"statusFail": "失败",
|
"statusFail": "失败",
|
||||||
"statusDone": "完成",
|
"statusDone": "完成",
|
||||||
"statusTesting": "测试中"
|
"statusTesting": "测试中"
|
||||||
|
},
|
||||||
|
"form": {
|
||||||
|
"titleAdd": "新增奖励配置权重测试记录",
|
||||||
|
"titleEdit": "编辑奖励配置权重测试记录",
|
||||||
|
"labelTestCount": "测试次数:100/500/1000",
|
||||||
|
"placeholderTestCount": "请输入测试次数:100/500/1000",
|
||||||
|
"labelWeightSnapshot": "测试时权重配比快照:按档位保存 id,grid_number,tier,weight",
|
||||||
|
"placeholderWeightSnapshot": "请输入测试时权重配比快照:按档位保存 id,grid_number,tier,weight",
|
||||||
|
"labelResultCounts": "落点统计:grid_number=>出现次数",
|
||||||
|
"placeholderResultCounts": "请输入落点统计:grid_number=>出现次数",
|
||||||
|
"ruleTestCountRequired": "测试次数:100/500/1000必需填写",
|
||||||
|
"addSuccess": "新增成功",
|
||||||
|
"editSuccess": "修改成功"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -14,5 +14,13 @@
|
|||||||
"fileType": "文件类型",
|
"fileType": "文件类型",
|
||||||
"fileSize": "文件大小",
|
"fileSize": "文件大小",
|
||||||
"uploadTime": "上传时间"
|
"uploadTime": "上传时间"
|
||||||
|
},
|
||||||
|
"form": {
|
||||||
|
"titleAdd": "新增文件",
|
||||||
|
"titleEdit": "编辑文件",
|
||||||
|
"labelFileName": "文件名称",
|
||||||
|
"placeholderFileName": "请输入文件名称",
|
||||||
|
"ruleFileNameRequired": "请输入文件名称",
|
||||||
|
"editSuccess": "修改成功"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -17,5 +17,49 @@
|
|||||||
"sort": "排序",
|
"sort": "排序",
|
||||||
"status": "状态",
|
"status": "状态",
|
||||||
"createTime": "创建时间"
|
"createTime": "创建时间"
|
||||||
|
},
|
||||||
|
"form": {
|
||||||
|
"titleAdd": "新增菜单",
|
||||||
|
"titleEdit": "编辑菜单",
|
||||||
|
"labelMenuType": "菜单类型",
|
||||||
|
"labelParentMenu": "上级菜单",
|
||||||
|
"labelMenuName": "菜单名称",
|
||||||
|
"labelRoutePath": "路由地址",
|
||||||
|
"labelRoutePathTip": "一级菜单:以 / 开头的绝对路径(如 /dashboard) 二级及以下:相对路径(如 console、user)",
|
||||||
|
"placeholderRoutePath": "如:/dashboard 或 console",
|
||||||
|
"labelComponentName": "组件名称",
|
||||||
|
"placeholderComponentName": "如: User",
|
||||||
|
"labelComponentPath": "组件路径",
|
||||||
|
"labelComponentPathTip": "填写组件路径(views目录下) 目录菜单:留空",
|
||||||
|
"placeholderComponentPath": "如:/system/user 或留空",
|
||||||
|
"labelMenuIcon": "菜单图标",
|
||||||
|
"labelPermSlug": "权限标识",
|
||||||
|
"placeholderPermSlug": "请输入权限标识",
|
||||||
|
"labelLinkUrl": "外链地址",
|
||||||
|
"placeholderLinkUrl": "如:https://saithink.top",
|
||||||
|
"labelSort": "排序",
|
||||||
|
"labelSortTip": "数字越大越靠前",
|
||||||
|
"placeholderSort": "请输入排序",
|
||||||
|
"labelStatus": "状态",
|
||||||
|
"labelStatusTip": "禁用后,该菜单项将不可用",
|
||||||
|
"labelIsIframe": "是否内嵌",
|
||||||
|
"labelIsIframeTip": "外链模式下有效",
|
||||||
|
"labelIsKeepAlive": "是否缓存",
|
||||||
|
"labelIsKeepAliveTip": "切换tabs不刷新",
|
||||||
|
"labelIsHidden": "是否隐藏",
|
||||||
|
"labelIsHiddenTip": "不在菜单栏显示,但是可以通过路由访问",
|
||||||
|
"labelIsFixedTab": "是否固定",
|
||||||
|
"labelIsFixedTabTip": "固定在tabs导航栏",
|
||||||
|
"labelIsFullPage": "是否全屏",
|
||||||
|
"labelIsFullPageTip": "不继承左侧菜单和顶部导航栏",
|
||||||
|
"noParentMenu": "无上级菜单",
|
||||||
|
"ruleParentMenuRequired": "请选择上级菜单",
|
||||||
|
"ruleMenuNameRequired": "请输入菜单名称",
|
||||||
|
"ruleRoutePathRequired": "请输入路由地址",
|
||||||
|
"ruleComponentNameRequired": "请输入组件名称",
|
||||||
|
"rulePermSlugRequired": "请输入权限标识",
|
||||||
|
"ruleLinkUrlRequired": "请输入外链地址",
|
||||||
|
"addSuccess": "新增成功",
|
||||||
|
"editSuccess": "修改成功"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -13,5 +13,22 @@
|
|||||||
"sort": "排序",
|
"sort": "排序",
|
||||||
"status": "状态",
|
"status": "状态",
|
||||||
"createTime": "创建时间"
|
"createTime": "创建时间"
|
||||||
|
},
|
||||||
|
"form": {
|
||||||
|
"titleAdd": "新增岗位",
|
||||||
|
"titleEdit": "编辑岗位",
|
||||||
|
"labelName": "岗位名称",
|
||||||
|
"labelCode": "岗位编码",
|
||||||
|
"labelRemark": "描述",
|
||||||
|
"labelSort": "排序",
|
||||||
|
"labelStatus": "启用",
|
||||||
|
"placeholderName": "请输入岗位名称",
|
||||||
|
"placeholderCode": "请输入岗位编码",
|
||||||
|
"placeholderRemark": "请输入岗位描述",
|
||||||
|
"placeholderSort": "请输入排序",
|
||||||
|
"ruleNameRequired": "请输入岗位名称",
|
||||||
|
"ruleCodeRequired": "请输入岗位编码",
|
||||||
|
"addSuccess": "新增成功",
|
||||||
|
"editSuccess": "修改成功"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -14,5 +14,25 @@
|
|||||||
"roleRemark": "角色描述",
|
"roleRemark": "角色描述",
|
||||||
"status": "状态",
|
"status": "状态",
|
||||||
"createTime": "创建时间"
|
"createTime": "创建时间"
|
||||||
|
},
|
||||||
|
"form": {
|
||||||
|
"titleAdd": "新增角色",
|
||||||
|
"titleEdit": "编辑角色",
|
||||||
|
"labelName": "角色名称",
|
||||||
|
"labelCode": "角色标识",
|
||||||
|
"labelLevel": "角色级别",
|
||||||
|
"levelTip": "控制角色的权限层级, 不能操作职级高于自己的角色",
|
||||||
|
"labelRemark": "描述",
|
||||||
|
"labelSort": "排序",
|
||||||
|
"labelStatus": "启用",
|
||||||
|
"placeholderName": "请输入角色名称",
|
||||||
|
"placeholderCode": "请输入角色编码",
|
||||||
|
"placeholderRemark": "请输入角色描述",
|
||||||
|
"placeholderSort": "请输入排序",
|
||||||
|
"ruleNameRequired": "请输入角色名称",
|
||||||
|
"ruleCodeRequired": "请输入角色编码",
|
||||||
|
"ruleLevelRequired": "请输入角色级别",
|
||||||
|
"addSuccess": "新增成功",
|
||||||
|
"editSuccess": "修改成功"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -17,5 +17,35 @@
|
|||||||
"status": "状态",
|
"status": "状态",
|
||||||
"createTime": "创建时间",
|
"createTime": "创建时间",
|
||||||
"updateTime": "更新时间"
|
"updateTime": "更新时间"
|
||||||
|
},
|
||||||
|
"form": {
|
||||||
|
"titleAdd": "新增用户",
|
||||||
|
"titleEdit": "编辑用户",
|
||||||
|
"labelAvatar": "头像",
|
||||||
|
"labelUsername": "用户名",
|
||||||
|
"labelRealname": "真实姓名",
|
||||||
|
"labelPassword": "密码",
|
||||||
|
"labelPasswordConfirm": "确认密码",
|
||||||
|
"labelEmail": "邮箱",
|
||||||
|
"labelPhone": "手机号",
|
||||||
|
"labelDept": "部门",
|
||||||
|
"labelRole": "角色",
|
||||||
|
"labelPost": "岗位",
|
||||||
|
"labelGender": "性别",
|
||||||
|
"labelStatus": "状态",
|
||||||
|
"labelRemark": "备注",
|
||||||
|
"placeholderEmail": "请输入邮箱",
|
||||||
|
"placeholderPhone": "请输入手机号",
|
||||||
|
"placeholderRemark": "请输入备注",
|
||||||
|
"rulePasswordNotMatch": "两次输入的密码不一致",
|
||||||
|
"ruleUsernameRequired": "请输入用户名",
|
||||||
|
"ruleUsernameLength": "长度在 2 到 20 个字符",
|
||||||
|
"rulePasswordRequired": "请输入密码",
|
||||||
|
"rulePasswordLength": "长度在 6 到 20 个字符",
|
||||||
|
"rulePasswordConfirmRequired": "请输入确认密码",
|
||||||
|
"ruleDeptRequired": "请选择部门",
|
||||||
|
"ruleRoleRequired": "请选择角色",
|
||||||
|
"addSuccess": "新增成功",
|
||||||
|
"editSuccess": "修改成功"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -17,5 +17,46 @@
|
|||||||
"executeTime": "执行时间",
|
"executeTime": "执行时间",
|
||||||
"parameter": "任务参数",
|
"parameter": "任务参数",
|
||||||
"executeStatus": "执行状态"
|
"executeStatus": "执行状态"
|
||||||
|
},
|
||||||
|
"form": {
|
||||||
|
"titleAdd": "新增定时任务",
|
||||||
|
"titleEdit": "编辑定时任务",
|
||||||
|
"labelName": "任务名称",
|
||||||
|
"labelType": "任务类型",
|
||||||
|
"labelTaskStyle": "定时规则",
|
||||||
|
"labelTarget": "调用目标",
|
||||||
|
"labelParams": "任务参数",
|
||||||
|
"labelStatus": "状态",
|
||||||
|
"labelRemark": "备注",
|
||||||
|
"placeholderName": "请输入任务名称",
|
||||||
|
"placeholderTarget": "请输入调用目标",
|
||||||
|
"placeholderParams": "请输入任务参数",
|
||||||
|
"placeholderRemark": "请输入备注",
|
||||||
|
"taskStyleEveryDay": "每天",
|
||||||
|
"taskStyleEveryHour": "每小时",
|
||||||
|
"taskStyleNHours": "N小时",
|
||||||
|
"taskStyleNMinutes": "N分钟",
|
||||||
|
"taskStyleNSeconds": "N秒",
|
||||||
|
"taskStyleEveryWeek": "每周",
|
||||||
|
"taskStyleEveryMonth": "每月",
|
||||||
|
"taskStyleEveryYear": "每年",
|
||||||
|
"weekMon": "周一",
|
||||||
|
"weekTue": "周二",
|
||||||
|
"weekWed": "周三",
|
||||||
|
"weekThu": "周四",
|
||||||
|
"weekFri": "周五",
|
||||||
|
"weekSat": "周六",
|
||||||
|
"weekSun": "周日",
|
||||||
|
"unitMonth": "月",
|
||||||
|
"unitDay": "日",
|
||||||
|
"unitHour": "时",
|
||||||
|
"unitMinute": "分",
|
||||||
|
"unitSecond": "秒",
|
||||||
|
"ruleNameRequired": "任务名称不能为空",
|
||||||
|
"ruleTypeRequired": "任务类型不能为空",
|
||||||
|
"ruleTaskStyleRequired": "定时规则不能为空",
|
||||||
|
"ruleTargetRequired": "调用目标不能为空",
|
||||||
|
"addSuccess": "新增成功",
|
||||||
|
"editSuccess": "修改成功"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -399,15 +399,15 @@
|
|||||||
if (props.dialogType === 'add') {
|
if (props.dialogType === 'add') {
|
||||||
delete payload.id
|
delete payload.id
|
||||||
await api.save(payload)
|
await api.save(payload)
|
||||||
ElMessage.success('新增成功')
|
ElMessage.success($t('page.form.addSuccess'))
|
||||||
} else {
|
} else {
|
||||||
await api.update(payload)
|
await api.update(payload)
|
||||||
ElMessage.success('修改成功')
|
ElMessage.success($t('page.form.editSuccess'))
|
||||||
}
|
}
|
||||||
emit('success')
|
emit('success')
|
||||||
handleClose()
|
handleClose()
|
||||||
} catch (error: any) {
|
} catch (error: any) {
|
||||||
let msg = '表单验证失败,请检查必填项与格式'
|
let msg = $t('page.form.validateFailed')
|
||||||
if (error?.message) {
|
if (error?.message) {
|
||||||
msg = error.message
|
msg = error.message
|
||||||
} else if (typeof error === 'string') {
|
} else if (typeof error === 'string') {
|
||||||
|
|||||||
@@ -1,52 +1,52 @@
|
|||||||
<template>
|
<template>
|
||||||
<el-dialog
|
<el-dialog
|
||||||
v-model="visible"
|
v-model="visible"
|
||||||
:title="dialogType === 'add' ? '新增玩家抽奖记录(测试数据)' : '编辑玩家抽奖记录(测试数据)'"
|
:title="dialogType === 'add' ? $t('page.form.titleAdd') : $t('page.form.titleEdit')"
|
||||||
width="600px"
|
width="600px"
|
||||||
align-center
|
align-center
|
||||||
:close-on-click-modal="false"
|
:close-on-click-modal="false"
|
||||||
@close="handleClose"
|
@close="handleClose"
|
||||||
>
|
>
|
||||||
<el-form ref="formRef" :model="formData" :rules="rules" label-width="120px">
|
<el-form ref="formRef" :model="formData" :rules="rules" label-width="120px">
|
||||||
<el-form-item label="彩金池配置id" prop="lottery_config_id">
|
<el-form-item :label="$t('page.form.labelLotteryConfigId')" prop="lottery_config_id">
|
||||||
<el-input v-model="formData.lottery_config_id" placeholder="请输入彩金池配置id" />
|
<el-input v-model="formData.lottery_config_id" :placeholder="$t('page.form.placeholderLotteryConfigId')" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="抽奖类型" prop="lottery_type">
|
<el-form-item :label="$t('page.form.drawType')" prop="lottery_type">
|
||||||
<el-select
|
<el-select
|
||||||
v-model="formData.lottery_type"
|
v-model="formData.lottery_type"
|
||||||
placeholder="请选择"
|
:placeholder="$t('form.placeholderSelect')"
|
||||||
clearable
|
clearable
|
||||||
style="width: 100%"
|
style="width: 100%"
|
||||||
>
|
>
|
||||||
<el-option label="付费" :value="0" />
|
<el-option :label="$t('page.search.paid')" :value="0" />
|
||||||
<el-option label="赠送" :value="1" />
|
<el-option :label="$t('page.search.free')" :value="1" />
|
||||||
</el-select>
|
</el-select>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="方向" prop="direction">
|
<el-form-item :label="$t('page.search.direction')" prop="direction">
|
||||||
<el-select v-model="formData.direction" placeholder="请选择" clearable style="width: 100%">
|
<el-select v-model="formData.direction" :placeholder="$t('form.placeholderSelect')" clearable style="width: 100%">
|
||||||
<el-option label="顺时针" :value="0" />
|
<el-option :label="$t('page.search.clockwise')" :value="0" />
|
||||||
<el-option label="逆时针" :value="1" />
|
<el-option :label="$t('page.search.anticlockwise')" :value="1" />
|
||||||
</el-select>
|
</el-select>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="是否中大奖" prop="is_win">
|
<el-form-item :label="$t('page.search.isBigWin')" prop="is_win">
|
||||||
<el-select v-model="formData.is_win" placeholder="请选择" clearable style="width: 100%">
|
<el-select v-model="formData.is_win" :placeholder="$t('form.placeholderSelect')" clearable style="width: 100%">
|
||||||
<el-option label="无" :value="0" />
|
<el-option :label="$t('page.search.noBigWin')" :value="0" />
|
||||||
<el-option label="中大奖" :value="1" />
|
<el-option :label="$t('page.search.bigWin')" :value="1" />
|
||||||
</el-select>
|
</el-select>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="赢取平台币" prop="win_coin">
|
<el-form-item :label="$t('page.search.winCoin')" prop="win_coin">
|
||||||
<el-input-number
|
<el-input-number
|
||||||
v-model="formData.win_coin"
|
v-model="formData.win_coin"
|
||||||
placeholder="赢取平台币"
|
:placeholder="$t('page.form.placeholderWinCoin')"
|
||||||
:precision="2"
|
:precision="2"
|
||||||
controls-position="right"
|
controls-position="right"
|
||||||
style="width: 100%"
|
style="width: 100%"
|
||||||
/>
|
/>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="中奖档位" prop="reward_tier">
|
<el-form-item :label="$t('page.search.rewardTier')" prop="reward_tier">
|
||||||
<el-select
|
<el-select
|
||||||
v-model="formData.reward_tier"
|
v-model="formData.reward_tier"
|
||||||
placeholder="请选择档位(选后自动带出奖励配置ID)"
|
:placeholder="$t('page.form.placeholderRewardTier')"
|
||||||
clearable
|
clearable
|
||||||
style="width: 100%"
|
style="width: 100%"
|
||||||
@change="onRewardTierChange"
|
@change="onRewardTierChange"
|
||||||
@@ -58,40 +58,40 @@
|
|||||||
<el-option label="T5" value="T5" />
|
<el-option label="T5" value="T5" />
|
||||||
</el-select>
|
</el-select>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="奖励配置id" prop="reward_config_id">
|
<el-form-item :label="$t('page.form.rewardConfigId')" prop="reward_config_id">
|
||||||
<el-input
|
<el-input
|
||||||
v-model="formData.reward_config_id"
|
v-model="formData.reward_config_id"
|
||||||
placeholder="可选中奖档位自动带出或手动输入"
|
:placeholder="$t('page.form.placeholderRewardConfigId')"
|
||||||
/>
|
/>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="起始索引" prop="start_index">
|
<el-form-item :label="$t('page.table.startIndex')" prop="start_index">
|
||||||
<el-input v-model="formData.start_index" placeholder="请输入起始索引" />
|
<el-input v-model="formData.start_index" :placeholder="$t('page.form.placeholderStartIndex')" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="结束索引" prop="target_index">
|
<el-form-item :label="$t('page.form.labelTargetIndex')" prop="target_index">
|
||||||
<el-input v-model="formData.target_index" placeholder="请输入结束索引" />
|
<el-input v-model="formData.target_index" :placeholder="$t('page.form.placeholderTargetIndex')" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="摇取点数和" prop="roll_number">
|
<el-form-item :label="$t('page.search.rollNumber')" prop="roll_number">
|
||||||
<el-input v-model="formData.roll_number" placeholder="请输入摇取点数和" />
|
<el-input v-model="formData.roll_number" :placeholder="$t('page.form.placeholderRollNumber')" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="摇取点数:[1,2,3,4,5,6]" prop="roll_array">
|
<el-form-item :label="$t('page.form.labelRollArray')" prop="roll_array">
|
||||||
<el-input v-model="formData.roll_array" placeholder="请输入摇取点数:[1,2,3,4,5,6]" />
|
<el-input v-model="formData.roll_array" :placeholder="$t('page.form.placeholderRollArray')" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="状态:0=失败,1=成功" prop="status">
|
<el-form-item :label="$t('page.form.labelStatus')" prop="status">
|
||||||
<sa-radio v-model="formData.status" dict="data_status" />
|
<sa-radio v-model="formData.status" dict="data_status" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="中大奖平台币" prop="super_win_coin">
|
<el-form-item :label="$t('page.table.superWinCoin')" prop="super_win_coin">
|
||||||
<el-input v-model="formData.super_win_coin" placeholder="请输入中大奖平台币" />
|
<el-input v-model="formData.super_win_coin" :placeholder="$t('page.form.placeholderSuperWinCoin')" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="摇色子中奖平台币" prop="reward_win_coin">
|
<el-form-item :label="$t('page.table.rewardWinCoin')" prop="reward_win_coin">
|
||||||
<el-input v-model="formData.reward_win_coin" placeholder="请输入摇色子中奖平台币" />
|
<el-input v-model="formData.reward_win_coin" :placeholder="$t('page.form.placeholderRewardWinCoin')" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="所属管理员" prop="admin_id">
|
<el-form-item :label="$t('page.form.labelAdminId')" prop="admin_id">
|
||||||
<el-input v-model="formData.admin_id" placeholder="请输入所属管理员" />
|
<el-input v-model="formData.admin_id" :placeholder="$t('page.form.placeholderAdminId')" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-form>
|
</el-form>
|
||||||
<template #footer>
|
<template #footer>
|
||||||
<el-button @click="handleClose">取消</el-button>
|
<el-button @click="handleClose">{{ $t('common.cancel') }}</el-button>
|
||||||
<el-button type="primary" @click="handleSubmit">提交</el-button>
|
<el-button type="primary" @click="handleSubmit">{{ $t('table.form.submit') }}</el-button>
|
||||||
</template>
|
</template>
|
||||||
</el-dialog>
|
</el-dialog>
|
||||||
</template>
|
</template>
|
||||||
@@ -101,6 +101,7 @@
|
|||||||
import rewardConfigApi from '../../../api/reward_config/index'
|
import rewardConfigApi from '../../../api/reward_config/index'
|
||||||
import { ElMessage } from 'element-plus'
|
import { ElMessage } from 'element-plus'
|
||||||
import type { FormInstance, FormRules } from 'element-plus'
|
import type { FormInstance, FormRules } from 'element-plus'
|
||||||
|
import { useI18n } from 'vue-i18n'
|
||||||
|
|
||||||
interface Props {
|
interface Props {
|
||||||
modelValue: boolean
|
modelValue: boolean
|
||||||
@@ -120,6 +121,7 @@
|
|||||||
})
|
})
|
||||||
|
|
||||||
const emit = defineEmits<Emits>()
|
const emit = defineEmits<Emits>()
|
||||||
|
const { t } = useI18n()
|
||||||
|
|
||||||
const formRef = ref<FormInstance>()
|
const formRef = ref<FormInstance>()
|
||||||
|
|
||||||
@@ -134,14 +136,14 @@
|
|||||||
/**
|
/**
|
||||||
* 表单验证规则
|
* 表单验证规则
|
||||||
*/
|
*/
|
||||||
const rules = reactive<FormRules>({
|
const rules = computed<FormRules>(() => ({
|
||||||
lottery_config_id: [{ required: true, message: '彩金池配置id必需填写', trigger: 'blur' }],
|
lottery_config_id: [{ required: true, message: t('page.form.ruleLotteryConfigIdRequired'), trigger: 'blur' }],
|
||||||
lottery_type: [{ required: true, message: '抽奖类型:0=付费,1=赠送必需填写', trigger: 'blur' }],
|
lottery_type: [{ required: true, message: t('page.form.ruleDrawTypeRequired'), trigger: 'blur' }],
|
||||||
is_win: [{ required: true, message: '中大奖:0=无,1=中奖必需填写', trigger: 'blur' }],
|
is_win: [{ required: true, message: t('page.form.ruleIsBigWinRequired'), trigger: 'blur' }],
|
||||||
direction: [{ required: true, message: '方向:0=顺时针,1=逆时针必需填写', trigger: 'blur' }],
|
direction: [{ required: true, message: t('page.form.ruleDirectionRequired'), trigger: 'blur' }],
|
||||||
reward_config_id: [{ required: true, message: '奖励配置id必需填写', trigger: 'blur' }],
|
reward_config_id: [{ required: true, message: t('page.form.ruleRewardConfigIdRequired'), trigger: 'blur' }],
|
||||||
status: [{ required: true, message: '状态:0=失败,1=成功必需填写', trigger: 'blur' }]
|
status: [{ required: true, message: t('page.form.ruleStatusRequired'), trigger: 'blur' }]
|
||||||
})
|
}))
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 初始数据
|
* 初始数据
|
||||||
@@ -256,10 +258,10 @@
|
|||||||
delete (payload as Record<string, unknown>).reward_tier
|
delete (payload as Record<string, unknown>).reward_tier
|
||||||
if (props.dialogType === 'add') {
|
if (props.dialogType === 'add') {
|
||||||
await api.save(payload)
|
await api.save(payload)
|
||||||
ElMessage.success('新增成功')
|
ElMessage.success(t('page.form.addSuccess'))
|
||||||
} else {
|
} else {
|
||||||
await api.update(payload)
|
await api.update(payload)
|
||||||
ElMessage.success('修改成功')
|
ElMessage.success(t('page.form.editSuccess'))
|
||||||
}
|
}
|
||||||
emit('success')
|
emit('success')
|
||||||
handleClose()
|
handleClose()
|
||||||
|
|||||||
@@ -416,7 +416,7 @@
|
|||||||
await formRef.value.validate()
|
await formRef.value.validate()
|
||||||
const useCustomWeights = isLotteryConfigEmpty()
|
const useCustomWeights = isLotteryConfigEmpty()
|
||||||
if (useCustomWeights && Math.abs(weightsSum.value - 100) > 0.01) {
|
if (useCustomWeights && Math.abs(weightsSum.value - 100) > 0.01) {
|
||||||
ElMessage.warning('五个池权重总和必须为100%')
|
ElMessage.warning($t('page.form.ruleWeightsSumMustBe100'))
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
const payload = { ...formData }
|
const payload = { ...formData }
|
||||||
@@ -428,10 +428,10 @@
|
|||||||
}
|
}
|
||||||
if (props.dialogType === 'add') {
|
if (props.dialogType === 'add') {
|
||||||
await api.save(payload)
|
await api.save(payload)
|
||||||
ElMessage.success('新增成功')
|
ElMessage.success($t('page.form.addSuccess'))
|
||||||
} else {
|
} else {
|
||||||
await api.update(payload)
|
await api.update(payload)
|
||||||
ElMessage.success('修改成功')
|
ElMessage.success($t('page.form.editSuccess'))
|
||||||
}
|
}
|
||||||
emit('success')
|
emit('success')
|
||||||
handleClose()
|
handleClose()
|
||||||
|
|||||||
@@ -230,10 +230,10 @@
|
|||||||
const rest = { ...formData } as Record<string, unknown>
|
const rest = { ...formData } as Record<string, unknown>
|
||||||
delete rest.id
|
delete rest.id
|
||||||
await api.save(rest)
|
await api.save(rest)
|
||||||
ElMessage.success('新增成功')
|
ElMessage.success($t('page.form.addSuccess'))
|
||||||
} else {
|
} else {
|
||||||
await api.update(formData)
|
await api.update(formData)
|
||||||
ElMessage.success('修改成功')
|
ElMessage.success($t('page.form.editSuccess'))
|
||||||
}
|
}
|
||||||
emit('success')
|
emit('success')
|
||||||
handleClose()
|
handleClose()
|
||||||
|
|||||||
@@ -225,10 +225,10 @@
|
|||||||
const payload = { ...formData }
|
const payload = { ...formData }
|
||||||
if (props.dialogType === 'add') {
|
if (props.dialogType === 'add') {
|
||||||
await api.save(payload)
|
await api.save(payload)
|
||||||
ElMessage.success('新增成功')
|
ElMessage.success($t('page.form.addSuccess'))
|
||||||
} else {
|
} else {
|
||||||
await api.update(payload)
|
await api.update(payload)
|
||||||
ElMessage.success('修改成功')
|
ElMessage.success($t('page.form.editSuccess'))
|
||||||
}
|
}
|
||||||
emit('success')
|
emit('success')
|
||||||
handleClose()
|
handleClose()
|
||||||
|
|||||||
@@ -1,33 +1,33 @@
|
|||||||
<template>
|
<template>
|
||||||
<el-dialog
|
<el-dialog
|
||||||
v-model="visible"
|
v-model="visible"
|
||||||
:title="dialogType === 'add' ? '新增奖励配置' : '编辑奖励配置'"
|
:title="dialogType === 'add' ? $t('page.form.titleAdd') : $t('page.form.titleEdit')"
|
||||||
width="600px"
|
width="600px"
|
||||||
align-center
|
align-center
|
||||||
:close-on-click-modal="false"
|
:close-on-click-modal="false"
|
||||||
@close="handleClose"
|
@close="handleClose"
|
||||||
>
|
>
|
||||||
<el-form ref="formRef" :model="formData" :rules="rules" label-width="120px">
|
<el-form ref="formRef" :model="formData" :rules="rules" label-width="120px">
|
||||||
<el-form-item label="色子点数" prop="grid_number">
|
<el-form-item :label="$t('page.form.labelDicePoints')" prop="grid_number">
|
||||||
<el-input-number
|
<el-input-number
|
||||||
v-model="formData.grid_number"
|
v-model="formData.grid_number"
|
||||||
placeholder="请输入色子点数"
|
:placeholder="$t('page.form.placeholderDicePoints')"
|
||||||
:disabled="dialogType === 'edit'"
|
:disabled="dialogType === 'edit'"
|
||||||
/>
|
/>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="前端显示文本" prop="ui_text">
|
<el-form-item :label="$t('page.form.labelUiText')" prop="ui_text">
|
||||||
<el-input v-model="formData.ui_text" placeholder="请输入前端显示文本(中文)" />
|
<el-input v-model="formData.ui_text" :placeholder="$t('page.form.placeholderUiText')"/>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="前端显示文本(英文)" prop="ui_text_en">
|
<el-form-item :label="$t('page.form.labelUiTextEn')" prop="ui_text_en">
|
||||||
<el-input v-model="formData.ui_text_en" placeholder="请输入前端显示文本(英文)" />
|
<el-input v-model="formData.ui_text_en" :placeholder="$t('page.form.placeholderUiTextEn')" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="真实资金结算" prop="real_ev">
|
<el-form-item :label="$t('page.form.labelRealEv')" prop="real_ev">
|
||||||
<el-input-number v-model="formData.real_ev" placeholder="请输入真实资金结算" />
|
<el-input-number v-model="formData.real_ev" :placeholder="$t('page.form.placeholderRealEv')" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="所属档位" prop="tier">
|
<el-form-item :label="$t('page.form.labelTier')" prop="tier">
|
||||||
<el-select
|
<el-select
|
||||||
v-model="formData.tier"
|
v-model="formData.tier"
|
||||||
placeholder="请选择所属档位"
|
:placeholder="$t('page.form.placeholderTier')"
|
||||||
clearable
|
clearable
|
||||||
style="width: 100%"
|
style="width: 100%"
|
||||||
:disabled="dialogType === 'edit'"
|
:disabled="dialogType === 'edit'"
|
||||||
@@ -37,39 +37,39 @@
|
|||||||
<el-option label="T3" value="T3" />
|
<el-option label="T3" value="T3" />
|
||||||
<el-option label="T4" value="T4" />
|
<el-option label="T4" value="T4" />
|
||||||
<el-option label="T5" value="T5" />
|
<el-option label="T5" value="T5" />
|
||||||
<el-option label="BIGWIN(超级大奖)" value="BIGWIN" />
|
<el-option :label="$t('page.form.tierBigWin')" value="BIGWIN" />
|
||||||
</el-select>
|
</el-select>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<!-- BIGWIN 时可编辑权重:10000=100% 中奖,0=0% 中奖;点数 5、30 固定 100% 不可改 -->
|
<!-- BIGWIN 时可编辑权重:10000=100% 中奖,0=0% 中奖;点数 5、30 固定 100% 不可改 -->
|
||||||
<el-form-item v-if="formData.tier === 'BIGWIN'" label="大奖权重" prop="weight">
|
<el-form-item v-if="formData.tier === 'BIGWIN'" :label="$t('page.form.labelBigWinWeight')" prop="weight">
|
||||||
<el-input-number
|
<el-input-number
|
||||||
v-model="formData.weight"
|
v-model="formData.weight"
|
||||||
:min="0"
|
:min="0"
|
||||||
:max="10000"
|
:max="10000"
|
||||||
:step="100"
|
:step="100"
|
||||||
placeholder="0~10000,10000=100%中奖"
|
:placeholder="$t('page.form.placeholderBigWinWeight')"
|
||||||
:disabled="isBigwinWeightDisabled"
|
:disabled="isBigwinWeightDisabled"
|
||||||
/>
|
/>
|
||||||
<div v-if="isBigwinWeightDisabled" class="form-tip">
|
<div v-if="isBigwinWeightDisabled" class="form-tip">
|
||||||
点数 5、30 摇到必中大奖,权重固定 10000
|
{{ $t('page.form.bigWinWeightDisabledTip') }}
|
||||||
</div>
|
</div>
|
||||||
<div v-else class="form-tip">10000=100% 中奖,0=0% 中奖;仅对点数 10/15/20/25 生效</div>
|
<div v-else class="form-tip">{{ $t('page.form.bigWinWeightTip') }}</div>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<!-- 权重已迁移至「T1-T5 与 BIGWIN 权重配比」弹窗(dice_reward 表);BIGWIN 时本弹窗可编辑 weight;起始索引已迁移至 dice_reward.start_index -->
|
<!-- 权重已迁移至「T1-T5 与 BIGWIN 权重配比」弹窗(dice_reward 表);BIGWIN 时本弹窗可编辑 weight;起始索引已迁移至 dice_reward.start_index -->
|
||||||
<el-form-item label="备注" prop="remark">
|
<el-form-item :label="$t('page.form.labelRemark')" prop="remark">
|
||||||
<el-input
|
<el-input
|
||||||
v-model="formData.remark"
|
v-model="formData.remark"
|
||||||
type="textarea"
|
type="textarea"
|
||||||
:rows="3"
|
:rows="3"
|
||||||
placeholder="请输入备注"
|
:placeholder="$t('page.form.placeholderRemark')"
|
||||||
maxlength="500"
|
maxlength="500"
|
||||||
show-word-limit
|
show-word-limit
|
||||||
/>
|
/>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-form>
|
</el-form>
|
||||||
<template #footer>
|
<template #footer>
|
||||||
<el-button @click="handleClose">取消</el-button>
|
<el-button @click="handleClose">{{ $t('common.cancel') }}</el-button>
|
||||||
<el-button type="primary" @click="handleSubmit">提交</el-button>
|
<el-button type="primary" @click="handleSubmit">{{ $t('table.form.submit') }}</el-button>
|
||||||
</template>
|
</template>
|
||||||
</el-dialog>
|
</el-dialog>
|
||||||
</template>
|
</template>
|
||||||
@@ -78,6 +78,7 @@
|
|||||||
import api from '../../../api/reward_config/index'
|
import api from '../../../api/reward_config/index'
|
||||||
import { ElMessage } from 'element-plus'
|
import { ElMessage } from 'element-plus'
|
||||||
import type { FormInstance, FormRules } from 'element-plus'
|
import type { FormInstance, FormRules } from 'element-plus'
|
||||||
|
import { useI18n } from 'vue-i18n'
|
||||||
|
|
||||||
interface Props {
|
interface Props {
|
||||||
modelValue: boolean
|
modelValue: boolean
|
||||||
@@ -97,6 +98,7 @@
|
|||||||
})
|
})
|
||||||
|
|
||||||
const emit = defineEmits<Emits>()
|
const emit = defineEmits<Emits>()
|
||||||
|
const { t } = useI18n()
|
||||||
|
|
||||||
const formRef = ref<FormInstance>()
|
const formRef = ref<FormInstance>()
|
||||||
|
|
||||||
@@ -112,12 +114,14 @@
|
|||||||
* 表单验证规则(权重已迁移至权重配比弹窗)
|
* 表单验证规则(权重已迁移至权重配比弹窗)
|
||||||
*/
|
*/
|
||||||
const rules = reactive<FormRules>({
|
const rules = reactive<FormRules>({
|
||||||
grid_number: [{ required: true, message: '色子点数必需填写', trigger: 'blur' }],
|
grid_number: [{ required: true, message: t('page.form.ruleDicePointsRequired'), trigger: 'blur' }],
|
||||||
ui_text: [{ required: true, message: '前端显示文本必需填写', trigger: 'blur' }],
|
ui_text: [{ required: true, message: t('page.form.ruleUiTextRequired'), trigger: 'blur' }],
|
||||||
ui_text_en: [{ max: 255, message: '前端显示文本(英文)长度需小于 255 字符', trigger: 'blur' }],
|
ui_text_en: [{ max: 255, message: t('page.form.ruleUiTextEnMax'), trigger: 'blur' }],
|
||||||
real_ev: [{ required: true, message: '真实资金结算必需填写', trigger: 'blur' }],
|
real_ev: [{ required: true, message: t('page.form.ruleRealEvRequired'), trigger: 'blur' }],
|
||||||
tier: [{ required: true, message: '所属档位必需填写', trigger: 'blur' }],
|
tier: [{ required: true, message: t('page.form.ruleTierRequired'), trigger: 'blur' }],
|
||||||
weight: [{ type: 'number', min: 0, max: 10000, message: '大奖权重 0~10000', trigger: 'blur' }]
|
weight: [
|
||||||
|
{ type: 'number', min: 0, max: 10000, message: t('page.form.ruleBigWinWeightRange'), trigger: 'blur' }
|
||||||
|
]
|
||||||
})
|
})
|
||||||
|
|
||||||
/** 点数 5、30 固定 100% 中大奖,权重不可改 */
|
/** 点数 5、30 固定 100% 中大奖,权重不可改 */
|
||||||
@@ -222,10 +226,10 @@
|
|||||||
}
|
}
|
||||||
if (props.dialogType === 'add') {
|
if (props.dialogType === 'add') {
|
||||||
await api.save(payload)
|
await api.save(payload)
|
||||||
ElMessage.success('新增成功')
|
ElMessage.success(t('page.form.addSuccess'))
|
||||||
} else {
|
} else {
|
||||||
await api.update(payload)
|
await api.update(payload)
|
||||||
ElMessage.success('修改成功')
|
ElMessage.success(t('page.form.editSuccess'))
|
||||||
}
|
}
|
||||||
emit('success')
|
emit('success')
|
||||||
handleClose()
|
handleClose()
|
||||||
|
|||||||
@@ -1,26 +1,26 @@
|
|||||||
<template>
|
<template>
|
||||||
<el-dialog
|
<el-dialog
|
||||||
v-model="visible"
|
v-model="visible"
|
||||||
:title="dialogType === 'add' ? '新增奖励配置权重测试记录' : '编辑奖励配置权重测试记录'"
|
:title="dialogType === 'add' ? $t('page.form.titleAdd') : $t('page.form.titleEdit')"
|
||||||
width="600px"
|
width="600px"
|
||||||
align-center
|
align-center
|
||||||
:close-on-click-modal="false"
|
:close-on-click-modal="false"
|
||||||
@close="handleClose"
|
@close="handleClose"
|
||||||
>
|
>
|
||||||
<el-form ref="formRef" :model="formData" :rules="rules" label-width="120px">
|
<el-form ref="formRef" :model="formData" :rules="rules" label-width="120px">
|
||||||
<el-form-item label="测试次数:100/500/1000" prop="test_count">
|
<el-form-item :label="$t('page.form.labelTestCount')" prop="test_count">
|
||||||
<el-input v-model="formData.test_count" placeholder="请输入测试次数:100/500/1000" />
|
<el-input v-model="formData.test_count" :placeholder="$t('page.form.placeholderTestCount')" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="测试时权重配比快照:按档位保存 id,grid_number,tier,weight" prop="weight_config_snapshot">
|
<el-form-item :label="$t('page.form.labelWeightSnapshot')" prop="weight_config_snapshot">
|
||||||
<el-input v-model="formData.weight_config_snapshot" placeholder="请输入测试时权重配比快照:按档位保存 id,grid_number,tier,weight" />
|
<el-input v-model="formData.weight_config_snapshot" :placeholder="$t('page.form.placeholderWeightSnapshot')" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="落点统计:grid_number=>出现次数" prop="result_counts">
|
<el-form-item :label="$t('page.form.labelResultCounts')" prop="result_counts">
|
||||||
<el-input v-model="formData.result_counts" placeholder="请输入落点统计:grid_number=>出现次数" />
|
<el-input v-model="formData.result_counts" :placeholder="$t('page.form.placeholderResultCounts')" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-form>
|
</el-form>
|
||||||
<template #footer>
|
<template #footer>
|
||||||
<el-button @click="handleClose">取消</el-button>
|
<el-button @click="handleClose">{{ $t('common.cancel') }}</el-button>
|
||||||
<el-button type="primary" @click="handleSubmit">提交</el-button>
|
<el-button type="primary" @click="handleSubmit">{{ $t('table.form.submit') }}</el-button>
|
||||||
</template>
|
</template>
|
||||||
</el-dialog>
|
</el-dialog>
|
||||||
</template>
|
</template>
|
||||||
@@ -29,6 +29,7 @@
|
|||||||
import api from '../../../api/reward_config_record/index'
|
import api from '../../../api/reward_config_record/index'
|
||||||
import { ElMessage } from 'element-plus'
|
import { ElMessage } from 'element-plus'
|
||||||
import type { FormInstance, FormRules } from 'element-plus'
|
import type { FormInstance, FormRules } from 'element-plus'
|
||||||
|
import { useI18n } from 'vue-i18n'
|
||||||
|
|
||||||
interface Props {
|
interface Props {
|
||||||
modelValue: boolean
|
modelValue: boolean
|
||||||
@@ -48,6 +49,7 @@
|
|||||||
})
|
})
|
||||||
|
|
||||||
const emit = defineEmits<Emits>()
|
const emit = defineEmits<Emits>()
|
||||||
|
const { t } = useI18n()
|
||||||
|
|
||||||
const formRef = ref<FormInstance>()
|
const formRef = ref<FormInstance>()
|
||||||
|
|
||||||
@@ -62,9 +64,9 @@
|
|||||||
/**
|
/**
|
||||||
* 表单验证规则
|
* 表单验证规则
|
||||||
*/
|
*/
|
||||||
const rules = reactive<FormRules>({
|
const rules = computed<FormRules>(() => ({
|
||||||
test_count: [{ required: true, message: '测试次数:100/500/1000必需填写', trigger: 'blur' }],
|
test_count: [{ required: true, message: t('page.form.ruleTestCountRequired'), trigger: 'blur' }]
|
||||||
})
|
}))
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 初始数据
|
* 初始数据
|
||||||
@@ -136,10 +138,10 @@
|
|||||||
await formRef.value.validate()
|
await formRef.value.validate()
|
||||||
if (props.dialogType === 'add') {
|
if (props.dialogType === 'add') {
|
||||||
await api.save(formData)
|
await api.save(formData)
|
||||||
ElMessage.success('新增成功')
|
ElMessage.success(t('page.form.addSuccess'))
|
||||||
} else {
|
} else {
|
||||||
await api.update(formData)
|
await api.update(formData)
|
||||||
ElMessage.success('修改成功')
|
ElMessage.success(t('page.form.editSuccess'))
|
||||||
}
|
}
|
||||||
emit('success')
|
emit('success')
|
||||||
handleClose()
|
handleClose()
|
||||||
|
|||||||
@@ -1,21 +1,21 @@
|
|||||||
<template>
|
<template>
|
||||||
<el-dialog
|
<el-dialog
|
||||||
v-model="visible"
|
v-model="visible"
|
||||||
:title="dialogType === 'add' ? '新增文件' : '编辑文件'"
|
:title="dialogType === 'add' ? $t('page.form.titleAdd') : $t('page.form.titleEdit')"
|
||||||
width="800px"
|
width="800px"
|
||||||
align-center
|
align-center
|
||||||
:close-on-click-modal="false"
|
:close-on-click-modal="false"
|
||||||
@close="handleClose"
|
@close="handleClose"
|
||||||
>
|
>
|
||||||
<el-form ref="formRef" :model="formData" :rules="rules" label-width="100px">
|
<el-form ref="formRef" :model="formData" :rules="rules" label-width="100px">
|
||||||
<el-form-item label="文件名称" prop="origin_name">
|
<el-form-item :label="$t('page.form.labelFileName')" prop="origin_name">
|
||||||
<el-input v-model="formData.origin_name" placeholder="请输入文件名称" />
|
<el-input v-model="formData.origin_name" :placeholder="$t('page.form.placeholderFileName')" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-form>
|
</el-form>
|
||||||
<template #footer>
|
<template #footer>
|
||||||
<div class="dialog-footer">
|
<div class="dialog-footer">
|
||||||
<el-button @click="handleClose">取消</el-button>
|
<el-button @click="handleClose">{{ $t('common.cancel') }}</el-button>
|
||||||
<el-button type="primary" @click="handleSubmit">提交</el-button>
|
<el-button type="primary" @click="handleSubmit">{{ $t('table.form.submit') }}</el-button>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
</el-dialog>
|
</el-dialog>
|
||||||
@@ -24,6 +24,8 @@
|
|||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import type { FormInstance, FormRules } from 'element-plus'
|
import type { FormInstance, FormRules } from 'element-plus'
|
||||||
import api from '@/api/safeguard/attachment'
|
import api from '@/api/safeguard/attachment'
|
||||||
|
import { ElMessage } from 'element-plus'
|
||||||
|
import { useI18n } from 'vue-i18n'
|
||||||
|
|
||||||
interface Props {
|
interface Props {
|
||||||
modelValue: boolean
|
modelValue: boolean
|
||||||
@@ -43,6 +45,7 @@
|
|||||||
})
|
})
|
||||||
|
|
||||||
const emit = defineEmits<Emits>()
|
const emit = defineEmits<Emits>()
|
||||||
|
const { t } = useI18n()
|
||||||
|
|
||||||
const formRef = ref<FormInstance>()
|
const formRef = ref<FormInstance>()
|
||||||
|
|
||||||
@@ -55,9 +58,9 @@
|
|||||||
})
|
})
|
||||||
|
|
||||||
// 表单验证规则
|
// 表单验证规则
|
||||||
const rules: FormRules = {
|
const rules = computed<FormRules>(() => ({
|
||||||
origin_name: [{ required: true, message: '请输入文件名称', trigger: 'blur' }]
|
origin_name: [{ required: true, message: t('page.form.ruleFileNameRequired'), trigger: 'blur' }]
|
||||||
}
|
}))
|
||||||
|
|
||||||
// 初始表单数据
|
// 初始表单数据
|
||||||
const initialFormData = {
|
const initialFormData = {
|
||||||
@@ -123,7 +126,7 @@
|
|||||||
await formRef.value.validate()
|
await formRef.value.validate()
|
||||||
if (props.dialogType === 'edit') {
|
if (props.dialogType === 'edit') {
|
||||||
await api.update(formData)
|
await api.update(formData)
|
||||||
ElMessage.success('修改成功')
|
ElMessage.success(t('page.form.editSuccess'))
|
||||||
}
|
}
|
||||||
emit('success')
|
emit('success')
|
||||||
handleClose()
|
handleClose()
|
||||||
|
|||||||
@@ -1,17 +1,17 @@
|
|||||||
<template>
|
<template>
|
||||||
<el-dialog
|
<el-dialog
|
||||||
v-model="visible"
|
v-model="visible"
|
||||||
:title="dialogType === 'add' ? '新增菜单' : '编辑菜单'"
|
:title="dialogType === 'add' ? $t('page.form.titleAdd') : $t('page.form.titleEdit')"
|
||||||
width="820px"
|
width="820px"
|
||||||
align-center
|
align-center
|
||||||
:close-on-click-modal="false"
|
:close-on-click-modal="false"
|
||||||
@close="handleClose"
|
@close="handleClose"
|
||||||
>
|
>
|
||||||
<el-form ref="formRef" :model="formData" :rules="rules" label-width="120px">
|
<el-form ref="formRef" :model="formData" :rules="rules" label-width="120px">
|
||||||
<el-form-item label="菜单类型" prop="type">
|
<el-form-item :label="$t('page.form.labelMenuType')" prop="type">
|
||||||
<sa-radio v-model="formData.type" type="button" dict="menu_type"></sa-radio>
|
<sa-radio v-model="formData.type" type="button" dict="menu_type"></sa-radio>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="上级菜单" prop="parent_id">
|
<el-form-item :label="$t('page.form.labelParentMenu')" prop="parent_id">
|
||||||
<el-tree-select
|
<el-tree-select
|
||||||
v-model="formData.parent_id"
|
v-model="formData.parent_id"
|
||||||
:data="optionData.treeData"
|
:data="optionData.treeData"
|
||||||
@@ -22,63 +22,63 @@
|
|||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-row>
|
<el-row>
|
||||||
<el-col :span="12">
|
<el-col :span="12">
|
||||||
<el-form-item label="菜单名称" prop="name">
|
<el-form-item :label="$t('page.form.labelMenuName')" prop="name">
|
||||||
<el-input v-model="formData.name" placeholder="请输入菜单名称" />
|
<el-input v-model="formData.name" :placeholder="$t('page.form.labelMenuName')" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-col>
|
</el-col>
|
||||||
<el-col :span="12" v-if="formData.type < 3">
|
<el-col :span="12" v-if="formData.type < 3">
|
||||||
<el-form-item prop="path">
|
<el-form-item prop="path">
|
||||||
<template #label>
|
<template #label>
|
||||||
<sa-label
|
<sa-label
|
||||||
label="路由地址"
|
:label="$t('page.form.labelRoutePath')"
|
||||||
tooltip="一级菜单:以 / 开头的绝对路径(如 /dashboard) 二级及以下:相对路径(如 console、user)"
|
:tooltip="$t('page.form.labelRoutePathTip')"
|
||||||
/>
|
/>
|
||||||
</template>
|
</template>
|
||||||
<el-input v-model="formData.path" placeholder="如:/dashboard 或 console" />
|
<el-input v-model="formData.path" :placeholder="$t('page.form.placeholderRoutePath')" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-col>
|
</el-col>
|
||||||
<el-col :span="12" v-if="formData.type != 3">
|
<el-col :span="12" v-if="formData.type != 3">
|
||||||
<el-form-item label="组件名称" prop="code">
|
<el-form-item :label="$t('page.form.labelComponentName')" prop="code">
|
||||||
<el-input v-model="formData.code" placeholder="如: User" />
|
<el-input v-model="formData.code" :placeholder="$t('page.form.placeholderComponentName')" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-col>
|
</el-col>
|
||||||
<el-col :span="12" v-if="formData.type === 2">
|
<el-col :span="12" v-if="formData.type === 2">
|
||||||
<el-form-item prop="component">
|
<el-form-item prop="component">
|
||||||
<template #label>
|
<template #label>
|
||||||
<sa-label label="组件路径" tooltip="填写组件路径(views目录下) 目录菜单:留空" />
|
<sa-label :label="$t('page.form.labelComponentPath')" :tooltip="$t('page.form.labelComponentPathTip')" />
|
||||||
</template>
|
</template>
|
||||||
<el-autocomplete
|
<el-autocomplete
|
||||||
class="w-full"
|
class="w-full"
|
||||||
v-model="formData.component"
|
v-model="formData.component"
|
||||||
:fetch-suggestions="querySearch"
|
:fetch-suggestions="querySearch"
|
||||||
clearable
|
clearable
|
||||||
placeholder="如:/system/user 或留空"
|
:placeholder="$t('page.form.placeholderComponentPath')"
|
||||||
/>
|
/>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-col>
|
</el-col>
|
||||||
<el-col :span="12" v-if="formData.type != 3">
|
<el-col :span="12" v-if="formData.type != 3">
|
||||||
<el-form-item label="菜单图标" prop="icon">
|
<el-form-item :label="$t('page.form.labelMenuIcon')" prop="icon">
|
||||||
<sa-icon-picker v-model="formData.icon" />
|
<sa-icon-picker v-model="formData.icon" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-col>
|
</el-col>
|
||||||
<el-col :span="12" v-if="formData.type === 3">
|
<el-col :span="12" v-if="formData.type === 3">
|
||||||
<el-form-item label="权限标识" prop="slug">
|
<el-form-item :label="$t('page.form.labelPermSlug')" prop="slug">
|
||||||
<el-input v-model="formData.slug" placeholder="请输入权限标识" />
|
<el-input v-model="formData.slug" :placeholder="$t('page.form.placeholderPermSlug')" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-col>
|
</el-col>
|
||||||
<el-col :span="24" v-if="formData.type === 4">
|
<el-col :span="24" v-if="formData.type === 4">
|
||||||
<el-form-item label="外链地址" prop="link_url">
|
<el-form-item :label="$t('page.form.labelLinkUrl')" prop="link_url">
|
||||||
<el-input v-model="formData.link_url" placeholder="如:https://saithink.top" />
|
<el-input v-model="formData.link_url" :placeholder="$t('page.form.placeholderLinkUrl')" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-col>
|
</el-col>
|
||||||
<el-col :span="12">
|
<el-col :span="12">
|
||||||
<el-form-item prop="sort">
|
<el-form-item prop="sort">
|
||||||
<template #label>
|
<template #label>
|
||||||
<sa-label label="排序" tooltip="数字越大越靠前" />
|
<sa-label :label="$t('page.form.labelSort')" :tooltip="$t('page.form.labelSortTip')" />
|
||||||
</template>
|
</template>
|
||||||
<el-input-number
|
<el-input-number
|
||||||
v-model="formData.sort"
|
v-model="formData.sort"
|
||||||
placeholder="请输入排序"
|
:placeholder="$t('page.form.placeholderSort')"
|
||||||
controls-position="right"
|
controls-position="right"
|
||||||
/>
|
/>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
@@ -86,7 +86,7 @@
|
|||||||
<el-col :span="12">
|
<el-col :span="12">
|
||||||
<el-form-item prop="status">
|
<el-form-item prop="status">
|
||||||
<template #label>
|
<template #label>
|
||||||
<sa-label label="状态" tooltip="禁用后,该菜单项将不可用" />
|
<sa-label :label="$t('page.form.labelStatus')" :tooltip="$t('page.form.labelStatusTip')" />
|
||||||
</template>
|
</template>
|
||||||
<sa-radio v-model="formData.status" dict="data_status" />
|
<sa-radio v-model="formData.status" dict="data_status" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
@@ -94,7 +94,7 @@
|
|||||||
<el-col :span="12">
|
<el-col :span="12">
|
||||||
<el-form-item prop="is_iframe">
|
<el-form-item prop="is_iframe">
|
||||||
<template #label>
|
<template #label>
|
||||||
<sa-label label="是否内嵌" tooltip="外链模式下有效" />
|
<sa-label :label="$t('page.form.labelIsIframe')" :tooltip="$t('page.form.labelIsIframeTip')" />
|
||||||
</template>
|
</template>
|
||||||
<sa-switch v-model="formData.is_iframe" dict="yes_or_no" :showText="false" />
|
<sa-switch v-model="formData.is_iframe" dict="yes_or_no" :showText="false" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
@@ -102,7 +102,7 @@
|
|||||||
<el-col :span="12">
|
<el-col :span="12">
|
||||||
<el-form-item prop="is_keep_alive">
|
<el-form-item prop="is_keep_alive">
|
||||||
<template #label>
|
<template #label>
|
||||||
<sa-label label="是否缓存" tooltip="切换tabs不刷新" />
|
<sa-label :label="$t('page.form.labelIsKeepAlive')" :tooltip="$t('page.form.labelIsKeepAliveTip')" />
|
||||||
</template>
|
</template>
|
||||||
<sa-switch v-model="formData.is_keep_alive" dict="yes_or_no" :showText="false" />
|
<sa-switch v-model="formData.is_keep_alive" dict="yes_or_no" :showText="false" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
@@ -110,7 +110,7 @@
|
|||||||
<el-col :span="12">
|
<el-col :span="12">
|
||||||
<el-form-item prop="is_hidden">
|
<el-form-item prop="is_hidden">
|
||||||
<template #label>
|
<template #label>
|
||||||
<sa-label label="是否隐藏" tooltip="不在菜单栏显示,但是可以通过路由访问" />
|
<sa-label :label="$t('page.form.labelIsHidden')" :tooltip="$t('page.form.labelIsHiddenTip')" />
|
||||||
</template>
|
</template>
|
||||||
<sa-switch v-model="formData.is_hidden" dict="yes_or_no" :showText="false" />
|
<sa-switch v-model="formData.is_hidden" dict="yes_or_no" :showText="false" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
@@ -118,7 +118,7 @@
|
|||||||
<el-col :span="12">
|
<el-col :span="12">
|
||||||
<el-form-item prop="is_fixed_tab">
|
<el-form-item prop="is_fixed_tab">
|
||||||
<template #label>
|
<template #label>
|
||||||
<sa-label label="是否固定" tooltip="固定在tabs导航栏" />
|
<sa-label :label="$t('page.form.labelIsFixedTab')" :tooltip="$t('page.form.labelIsFixedTabTip')" />
|
||||||
</template>
|
</template>
|
||||||
<sa-switch v-model="formData.is_fixed_tab" dict="yes_or_no" :showText="false" />
|
<sa-switch v-model="formData.is_fixed_tab" dict="yes_or_no" :showText="false" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
@@ -126,7 +126,7 @@
|
|||||||
<el-col :span="12">
|
<el-col :span="12">
|
||||||
<el-form-item prop="is_full_page">
|
<el-form-item prop="is_full_page">
|
||||||
<template #label>
|
<template #label>
|
||||||
<sa-label label="是否全屏" tooltip="不继承左侧菜单和顶部导航栏" />
|
<sa-label :label="$t('page.form.labelIsFullPage')" :tooltip="$t('page.form.labelIsFullPageTip')" />
|
||||||
</template>
|
</template>
|
||||||
<sa-switch v-model="formData.is_full_page" dict="yes_or_no" :showText="false" />
|
<sa-switch v-model="formData.is_full_page" dict="yes_or_no" :showText="false" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
@@ -134,8 +134,8 @@
|
|||||||
</el-row>
|
</el-row>
|
||||||
</el-form>
|
</el-form>
|
||||||
<template #footer>
|
<template #footer>
|
||||||
<el-button @click="handleClose">取消</el-button>
|
<el-button @click="handleClose">{{ $t('common.cancel') }}</el-button>
|
||||||
<el-button type="primary" @click="handleSubmit">提交</el-button>
|
<el-button type="primary" @click="handleSubmit">{{ $t('table.form.submit') }}</el-button>
|
||||||
</template>
|
</template>
|
||||||
</el-dialog>
|
</el-dialog>
|
||||||
</template>
|
</template>
|
||||||
@@ -144,6 +144,7 @@
|
|||||||
import api from '@/api/system/menu'
|
import api from '@/api/system/menu'
|
||||||
import { ElMessage } from 'element-plus'
|
import { ElMessage } from 'element-plus'
|
||||||
import type { FormInstance, FormRules } from 'element-plus'
|
import type { FormInstance, FormRules } from 'element-plus'
|
||||||
|
import { useI18n } from 'vue-i18n'
|
||||||
|
|
||||||
interface Props {
|
interface Props {
|
||||||
modelValue: boolean
|
modelValue: boolean
|
||||||
@@ -163,6 +164,7 @@
|
|||||||
})
|
})
|
||||||
|
|
||||||
const emit = defineEmits<Emits>()
|
const emit = defineEmits<Emits>()
|
||||||
|
const { t } = useI18n()
|
||||||
|
|
||||||
const formRef = ref<FormInstance>()
|
const formRef = ref<FormInstance>()
|
||||||
const optionData = reactive({
|
const optionData = reactive({
|
||||||
@@ -197,14 +199,14 @@
|
|||||||
/**
|
/**
|
||||||
* 表单验证规则
|
* 表单验证规则
|
||||||
*/
|
*/
|
||||||
const rules = reactive<FormRules>({
|
const rules = computed<FormRules>(() => ({
|
||||||
parent_id: [{ required: true, message: '请选择上级菜单', trigger: 'change' }],
|
parent_id: [{ required: true, message: t('page.form.ruleParentMenuRequired'), trigger: 'change' }],
|
||||||
name: [{ required: true, message: '请输入菜单名称', trigger: 'blur' }],
|
name: [{ required: true, message: t('page.form.ruleMenuNameRequired'), trigger: 'blur' }],
|
||||||
path: [{ required: true, message: '请输入路由地址', trigger: 'blur' }],
|
path: [{ required: true, message: t('page.form.ruleRoutePathRequired'), trigger: 'blur' }],
|
||||||
code: [{ required: true, message: '请输入组件名称', trigger: 'blur' }],
|
code: [{ required: true, message: t('page.form.ruleComponentNameRequired'), trigger: 'blur' }],
|
||||||
slug: [{ required: true, message: '请输入权限标识', trigger: 'blur' }],
|
slug: [{ required: true, message: t('page.form.rulePermSlugRequired'), trigger: 'blur' }],
|
||||||
link_url: [{ required: true, message: '请输入外链地址', trigger: 'blur' }]
|
link_url: [{ required: true, message: t('page.form.ruleLinkUrlRequired'), trigger: 'blur' }]
|
||||||
})
|
}))
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 初始数据
|
* 初始数据
|
||||||
@@ -302,10 +304,10 @@
|
|||||||
await formRef.value.validate()
|
await formRef.value.validate()
|
||||||
if (props.dialogType === 'add') {
|
if (props.dialogType === 'add') {
|
||||||
await api.save(formData)
|
await api.save(formData)
|
||||||
ElMessage.success('新增成功')
|
ElMessage.success(t('page.form.addSuccess'))
|
||||||
} else {
|
} else {
|
||||||
await api.update(formData)
|
await api.update(formData)
|
||||||
ElMessage.success('修改成功')
|
ElMessage.success(t('page.form.editSuccess'))
|
||||||
}
|
}
|
||||||
emit('success')
|
emit('success')
|
||||||
handleClose()
|
handleClose()
|
||||||
|
|||||||
@@ -1,37 +1,37 @@
|
|||||||
<template>
|
<template>
|
||||||
<el-dialog
|
<el-dialog
|
||||||
v-model="visible"
|
v-model="visible"
|
||||||
:title="dialogType === 'add' ? '新增岗位' : '编辑岗位'"
|
:title="dialogType === 'add' ? $t('page.form.titleAdd') : $t('page.form.titleEdit')"
|
||||||
width="600px"
|
width="600px"
|
||||||
align-center
|
align-center
|
||||||
:close-on-click-modal="false"
|
:close-on-click-modal="false"
|
||||||
@close="handleClose"
|
@close="handleClose"
|
||||||
>
|
>
|
||||||
<el-form ref="formRef" :model="formData" :rules="rules" label-width="120px">
|
<el-form ref="formRef" :model="formData" :rules="rules" label-width="120px">
|
||||||
<el-form-item label="岗位名称" prop="name">
|
<el-form-item :label="$t('page.form.labelName')" prop="name">
|
||||||
<el-input v-model="formData.name" placeholder="请输入岗位名称" />
|
<el-input v-model="formData.name" :placeholder="$t('page.form.placeholderName')" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="岗位编码" prop="code">
|
<el-form-item :label="$t('page.form.labelCode')" prop="code">
|
||||||
<el-input v-model="formData.code" placeholder="请输入岗位编码" />
|
<el-input v-model="formData.code" :placeholder="$t('page.form.placeholderCode')" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="描述" prop="remark">
|
<el-form-item :label="$t('page.form.labelRemark')" prop="remark">
|
||||||
<el-input
|
<el-input
|
||||||
v-model="formData.remark"
|
v-model="formData.remark"
|
||||||
type="textarea"
|
type="textarea"
|
||||||
:rows="3"
|
:rows="3"
|
||||||
placeholder="请输入岗位描述"
|
:placeholder="$t('page.form.placeholderRemark')"
|
||||||
/>
|
/>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="排序" prop="sort">
|
<el-form-item :label="$t('page.form.labelSort')" prop="sort">
|
||||||
<el-input-number v-model="formData.sort" placeholder="请输入排序" />
|
<el-input-number v-model="formData.sort" :placeholder="$t('page.form.placeholderSort')" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="启用" prop="status">
|
<el-form-item :label="$t('page.form.labelStatus')" prop="status">
|
||||||
<sa-radio v-model="formData.status" dict="data_status" />
|
<sa-radio v-model="formData.status" dict="data_status" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-form>
|
</el-form>
|
||||||
<template #footer>
|
<template #footer>
|
||||||
<el-button @click="handleClose">取消</el-button>
|
<el-button @click="handleClose">{{ $t('common.cancel') }}</el-button>
|
||||||
<el-button type="primary" @click="handleSubmit">提交</el-button>
|
<el-button type="primary" @click="handleSubmit">{{ $t('table.form.submit') }}</el-button>
|
||||||
</template>
|
</template>
|
||||||
</el-dialog>
|
</el-dialog>
|
||||||
</template>
|
</template>
|
||||||
@@ -40,6 +40,7 @@
|
|||||||
import api from '@/api/system/post'
|
import api from '@/api/system/post'
|
||||||
import { ElMessage } from 'element-plus'
|
import { ElMessage } from 'element-plus'
|
||||||
import type { FormInstance, FormRules } from 'element-plus'
|
import type { FormInstance, FormRules } from 'element-plus'
|
||||||
|
import { useI18n } from 'vue-i18n'
|
||||||
|
|
||||||
interface Props {
|
interface Props {
|
||||||
modelValue: boolean
|
modelValue: boolean
|
||||||
@@ -59,6 +60,7 @@
|
|||||||
})
|
})
|
||||||
|
|
||||||
const emit = defineEmits<Emits>()
|
const emit = defineEmits<Emits>()
|
||||||
|
const { t } = useI18n()
|
||||||
|
|
||||||
const formRef = ref<FormInstance>()
|
const formRef = ref<FormInstance>()
|
||||||
|
|
||||||
@@ -73,10 +75,10 @@
|
|||||||
/**
|
/**
|
||||||
* 表单验证规则
|
* 表单验证规则
|
||||||
*/
|
*/
|
||||||
const rules = reactive<FormRules>({
|
const rules = computed<FormRules>(() => ({
|
||||||
name: [{ required: true, message: '请输入岗位名称', trigger: 'blur' }],
|
name: [{ required: true, message: t('page.form.ruleNameRequired'), trigger: 'blur' }],
|
||||||
code: [{ required: true, message: '请输入岗位编码', trigger: 'blur' }]
|
code: [{ required: true, message: t('page.form.ruleCodeRequired'), trigger: 'blur' }]
|
||||||
})
|
}))
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 初始数据
|
* 初始数据
|
||||||
@@ -150,10 +152,10 @@
|
|||||||
await formRef.value.validate()
|
await formRef.value.validate()
|
||||||
if (props.dialogType === 'add') {
|
if (props.dialogType === 'add') {
|
||||||
await api.save(formData)
|
await api.save(formData)
|
||||||
ElMessage.success('新增成功')
|
ElMessage.success(t('page.form.addSuccess'))
|
||||||
} else {
|
} else {
|
||||||
await api.update(formData)
|
await api.update(formData)
|
||||||
ElMessage.success('修改成功')
|
ElMessage.success(t('page.form.editSuccess'))
|
||||||
}
|
}
|
||||||
emit('success')
|
emit('success')
|
||||||
handleClose()
|
handleClose()
|
||||||
|
|||||||
@@ -1,42 +1,40 @@
|
|||||||
<template>
|
<template>
|
||||||
<el-dialog
|
<el-dialog
|
||||||
v-model="visible"
|
v-model="visible"
|
||||||
:title="dialogType === 'add' ? '新增角色' : '编辑角色'"
|
:title="dialogType === 'add' ? $t('page.form.titleAdd') : $t('page.form.titleEdit')"
|
||||||
width="600px"
|
width="600px"
|
||||||
align-center
|
align-center
|
||||||
@close="handleClose"
|
@close="handleClose"
|
||||||
>
|
>
|
||||||
<el-form ref="formRef" :model="formData" :rules="rules" label-width="120px">
|
<el-form ref="formRef" :model="formData" :rules="rules" label-width="120px">
|
||||||
<el-form-item label="角色名称" prop="name">
|
<el-form-item :label="$t('page.form.labelName')" prop="name">
|
||||||
<el-input v-model="formData.name" placeholder="请输入角色名称" />
|
<el-input v-model="formData.name" :placeholder="$t('page.form.placeholderName')" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="角色标识" prop="code">
|
<el-form-item :label="$t('page.form.labelCode')" prop="code">
|
||||||
<el-input v-model="formData.code" placeholder="请输入角色编码" />
|
<el-input v-model="formData.code" :placeholder="$t('page.form.placeholderCode')" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="角色级别" prop="level">
|
<el-form-item :label="$t('page.form.labelLevel')" prop="level">
|
||||||
<el-input-number v-model="formData.level" placeholder="角色级别" :max="99" :min="1" />
|
<el-input-number v-model="formData.level" :placeholder="$t('page.form.labelLevel')" :max="99" :min="1" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<div class="text-xs text-gray-400 pl-32 pb-4"
|
<div class="text-xs text-gray-400 pl-32 pb-4">{{ $t('page.form.levelTip') }}</div>
|
||||||
>控制角色的权限层级, 不能操作职级高于自己的角色</div
|
<el-form-item :label="$t('page.form.labelRemark')" prop="remark">
|
||||||
>
|
|
||||||
<el-form-item label="描述" prop="remark">
|
|
||||||
<el-input
|
<el-input
|
||||||
v-model="formData.remark"
|
v-model="formData.remark"
|
||||||
type="textarea"
|
type="textarea"
|
||||||
:rows="3"
|
:rows="3"
|
||||||
placeholder="请输入角色描述"
|
:placeholder="$t('page.form.placeholderRemark')"
|
||||||
/>
|
/>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="排序" prop="sort">
|
<el-form-item :label="$t('page.form.labelSort')" prop="sort">
|
||||||
<el-input-number v-model="formData.sort" placeholder="请输入排序" />
|
<el-input-number v-model="formData.sort" :placeholder="$t('page.form.placeholderSort')" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="启用" prop="status">
|
<el-form-item :label="$t('page.form.labelStatus')" prop="status">
|
||||||
<sa-radio v-model="formData.status" dict="data_status" />
|
<sa-radio v-model="formData.status" dict="data_status" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-form>
|
</el-form>
|
||||||
<template #footer>
|
<template #footer>
|
||||||
<el-button @click="handleClose">取消</el-button>
|
<el-button @click="handleClose">{{ $t('common.cancel') }}</el-button>
|
||||||
<el-button type="primary" @click="handleSubmit">提交</el-button>
|
<el-button type="primary" @click="handleSubmit">{{ $t('table.form.submit') }}</el-button>
|
||||||
</template>
|
</template>
|
||||||
</el-dialog>
|
</el-dialog>
|
||||||
</template>
|
</template>
|
||||||
@@ -45,6 +43,7 @@
|
|||||||
import api from '@/api/system/role'
|
import api from '@/api/system/role'
|
||||||
import { ElMessage } from 'element-plus'
|
import { ElMessage } from 'element-plus'
|
||||||
import type { FormInstance, FormRules } from 'element-plus'
|
import type { FormInstance, FormRules } from 'element-plus'
|
||||||
|
import { useI18n } from 'vue-i18n'
|
||||||
|
|
||||||
interface Props {
|
interface Props {
|
||||||
modelValue: boolean
|
modelValue: boolean
|
||||||
@@ -64,6 +63,7 @@
|
|||||||
})
|
})
|
||||||
|
|
||||||
const emit = defineEmits<Emits>()
|
const emit = defineEmits<Emits>()
|
||||||
|
const { t } = useI18n()
|
||||||
|
|
||||||
const formRef = ref<FormInstance>()
|
const formRef = ref<FormInstance>()
|
||||||
|
|
||||||
@@ -78,11 +78,11 @@
|
|||||||
/**
|
/**
|
||||||
* 表单验证规则
|
* 表单验证规则
|
||||||
*/
|
*/
|
||||||
const rules = reactive<FormRules>({
|
const rules = computed<FormRules>(() => ({
|
||||||
name: [{ required: true, message: '请输入角色名称', trigger: 'blur' }],
|
name: [{ required: true, message: t('page.form.ruleNameRequired'), trigger: 'blur' }],
|
||||||
code: [{ required: true, message: '请输入角色编码', trigger: 'blur' }],
|
code: [{ required: true, message: t('page.form.ruleCodeRequired'), trigger: 'blur' }],
|
||||||
level: [{ required: true, message: '请输入角色级别', trigger: 'blur' }]
|
level: [{ required: true, message: t('page.form.ruleLevelRequired'), trigger: 'blur' }]
|
||||||
})
|
}))
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 初始数据
|
* 初始数据
|
||||||
@@ -157,10 +157,10 @@
|
|||||||
await formRef.value.validate()
|
await formRef.value.validate()
|
||||||
if (props.dialogType === 'add') {
|
if (props.dialogType === 'add') {
|
||||||
await api.save(formData)
|
await api.save(formData)
|
||||||
ElMessage.success('新增成功')
|
ElMessage.success(t('page.form.addSuccess'))
|
||||||
} else {
|
} else {
|
||||||
await api.update(formData)
|
await api.update(formData)
|
||||||
ElMessage.success('修改成功')
|
ElMessage.success(t('page.form.editSuccess'))
|
||||||
}
|
}
|
||||||
emit('success')
|
emit('success')
|
||||||
handleClose()
|
handleClose()
|
||||||
|
|||||||
@@ -1,36 +1,36 @@
|
|||||||
<template>
|
<template>
|
||||||
<el-dialog
|
<el-dialog
|
||||||
v-model="visible"
|
v-model="visible"
|
||||||
:title="dialogType === 'add' ? '新增用户' : '编辑用户'"
|
:title="dialogType === 'add' ? $t('page.form.titleAdd') : $t('page.form.titleEdit')"
|
||||||
width="800px"
|
width="800px"
|
||||||
align-center
|
align-center
|
||||||
:close-on-click-modal="false"
|
:close-on-click-modal="false"
|
||||||
@close="handleClose"
|
@close="handleClose"
|
||||||
>
|
>
|
||||||
<el-form ref="formRef" :model="formData" :rules="rules" label-width="100px">
|
<el-form ref="formRef" :model="formData" :rules="rules" label-width="100px">
|
||||||
<el-form-item label="头像" prop="avatar">
|
<el-form-item :label="$t('page.form.labelAvatar')" prop="avatar">
|
||||||
<sa-image-picker v-model="formData.avatar" round />
|
<sa-image-picker v-model="formData.avatar" round />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-row>
|
<el-row>
|
||||||
<el-col :span="12">
|
<el-col :span="12">
|
||||||
<el-form-item label="用户名" prop="username">
|
<el-form-item :label="$t('page.form.labelUsername')" prop="username">
|
||||||
<el-input v-model="formData.username" />
|
<el-input v-model="formData.username" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-col>
|
</el-col>
|
||||||
<el-col :span="12">
|
<el-col :span="12">
|
||||||
<el-form-item label="真实姓名" prop="realname">
|
<el-form-item :label="$t('page.form.labelRealname')" prop="realname">
|
||||||
<el-input v-model="formData.realname" />
|
<el-input v-model="formData.realname" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-col>
|
</el-col>
|
||||||
</el-row>
|
</el-row>
|
||||||
<el-row v-if="dialogType === 'add'">
|
<el-row v-if="dialogType === 'add'">
|
||||||
<el-col :span="12">
|
<el-col :span="12">
|
||||||
<el-form-item label="密码" prop="password">
|
<el-form-item :label="$t('page.form.labelPassword')" prop="password">
|
||||||
<el-input type="password" v-model="formData.password" show-password />
|
<el-input type="password" v-model="formData.password" show-password />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-col>
|
</el-col>
|
||||||
<el-col :span="12">
|
<el-col :span="12">
|
||||||
<el-form-item label="确认密码" prop="password_confirm">
|
<el-form-item :label="$t('page.form.labelPasswordConfirm')" prop="password_confirm">
|
||||||
<el-input type="password" v-model="formData.password_confirm" show-password />
|
<el-input type="password" v-model="formData.password_confirm" show-password />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-col>
|
</el-col>
|
||||||
@@ -38,20 +38,20 @@
|
|||||||
|
|
||||||
<el-row>
|
<el-row>
|
||||||
<el-col :span="12">
|
<el-col :span="12">
|
||||||
<el-form-item label="邮箱" prop="email">
|
<el-form-item :label="$t('page.form.labelEmail')" prop="email">
|
||||||
<el-input v-model="formData.email" placeholder="请输入邮箱" />
|
<el-input v-model="formData.email" :placeholder="$t('page.form.placeholderEmail')" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-col>
|
</el-col>
|
||||||
<el-col :span="12">
|
<el-col :span="12">
|
||||||
<el-form-item label="手机号" prop="phone">
|
<el-form-item :label="$t('page.form.labelPhone')" prop="phone">
|
||||||
<el-input v-model="formData.phone" placeholder="请输入手机号" />
|
<el-input v-model="formData.phone" :placeholder="$t('page.form.placeholderPhone')" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-col>
|
</el-col>
|
||||||
</el-row>
|
</el-row>
|
||||||
|
|
||||||
<el-row>
|
<el-row>
|
||||||
<el-col :span="12">
|
<el-col :span="12">
|
||||||
<el-form-item label="部门" prop="dept_id">
|
<el-form-item :label="$t('page.form.labelDept')" prop="dept_id">
|
||||||
<el-tree-select
|
<el-tree-select
|
||||||
v-model="formData.dept_id"
|
v-model="formData.dept_id"
|
||||||
:data="optionData.deptData"
|
:data="optionData.deptData"
|
||||||
@@ -62,7 +62,7 @@
|
|||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-col>
|
</el-col>
|
||||||
<el-col :span="12">
|
<el-col :span="12">
|
||||||
<el-form-item label="角色" prop="role_ids">
|
<el-form-item :label="$t('page.form.labelRole')" prop="role_ids">
|
||||||
<el-select v-model="formData.role_ids" multiple clearable>
|
<el-select v-model="formData.role_ids" multiple clearable>
|
||||||
<el-option
|
<el-option
|
||||||
v-for="role in optionData.roleList"
|
v-for="role in optionData.roleList"
|
||||||
@@ -77,7 +77,7 @@
|
|||||||
|
|
||||||
<el-row>
|
<el-row>
|
||||||
<el-col :span="12">
|
<el-col :span="12">
|
||||||
<el-form-item label="岗位" prop="post_ids">
|
<el-form-item :label="$t('page.form.labelPost')" prop="post_ids">
|
||||||
<el-select v-model="formData.post_ids" multiple clearable>
|
<el-select v-model="formData.post_ids" multiple clearable>
|
||||||
<el-option
|
<el-option
|
||||||
v-for="post in optionData.postList"
|
v-for="post in optionData.postList"
|
||||||
@@ -89,14 +89,14 @@
|
|||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-col>
|
</el-col>
|
||||||
<el-col :span="12">
|
<el-col :span="12">
|
||||||
<el-form-item label="性别" prop="gender">
|
<el-form-item :label="$t('page.form.labelGender')" prop="gender">
|
||||||
<sa-radio v-model="formData.gender" dict="gender" valueType="string" />
|
<sa-radio v-model="formData.gender" dict="gender" valueType="string" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-col>
|
</el-col>
|
||||||
</el-row>
|
</el-row>
|
||||||
<el-row>
|
<el-row>
|
||||||
<el-col :span="24">
|
<el-col :span="24">
|
||||||
<el-form-item label="状态" prop="status">
|
<el-form-item :label="$t('page.form.labelStatus')" prop="status">
|
||||||
<sa-radio v-model="formData.status" dict="data_status" />
|
<sa-radio v-model="formData.status" dict="data_status" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-col>
|
</el-col>
|
||||||
@@ -104,12 +104,12 @@
|
|||||||
|
|
||||||
<el-row>
|
<el-row>
|
||||||
<el-col :span="24">
|
<el-col :span="24">
|
||||||
<el-form-item label="备注" prop="remark">
|
<el-form-item :label="$t('page.form.labelRemark')" prop="remark">
|
||||||
<el-input
|
<el-input
|
||||||
v-model="formData.remark"
|
v-model="formData.remark"
|
||||||
type="textarea"
|
type="textarea"
|
||||||
:rows="3"
|
:rows="3"
|
||||||
placeholder="请输入备注"
|
:placeholder="$t('page.form.placeholderRemark')"
|
||||||
/>
|
/>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-col>
|
</el-col>
|
||||||
@@ -117,8 +117,8 @@
|
|||||||
</el-form>
|
</el-form>
|
||||||
<template #footer>
|
<template #footer>
|
||||||
<div class="dialog-footer">
|
<div class="dialog-footer">
|
||||||
<el-button @click="handleClose">取消</el-button>
|
<el-button @click="handleClose">{{ $t('common.cancel') }}</el-button>
|
||||||
<el-button type="primary" @click="handleSubmit">提交</el-button>
|
<el-button type="primary" @click="handleSubmit">{{ $t('table.form.submit') }}</el-button>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
</el-dialog>
|
</el-dialog>
|
||||||
@@ -130,6 +130,8 @@
|
|||||||
import deptApi from '@/api/system/dept'
|
import deptApi from '@/api/system/dept'
|
||||||
import roleApi from '@/api/system/role'
|
import roleApi from '@/api/system/role'
|
||||||
import postApi from '@/api/system/post'
|
import postApi from '@/api/system/post'
|
||||||
|
import { ElMessage } from 'element-plus'
|
||||||
|
import { useI18n } from 'vue-i18n'
|
||||||
|
|
||||||
interface Props {
|
interface Props {
|
||||||
modelValue: boolean
|
modelValue: boolean
|
||||||
@@ -149,6 +151,7 @@
|
|||||||
})
|
})
|
||||||
|
|
||||||
const emit = defineEmits<Emits>()
|
const emit = defineEmits<Emits>()
|
||||||
|
const { t } = useI18n()
|
||||||
|
|
||||||
const formRef = ref<FormInstance>()
|
const formRef = ref<FormInstance>()
|
||||||
const optionData = reactive({
|
const optionData = reactive({
|
||||||
@@ -167,30 +170,30 @@
|
|||||||
|
|
||||||
const validatePasswordConfirm = (rule: any, value: any, callback: any) => {
|
const validatePasswordConfirm = (rule: any, value: any, callback: any) => {
|
||||||
if (value !== formData.password) {
|
if (value !== formData.password) {
|
||||||
callback(new Error('两次输入的密码不一致'))
|
callback(new Error(t('page.form.rulePasswordNotMatch')))
|
||||||
} else {
|
} else {
|
||||||
callback()
|
callback()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// 表单验证规则
|
// 表单验证规则
|
||||||
const rules: FormRules = {
|
const rules = computed<FormRules>(() => ({
|
||||||
username: [
|
username: [
|
||||||
{ required: true, message: '请输入用户名', trigger: 'blur' },
|
{ required: true, message: t('page.form.ruleUsernameRequired'), trigger: 'blur' },
|
||||||
{ min: 2, max: 20, message: '长度在 2 到 20 个字符', trigger: 'blur' }
|
{ min: 2, max: 20, message: t('page.form.ruleUsernameLength'), trigger: 'blur' }
|
||||||
],
|
],
|
||||||
password: [
|
password: [
|
||||||
{ required: true, message: '请输入密码', trigger: 'blur' },
|
{ required: true, message: t('page.form.rulePasswordRequired'), trigger: 'blur' },
|
||||||
{ min: 6, max: 20, message: '长度在 6 到 20 个字符', trigger: 'blur' }
|
{ min: 6, max: 20, message: t('page.form.rulePasswordLength'), trigger: 'blur' }
|
||||||
],
|
],
|
||||||
password_confirm: [
|
password_confirm: [
|
||||||
{ required: true, message: '请输入确认密码', trigger: 'blur' },
|
{ required: true, message: t('page.form.rulePasswordConfirmRequired'), trigger: 'blur' },
|
||||||
{ min: 6, max: 20, message: '长度在 6 到 20 个字符', trigger: 'blur' },
|
{ min: 6, max: 20, message: t('page.form.rulePasswordLength'), trigger: 'blur' },
|
||||||
{ validator: validatePasswordConfirm, trigger: 'blur' }
|
{ validator: validatePasswordConfirm, trigger: 'blur' }
|
||||||
],
|
],
|
||||||
dept_id: [{ required: true, message: '请选择部门', trigger: 'change' }],
|
dept_id: [{ required: true, message: t('page.form.ruleDeptRequired'), trigger: 'change' }],
|
||||||
role_ids: [{ required: true, message: '请选择角色', trigger: 'blur' }]
|
role_ids: [{ required: true, message: t('page.form.ruleRoleRequired'), trigger: 'blur' }]
|
||||||
}
|
}))
|
||||||
|
|
||||||
// 初始表单数据
|
// 初始表单数据
|
||||||
const initialFormData = {
|
const initialFormData = {
|
||||||
@@ -287,10 +290,10 @@
|
|||||||
await formRef.value.validate()
|
await formRef.value.validate()
|
||||||
if (props.dialogType === 'add') {
|
if (props.dialogType === 'add') {
|
||||||
await api.save(formData)
|
await api.save(formData)
|
||||||
ElMessage.success('新增成功')
|
ElMessage.success(t('page.form.addSuccess'))
|
||||||
} else {
|
} else {
|
||||||
await api.update(formData)
|
await api.update(formData)
|
||||||
ElMessage.success('修改成功')
|
ElMessage.success(t('page.form.editSuccess'))
|
||||||
}
|
}
|
||||||
emit('success')
|
emit('success')
|
||||||
handleClose()
|
handleClose()
|
||||||
|
|||||||
@@ -1,30 +1,30 @@
|
|||||||
<template>
|
<template>
|
||||||
<el-dialog
|
<el-dialog
|
||||||
v-model="visible"
|
v-model="visible"
|
||||||
:title="dialogType === 'add' ? '新增定时任务' : '编辑定时任务'"
|
:title="dialogType === 'add' ? $t('page.form.titleAdd') : $t('page.form.titleEdit')"
|
||||||
width="800px"
|
width="800px"
|
||||||
align-center
|
align-center
|
||||||
:close-on-click-modal="false"
|
:close-on-click-modal="false"
|
||||||
@close="handleClose"
|
@close="handleClose"
|
||||||
>
|
>
|
||||||
<el-form ref="formRef" :model="formData" :rules="rules" label-width="120px">
|
<el-form ref="formRef" :model="formData" :rules="rules" label-width="120px">
|
||||||
<el-form-item label="任务名称" prop="name">
|
<el-form-item :label="$t('page.form.labelName')" prop="name">
|
||||||
<el-input v-model="formData.name" placeholder="请输入任务名称" />
|
<el-input v-model="formData.name" :placeholder="$t('page.form.placeholderName')" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="任务类型" prop="type">
|
<el-form-item :label="$t('page.form.labelType')" prop="type">
|
||||||
<sa-select v-model="formData.type" dict="crontab_task_type" />
|
<sa-select v-model="formData.type" dict="crontab_task_type" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="定时规则" prop="task_style">
|
<el-form-item :label="$t('page.form.labelTaskStyle')" prop="task_style">
|
||||||
<el-space>
|
<el-space>
|
||||||
<el-select v-model="formData.task_style" :style="{ width: '100px' }">
|
<el-select v-model="formData.task_style" :style="{ width: '100px' }">
|
||||||
<el-option :value="1" label="每天" />
|
<el-option :value="1" :label="$t('page.form.taskStyleEveryDay')" />
|
||||||
<el-option :value="2" label="每小时" />
|
<el-option :value="2" :label="$t('page.form.taskStyleEveryHour')" />
|
||||||
<el-option :value="3" label="N小时" />
|
<el-option :value="3" :label="$t('page.form.taskStyleNHours')" />
|
||||||
<el-option :value="4" label="N分钟" />
|
<el-option :value="4" :label="$t('page.form.taskStyleNMinutes')" />
|
||||||
<el-option :value="5" label="N秒" />
|
<el-option :value="5" :label="$t('page.form.taskStyleNSeconds')" />
|
||||||
<el-option :value="6" label="每周" />
|
<el-option :value="6" :label="$t('page.form.taskStyleEveryWeek')" />
|
||||||
<el-option :value="7" label="每月" />
|
<el-option :value="7" :label="$t('page.form.taskStyleEveryMonth')" />
|
||||||
<el-option :value="8" label="每年" />
|
<el-option :value="8" :label="$t('page.form.taskStyleEveryYear')" />
|
||||||
</el-select>
|
</el-select>
|
||||||
<template v-if="formData.task_style == 8">
|
<template v-if="formData.task_style == 8">
|
||||||
<el-input-number
|
<el-input-number
|
||||||
@@ -35,7 +35,7 @@
|
|||||||
controls-position="right"
|
controls-position="right"
|
||||||
:style="{ width: '100px' }"
|
:style="{ width: '100px' }"
|
||||||
/>
|
/>
|
||||||
<span>月</span>
|
<span>{{ $t('page.form.unitMonth') }}</span>
|
||||||
</template>
|
</template>
|
||||||
<template v-if="formData.task_style > 6">
|
<template v-if="formData.task_style > 6">
|
||||||
<el-input-number
|
<el-input-number
|
||||||
@@ -46,20 +46,20 @@
|
|||||||
controls-position="right"
|
controls-position="right"
|
||||||
:style="{ width: '100px' }"
|
:style="{ width: '100px' }"
|
||||||
/>
|
/>
|
||||||
<span>日</span>
|
<span>{{ $t('page.form.unitDay') }}</span>
|
||||||
</template>
|
</template>
|
||||||
<el-select
|
<el-select
|
||||||
v-if="formData.task_style == 6"
|
v-if="formData.task_style == 6"
|
||||||
v-model="formData.week"
|
v-model="formData.week"
|
||||||
:style="{ width: '100px' }"
|
:style="{ width: '100px' }"
|
||||||
>
|
>
|
||||||
<el-option :value="1" label="周一" />
|
<el-option :value="1" :label="$t('page.form.weekMon')" />
|
||||||
<el-option :value="2" label="周二" />
|
<el-option :value="2" :label="$t('page.form.weekTue')" />
|
||||||
<el-option :value="3" label="周三" />
|
<el-option :value="3" :label="$t('page.form.weekWed')" />
|
||||||
<el-option :value="4" label="周四" />
|
<el-option :value="4" :label="$t('page.form.weekThu')" />
|
||||||
<el-option :value="5" label="周五" />
|
<el-option :value="5" :label="$t('page.form.weekFri')" />
|
||||||
<el-option :value="6" label="周六" />
|
<el-option :value="6" :label="$t('page.form.weekSat')" />
|
||||||
<el-option :value="0" label="周日" />
|
<el-option :value="0" :label="$t('page.form.weekSun')" />
|
||||||
</el-select>
|
</el-select>
|
||||||
<template v-if="[1, 3, 6, 7, 8].includes(formData.task_style)">
|
<template v-if="[1, 3, 6, 7, 8].includes(formData.task_style)">
|
||||||
<el-input-number
|
<el-input-number
|
||||||
@@ -70,7 +70,7 @@
|
|||||||
controls-position="right"
|
controls-position="right"
|
||||||
:style="{ width: '100px' }"
|
:style="{ width: '100px' }"
|
||||||
/>
|
/>
|
||||||
<span>时</span>
|
<span>{{ $t('page.form.unitHour') }}</span>
|
||||||
</template>
|
</template>
|
||||||
<template v-if="formData.task_style != 5">
|
<template v-if="formData.task_style != 5">
|
||||||
<el-input-number
|
<el-input-number
|
||||||
@@ -81,7 +81,7 @@
|
|||||||
controls-position="right"
|
controls-position="right"
|
||||||
:style="{ width: '100px' }"
|
:style="{ width: '100px' }"
|
||||||
/>
|
/>
|
||||||
<span>分</span>
|
<span>{{ $t('page.form.unitMinute') }}</span>
|
||||||
</template>
|
</template>
|
||||||
<template v-if="formData.task_style == 5">
|
<template v-if="formData.task_style == 5">
|
||||||
<el-input-number
|
<el-input-number
|
||||||
@@ -92,36 +92,41 @@
|
|||||||
controls-position="right"
|
controls-position="right"
|
||||||
:style="{ width: '100px' }"
|
:style="{ width: '100px' }"
|
||||||
/>
|
/>
|
||||||
<span>秒</span>
|
<span>{{ $t('page.form.unitSecond') }}</span>
|
||||||
</template>
|
</template>
|
||||||
</el-space>
|
</el-space>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="调用目标" prop="target">
|
<el-form-item :label="$t('page.form.labelTarget')" prop="target">
|
||||||
<el-input
|
<el-input
|
||||||
v-model="formData.target"
|
v-model="formData.target"
|
||||||
type="textarea"
|
type="textarea"
|
||||||
:rows="3"
|
:rows="3"
|
||||||
placeholder="请输入调用目标"
|
:placeholder="$t('page.form.placeholderTarget')"
|
||||||
/>
|
/>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="任务参数" prop="params">
|
<el-form-item :label="$t('page.form.labelParams')" prop="params">
|
||||||
<el-input
|
<el-input
|
||||||
v-model="formData.parameter"
|
v-model="formData.parameter"
|
||||||
type="textarea"
|
type="textarea"
|
||||||
:rows="3"
|
:rows="3"
|
||||||
placeholder="请输入任务参数"
|
:placeholder="$t('page.form.placeholderParams')"
|
||||||
/>
|
/>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="状态" prop="status">
|
<el-form-item :label="$t('page.form.labelStatus')" prop="status">
|
||||||
<sa-radio v-model="formData.status" dict="data_status" />
|
<sa-radio v-model="formData.status" dict="data_status" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="备注" prop="remark">
|
<el-form-item :label="$t('page.form.labelRemark')" prop="remark">
|
||||||
<el-input v-model="formData.remark" type="textarea" :rows="2" placeholder="请输入备注" />
|
<el-input
|
||||||
|
v-model="formData.remark"
|
||||||
|
type="textarea"
|
||||||
|
:rows="2"
|
||||||
|
:placeholder="$t('page.form.placeholderRemark')"
|
||||||
|
/>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-form>
|
</el-form>
|
||||||
<template #footer>
|
<template #footer>
|
||||||
<el-button @click="handleClose">取消</el-button>
|
<el-button @click="handleClose">{{ $t('common.cancel') }}</el-button>
|
||||||
<el-button type="primary" @click="handleSubmit">提交</el-button>
|
<el-button type="primary" @click="handleSubmit">{{ $t('table.form.submit') }}</el-button>
|
||||||
</template>
|
</template>
|
||||||
</el-dialog>
|
</el-dialog>
|
||||||
</template>
|
</template>
|
||||||
@@ -130,6 +135,7 @@
|
|||||||
import api from '@/api/tool/crontab'
|
import api from '@/api/tool/crontab'
|
||||||
import { ElMessage } from 'element-plus'
|
import { ElMessage } from 'element-plus'
|
||||||
import type { FormInstance, FormRules } from 'element-plus'
|
import type { FormInstance, FormRules } from 'element-plus'
|
||||||
|
import { useI18n } from 'vue-i18n'
|
||||||
|
|
||||||
interface Props {
|
interface Props {
|
||||||
modelValue: boolean
|
modelValue: boolean
|
||||||
@@ -149,6 +155,7 @@
|
|||||||
})
|
})
|
||||||
|
|
||||||
const emit = defineEmits<Emits>()
|
const emit = defineEmits<Emits>()
|
||||||
|
const { t } = useI18n()
|
||||||
|
|
||||||
const formRef = ref<FormInstance>()
|
const formRef = ref<FormInstance>()
|
||||||
|
|
||||||
@@ -163,12 +170,12 @@
|
|||||||
/**
|
/**
|
||||||
* 表单验证规则
|
* 表单验证规则
|
||||||
*/
|
*/
|
||||||
const rules = reactive<FormRules>({
|
const rules = computed<FormRules>(() => ({
|
||||||
name: [{ required: true, message: '任务名称不能为空', trigger: 'blur' }],
|
name: [{ required: true, message: t('page.form.ruleNameRequired'), trigger: 'blur' }],
|
||||||
type: [{ required: true, message: '任务类型不能为空', trigger: 'blur' }],
|
type: [{ required: true, message: t('page.form.ruleTypeRequired'), trigger: 'blur' }],
|
||||||
task_style: [{ required: true, message: '定时规则不能为空', trigger: 'blur' }],
|
task_style: [{ required: true, message: t('page.form.ruleTaskStyleRequired'), trigger: 'blur' }],
|
||||||
target: [{ required: true, message: '调用目标不能为空', trigger: 'blur' }]
|
target: [{ required: true, message: t('page.form.ruleTargetRequired'), trigger: 'blur' }]
|
||||||
})
|
}))
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 初始数据
|
* 初始数据
|
||||||
@@ -264,10 +271,10 @@
|
|||||||
await formRef.value.validate()
|
await formRef.value.validate()
|
||||||
if (props.dialogType === 'add') {
|
if (props.dialogType === 'add') {
|
||||||
await api.save(formData)
|
await api.save(formData)
|
||||||
ElMessage.success('新增成功')
|
ElMessage.success(t('page.form.addSuccess'))
|
||||||
} else {
|
} else {
|
||||||
await api.update(formData)
|
await api.update(formData)
|
||||||
ElMessage.success('修改成功')
|
ElMessage.success(t('page.form.editSuccess'))
|
||||||
}
|
}
|
||||||
emit('success')
|
emit('success')
|
||||||
handleClose()
|
handleClose()
|
||||||
|
|||||||
Reference in New Issue
Block a user