Merge pull request #493 from xixingya/feature/bug-fix

ratio must gte 0
This commit is contained in:
Calcium-Ion
2024-11-19 18:34:24 +08:00
committed by GitHub
3 changed files with 32 additions and 1 deletions

View File

@@ -2,6 +2,7 @@ package common
import ( import (
"encoding/json" "encoding/json"
"errors"
) )
var GroupRatio = map[string]float64{ var GroupRatio = map[string]float64{
@@ -31,3 +32,17 @@ func GetGroupRatio(name string) float64 {
} }
return ratio return ratio
} }
func CheckGroupRatio(jsonStr string) error {
checkGroupRatio := make(map[string]float64)
err := json.Unmarshal([]byte(jsonStr), &checkGroupRatio)
if err != nil {
return err
}
for name, ratio := range checkGroupRatio {
if ratio < 0 {
return errors.New("group ratio must be not less than 0: " + name)
}
}
return nil
}

View File

@@ -82,6 +82,15 @@ func UpdateOption(c *gin.Context) {
}) })
return return
} }
case "GroupRatio":
err = common.CheckGroupRatio(option.Value)
if err != nil {
c.JSON(http.StatusOK, gin.H{
"success": false,
"message": err.Error(),
})
return
}
} }
err = model.UpdateOption(option.Key, option.Value) err = model.UpdateOption(option.Key, option.Value)
if err != nil { if err != nil {

View File

@@ -50,10 +50,17 @@ export default function SettingsMagnification(props) {
if (res.includes(undefined)) if (res.includes(undefined))
return showError('部分保存失败,请重试'); return showError('部分保存失败,请重试');
} }
for (let i = 0; i < res.length; i++) {
if (!res[i].data.success) {
return showError(res[i].data.message)
}
}
showSuccess('保存成功'); showSuccess('保存成功');
props.refresh(); props.refresh();
}) })
.catch(() => { .catch(error => {
console.error('Unexpected error in Promise.all:', error);
showError('保存失败,请重试'); showError('保存失败,请重试');
}) })
.finally(() => { .finally(() => {