This commit is contained in:
孟帅 2024-11-27 18:44:19 +08:00
parent 6254505a7d
commit 2fd3854aeb
69 changed files with 656 additions and 245 deletions

View File

@ -6,19 +6,19 @@
</p> </p>
<p align="center"> <p align="center">
<a href="https://goframe.org/pages/viewpage.action?pageId=1114119" target="_blank"> <a href="https://goframe.org/pages/viewpage.action?pageId=1114119" target="_blank">
<img src="https://img.shields.io/badge/goframe-2.7-green" alt="goframe"> <img src="https://img.shields.io/badge/goframe-2.8-green" alt="goframe">
</a> </a>
<a href="https://v3.vuejs.org/" target="_blank"> <a href="https://v3.vuejs.org/" target="_blank">
<img src="https://img.shields.io/badge/vue.js-vue3.4-green" alt="vue"> <img src="https://img.shields.io/badge/vue.js-vue3.4-green" alt="vue">
</a> </a>
<a href="https://www.naiveui.com" target="_blank"> <a href="https://www.naiveui.com" target="_blank">
<img src="https://img.shields.io/badge/naiveui-%3E2.38.0-blue" alt="naiveui"> <img src="https://img.shields.io/badge/naiveui-%3E2.39.0-blue" alt="naiveui">
</a> </a>
<a href="https://www.tslang.cn/" target="_blank"> <a href="https://www.tslang.cn/" target="_blank">
<img src="https://img.shields.io/badge/typescript-%3E4.0.0-blue" alt="typescript"> <img src="https://img.shields.io/badge/typescript-%3E4.0.0-blue" alt="typescript">
</a> </a>
<a href="https://vitejs.dev/" target="_blank"> <a href="https://vitejs.dev/" target="_blank">
<img src="https://img.shields.io/badge/vite-%3E4.0.0-yellow" alt="vite"> <img src="https://img.shields.io/badge/vite-%3E5.4.2-yellow" alt="vite">
</a> </a>
<a href="https://github.com/bufanyun/hotgo/blob/v2.0/LICENSE" target="_blank"> <a href="https://github.com/bufanyun/hotgo/blob/v2.0/LICENSE" target="_blank">
<img src="https://img.shields.io/badge/license-MIT-success" alt="license"> <img src="https://img.shields.io/badge/license-MIT-success" alt="license">

View File

@ -11,6 +11,15 @@
> 如果升级(覆盖)代码后打开会出现 sql 报错, 请检查更新的数据库格式或自行调整 > 如果升级(覆盖)代码后打开会出现 sql 报错, 请检查更新的数据库格式或自行调整
### v2.15.11
updated 2024.11.27
- 增加:增加配置管理子页面选项参数记忆
- 修复:修复定时任务中日志配置的读取并发读问题
- 优化gf版本升级到v2.8.2
- 优化:优化数据卡片展示
### v2.15.7 ### v2.15.7
updated 2024.7.21 updated 2024.7.21

View File

@ -3,7 +3,7 @@
// @Copyright Copyright (c) 2024 HotGo CLI // @Copyright Copyright (c) 2024 HotGo CLI
// @Author Ms <133814250@qq.com> // @Author Ms <133814250@qq.com>
// @License https://github.com/bufanyun/hotgo/blob/master/LICENSE // @License https://github.com/bufanyun/hotgo/blob/master/LICENSE
// @AutoGenerate Version 2.15.1 // @AutoGenerate Version 2.15.7
package testcategory package testcategory
import ( import (
@ -66,4 +66,4 @@ type StatusReq struct {
sysin.TestCategoryStatusInp sysin.TestCategoryStatusInp
} }
type StatusRes struct{} type StatusRes struct{}

View File

@ -14,10 +14,10 @@ require (
github.com/forgoer/openssl v1.6.0 github.com/forgoer/openssl v1.6.0
github.com/go-pay/crypto v0.0.1 github.com/go-pay/crypto v0.0.1
github.com/go-pay/gopay v1.5.104 github.com/go-pay/gopay v1.5.104
github.com/gogf/gf/contrib/drivers/mysql/v2 v2.7.2 github.com/gogf/gf/contrib/drivers/mysql/v2 v2.8.1
github.com/gogf/gf/contrib/nosql/redis/v2 v2.7.2 github.com/gogf/gf/contrib/nosql/redis/v2 v2.8.1
github.com/gogf/gf/contrib/trace/jaeger/v2 v2.7.2 github.com/gogf/gf/contrib/trace/jaeger/v2 v2.7.4
github.com/gogf/gf/v2 v2.7.2 github.com/gogf/gf/v2 v2.8.1
github.com/gogf/selfupdate v0.0.0-20231215043001-5c48c528462f github.com/gogf/selfupdate v0.0.0-20231215043001-5c48c528462f
github.com/golang-jwt/jwt/v5 v5.2.1 github.com/golang-jwt/jwt/v5 v5.2.1
github.com/gorilla/websocket v1.5.3 github.com/gorilla/websocket v1.5.3
@ -33,9 +33,9 @@ require (
github.com/tencentyun/cos-go-sdk-v5 v0.7.54 github.com/tencentyun/cos-go-sdk-v5 v0.7.54
github.com/ufilesdk-dev/ufile-gosdk v1.0.4 github.com/ufilesdk-dev/ufile-gosdk v1.0.4
github.com/xuri/excelize/v2 v2.6.0 github.com/xuri/excelize/v2 v2.6.0
go.opentelemetry.io/otel v1.29.0 go.opentelemetry.io/otel v1.32.0
golang.org/x/mod v0.20.0 golang.org/x/mod v0.20.0
golang.org/x/net v0.28.0 golang.org/x/net v0.31.0
golang.org/x/tools v0.24.0 golang.org/x/tools v0.24.0
gopkg.in/yaml.v3 v3.0.1 gopkg.in/yaml.v3 v3.0.1
) )
@ -64,9 +64,9 @@ require (
github.com/eapache/go-xerial-snappy v0.0.0-20230731223053-c322873962e3 // indirect github.com/eapache/go-xerial-snappy v0.0.0-20230731223053-c322873962e3 // indirect
github.com/eapache/queue v1.1.0 // indirect github.com/eapache/queue v1.1.0 // indirect
github.com/emirpasic/gods v1.18.1 // indirect github.com/emirpasic/gods v1.18.1 // indirect
github.com/fatih/color v1.17.0 // indirect github.com/fatih/color v1.18.0 // indirect
github.com/fatih/structs v1.1.0 // indirect github.com/fatih/structs v1.1.0 // indirect
github.com/fsnotify/fsnotify v1.7.0 // indirect github.com/fsnotify/fsnotify v1.8.0 // indirect
github.com/go-ini/ini v1.67.0 // indirect github.com/go-ini/ini v1.67.0 // indirect
github.com/go-logr/logr v1.4.2 // indirect github.com/go-logr/logr v1.4.2 // indirect
github.com/go-logr/stdr v1.2.2 // indirect github.com/go-logr/stdr v1.2.2 // indirect
@ -114,7 +114,7 @@ require (
github.com/pkg/errors v0.9.1 // indirect github.com/pkg/errors v0.9.1 // indirect
github.com/power-devops/perfstat v0.0.0-20240221224432-82ca36839d55 // indirect github.com/power-devops/perfstat v0.0.0-20240221224432-82ca36839d55 // indirect
github.com/rcrowley/go-metrics v0.0.0-20201227073835-cf1acfcdf475 // indirect github.com/rcrowley/go-metrics v0.0.0-20201227073835-cf1acfcdf475 // indirect
github.com/redis/go-redis/v9 v9.6.1 // indirect github.com/redis/go-redis/v9 v9.7.0 // indirect
github.com/richardlehane/mscfb v1.0.4 // indirect github.com/richardlehane/mscfb v1.0.4 // indirect
github.com/richardlehane/msoleps v1.0.3 // indirect github.com/richardlehane/msoleps v1.0.3 // indirect
github.com/rivo/uniseg v0.4.7 // indirect github.com/rivo/uniseg v0.4.7 // indirect
@ -132,15 +132,15 @@ require (
github.com/xuri/nfp v0.0.0-20240318013403-ab9948c2c4a7 // indirect github.com/xuri/nfp v0.0.0-20240318013403-ab9948c2c4a7 // indirect
github.com/yusufpapurcu/wmi v1.2.4 // indirect github.com/yusufpapurcu/wmi v1.2.4 // indirect
go.opentelemetry.io/otel/exporters/jaeger v1.17.0 // indirect go.opentelemetry.io/otel/exporters/jaeger v1.17.0 // indirect
go.opentelemetry.io/otel/metric v1.29.0 // indirect go.opentelemetry.io/otel/metric v1.32.0 // indirect
go.opentelemetry.io/otel/sdk v1.29.0 // indirect go.opentelemetry.io/otel/sdk v1.32.0 // indirect
go.opentelemetry.io/otel/trace v1.29.0 // indirect go.opentelemetry.io/otel/trace v1.32.0 // indirect
go.uber.org/atomic v1.11.0 // indirect go.uber.org/atomic v1.11.0 // indirect
golang.org/x/crypto v0.26.0 // indirect golang.org/x/crypto v0.29.0 // indirect
golang.org/x/image v0.19.0 // indirect golang.org/x/image v0.19.0 // indirect
golang.org/x/sync v0.8.0 // indirect golang.org/x/sync v0.9.0 // indirect
golang.org/x/sys v0.24.0 // indirect golang.org/x/sys v0.27.0 // indirect
golang.org/x/text v0.17.0 // indirect golang.org/x/text v0.20.0 // indirect
golang.org/x/time v0.6.0 // indirect golang.org/x/time v0.6.0 // indirect
gopkg.in/ini.v1 v1.67.0 // indirect gopkg.in/ini.v1 v1.67.0 // indirect
gopkg.in/natefinch/lumberjack.v2 v2.2.1 // indirect gopkg.in/natefinch/lumberjack.v2 v2.2.1 // indirect

View File

@ -110,8 +110,8 @@ github.com/emirpasic/gods v1.18.1/go.mod h1:8tpGGwCnJ5H4r6BWwaV6OrWmMoPhUl5jm/FM
github.com/envoyproxy/go-control-plane v0.9.0/go.mod h1:YTl/9mNaCwkRvm6d1a2C3ymFceY/DCBVvsKhRF0iEA4= github.com/envoyproxy/go-control-plane v0.9.0/go.mod h1:YTl/9mNaCwkRvm6d1a2C3ymFceY/DCBVvsKhRF0iEA4=
github.com/envoyproxy/go-control-plane v0.9.4/go.mod h1:6rpuAdCZL397s3pYoYcLgu1mIlRU8Am5FuJP05cCM98= github.com/envoyproxy/go-control-plane v0.9.4/go.mod h1:6rpuAdCZL397s3pYoYcLgu1mIlRU8Am5FuJP05cCM98=
github.com/envoyproxy/protoc-gen-validate v0.1.0/go.mod h1:iSmxcyjqTsJpI2R4NaDN7+kN2VEUnK/pcBlmesArF7c= github.com/envoyproxy/protoc-gen-validate v0.1.0/go.mod h1:iSmxcyjqTsJpI2R4NaDN7+kN2VEUnK/pcBlmesArF7c=
github.com/fatih/color v1.17.0 h1:GlRw1BRJxkpqUCBKzKOw098ed57fEsKeNjpTe3cSjK4= github.com/fatih/color v1.18.0 h1:S8gINlzdQ840/4pfAwic/ZE0djQEH3wM94VfqLTZcOM=
github.com/fatih/color v1.17.0/go.mod h1:YZ7TlrGPkiz6ku9fK3TLD/pl3CpsiFyu8N92HLgmosI= github.com/fatih/color v1.18.0/go.mod h1:4FelSpRwEGDpQ12mAdzqdOukCy4u8WUtOY6lkT/6HfU=
github.com/fatih/structs v1.1.0 h1:Q7juDM0QtcnhCpeyLGQKyg4TOIghuNXrkL32pHAUMxo= github.com/fatih/structs v1.1.0 h1:Q7juDM0QtcnhCpeyLGQKyg4TOIghuNXrkL32pHAUMxo=
github.com/fatih/structs v1.1.0/go.mod h1:9NiDSp5zOcgEDl+j00MP/WkGVPOlPRLejGD8Ga6PJ7M= github.com/fatih/structs v1.1.0/go.mod h1:9NiDSp5zOcgEDl+j00MP/WkGVPOlPRLejGD8Ga6PJ7M=
github.com/forgoer/openssl v1.6.0 h1:IueL+UfH0hKo99xFPojHLlO3QzRBQqFY+Cht0WwtOC0= github.com/forgoer/openssl v1.6.0 h1:IueL+UfH0hKo99xFPojHLlO3QzRBQqFY+Cht0WwtOC0=
@ -122,8 +122,8 @@ github.com/frankban/quicktest v1.14.6 h1:7Xjx+VpznH+oBnejlPUj8oUpdxnVs4f8XU8WnHk
github.com/frankban/quicktest v1.14.6/go.mod h1:4ptaffx2x8+WTWXmUCuVU6aPUX1/Mz7zb5vbUoiM6w0= github.com/frankban/quicktest v1.14.6/go.mod h1:4ptaffx2x8+WTWXmUCuVU6aPUX1/Mz7zb5vbUoiM6w0=
github.com/fsnotify/fsnotify v1.4.7/go.mod h1:jwhsz4b93w/PPRr/qN1Yymfu8t87LnFCMoQvtojpjFo= github.com/fsnotify/fsnotify v1.4.7/go.mod h1:jwhsz4b93w/PPRr/qN1Yymfu8t87LnFCMoQvtojpjFo=
github.com/fsnotify/fsnotify v1.4.9/go.mod h1:znqG4EE+3YCdAaPaxE2ZRY/06pZUdp0tY4IgpuI1SZQ= github.com/fsnotify/fsnotify v1.4.9/go.mod h1:znqG4EE+3YCdAaPaxE2ZRY/06pZUdp0tY4IgpuI1SZQ=
github.com/fsnotify/fsnotify v1.7.0 h1:8JEhPFa5W2WU7YfeZzPNqzMP6Lwt7L2715Ggo0nosvA= github.com/fsnotify/fsnotify v1.8.0 h1:dAwr6QBTBZIkG8roQaJjGof0pp0EeF+tNV7YBP3F/8M=
github.com/fsnotify/fsnotify v1.7.0/go.mod h1:40Bi/Hjc2AVfZrqy+aj+yEI+/bRxZnMJyTJwOpGvigM= github.com/fsnotify/fsnotify v1.8.0/go.mod h1:8jBTzvmWwFyi3Pb8djgCCO5IBqzKJ/Jwo8TRcHyHii0=
github.com/go-ini/ini v1.67.0 h1:z6ZrTEZqSWOTyH2FlglNbNgARyHG8oLW9gMELqKr06A= github.com/go-ini/ini v1.67.0 h1:z6ZrTEZqSWOTyH2FlglNbNgARyHG8oLW9gMELqKr06A=
github.com/go-ini/ini v1.67.0/go.mod h1:ByCAeIL28uOIIG0E3PJtZPDL8WnHpFKFOtgjp+3Ies8= github.com/go-ini/ini v1.67.0/go.mod h1:ByCAeIL28uOIIG0E3PJtZPDL8WnHpFKFOtgjp+3Ies8=
github.com/go-logr/logr v1.2.2/go.mod h1:jdQByPbusPIv2/zmleS9BjJVeZ6kBagPoEUsqbVz/1A= github.com/go-logr/logr v1.2.2/go.mod h1:jdQByPbusPIv2/zmleS9BjJVeZ6kBagPoEUsqbVz/1A=
@ -162,14 +162,14 @@ github.com/goccy/go-json v0.10.3/go.mod h1:oq7eo15ShAhp70Anwd5lgX2pLfOS3QCiwU/PU
github.com/gofrs/flock v0.8.1/go.mod h1:F1TvTiK9OcQqauNUHlbJvyl9Qa1QvF/gOUDKA14jxHU= github.com/gofrs/flock v0.8.1/go.mod h1:F1TvTiK9OcQqauNUHlbJvyl9Qa1QvF/gOUDKA14jxHU=
github.com/gofrs/flock v0.12.1 h1:MTLVXXHf8ekldpJk3AKicLij9MdwOWkZ+a/jHHZby9E= github.com/gofrs/flock v0.12.1 h1:MTLVXXHf8ekldpJk3AKicLij9MdwOWkZ+a/jHHZby9E=
github.com/gofrs/flock v0.12.1/go.mod h1:9zxTsyu5xtJ9DK+1tFZyibEV7y3uwDxPPfbxeeHCoD0= github.com/gofrs/flock v0.12.1/go.mod h1:9zxTsyu5xtJ9DK+1tFZyibEV7y3uwDxPPfbxeeHCoD0=
github.com/gogf/gf/contrib/drivers/mysql/v2 v2.7.2 h1:GpE2JuHVoNJD4lNP1omC1+TKXNCSvXr5oil1bNULYd0= github.com/gogf/gf/contrib/drivers/mysql/v2 v2.8.1 h1:jbaPawkb8qmaYzrmBDbTa8Zkhzacq1RBOZw+qRJExI4=
github.com/gogf/gf/contrib/drivers/mysql/v2 v2.7.2/go.mod h1:0h3UmNAmA8hnjvTyozZelSWWxiAjGDQttzZqMhkCkJo= github.com/gogf/gf/contrib/drivers/mysql/v2 v2.8.1/go.mod h1:s2aI1fV9AvKi4NtMpv3pV0EHtazkvfUNVQmzapr7UJQ=
github.com/gogf/gf/contrib/nosql/redis/v2 v2.7.2 h1:V1hdGnyjU9kT0I3DDDFDl6Ll8yC6aAIFJa/lMQwB8V4= github.com/gogf/gf/contrib/nosql/redis/v2 v2.8.1 h1:1vPFyN0GLv24JD3WGhvKzXvKG+fmuixDTawbtfzCzRQ=
github.com/gogf/gf/contrib/nosql/redis/v2 v2.7.2/go.mod h1:XzkPv3G8TdKczqoB/ydR3bxvBRdQLQNCOCEgxso/c3o= github.com/gogf/gf/contrib/nosql/redis/v2 v2.8.1/go.mod h1:IWyGxzplp06tRc6Ah/eCLuBntnKSw9sn1maH0vzPPtw=
github.com/gogf/gf/contrib/trace/jaeger/v2 v2.7.2 h1:YKMJMhJJjbaPhgjpH9veZpn80mwkPgPAIatSvUFTt38= github.com/gogf/gf/contrib/trace/jaeger/v2 v2.7.4 h1:JnUjXb7C9vmwcZFwXqnxi9H4/I0rir9LmRryIX7xNds=
github.com/gogf/gf/contrib/trace/jaeger/v2 v2.7.2/go.mod h1:kzxWAaY5Livk2SNPNrs9PJJvxK8A7uVwd8UGwjdMEfU= github.com/gogf/gf/contrib/trace/jaeger/v2 v2.7.4/go.mod h1:A3NhV8u45twLq5VdqObhYNhT4szLFLCROw4LzHM+lYg=
github.com/gogf/gf/v2 v2.7.2 h1:uZDfyblasI12lZUtFd1mfxsIr8b14cd/F88DJUTCSDM= github.com/gogf/gf/v2 v2.8.1 h1:1oVQg3G5OgCats4qWFTH3pHLe92nfUQeUDta05tUs1g=
github.com/gogf/gf/v2 v2.7.2/go.mod h1:EBXneAg/wes86rfeh68XC0a2JBNQylmT7Sp6/8Axk88= github.com/gogf/gf/v2 v2.8.1/go.mod h1:6iYuZZ+A0ZcH8+4MDS/P0SvTPCvKzRvyAsY1kbkJYJc=
github.com/gogf/selfupdate v0.0.0-20231215043001-5c48c528462f h1:7xfXR/BhG3JDqO1s45n65Oyx9t4E/UqDOXep6jXdLCM= github.com/gogf/selfupdate v0.0.0-20231215043001-5c48c528462f h1:7xfXR/BhG3JDqO1s45n65Oyx9t4E/UqDOXep6jXdLCM=
github.com/gogf/selfupdate v0.0.0-20231215043001-5c48c528462f/go.mod h1:HnYoio6S7VaFJdryKcD/r9HgX+4QzYfr00XiXUo/xz0= github.com/gogf/selfupdate v0.0.0-20231215043001-5c48c528462f/go.mod h1:HnYoio6S7VaFJdryKcD/r9HgX+4QzYfr00XiXUo/xz0=
github.com/golang-jwt/jwt/v5 v5.2.1 h1:OuVbFODueb089Lh128TAcimifWaLhJwVflnrgM17wHk= github.com/golang-jwt/jwt/v5 v5.2.1 h1:OuVbFODueb089Lh128TAcimifWaLhJwVflnrgM17wHk=
@ -344,8 +344,8 @@ github.com/qiniu/go-sdk/v7 v7.21.1/go.mod h1:8EM2awITynlem2VML2dXGHkMYP2UyECsGLO
github.com/qiniu/x v1.10.5/go.mod h1:03Ni9tj+N2h2aKnAz+6N0Xfl8FwMEDRC2PAlxekASDs= github.com/qiniu/x v1.10.5/go.mod h1:03Ni9tj+N2h2aKnAz+6N0Xfl8FwMEDRC2PAlxekASDs=
github.com/rcrowley/go-metrics v0.0.0-20201227073835-cf1acfcdf475 h1:N/ElC8H3+5XpJzTSTfLsJV/mx9Q9g7kxmchpfZyxgzM= github.com/rcrowley/go-metrics v0.0.0-20201227073835-cf1acfcdf475 h1:N/ElC8H3+5XpJzTSTfLsJV/mx9Q9g7kxmchpfZyxgzM=
github.com/rcrowley/go-metrics v0.0.0-20201227073835-cf1acfcdf475/go.mod h1:bCqnVzQkZxMG4s8nGwiZ5l3QUCyqpo9Y+/ZMZ9VjZe4= github.com/rcrowley/go-metrics v0.0.0-20201227073835-cf1acfcdf475/go.mod h1:bCqnVzQkZxMG4s8nGwiZ5l3QUCyqpo9Y+/ZMZ9VjZe4=
github.com/redis/go-redis/v9 v9.6.1 h1:HHDteefn6ZkTtY5fGUE8tj8uy85AHk6zP7CpzIAM0y4= github.com/redis/go-redis/v9 v9.7.0 h1:HhLSs+B6O021gwzl+locl0zEDnyNkxMtf/Z3NNBMa9E=
github.com/redis/go-redis/v9 v9.6.1/go.mod h1:0C0c6ycQsdpVNQpxb1njEQIqkx5UcsM8FJCQLgE9+RA= github.com/redis/go-redis/v9 v9.7.0/go.mod h1:f6zhXITC7JUJIlPEiBOTXxJgPLdZcA93GewI7inzyWw=
github.com/richardlehane/mscfb v1.0.4 h1:WULscsljNPConisD5hR0+OyZjwK46Pfyr6mPu5ZawpM= github.com/richardlehane/mscfb v1.0.4 h1:WULscsljNPConisD5hR0+OyZjwK46Pfyr6mPu5ZawpM=
github.com/richardlehane/mscfb v1.0.4/go.mod h1:YzVpcZg9czvAuhk9T+a3avCpcFPMUWm7gK3DypaEsUk= github.com/richardlehane/mscfb v1.0.4/go.mod h1:YzVpcZg9czvAuhk9T+a3avCpcFPMUWm7gK3DypaEsUk=
github.com/richardlehane/msoleps v1.0.1/go.mod h1:BWev5JBpU9Ko2WAgmZEuiz4/u3ZYTKbjLycmwiWUfWg= github.com/richardlehane/msoleps v1.0.1/go.mod h1:BWev5JBpU9Ko2WAgmZEuiz4/u3ZYTKbjLycmwiWUfWg=
@ -440,16 +440,16 @@ github.com/yuin/gopher-lua v0.0.0-20220504180219-658193537a64 h1:5mLPGnFdSsevFRF
github.com/yuin/gopher-lua v0.0.0-20220504180219-658193537a64/go.mod h1:GBR0iDaNXjAgGg9zfCvksxSRnQx76gclCIb7kdAd1Pw= github.com/yuin/gopher-lua v0.0.0-20220504180219-658193537a64/go.mod h1:GBR0iDaNXjAgGg9zfCvksxSRnQx76gclCIb7kdAd1Pw=
github.com/yusufpapurcu/wmi v1.2.4 h1:zFUKzehAFReQwLys1b/iSMl+JQGSCSjtVqQn9bBrPo0= github.com/yusufpapurcu/wmi v1.2.4 h1:zFUKzehAFReQwLys1b/iSMl+JQGSCSjtVqQn9bBrPo0=
github.com/yusufpapurcu/wmi v1.2.4/go.mod h1:SBZ9tNy3G9/m5Oi98Zks0QjeHVDvuK0qfxQmPyzfmi0= github.com/yusufpapurcu/wmi v1.2.4/go.mod h1:SBZ9tNy3G9/m5Oi98Zks0QjeHVDvuK0qfxQmPyzfmi0=
go.opentelemetry.io/otel v1.29.0 h1:PdomN/Al4q/lN6iBJEN3AwPvUiHPMlt93c8bqTG5Llw= go.opentelemetry.io/otel v1.32.0 h1:WnBN+Xjcteh0zdk01SVqV55d/m62NJLJdIyb4y/WO5U=
go.opentelemetry.io/otel v1.29.0/go.mod h1:N/WtXPs1CNCUEx+Agz5uouwCba+i+bJGFicT8SR4NP8= go.opentelemetry.io/otel v1.32.0/go.mod h1:00DCVSB0RQcnzlwyTfqtxSm+DRr9hpYrHjNGiBHVQIg=
go.opentelemetry.io/otel/exporters/jaeger v1.17.0 h1:D7UpUy2Xc2wsi1Ras6V40q806WM07rqoCWzXu7Sqy+4= go.opentelemetry.io/otel/exporters/jaeger v1.17.0 h1:D7UpUy2Xc2wsi1Ras6V40q806WM07rqoCWzXu7Sqy+4=
go.opentelemetry.io/otel/exporters/jaeger v1.17.0/go.mod h1:nPCqOnEH9rNLKqH/+rrUjiMzHJdV1BlpKcTwRTyKkKI= go.opentelemetry.io/otel/exporters/jaeger v1.17.0/go.mod h1:nPCqOnEH9rNLKqH/+rrUjiMzHJdV1BlpKcTwRTyKkKI=
go.opentelemetry.io/otel/metric v1.29.0 h1:vPf/HFWTNkPu1aYeIsc98l4ktOQaL6LeSoeV2g+8YLc= go.opentelemetry.io/otel/metric v1.32.0 h1:xV2umtmNcThh2/a/aCP+h64Xx5wsj8qqnkYZktzNa0M=
go.opentelemetry.io/otel/metric v1.29.0/go.mod h1:auu/QWieFVWx+DmQOUMgj0F8LHWdgalxXqvp7BII/W8= go.opentelemetry.io/otel/metric v1.32.0/go.mod h1:jH7CIbbK6SH2V2wE16W05BHCtIDzauciCRLoc/SyMv8=
go.opentelemetry.io/otel/sdk v1.29.0 h1:vkqKjk7gwhS8VaWb0POZKmIEDimRCMsopNYnriHyryo= go.opentelemetry.io/otel/sdk v1.32.0 h1:RNxepc9vK59A8XsgZQouW8ue8Gkb4jpWtJm9ge5lEG4=
go.opentelemetry.io/otel/sdk v1.29.0/go.mod h1:pM8Dx5WKnvxLCb+8lG1PRNIDxu9g9b9g59Qr7hfAAok= go.opentelemetry.io/otel/sdk v1.32.0/go.mod h1:LqgegDBjKMmb2GC6/PrTnteJG39I8/vJCAP9LlJXEjU=
go.opentelemetry.io/otel/trace v1.29.0 h1:J/8ZNK4XgR7a21DZUAsbF8pZ5Jcw1VhACmnYt39JTi4= go.opentelemetry.io/otel/trace v1.32.0 h1:WIC9mYrXf8TmY/EXuULKc8hR17vE+Hjv2cssQDe03fM=
go.opentelemetry.io/otel/trace v1.29.0/go.mod h1:eHl3w0sp3paPkYstJOmAimxhiFXPg+MMTlEh3nsQgWQ= go.opentelemetry.io/otel/trace v1.32.0/go.mod h1:+i4rkvCraA+tG6AzwloGaCtkx53Fa+L+V8e9a7YvhT8=
go.uber.org/atomic v1.5.1/go.mod h1:sABNBOSYdrvTF6hTgEIbc7YasKWGhgEQZyfxyTvoXHQ= go.uber.org/atomic v1.5.1/go.mod h1:sABNBOSYdrvTF6hTgEIbc7YasKWGhgEQZyfxyTvoXHQ=
go.uber.org/atomic v1.11.0 h1:ZvwS0R+56ePWxUNi+Atn9dWONBPp/AUETXlHW0DxSjE= go.uber.org/atomic v1.11.0 h1:ZvwS0R+56ePWxUNi+Atn9dWONBPp/AUETXlHW0DxSjE=
go.uber.org/atomic v1.11.0/go.mod h1:LUxbIzbOniOlMKjJjyPfpl4v+PKK2cNJn91OQbhoJI0= go.uber.org/atomic v1.11.0/go.mod h1:LUxbIzbOniOlMKjJjyPfpl4v+PKK2cNJn91OQbhoJI0=
@ -468,8 +468,8 @@ golang.org/x/crypto v0.1.0/go.mod h1:RecgLatLF4+eUMCP1PoPZQb+cVrJcOPbHkTkbkB9sbw
golang.org/x/crypto v0.6.0/go.mod h1:OFC/31mSvZgRz0V1QTNCzfAI1aIRzbiufJtkMIlEp58= golang.org/x/crypto v0.6.0/go.mod h1:OFC/31mSvZgRz0V1QTNCzfAI1aIRzbiufJtkMIlEp58=
golang.org/x/crypto v0.10.0/go.mod h1:o4eNf7Ede1fv+hwOwZsTHl9EsPFO6q6ZvYR8vYfY45I= golang.org/x/crypto v0.10.0/go.mod h1:o4eNf7Ede1fv+hwOwZsTHl9EsPFO6q6ZvYR8vYfY45I=
golang.org/x/crypto v0.18.0/go.mod h1:R0j02AL6hcrfOiy9T4ZYp/rcWeMxM3L6QYxlOuEG1mg= golang.org/x/crypto v0.18.0/go.mod h1:R0j02AL6hcrfOiy9T4ZYp/rcWeMxM3L6QYxlOuEG1mg=
golang.org/x/crypto v0.26.0 h1:RrRspgV4mU+YwB4FYnuBoKsUapNIL5cohGAmSH3azsw= golang.org/x/crypto v0.29.0 h1:L5SG1JTTXupVV3n6sUqMTeWbjAyfPwoda2DLX8J8FrQ=
golang.org/x/crypto v0.26.0/go.mod h1:GY7jblb9wI+FOo5y8/S2oY4zWP07AkOJ4+jxCqdqn54= golang.org/x/crypto v0.29.0/go.mod h1:+F4F4N5hv6v38hfeYwTdx20oUvLLc+QfrE9Ax9HtgRg=
golang.org/x/exp v0.0.0-20190121172915-509febef88a4/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= golang.org/x/exp v0.0.0-20190121172915-509febef88a4/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA=
golang.org/x/image v0.0.0-20211028202545-6944b10bf410/go.mod h1:023OzeP/+EPmXeapQh35lcL3II3LrY8Ic+EFFKVhULM= golang.org/x/image v0.0.0-20211028202545-6944b10bf410/go.mod h1:023OzeP/+EPmXeapQh35lcL3II3LrY8Ic+EFFKVhULM=
golang.org/x/image v0.13.0/go.mod h1:6mmbMOeV28HuMTgA6OSRkdXKYw/t5W9Uwn2Yv1r3Yxk= golang.org/x/image v0.13.0/go.mod h1:6mmbMOeV28HuMTgA6OSRkdXKYw/t5W9Uwn2Yv1r3Yxk=
@ -511,8 +511,8 @@ golang.org/x/net v0.7.0/go.mod h1:2Tu9+aMcznHK/AK1HMvgo6xiTLG5rD5rZLDS+rp2Bjs=
golang.org/x/net v0.10.0/go.mod h1:0qNGK6F8kojg2nk9dLZ2mShWaEBan6FAoqfSigmmuDg= golang.org/x/net v0.10.0/go.mod h1:0qNGK6F8kojg2nk9dLZ2mShWaEBan6FAoqfSigmmuDg=
golang.org/x/net v0.11.0/go.mod h1:2L/ixqYpgIVXmeoSA/4Lu7BzTG4KIyPIryS4IsOd1oQ= golang.org/x/net v0.11.0/go.mod h1:2L/ixqYpgIVXmeoSA/4Lu7BzTG4KIyPIryS4IsOd1oQ=
golang.org/x/net v0.20.0/go.mod h1:z8BVo6PvndSri0LbOE3hAn0apkU+1YvI6E70E9jsnvY= golang.org/x/net v0.20.0/go.mod h1:z8BVo6PvndSri0LbOE3hAn0apkU+1YvI6E70E9jsnvY=
golang.org/x/net v0.28.0 h1:a9JDOJc5GMUJ0+UDqmLT86WiEy7iWyIhz8gz8E4e5hE= golang.org/x/net v0.31.0 h1:68CPQngjLL0r2AlUKiSxtQFKvzRVbnzLwMUn5SzcLHo=
golang.org/x/net v0.28.0/go.mod h1:yqtgsTWOOnlGLG9GFRrK3++bGOUEkNBoHZc8MEDWPNg= golang.org/x/net v0.31.0/go.mod h1:P4fl1q7dY2hnZFxEk4pPSkDHF+QqjitcnDjUQyMM+pM=
golang.org/x/oauth2 v0.0.0-20180821212333-d2e6202438be/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U= golang.org/x/oauth2 v0.0.0-20180821212333-d2e6202438be/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U=
golang.org/x/sync v0.0.0-20180314180146-1d60e4601c6f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.0.0-20180314180146-1d60e4601c6f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
golang.org/x/sync v0.0.0-20181108010431-42b317875d0f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.0.0-20181108010431-42b317875d0f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
@ -523,8 +523,8 @@ golang.org/x/sync v0.0.0-20201020160332-67f06af15bc9/go.mod h1:RxMgew5VJxzue5/jJ
golang.org/x/sync v0.0.0-20210220032951-036812b2e83c/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.0.0-20210220032951-036812b2e83c/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
golang.org/x/sync v0.0.0-20220722155255-886fb9371eb4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.0.0-20220722155255-886fb9371eb4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
golang.org/x/sync v0.1.0/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.1.0/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
golang.org/x/sync v0.8.0 h1:3NFvSEYkUoMifnESzZl15y791HH1qU2xm6eCJU5ZPXQ= golang.org/x/sync v0.9.0 h1:fEo0HyrW1GIgZdpbhCRO0PkJajUS5H9IFUztCgEo2jQ=
golang.org/x/sync v0.8.0/go.mod h1:Czt+wKu1gCyEFDUtn0jG5QVvpJ6rzVqr5aXyt9drQfk= golang.org/x/sync v0.9.0/go.mod h1:Czt+wKu1gCyEFDUtn0jG5QVvpJ6rzVqr5aXyt9drQfk=
golang.org/x/sys v0.0.0-20180830151530-49385e6e1522/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= golang.org/x/sys v0.0.0-20180830151530-49385e6e1522/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
golang.org/x/sys v0.0.0-20180905080454-ebe1bf3edb33/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= golang.org/x/sys v0.0.0-20180905080454-ebe1bf3edb33/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
golang.org/x/sys v0.0.0-20180909124046-d0be0721c37e/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= golang.org/x/sys v0.0.0-20180909124046-d0be0721c37e/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
@ -559,8 +559,8 @@ golang.org/x/sys v0.8.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.9.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.9.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.12.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.12.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.16.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= golang.org/x/sys v0.16.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA=
golang.org/x/sys v0.24.0 h1:Twjiwq9dn6R1fQcyiK+wQyHWfaz/BJB+YIpzU/Cv3Xg= golang.org/x/sys v0.27.0 h1:wBqf8DvsY9Y/2P8gAfPDEYNuS30J4lPHJxXSb/nJZ+s=
golang.org/x/sys v0.24.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= golang.org/x/sys v0.27.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA=
golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo=
golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8= golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8=
golang.org/x/term v0.1.0/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8= golang.org/x/term v0.1.0/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8=
@ -579,8 +579,8 @@ golang.org/x/text v0.9.0/go.mod h1:e1OnstbJyHTd6l/uOt8jFFHp6TRDWZR/bV3emEE/zU8=
golang.org/x/text v0.10.0/go.mod h1:TvPlkZtksWOMsz7fbANvkp4WM8x/WCo/om8BMLbz+aE= golang.org/x/text v0.10.0/go.mod h1:TvPlkZtksWOMsz7fbANvkp4WM8x/WCo/om8BMLbz+aE=
golang.org/x/text v0.13.0/go.mod h1:TvPlkZtksWOMsz7fbANvkp4WM8x/WCo/om8BMLbz+aE= golang.org/x/text v0.13.0/go.mod h1:TvPlkZtksWOMsz7fbANvkp4WM8x/WCo/om8BMLbz+aE=
golang.org/x/text v0.14.0/go.mod h1:18ZOQIKpY8NJVqYksKHtTdi31H5itFRjB5/qKTNYzSU= golang.org/x/text v0.14.0/go.mod h1:18ZOQIKpY8NJVqYksKHtTdi31H5itFRjB5/qKTNYzSU=
golang.org/x/text v0.17.0 h1:XtiM5bkSOt+ewxlOE/aE/AKEHibwj/6gvWMl9Rsh0Qc= golang.org/x/text v0.20.0 h1:gK/Kv2otX8gz+wn7Rmb3vT96ZwuoxnQlY+HlJVj7Qug=
golang.org/x/text v0.17.0/go.mod h1:BuEKDfySbSR4drPmRPG/7iBdf8hvFMuRexcpahXilzY= golang.org/x/text v0.20.0/go.mod h1:D4IsuqiFMhST5bX19pQ9ikHC2GsaKyk/oF+pn3ducp4=
golang.org/x/time v0.6.0 h1:eTDhh4ZXt5Qf0augr54TN6suAUudPcawVZeIAPU7D4U= golang.org/x/time v0.6.0 h1:eTDhh4ZXt5Qf0augr54TN6suAUudPcawVZeIAPU7D4U=
golang.org/x/time v0.6.0/go.mod h1:3BpzKBy/shNhVucY/MWOyx10tF3SFh9QdLuxbVysPQM= golang.org/x/time v0.6.0/go.mod h1:3BpzKBy/shNhVucY/MWOyx10tF3SFh9QdLuxbVysPQM=
golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ=

View File

@ -7,5 +7,5 @@ package consts
// VersionApp HotGo版本 // VersionApp HotGo版本
const ( const (
VersionApp = "2.15.7" VersionApp = "2.15.11"
) )

View File

@ -3,7 +3,7 @@
// @Copyright Copyright (c) 2024 HotGo CLI // @Copyright Copyright (c) 2024 HotGo CLI
// @Author Ms <133814250@qq.com> // @Author Ms <133814250@qq.com>
// @License https://github.com/bufanyun/hotgo/blob/master/LICENSE // @License https://github.com/bufanyun/hotgo/blob/master/LICENSE
// @AutoGenerate Version 2.15.1 // @AutoGenerate Version 2.15.7
package sys package sys
import ( import (
@ -76,4 +76,4 @@ func (c *cTestCategory) Delete(ctx context.Context, req *testcategory.DeleteReq)
func (c *cTestCategory) Status(ctx context.Context, req *testcategory.StatusReq) (res *testcategory.StatusRes, err error) { func (c *cTestCategory) Status(ctx context.Context, req *testcategory.StatusReq) (res *testcategory.StatusRes, err error) {
err = service.SysTestCategory().Status(ctx, &req.TestCategoryStatusInp) err = service.SysTestCategory().Status(ctx, &req.TestCategoryStatusInp)
return return
} }

View File

@ -113,7 +113,7 @@ export function updateConfig(params) {
webConfigSystem = `<template> webConfigSystem = `<template>
<div> <div>
<n-grid cols="24 300:1 600:24" :x-gap="24"> <n-grid cols="24 300:1 600:24" :x-gap="12">
<n-grid-item span="6"> <n-grid-item span="6">
<n-card :bordered="false" size="small" class="proCard"> <n-card :bordered="false" size="small" class="proCard">
<n-thing <n-thing

View File

@ -35,7 +35,9 @@ func GenLoggerByCtx(ctx context.Context) *glog.Logger {
Logger().Panic(ctx, "获取定时任务序列号失败!") Logger().Panic(ctx, "获取定时任务序列号失败!")
} }
crons.RLock()
logger, ok := crons.loggers[sn] logger, ok := crons.loggers[sn]
crons.RUnlock()
if ok { if ok {
return logger return logger
} }

View File

@ -136,6 +136,16 @@ func GenHashOption(key interface{}, label string, extra ...any) *model.Option {
} }
} }
// GetOption 通过key找到label
func GetOption(ses []*model.Option, key interface{}) *model.Option {
for _, v := range ses {
if gconv.String(v.Key) == gconv.String(key) {
return v
}
}
return nil
}
// GetOptionLabel 通过key找到label // GetOptionLabel 通过key找到label
func GetOptionLabel(ses []*model.Option, key interface{}) string { func GetOptionLabel(ses []*model.Option, key interface{}) string {
for _, v := range ses { for _, v := range ses {
@ -155,3 +165,16 @@ func HasOptionKey(ses []*model.Option, key interface{}) bool {
} }
return false return false
} }
// UniqueOption 去重选项
func UniqueOption(src []*model.Option) (dst []*model.Option) {
temp := map[string]struct{}{}
for _, item := range src {
key := gconv.String(item.Key)
if _, ok := temp[key]; !ok {
temp[key] = struct{}{}
dst = append(dst, item)
}
}
return dst
}

View File

@ -59,7 +59,7 @@ func (c cGF) Index(ctx context.Context, in cGFInput) (out *cGFOutput, err error)
answer := "n" answer := "n"
// No argument or option, do installation checks. // No argument or option, do installation checks.
if data, isInstalled := service.Install.IsInstalled(); !isInstalled { if data, isInstalled := service.Install.IsInstalled(); !isInstalled {
mlog.Print("hi, it seams it's the first time you installing gf cli.") mlog.Print("hi, it seems it's the first time you installing gf cli.")
answer = gcmd.Scanf("do you want to install gf(%s) binary to your system? [y/n]: ", gf.VERSION) answer = gcmd.Scanf("do you want to install gf(%s) binary to your system? [y/n]: ", gf.VERSION)
} else if !data.IsSelf { } else if !data.IsSelf {
mlog.Print("hi, you have installed gf cli.") mlog.Print("hi, you have installed gf cli.")

View File

@ -138,11 +138,6 @@ type cBuildInput struct {
type cBuildOutput struct{} type cBuildOutput struct{}
func (c cBuild) Index(ctx context.Context, in cBuildInput) (out *cBuildOutput, err error) { func (c cBuild) Index(ctx context.Context, in cBuildInput) (out *cBuildOutput, err error) {
// print used go env
if in.DumpENV {
_, _ = Env.Index(ctx, cEnvInput{})
}
mlog.SetHeaderPrint(true) mlog.SetHeaderPrint(true)
mlog.Debugf(`build command input: %+v`, in) mlog.Debugf(`build command input: %+v`, in)
@ -217,7 +212,7 @@ func (c cBuild) Index(ctx context.Context, in cBuildInput) (out *cBuildOutput, e
if !gfile.Exists(in.PackDst) { if !gfile.Exists(in.PackDst) {
// Remove the go file that is automatically packed resource. // Remove the go file that is automatically packed resource.
defer func() { defer func() {
_ = gfile.Remove(in.PackDst) _ = gfile.RemoveFile(in.PackDst)
mlog.Printf(`remove the automatically generated resource go file: %s`, in.PackDst) mlog.Printf(`remove the automatically generated resource go file: %s`, in.PackDst)
}() }()
} }
@ -241,6 +236,10 @@ func (c cBuild) Index(ctx context.Context, in cBuildInput) (out *cBuildOutput, e
} else { } else {
genv.MustSet("CGO_ENABLED", "0") genv.MustSet("CGO_ENABLED", "0")
} }
// print used go env
if in.DumpENV {
_, _ = Env.Index(ctx, cEnvInput{})
}
for system, item := range platformMap { for system, item := range platformMap {
if len(customSystems) > 0 && customSystems[0] != "all" && !gstr.InArray(customSystems, system) { if len(customSystems) > 0 && customSystems[0] != "all" && !gstr.InArray(customSystems, system) {
continue continue

View File

@ -8,6 +8,7 @@ package cmd
import ( import (
"context" "context"
"fmt"
"io" "io"
"net/http" "net/http"
"os" "os"
@ -22,8 +23,12 @@ import (
) )
const ( const (
GitName = "gf-site"
BranchName = "gh-pages"
SiteFileName = GitName + "-" + BranchName
// DocURL is the download address of the document // DocURL is the download address of the document
DocURL = "https://github.com/gogf/gf/archive/refs/heads/gh-pages.zip" DocURL = "https://github.com/gogf/" + GitName + "/archive/refs/heads/" + BranchName + ".zip"
) )
var ( var (
@ -70,12 +75,13 @@ func (c cDoc) Index(ctx context.Context, in cDocInput) (out *cDocOutput, err err
mlog.Print("Failed to download document:", err) mlog.Print("Failed to download document:", err)
return return
} }
s := g.Server()
s.SetServerRoot(docs.DocDir) http.Handle("/", http.FileServer(http.Dir(docs.DocDir)))
s.SetPort(in.Port) mlog.Printf("Access address http://127.0.0.1:%d in %s", in.Port, docs.DocDir)
s.SetDumpRouterMap(false) err = http.ListenAndServe(fmt.Sprintf(":%d", in.Port), nil)
mlog.Printf("Access address http://127.0.0.1:%d", in.Port) if err != nil {
s.Run() return nil, err
}
return return
} }
@ -89,7 +95,7 @@ type DocSetting struct {
// NewDocSetting new DocSetting // NewDocSetting new DocSetting
func NewDocSetting(ctx context.Context, in cDocInput) *DocSetting { func NewDocSetting(ctx context.Context, in cDocInput) *DocSetting {
fileName := "gf-doc-md.zip" fileName := SiteFileName + ".zip"
tempDir := in.Path tempDir := in.Path
if tempDir == "" { if tempDir == "" {
tempDir = gfile.Temp("goframe/docs") tempDir = gfile.Temp("goframe/docs")
@ -99,17 +105,17 @@ func NewDocSetting(ctx context.Context, in cDocInput) *DocSetting {
return &DocSetting{ return &DocSetting{
TempDir: filepath.FromSlash(tempDir), TempDir: filepath.FromSlash(tempDir),
DocDir: filepath.FromSlash(path.Join(tempDir, "gf-gh-pages")), DocDir: filepath.FromSlash(path.Join(tempDir, SiteFileName)),
DocURL: in.Proxy + DocURL, DocURL: in.Proxy + DocURL,
DocZipFile: filepath.FromSlash(path.Join(tempDir, fileName)), DocZipFile: filepath.FromSlash(path.Join(tempDir, fileName)),
} }
} }
// Clean clean the temporary directory // Clean cleans the temporary directory
func (d *DocSetting) Clean() error { func (d *DocSetting) Clean() error {
if _, err := os.Stat(d.TempDir); err == nil { if _, err := os.Stat(d.TempDir); err == nil {
err = gfile.Remove(d.TempDir) err = gfile.RemoveAll(d.TempDir)
if err != nil { if err != nil {
mlog.Print("Failed to delete temporary directory:", err) mlog.Print("Failed to delete temporary directory:", err)
return err return err
@ -168,7 +174,7 @@ func (d *DocSetting) DownloadDoc() error {
err := gcompress.UnZipFile(d.DocZipFile, d.TempDir) err := gcompress.UnZipFile(d.DocZipFile, d.TempDir)
if err != nil { if err != nil {
mlog.Print("Failed to unzip the file, please run again:", err) mlog.Print("Failed to unzip the file, please run again:", err)
gfile.Remove(d.DocZipFile) _ = gfile.RemoveFile(d.DocZipFile)
return err return err
} }

View File

@ -93,6 +93,12 @@ type (
) )
func (c cRun) Index(ctx context.Context, in cRunInput) (out *cRunOutput, err error) { func (c cRun) Index(ctx context.Context, in cRunInput) (out *cRunOutput, err error) {
if !gfile.Exists(in.File) {
mlog.Fatalf(`given file "%s" not found`, in.File)
}
if !gfile.IsFile(in.File) {
mlog.Fatalf(`given "%s" is not a file`, in.File)
}
// Necessary check. // Necessary check.
if gproc.SearchBinary("go") == "" { if gproc.SearchBinary("go") == "" {
mlog.Fatalf(`command "go" not found in your environment, please install golang first to proceed this command`) mlog.Fatalf(`command "go" not found in your environment, please install golang first to proceed this command`)
@ -205,7 +211,7 @@ func (app *cRunApp) End(ctx context.Context, sig os.Signal, outputPath string) {
mlog.Debugf("kill process error: %s", err.Error()) mlog.Debugf("kill process error: %s", err.Error())
} }
} }
if err := gfile.Remove(outputPath); err != nil { if err := gfile.RemoveFile(outputPath); err != nil {
mlog.Printf("delete binary file error: %s", err.Error()) mlog.Printf("delete binary file error: %s", err.Error())
} else { } else {
mlog.Printf("deleted binary file: %s", outputPath) mlog.Printf("deleted binary file: %s", outputPath)

View File

@ -192,7 +192,7 @@ func (c cUp) doUpgradeCLI(ctx context.Context) (err error) {
defer func() { defer func() {
mlog.Printf(`new version cli binary is successfully installed to "%s"`, gfile.SelfPath()) mlog.Printf(`new version cli binary is successfully installed to "%s"`, gfile.SelfPath())
mlog.Printf(`remove temporary buffer file "%s"`, localSaveFilePath) mlog.Printf(`remove temporary buffer file "%s"`, localSaveFilePath)
_ = gfile.Remove(localSaveFilePath) _ = gfile.RemoveFile(localSaveFilePath)
}() }()
// It fails if file not exist or its size is less than 1MB. // It fails if file not exist or its size is less than 1MB.

View File

@ -691,3 +691,151 @@ func Test_Gen_Dao_Issue3459(t *testing.T) {
} }
}) })
} }
// https://github.com/gogf/gf/issues/3749
func Test_Gen_Dao_Issue3749(t *testing.T) {
gtest.C(t, func(t *gtest.T) {
var (
err error
db = testDB
table = "table_user"
sqlContent = fmt.Sprintf(
gtest.DataContent(`issue`, `3749`, `user.tpl.sql`),
table,
)
)
dropTableWithDb(db, table)
array := gstr.SplitAndTrim(sqlContent, ";")
for _, v := range array {
if _, err = db.Exec(ctx, v); err != nil {
t.AssertNil(err)
}
}
defer dropTableWithDb(db, table)
var (
path = gfile.Temp(guid.S())
group = "test"
in = gendao.CGenDaoInput{
Path: path,
Link: link,
Group: group,
}
)
err = gutil.FillStructWithDefault(&in)
t.AssertNil(err)
err = gfile.Mkdir(path)
t.AssertNil(err)
// for go mod import path auto retrieve.
err = gfile.Copy(
gtest.DataPath("gendao", "go.mod.txt"),
gfile.Join(path, "go.mod"),
)
t.AssertNil(err)
_, err = gendao.CGenDao{}.Dao(ctx, in)
t.AssertNil(err)
defer gfile.Remove(path)
// files
files, err := gfile.ScanDir(path, "*.go", true)
t.AssertNil(err)
t.Assert(files, []string{
filepath.FromSlash(path + "/dao/internal/table_user.go"),
filepath.FromSlash(path + "/dao/table_user.go"),
filepath.FromSlash(path + "/model/do/table_user.go"),
filepath.FromSlash(path + "/model/entity/table_user.go"),
})
// content
testPath := gtest.DataPath(`issue`, `3749`)
expectFiles := []string{
filepath.FromSlash(testPath + "/dao/internal/table_user.go"),
filepath.FromSlash(testPath + "/dao/table_user.go"),
filepath.FromSlash(testPath + "/model/do/table_user.go"),
filepath.FromSlash(testPath + "/model/entity/table_user.go"),
}
for i, _ := range files {
t.Assert(gfile.GetContents(files[i]), gfile.GetContents(expectFiles[i]))
}
})
}
func Test_Gen_Dao_Sqlite3(t *testing.T) {
gtest.C(t, func(t *gtest.T) {
var (
err error
table = "table_user"
path = gfile.Temp(guid.S())
linkSqlite3 = fmt.Sprintf("sqlite::@file(%s/db.sqlite3)", path)
sqlContent = fmt.Sprintf(
gtest.DataContent(`gendao`, `sqlite3`, `user.sqlite3.sql`),
table,
)
)
err = gfile.Mkdir(path)
t.AssertNil(err)
defer gfile.Remove(path)
dbSqlite3, err := gdb.New(gdb.ConfigNode{
Link: linkSqlite3,
})
t.AssertNil(err)
array := gstr.SplitAndTrim(sqlContent, ";")
for _, v := range array {
if v == "" {
continue
}
if _, err = dbSqlite3.Exec(ctx, v); err != nil {
t.AssertNil(err)
}
}
var (
group = "test"
in = gendao.CGenDaoInput{
Path: path,
Link: linkSqlite3,
Group: group,
Tables: table,
}
)
err = gutil.FillStructWithDefault(&in)
t.AssertNil(err)
// for go mod import path auto retrieve.
err = gfile.Copy(
gtest.DataPath("gendao", "go.mod.txt"),
gfile.Join(path, "go.mod"),
)
t.AssertNil(err)
_, err = gendao.CGenDao{}.Dao(ctx, in)
t.AssertNil(err)
defer gfile.Remove(path)
// files
files, err := gfile.ScanDir(path, "*.go", true)
t.AssertNil(err)
t.Assert(files, []string{
filepath.FromSlash(path + "/dao/internal/table_user.go"),
filepath.FromSlash(path + "/dao/table_user.go"),
filepath.FromSlash(path + "/model/do/table_user.go"),
filepath.FromSlash(path + "/model/entity/table_user.go"),
})
// content
testPath := gtest.DataPath("gendao", "generated_user_sqlite3")
expectFiles := []string{
filepath.FromSlash(testPath + "/dao/internal/table_user.go"),
filepath.FromSlash(testPath + "/dao/table_user.go"),
filepath.FromSlash(testPath + "/model/do/table_user.go"),
filepath.FromSlash(testPath + "/model/entity/table_user.go"),
}
for i, _ := range files {
t.Assert(gfile.GetContents(files[i]), gfile.GetContents(expectFiles[i]))
}
})
}

View File

@ -0,0 +1,50 @@
// Copyright GoFrame gf Author(https://goframe.org). All Rights Reserved.
//
// This Source Code Form is subject to the terms of the MIT License.
// If a copy of the MIT was not distributed with this file,
// You can obtain one at https://github.com/gogf/gf.
package cmd
import (
"path/filepath"
"testing"
"github.com/gogf/gf/v2/os/gfile"
"github.com/gogf/gf/v2/test/gtest"
"github.com/gogf/gf/v2/text/gstr"
"github.com/gogf/gf/v2/util/guid"
"hotgo/internal/library/hggen/internal/cmd/genpb"
)
func TestGenPbIssue3882(t *testing.T) {
gtest.C(t, func(t *gtest.T) {
var (
outputPath = gfile.Temp(guid.S())
outputApiPath = filepath.Join(outputPath, "api")
outputCtrlPath = filepath.Join(outputPath, "controller")
protobufFolder = gtest.DataPath("issue", "3882")
in = genpb.CGenPbInput{
Path: protobufFolder,
OutputApi: outputApiPath,
OutputCtrl: outputCtrlPath,
}
err error
)
err = gfile.Mkdir(outputApiPath)
t.AssertNil(err)
err = gfile.Mkdir(outputCtrlPath)
t.AssertNil(err)
defer gfile.Remove(outputPath)
_, err = genpb.CGenPb{}.Pb(ctx, in)
t.AssertNil(err)
var (
genContent = gfile.GetContents(filepath.Join(outputApiPath, "issue3882.pb.go"))
exceptText = `dc:"Some comment on field with 'one' 'two' 'three' in the comment."`
)
t.Assert(gstr.Contains(genContent, exceptText), true)
})
}

View File

@ -22,9 +22,9 @@ func Test_Gen_Service_Default(t *testing.T) {
var ( var (
path = gfile.Temp(guid.S()) path = gfile.Temp(guid.S())
dstFolder = path + filepath.FromSlash("/service") dstFolder = path + filepath.FromSlash("/service")
apiFolder = gtest.DataPath("genservice", "logic") srvFolder = gtest.DataPath("genservice", "logic")
in = genservice.CGenServiceInput{ in = genservice.CGenServiceInput{
SrcFolder: apiFolder, SrcFolder: srvFolder,
DstFolder: dstFolder, DstFolder: dstFolder,
DstFileNameCase: "Snake", DstFileNameCase: "Snake",
WatchFile: "", WatchFile: "",
@ -46,11 +46,11 @@ func Test_Gen_Service_Default(t *testing.T) {
// logic file // logic file
var ( var (
genApi = apiFolder + filepath.FromSlash("/logic.go") genSrv = srvFolder + filepath.FromSlash("/logic.go")
genApiExpect = apiFolder + filepath.FromSlash("/logic_expect.go") genSrvExpect = srvFolder + filepath.FromSlash("/logic_expect.go")
) )
defer gfile.Remove(genApi) defer gfile.Remove(genSrv)
t.Assert(gfile.GetContents(genApi), gfile.GetContents(genApiExpect)) t.Assert(gfile.GetContents(genSrv), gfile.GetContents(genSrvExpect))
// files // files
files, err := gfile.ScanDir(dstFolder, "*.go", true) files, err := gfile.ScanDir(dstFolder, "*.go", true)
@ -73,3 +73,83 @@ func Test_Gen_Service_Default(t *testing.T) {
} }
}) })
} }
// https://github.com/gogf/gf/issues/3328
func Test_Issue3328(t *testing.T) {
gtest.C(t, func(t *gtest.T) {
var (
path = gfile.Temp(guid.S())
dstFolder = path + filepath.FromSlash("/service")
srvFolder = gtest.DataPath("issue", "3328", "logic")
logicGoPath = srvFolder + filepath.FromSlash("/logic.go")
in = genservice.CGenServiceInput{
SrcFolder: srvFolder,
DstFolder: dstFolder,
DstFileNameCase: "Snake",
WatchFile: "",
StPattern: "",
Packages: nil,
ImportPrefix: "",
Clear: false,
}
)
gfile.Remove(logicGoPath)
defer gfile.Remove(logicGoPath)
err := gutil.FillStructWithDefault(&in)
t.AssertNil(err)
err = gfile.Mkdir(path)
t.AssertNil(err)
defer gfile.Remove(path)
_, err = genservice.CGenService{}.Service(ctx, in)
t.AssertNil(err)
files, err := gfile.ScanDir(srvFolder, "*", true)
for _, file := range files {
if file == logicGoPath {
if gfile.IsDir(logicGoPath) {
t.Fatalf("%s should not is folder", logicGoPath)
}
}
}
})
}
// https://github.com/gogf/gf/issues/3835
func Test_Issue3835(t *testing.T) {
gtest.C(t, func(t *gtest.T) {
var (
path = gfile.Temp(guid.S())
dstFolder = path + filepath.FromSlash("/service")
srvFolder = gtest.DataPath("issue", "3835", "logic")
in = genservice.CGenServiceInput{
SrcFolder: srvFolder,
DstFolder: dstFolder,
DstFileNameCase: "Snake",
WatchFile: "",
StPattern: "",
Packages: nil,
ImportPrefix: "",
Clear: false,
}
)
err := gutil.FillStructWithDefault(&in)
t.AssertNil(err)
err = gfile.Mkdir(path)
t.AssertNil(err)
defer gfile.Remove(path)
_, err = genservice.CGenService{}.Service(ctx, in)
t.AssertNil(err)
// contents
var (
genFile = dstFolder + filepath.FromSlash("/issue_3835.go")
expectFile = gtest.DataPath("issue", "3835", "service", "issue_3835.go")
)
t.Assert(gfile.GetContents(genFile), gfile.GetContents(expectFile))
})
}

View File

@ -128,7 +128,7 @@ func (c CGenCtrl) generateByWatchFile(watchFile, sdkPath string, sdkStdVersion,
return return
} }
} }
defer gfile.Remove(flockFilePath) defer gfile.RemoveFile(flockFilePath)
_ = gfile.PutContents(flockFilePath, gtime.TimestampStr()) _ = gfile.PutContents(flockFilePath, gtime.TimestampStr())
// check this updated file is an api file. // check this updated file is an api file.

View File

@ -89,7 +89,7 @@ func (c *controllerGenerator) doGenerateCtrlNewByModuleAndVersion(
if err = gfile.PutContents(moduleFilePath, gstr.TrimLeft(content)); err != nil { if err = gfile.PutContents(moduleFilePath, gstr.TrimLeft(content)); err != nil {
return err return err
} }
mlog.Printf(`generated: %s`, moduleFilePath) mlog.Printf(`generated: %s`, gfile.RealPath(moduleFilePath))
} }
if !gfile.Exists(moduleFilePathNew) { if !gfile.Exists(moduleFilePathNew) {
content := gstr.ReplaceByMap(consts.TemplateGenCtrlControllerNewEmpty, g.MapStrStr{ content := gstr.ReplaceByMap(consts.TemplateGenCtrlControllerNewEmpty, g.MapStrStr{
@ -99,7 +99,7 @@ func (c *controllerGenerator) doGenerateCtrlNewByModuleAndVersion(
if err = gfile.PutContents(moduleFilePathNew, gstr.TrimLeft(content)); err != nil { if err = gfile.PutContents(moduleFilePathNew, gstr.TrimLeft(content)); err != nil {
return err return err
} }
mlog.Printf(`generated: %s`, moduleFilePathNew) mlog.Printf(`generated: %s`, gfile.RealPath(moduleFilePathNew))
} }
filePaths, err := gfile.ScanDir(dstModuleFolderPath, "*.go", false) filePaths, err := gfile.ScanDir(dstModuleFolderPath, "*.go", false)
if err != nil { if err != nil {
@ -161,7 +161,7 @@ func (c *controllerGenerator) doGenerateCtrlItem(dstModuleFolderPath string, ite
return err return err
} }
} }
mlog.Printf(`generated: %s`, methodFilePath) mlog.Printf(`generated: %s`, gfile.RealPath(methodFilePath))
return return
} }
@ -221,7 +221,7 @@ func (c *controllerGenerator) doGenerateCtrlMergeItem(dstModuleFolderPath string
if err = gfile.PutContentsAppend(ctrlFilePath, ctrlFileItem.controllers.String()); err != nil { if err = gfile.PutContentsAppend(ctrlFilePath, ctrlFileItem.controllers.String()); err != nil {
return err return err
} }
mlog.Printf(`generated: %s`, ctrlFilePath) mlog.Printf(`generated: %s`, gfile.RealPath(ctrlFilePath))
} }
return return
} }

View File

@ -49,7 +49,7 @@ func (c *controllerClearer) doClear(dstModuleFolderPath string, item apiItem) (e
`remove unimplemented and of no api definitions controller file: %s`, `remove unimplemented and of no api definitions controller file: %s`,
methodFilePath, methodFilePath,
) )
err = gfile.Remove(methodFilePath) err = gfile.RemoveFile(methodFilePath)
} }
} }
return return

View File

@ -94,7 +94,7 @@ func (c *apiInterfaceGenerator) doGenerate(apiModuleFolderPath string, module st
"{Interfaces}": gstr.TrimRightStr(interfaceDefinition, "\n", 2), "{Interfaces}": gstr.TrimRightStr(interfaceDefinition, "\n", 2),
})) }))
err = gfile.PutContents(moduleFilePath, interfaceContent) err = gfile.PutContents(moduleFilePath, interfaceContent)
mlog.Printf(`generated: %s`, moduleFilePath) mlog.Printf(`generated: %s`, gfile.RealPath(moduleFilePath))
return return
} }

View File

@ -65,7 +65,7 @@ func (c *apiSdkGenerator) doGenerateSdkPkgFile(sdkFolderPath string) (err error)
"{PkgName}": pkgName, "{PkgName}": pkgName,
})) }))
err = gfile.PutContents(pkgFilePath, fileContent) err = gfile.PutContents(pkgFilePath, fileContent)
mlog.Printf(`generated: %s`, pkgFilePath) mlog.Printf(`generated: %s`, gfile.RealPath(pkgFilePath))
return return
} }
@ -130,9 +130,9 @@ func (c *apiSdkGenerator) doGenerateSdkIClient(
if isDirty { if isDirty {
err = gfile.PutContents(iClientFilePath, fileContent) err = gfile.PutContents(iClientFilePath, fileContent)
if isExist { if isExist {
mlog.Printf(`updated: %s`, iClientFilePath) mlog.Printf(`updated: %s`, gfile.RealPath(iClientFilePath))
} else { } else {
mlog.Printf(`generated: %s`, iClientFilePath) mlog.Printf(`generated: %s`, gfile.RealPath(iClientFilePath))
} }
} }
return return
@ -183,7 +183,7 @@ func (c *apiSdkGenerator) doGenerateSdkImplementer(
implementerFileContent += "\n" implementerFileContent += "\n"
} }
err = gfile.PutContents(implementerFilePath, implementerFileContent) err = gfile.PutContents(implementerFilePath, implementerFileContent)
mlog.Printf(`generated: %s`, implementerFilePath) mlog.Printf(`generated: %s`, gfile.RealPath(implementerFilePath))
return return
} }

View File

@ -208,9 +208,11 @@ type (
NoModelComment bool `name:"noModelComment" short:"m" brief:"{CGenDaoBriefNoModelComment}" orphan:"true"` NoModelComment bool `name:"noModelComment" short:"m" brief:"{CGenDaoBriefNoModelComment}" orphan:"true"`
Clear bool `name:"clear" short:"a" brief:"{CGenDaoBriefClear}" orphan:"true"` Clear bool `name:"clear" short:"a" brief:"{CGenDaoBriefClear}" orphan:"true"`
TypeMapping map[DBFieldTypeName]CustomAttributeType `name:"typeMapping" short:"y" brief:"{CGenDaoBriefTypeMapping}" orphan:"true"` TypeMapping map[DBFieldTypeName]CustomAttributeType `name:"typeMapping" short:"y" brief:"{CGenDaoBriefTypeMapping}" orphan:"true"`
FieldMapping map[DBTableFieldName]CustomAttributeType `name:"fieldMapping" short:"fm" brief:"{CGenDaoBriefFieldMapping}" orphan:"true"` FieldMapping map[DBTableFieldName]CustomAttributeType `name:"fieldMapping" short:"fm" brief:"{CGenDaoBriefFieldMapping}" orphan:"true"`
genItems *CGenDaoInternalGenItems
// internal usage purpose.
genItems *CGenDaoInternalGenItems
} }
CGenDaoOutput struct{} CGenDaoOutput struct{}

View File

@ -40,7 +40,7 @@ func doClearItem(item CGenDaoInternalGenItem, allGeneratedFilePaths []string) {
} }
for _, filePath := range generatedFilePaths { for _, filePath := range generatedFilePaths {
if !gstr.InArray(allGeneratedFilePaths, filePath) { if !gstr.InArray(allGeneratedFilePaths, filePath) {
if err := gfile.Remove(filePath); err != nil { if err := gfile.RemoveFile(filePath); err != nil {
mlog.Print(err) mlog.Print(err)
} }
} }

View File

@ -58,8 +58,8 @@ func generateDaoSingle(ctx context.Context, in generateDaoSingleInput) {
mlog.Fatalf(`fetching tables fields failed for table "%s": %+v`, in.TableName, err) mlog.Fatalf(`fetching tables fields failed for table "%s": %+v`, in.TableName, err)
} }
var ( var (
tableNameCamelCase = gstr.CaseCamel(strings.ToLower(in.NewTableName)) tableNameCamelCase = formatFieldName(in.NewTableName, FieldNameCaseCamel)
tableNameCamelLowerCase = gstr.CaseCamelLower(strings.ToLower(in.NewTableName)) tableNameCamelLowerCase = formatFieldName(in.NewTableName, FieldNameCaseCamelLower)
tableNameSnakeCase = gstr.CaseSnake(in.NewTableName) tableNameSnakeCase = gstr.CaseSnake(in.NewTableName)
importPrefix = in.ImportPrefix importPrefix = in.ImportPrefix
) )
@ -123,7 +123,7 @@ func generateDaoIndex(in generateDaoIndexInput) {
mlog.Fatalf("writing content to '%s' failed: %v", path, err) mlog.Fatalf("writing content to '%s' failed: %v", path, err)
} else { } else {
utils.GoFmt(path) utils.GoFmt(path)
mlog.Print("generated:", path) mlog.Print("generated:", gfile.RealPath(path))
} }
} }
} }
@ -157,7 +157,7 @@ func generateDaoInternal(in generateDaoInternalInput) {
mlog.Fatalf("writing content to '%s' failed: %v", path, err) mlog.Fatalf("writing content to '%s' failed: %v", path, err)
} else { } else {
utils.GoFmt(path) utils.GoFmt(path)
mlog.Print("generated:", path) mlog.Print("generated:", gfile.RealPath(path))
} }
} }
@ -179,7 +179,7 @@ func generateColumnNamesForDao(fieldMap map[string]*gdb.TableField, removeFieldP
} }
array[index] = []string{ array[index] = []string{
" #" + gstr.CaseCamel(strings.ToLower(newFiledName)) + ":", " #" + formatFieldName(newFiledName, FieldNameCaseCamel) + ":",
fmt.Sprintf(` #"%s",`, field.Name), fmt.Sprintf(` #"%s",`, field.Name),
} }
} }
@ -219,7 +219,7 @@ func generateColumnDefinitionForDao(fieldMap map[string]*gdb.TableField, removeF
newFiledName = gstr.TrimLeftStr(newFiledName, v, 1) newFiledName = gstr.TrimLeftStr(newFiledName, v, 1)
} }
array[index] = []string{ array[index] = []string{
" #" + gstr.CaseCamel(strings.ToLower(newFiledName)), " #" + formatFieldName(newFiledName, FieldNameCaseCamel),
" # " + "string", " # " + "string",
" #" + fmt.Sprintf(`// %s`, comment), " #" + fmt.Sprintf(`// %s`, comment),
} }

View File

@ -40,7 +40,7 @@ func generateDo(ctx context.Context, in CGenDaoInternalInput) {
structDefinition, _ = generateStructDefinition(ctx, generateStructDefinitionInput{ structDefinition, _ = generateStructDefinition(ctx, generateStructDefinitionInput{
CGenDaoInternalInput: in, CGenDaoInternalInput: in,
TableName: tableName, TableName: tableName,
StructName: gstr.CaseCamel(strings.ToLower(newTableName)), StructName: formatFieldName(newTableName, FieldNameCaseCamel),
FieldMap: fieldMap, FieldMap: fieldMap,
IsDo: true, IsDo: true,
}) })
@ -61,7 +61,7 @@ func generateDo(ctx context.Context, in CGenDaoInternalInput) {
ctx, ctx,
in, in,
tableName, tableName,
gstr.CaseCamel(strings.ToLower(newTableName)), formatFieldName(newTableName, FieldNameCaseCamel),
structDefinition, structDefinition,
) )
in.genItems.AppendGeneratedFilePath(doFilePath) in.genItems.AppendGeneratedFilePath(doFilePath)
@ -70,7 +70,7 @@ func generateDo(ctx context.Context, in CGenDaoInternalInput) {
mlog.Fatalf(`writing content to "%s" failed: %v`, doFilePath, err) mlog.Fatalf(`writing content to "%s" failed: %v`, doFilePath, err)
} else { } else {
utils.GoFmt(doFilePath) utils.GoFmt(doFilePath)
mlog.Print("generated:", doFilePath) mlog.Print("generated:", gfile.RealPath(doFilePath))
} }
} }
} }

View File

@ -36,7 +36,7 @@ func generateEntity(ctx context.Context, in CGenDaoInternalInput) {
structDefinition, appendImports = generateStructDefinition(ctx, generateStructDefinitionInput{ structDefinition, appendImports = generateStructDefinition(ctx, generateStructDefinitionInput{
CGenDaoInternalInput: in, CGenDaoInternalInput: in,
TableName: tableName, TableName: tableName,
StructName: gstr.CaseCamel(strings.ToLower(newTableName)), StructName: formatFieldName(newTableName, FieldNameCaseCamel),
FieldMap: fieldMap, FieldMap: fieldMap,
IsDo: false, IsDo: false,
}) })
@ -44,7 +44,7 @@ func generateEntity(ctx context.Context, in CGenDaoInternalInput) {
ctx, ctx,
in, in,
newTableName, newTableName,
gstr.CaseCamel(strings.ToLower(newTableName)), formatFieldName(newTableName, FieldNameCaseCamel),
structDefinition, structDefinition,
appendImports, appendImports,
) )
@ -55,7 +55,7 @@ func generateEntity(ctx context.Context, in CGenDaoInternalInput) {
mlog.Fatalf("writing content to '%s' failed: %v", entityFilePath, err) mlog.Fatalf("writing content to '%s' failed: %v", entityFilePath, err)
} else { } else {
utils.GoFmt(entityFilePath) utils.GoFmt(entityFilePath)
mlog.Print("generated:", entityFilePath) mlog.Print("generated:", gfile.RealPath(entityFilePath))
} }
} }
} }

View File

@ -99,7 +99,7 @@ func generateStructFieldDefinition(
} }
localTypeNameStr = string(localTypeName) localTypeNameStr = string(localTypeName)
switch localTypeName { switch localTypeName {
case gdb.LocalTypeDate, gdb.LocalTypeDatetime: case gdb.LocalTypeDate, gdb.LocalTypeTime, gdb.LocalTypeDatetime:
if in.StdTime { if in.StdTime {
localTypeNameStr = "time.Time" localTypeNameStr = "time.Time"
} else { } else {
@ -140,7 +140,7 @@ func generateStructFieldDefinition(
} }
attrLines = []string{ attrLines = []string{
" #" + gstr.CaseCamel(strings.ToLower(newFiledName)), " #" + formatFieldName(newFiledName, FieldNameCaseCamel),
" #" + localTypeNameStr, " #" + localTypeNameStr,
} }
attrLines = append(attrLines, fmt.Sprintf(` #%sjson:"%s"`, tagKey, jsonTag)) attrLines = append(attrLines, fmt.Sprintf(` #%sjson:"%s"`, tagKey, jsonTag))
@ -167,6 +167,43 @@ func generateStructFieldDefinition(
return attrLines, appendImport return attrLines, appendImport
} }
type FieldNameCase string
const (
FieldNameCaseCamel FieldNameCase = "CaseCamel"
FieldNameCaseCamelLower FieldNameCase = "CaseCamelLower"
)
// formatFieldName formats and returns a new field name that is used for golang codes generating.
func formatFieldName(fieldName string, nameCase FieldNameCase) string {
// For normal databases like mysql, pgsql, sqlite,
// field/table names of that are in normal case.
var newFieldName = fieldName
if isAllUpper(fieldName) {
// For special databases like dm, oracle,
// field/table names of that are in upper case.
newFieldName = strings.ToLower(fieldName)
}
switch nameCase {
case FieldNameCaseCamel:
return gstr.CaseCamel(newFieldName)
case FieldNameCaseCamelLower:
return gstr.CaseCamelLower(newFieldName)
default:
return ""
}
}
// isAllUpper checks and returns whether given `fieldName` all letters are upper case.
func isAllUpper(fieldName string) bool {
for _, b := range fieldName {
if b >= 'a' && b <= 'z' {
return false
}
}
return true
}
// formatComment formats the comment string to fit the golang code without any lines. // formatComment formats the comment string to fit the golang code without any lines.
func formatComment(comment string) string { func formatComment(comment string) string {
comment = gstr.ReplaceByArray(comment, g.SliceStr{ comment = gstr.ReplaceByArray(comment, g.SliceStr{

View File

@ -94,6 +94,9 @@ func (c CGenPb) Pb(ctx context.Context, in CGenPbInput) (out *CGenPbOutput, err
mlog.Fatalf(`no proto files found in folder "%s"`, in.Path) mlog.Fatalf(`no proto files found in folder "%s"`, in.Path)
} }
var originPwd = gfile.Pwd()
defer gfile.Chdir(originPwd)
if err = gfile.Chdir(protoPath); err != nil { if err = gfile.Chdir(protoPath); err != nil {
mlog.Fatal(err) mlog.Fatal(err)
} }

View File

@ -11,6 +11,7 @@ import (
"fmt" "fmt"
"github.com/gogf/gf/v2/container/gmap" "github.com/gogf/gf/v2/container/gmap"
"github.com/gogf/gf/v2/frame/g"
"github.com/gogf/gf/v2/os/gfile" "github.com/gogf/gf/v2/os/gfile"
"github.com/gogf/gf/v2/text/gregex" "github.com/gogf/gf/v2/text/gregex"
"github.com/gogf/gf/v2/text/gstr" "github.com/gogf/gf/v2/text/gstr"
@ -90,8 +91,12 @@ func (c CGenPb) tagCommentIntoListMap(comment string, lineTagMap *gmap.ListMap)
lineTagMap.Set(tagName, lineTagMap.GetVar(tagName).String()+tagContent) lineTagMap.Set(tagName, lineTagMap.GetVar(tagName).String()+tagContent)
} else { } else {
var ( var (
tagName = "dc" tagName = "dc"
tagContent = comment // Convert backticks and double quotes to single quotes.
tagContent = gstr.ReplaceByMap(comment, g.MapStrStr{
"`": `'`,
`"`: `'`,
})
) )
lineTagMap.Set(tagName, lineTagMap.GetVar(tagName).String()+tagContent) lineTagMap.Set(tagName, lineTagMap.GetVar(tagName).String()+tagContent)
} }

View File

@ -254,7 +254,7 @@ func generatePbEntityContentFile(ctx context.Context, in CGenPbEntityInternalInp
if err := gfile.PutContents(path, strings.TrimSpace(entityContent)); err != nil { if err := gfile.PutContents(path, strings.TrimSpace(entityContent)); err != nil {
mlog.Fatalf("writing content to '%s' failed: %v", path, err) mlog.Fatalf("writing content to '%s' failed: %v", path, err)
} else { } else {
mlog.Print("generated:", path) mlog.Print("generated:", gfile.RealPath(path))
} }
} }

View File

@ -114,7 +114,7 @@ func (c CGenService) Service(ctx context.Context, in CGenServiceInput) (out *CGe
return return
} }
} }
defer gfile.Remove(flockFilePath) defer gfile.RemoveFile(flockFilePath)
_ = gfile.PutContents(flockFilePath, gtime.TimestampStr()) _ = gfile.PutContents(flockFilePath, gtime.TimestampStr())
// It works only if given WatchFile is in SrcFolder. // It works only if given WatchFile is in SrcFolder.
@ -253,7 +253,7 @@ func (c CGenService) Service(ctx context.Context, in CGenServiceInput) (out *CGe
utils.IsFileDoNotEdit(relativeFilePath) { utils.IsFileDoNotEdit(relativeFilePath) {
mlog.Printf(`remove no longer used service file: %s`, relativeFilePath) mlog.Printf(`remove no longer used service file: %s`, relativeFilePath)
if err = gfile.Remove(file); err != nil { if err = gfile.RemoveFile(file); err != nil {
return nil, err return nil, err
} }
} }
@ -289,7 +289,7 @@ func (c CGenService) checkAndUpdateMain(srcFolder string) (err error) {
var ( var (
logicPackageName = gstr.ToLower(gfile.Basename(srcFolder)) logicPackageName = gstr.ToLower(gfile.Basename(srcFolder))
logicFilePath = gfile.Join(srcFolder, logicPackageName+".go") logicFilePath = gfile.Join(srcFolder, logicPackageName+".go")
importPath = utils.GetImportPath(logicFilePath) importPath = utils.GetImportPath(srcFolder)
importStr = fmt.Sprintf(`_ "%s"`, importPath) importStr = fmt.Sprintf(`_ "%s"`, importPath)
mainFilePath = gfile.Join(gfile.Dir(gfile.Dir(gfile.Dir(logicFilePath))), "main.go") mainFilePath = gfile.Join(gfile.Dir(gfile.Dir(gfile.Dir(logicFilePath))), "main.go")
mainFileContent = gfile.GetContents(mainFilePath) mainFileContent = gfile.GetContents(mainFilePath)

View File

@ -12,6 +12,7 @@ import (
"go/token" "go/token"
"github.com/gogf/gf/v2/os/gfile" "github.com/gogf/gf/v2/os/gfile"
"github.com/gogf/gf/v2/text/gstr"
) )
type pkgItem struct { type pkgItem struct {
@ -78,12 +79,19 @@ func (c CGenService) parseImportPackages(node *ast.ImportSpec) (packages pkgItem
path = node.Path.Value path = node.Path.Value
rawImport string rawImport string
) )
if node.Name != nil { if node.Name != nil {
alias = node.Name.Name alias = node.Name.Name
rawImport = alias + " " + path rawImport = node.Name.Name + " " + path
} else { } else {
rawImport = path rawImport = path
} }
// if the alias is empty, it will further retrieve the real alias.
if alias == "" {
alias = c.getRealAlias(path)
}
return pkgItem{ return pkgItem{
Alias: alias, Alias: alias,
Path: path, Path: path,
@ -91,6 +99,33 @@ func (c CGenService) parseImportPackages(node *ast.ImportSpec) (packages pkgItem
} }
} }
// getRealAlias retrieves the real alias of the package.
// If package is "github.com/gogf/gf", the alias is "gf".
// If package is "github.com/gogf/gf/v2", the alias is "gf" instead of "v2".
func (c CGenService) getRealAlias(importPath string) (pkgName string) {
importPath = gstr.Trim(importPath, `"`)
parts := gstr.Split(importPath, "/")
if len(parts) == 0 {
return
}
pkgName = parts[len(parts)-1]
if !gstr.HasPrefix(pkgName, "v") {
return pkgName
}
if len(parts) < 2 {
return pkgName
}
if gstr.IsNumeric(gstr.SubStr(pkgName, 1)) {
pkgName = parts[len(parts)-2]
}
return pkgName
}
// parseFuncReceiverTypeName retrieves the receiver type of the function. // parseFuncReceiverTypeName retrieves the receiver type of the function.
// For example: // For example:
// //

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

View File

@ -75,28 +75,24 @@ func ReplaceGeneratedContentGFV2(folderPath string) (err error) {
}, folderPath, "*.go", true) }, folderPath, "*.go", true)
} }
// GetImportPath calculates and returns the golang import path for given `filePath`. // GetImportPath calculates and returns the golang import path for given `dirPath`.
// Note that it needs a `go.mod` in current working directory or parent directories to detect the path. // Note that it needs a `go.mod` in current working directory or parent directories to detect the path.
func GetImportPath(filePath string) string { func GetImportPath(dirPath string) string {
// If `filePath` does not exist, create it firstly to find the import path. // If `filePath` does not exist, create it firstly to find the import path.
var realPath = gfile.RealPath(filePath) var realPath = gfile.RealPath(dirPath)
if realPath == "" { if realPath == "" {
_ = gfile.Mkdir(filePath) _ = gfile.Mkdir(dirPath)
realPath = gfile.RealPath(filePath) realPath = gfile.RealPath(dirPath)
} }
var ( var (
newDir = gfile.Dir(realPath) newDir = gfile.Dir(realPath)
oldDir string oldDir string
suffix string suffix = gfile.Basename(dirPath)
goModName = "go.mod" goModName = "go.mod"
goModPath string goModPath string
importPath string importPath string
) )
if gfile.IsDir(filePath) {
suffix = gfile.Basename(filePath)
}
for { for {
goModPath = gfile.Join(newDir, goModName) goModPath = gfile.Join(newDir, goModName)
if gfile.Exists(goModPath) { if gfile.Exists(goModPath) {

View File

@ -796,7 +796,7 @@ func (s *sAdminMember) VerifySuperId(ctx context.Context, verifyId int64) bool {
// LoadSuperAdmin 加载超管数据 // LoadSuperAdmin 加载超管数据
func (s *sAdminMember) LoadSuperAdmin(ctx context.Context) { func (s *sAdminMember) LoadSuperAdmin(ctx context.Context) {
value, err := dao.AdminRole.Ctx(ctx).Where(dao.AdminRole.Columns().Key, consts.SuperRoleKey).Value() value, err := dao.AdminRole.Ctx(ctx).Fields("id").Where(dao.AdminRole.Columns().Key, consts.SuperRoleKey).Value()
if err != nil { if err != nil {
g.Log().Errorf(ctx, "LoadSuperAdmin AdminRole err:%+v", err) g.Log().Errorf(ctx, "LoadSuperAdmin AdminRole err:%+v", err)
return return

View File

@ -130,7 +130,8 @@ func (s *sSysOptionTreeDemo) Delete(ctx context.Context, in *sysin.OptionTreeDem
if count > 0 { if count > 0 {
return gerror.New("请先删除该选项树表下的所有下级!") return gerror.New("请先删除该选项树表下的所有下级!")
} }
if _, err = s.Model(ctx).WherePri(in.Id).Delete(); err != nil {
if _, err = s.Model(ctx).WherePri(in.Id).Unscoped().Delete(); err != nil {
err = gerror.Wrap(err, "删除选项树表失败,请稍后重试!") err = gerror.Wrap(err, "删除选项树表失败,请稍后重试!")
return return
} }

View File

@ -3,7 +3,7 @@
// @Copyright Copyright (c) 2024 HotGo CLI // @Copyright Copyright (c) 2024 HotGo CLI
// @Author Ms <133814250@qq.com> // @Author Ms <133814250@qq.com>
// @License https://github.com/bufanyun/hotgo/blob/master/LICENSE // @License https://github.com/bufanyun/hotgo/blob/master/LICENSE
// @AutoGenerate Version 2.15.1 // @AutoGenerate Version 2.15.7
package sys package sys
import ( import (
@ -108,7 +108,7 @@ func (s *sSysTestCategory) Edit(ctx context.Context, in *sysin.TestCategoryEditI
// Delete 删除测试分类 // Delete 删除测试分类
func (s *sSysTestCategory) Delete(ctx context.Context, in *sysin.TestCategoryDeleteInp) (err error) { func (s *sSysTestCategory) Delete(ctx context.Context, in *sysin.TestCategoryDeleteInp) (err error) {
if _, err = s.Model(ctx).WherePri(in.Id).Delete(); err != nil { if _, err = s.Model(ctx).WherePri(in.Id).Unscoped().Delete(); err != nil {
err = gerror.Wrap(err, "删除测试分类失败,请稍后重试!") err = gerror.Wrap(err, "删除测试分类失败,请稍后重试!")
return return
} }
@ -164,4 +164,4 @@ func (s *sSysTestCategory) Option(ctx context.Context) (opts []*model.Option, er
opts[k] = dict.GenHashOption(v.Id, gconv.String(v.Name)) opts[k] = dict.GenHashOption(v.Id, gconv.String(v.Name))
} }
return return
} }

View File

@ -3,7 +3,7 @@
// @Copyright Copyright (c) 2024 HotGo CLI // @Copyright Copyright (c) 2024 HotGo CLI
// @Author Ms <133814250@qq.com> // @Author Ms <133814250@qq.com>
// @License https://github.com/bufanyun/hotgo/blob/master/LICENSE // @License https://github.com/bufanyun/hotgo/blob/master/LICENSE
// @AutoGenerate Version 2.15.1 // @AutoGenerate Version 2.15.7
package sysin package sysin
import ( import (
@ -140,4 +140,4 @@ func (in *TestCategoryStatusInp) Filter(ctx context.Context) (err error) {
return return
} }
type TestCategoryStatusModel struct{} type TestCategoryStatusModel struct{}

View File

@ -3,11 +3,11 @@
// @Copyright Copyright (c) 2024 HotGo CLI // @Copyright Copyright (c) 2024 HotGo CLI
// @Author Ms <133814250@qq.com> // @Author Ms <133814250@qq.com>
// @License https://github.com/bufanyun/hotgo/blob/master/LICENSE // @License https://github.com/bufanyun/hotgo/blob/master/LICENSE
// @AutoGenerate Version 2.15.1 // @AutoGenerate Version 2.15.7
package genrouter package genrouter
import "hotgo/internal/controller/admin/sys" import "hotgo/internal/controller/admin/sys"
func init() { func init() {
LoginRequiredRouter = append(LoginRequiredRouter, sys.TestCategory) // 测试分类 LoginRequiredRouter = append(LoginRequiredRouter, sys.TestCategory) // 测试分类
} }

View File

@ -8,9 +8,9 @@
@{ if eq .options.Step.IsOptionTreeTable false }<n-card :bordered="false" class="proCard">@{end} @{ if eq .options.Step.IsOptionTreeTable false }<n-card :bordered="false" class="proCard">@{end}
@{ if eq .options.Step.IsOptionTreeTable true } @{ if eq .options.Step.IsOptionTreeTable true }
<n-grid class="mt-4" cols="1 s:1 m:1 l:4 xl:4 2xl:4" responsive="screen" :x-gap="12"> <n-grid cols="1 s:1 m:1 l:4 xl:4 2xl:4" responsive="screen" :x-gap="12">
<n-gi span="1"> <n-gi span="1">
<n-card :segmented="{ content: true }" :bordered="false" size="small"> <n-card :segmented="{ content: true }" :bordered="false" size="small" class="proCard">
<template #header> <template #header>
<n-space> <n-space>
@{ if eq .options.Step.HasAdd true } @{ if eq .options.Step.HasAdd true }

View File

@ -1,7 +1,7 @@
{ {
"name": "hotgo", "name": "hotgo",
"type": "module", "type": "module",
"version": "2.15.8", "version": "2.15.11",
"author": { "author": {
"name": "MengShuai", "name": "MengShuai",
"email": "133814250@qq.com", "email": "133814250@qq.com",

View File

@ -104,7 +104,8 @@ body .n-icon {
} }
body .proCard { body .proCard {
border-radius: 4px; border-radius: 12px;
margin-top: 12px;
.n-card__content { .n-card__content {
padding: 16px; padding: 16px;
@ -119,11 +120,15 @@ body .n-modal {
border-radius: 6px; border-radius: 6px;
} }
.n-layout-page-header .n-card {
border-radius: 12px;
}
//body .proCardTabs{ //body .proCardTabs{
// .n-card__content{ padding-top: 3px} // .n-card__content{ padding-top: 3px}
// .n-card__content:first-child{ padding-top: 3px} // .n-card__content:first-child{ padding-top: 3px}
//} //}
.n-layout-page-header { .n-layout-page-header {
margin: 0 -10px; margin: 8px 0;
} }

View File

@ -63,3 +63,19 @@ export function goBackOrToPage(to: RouteLocationRaw): void {
}); });
} }
} }
// 更新hash路由get参数不刷新页面
export function pushHashRouterParameter(url, key, value) {
const urlParts = url.split('?');
let newUrl = '';
if (urlParts.length >= 2) {
const baseUrl = urlParts[0];
const queryString = urlParts[1];
const searchParams = new URLSearchParams(queryString);
searchParams.set(key, value);
newUrl = `${baseUrl}?${searchParams.toString()}`;
} else {
newUrl = `${url}?${key}=${value}`;
}
window.history.pushState({ path: newUrl }, '', newUrl);
}

View File

@ -1,6 +1,6 @@
<template> <template>
<div> <div>
<n-grid cols="24 300:1 600:24" :x-gap="24"> <n-grid cols="24 300:1 600:24" :x-gap="12">
<n-grid-item span="6"> <n-grid-item span="6">
<n-card :bordered="false" size="small" class="proCard"> <n-card :bordered="false" size="small" class="proCard">
<n-thing <n-thing

View File

@ -1,6 +1,6 @@
<template> <template>
<div> <div>
<n-card title="应用入口" style="margin-bottom: 16px"> <n-card title="应用入口" class="proCard">
<n-tabs type="line" animated> <n-tabs type="line" animated>
<n-tab-pane name="admin" tab="后台API"> <n-tab-pane name="admin" tab="后台API">
<Form path="/admin/hgexample/index/test?name=HotGo" /> <Form path="/admin/hgexample/index/test?name=HotGo" />

View File

@ -3,9 +3,9 @@
<div class="n-layout-page-header"> <div class="n-layout-page-header">
<n-card :bordered="false" title="表格例子"> 一个树形表格例子 </n-card> <n-card :bordered="false" title="表格例子"> 一个树形表格例子 </n-card>
</div> </div>
<n-grid class="mt-6" cols="1 s:1 m:1 l:4 xl:4 2xl:4" responsive="screen" :x-gap="12"> <n-grid cols="1 s:1 m:1 l:4 xl:4 2xl:4" responsive="screen" :x-gap="12">
<n-gi span="1"> <n-gi span="1">
<n-card :segmented="{ content: true }" :bordered="false" size="small"> <n-card :segmented="{ content: true }" :bordered="false" size="small" class="proCard">
<template #header> <template #header>
<n-space> <n-space>
<n-button type="info" icon-placement="left" @click="openCreateDrawer"> <n-button type="info" icon-placement="left" @click="openCreateDrawer">
@ -88,7 +88,7 @@
</n-card> </n-card>
</n-gi> </n-gi>
<n-gi span="3"> <n-gi span="3">
<n-card :segmented="{ content: true }" :bordered="false" size="small"> <n-card :segmented="{ content: true }" :bordered="false" size="small" class="proCard">
<template #header> <template #header>
<n-space> <n-space>
<n-icon size="18"> <n-icon size="18">

View File

@ -3,9 +3,9 @@
<div class="n-layout-page-header"> <div class="n-layout-page-header">
<n-card :bordered="false" title="省市区"> 中国省市区编码对照表 </n-card> <n-card :bordered="false" title="省市区"> 中国省市区编码对照表 </n-card>
</div> </div>
<n-grid class="mt-6" cols="1 s:1 m:1 l:4 xl:4 2xl:4" responsive="screen" :x-gap="12"> <n-grid cols="1 s:1 m:1 l:4 xl:4 2xl:4" responsive="screen" :x-gap="12">
<n-gi span="1"> <n-gi span="1">
<n-card :segmented="{ content: true }" :bordered="false" size="small"> <n-card :segmented="{ content: true }" :bordered="false" size="small" class="proCard">
<template #header> <template #header>
<n-space> <n-space>
<n-button type="info" icon-placement="left" @click="openCreateDrawer"> <n-button type="info" icon-placement="left" @click="openCreateDrawer">
@ -88,7 +88,7 @@
</n-card> </n-card>
</n-gi> </n-gi>
<n-gi span="3"> <n-gi span="3">
<n-card :segmented="{ content: true }" :bordered="false" size="small"> <n-card :segmented="{ content: true }" :bordered="false" size="small" class="proCard">
<template #header> <template #header>
<n-space> <n-space>
<n-icon size="18"> <n-icon size="18">

View File

@ -1,10 +1,6 @@
<template> <template>
<div> <div>
<div class="n-layout-page-header"> <n-card :bordered="false" class="proCard" title="提现管理">
<n-card :bordered="false" title="提现管理" />
</div>
<n-card :bordered="false" class="proCard">
<n-tabs <n-tabs
type="card" type="card"
class="card-tabs" class="card-tabs"

View File

@ -4,7 +4,7 @@
<n-card :bordered="false" title="在线充值"> 余额可用于购买付费产品或商城消费 </n-card> <n-card :bordered="false" title="在线充值"> 余额可用于购买付费产品或商城消费 </n-card>
</div> </div>
<n-spin :show="loading"> <n-spin :show="loading">
<n-grid class="mt-6" cols="1 s:1 m:1 l:4 xl:4 2xl:4" responsive="screen" :x-gap="12"> <n-grid cols="1 s:1 m:1 l:4 xl:4 2xl:4" responsive="screen" :x-gap="12">
<n-gi span="4"> <n-gi span="4">
<n-card :bordered="false" class="proCard"> <n-card :bordered="false" class="proCard">
<n-thing> <n-thing>

View File

@ -1,9 +1,6 @@
<template> <template>
<div> <div>
<div class="n-layout-page-header"> <n-card :bordered="false" title="充值记录" class="proCard">
<n-card :bordered="false" title="充值记录" />
</div>
<n-card :bordered="false" class="proCard">
<n-tabs <n-tabs
type="card" type="card"
class="card-tabs" class="card-tabs"

View File

@ -1,5 +1,5 @@
<template> <template>
<div> <div class="mt-2">
<Company v-if="userStore.isCompanyDept" /> <Company v-if="userStore.isCompanyDept" />
<Tenant v-else-if="userStore.isTenantDept" /> <Tenant v-else-if="userStore.isTenantDept" />
<Merchant v-else-if="userStore.isMerchantDept" /> <Merchant v-else-if="userStore.isMerchantDept" />

View File

@ -1,6 +1,6 @@
<template> <template>
<div> <div>
<div class="n-layout-page-header"> <div class="mt-2">
<n-card :bordered="false" title="工作台"> <n-card :bordered="false" title="工作台">
<n-grid cols="2 s:1 m:1 l:2 xl:2 2xl:2" responsive="screen"> <n-grid cols="2 s:1 m:1 l:2 xl:2 2xl:2" responsive="screen">
<n-gi> <n-gi>

View File

@ -1,7 +1,7 @@
<template> <template>
<div> <div>
<n-spin :show="show" description="正在生成配置信息..."> <n-spin :show="show" description="正在生成配置信息...">
<n-card> <n-card class="proCard">
<n-tabs <n-tabs
type="card" type="card"
class="card-tabs" class="card-tabs"

View File

@ -1,6 +1,6 @@
<template> <template>
<div> <div>
<n-grid cols="24 300:1 600:24" :x-gap="24"> <n-grid cols="24 300:1 600:24" :x-gap="12">
<n-grid-item span="6"> <n-grid-item span="6">
<n-card :bordered="false" class="proCard"> <n-card :bordered="false" class="proCard">
<n-thing <n-thing
@ -33,6 +33,7 @@
import CashSetting from './CashSetting.vue'; import CashSetting from './CashSetting.vue';
import ThirdBind from './ThirdBind.vue'; import ThirdBind from './ThirdBind.vue';
import { useRouter } from 'vue-router'; import { useRouter } from 'vue-router';
import {pushHashRouterParameter} from "@/utils/urlUtils";
const router = useRouter(); const router = useRouter();
const type = ref(1); const type = ref(1);
@ -81,6 +82,7 @@
function switchType(e) { function switchType(e) {
type.value = e.key; type.value = e.key;
typeTitle.value = e.name; typeTitle.value = e.name;
pushHashRouterParameter(window.location.href, 'type', e.key);
} }
</script> </script>
<style lang="less" scoped> <style lang="less" scoped>

View File

@ -1,9 +1,6 @@
<template> <template>
<div> <div>
<div class="n-layout-page-header"> <n-card :bordered="false" class="proCard" title="在线用户">
<n-card :bordered="false" title="在线用户" />
</div>
<n-card :bordered="false" class="proCard">
<BasicForm @register="register" @submit="handleSubmit" @reset="handleReset"> <BasicForm @register="register" @submit="handleSubmit" @reset="handleReset">
<template #statusSlot="{ model, field }"> <template #statusSlot="{ model, field }">
<n-input v-model:value="model[field]" /> <n-input v-model:value="model[field]" />

View File

@ -5,9 +5,9 @@
<!-- 这是由系统生成的CURD表格你可以将此行注释改为表格的描述 --> <!-- 这是由系统生成的CURD表格你可以将此行注释改为表格的描述 -->
</n-card> </n-card>
</div> </div>
<n-grid class="mt-4" cols="1 s:1 m:1 l:4 xl:4 2xl:4" responsive="screen" :x-gap="12"> <n-grid cols="1 s:1 m:1 l:4 xl:4 2xl:4" responsive="screen" :x-gap="12">
<n-gi span="1"> <n-gi span="1">
<n-card :segmented="{ content: true }" :bordered="false" size="small"> <n-card :segmented="{ content: true }" :bordered="false" size="small" class="proCard">
<template #header> <template #header>
<n-space> <n-space>
<n-button type="info" icon-placement="left" @click="addTable" v-if="hasPermission(['/optionTreeDemo/edit'])"> <n-button type="info" icon-placement="left" @click="addTable" v-if="hasPermission(['/optionTreeDemo/edit'])">

View File

@ -1,11 +1,6 @@
<template> <template>
<div> <div>
<div class="n-layout-page-header"> <n-card :bordered="false" class="proCard" title="部门管理">
<n-card :bordered="false" title="部门管理">
<!-- 这是由系统生成的CURD表格你可以将此行注释改为表格的描述 -->
</n-card>
</div>
<n-card :bordered="false" class="proCard">
<BasicForm <BasicForm
ref="searchFormRef" ref="searchFormRef"
@register="register" @register="register"

View File

@ -1,9 +1,6 @@
<template> <template>
<div> <div>
<div class="n-layout-page-header"> <n-card :bordered="false" class="proCard" title="后台用户">
<n-card :bordered="false" title="后台用户" />
</div>
<n-card :bordered="false" class="proCard">
<n-tabs <n-tabs
type="card" type="card"
class="card-tabs" class="card-tabs"

View File

@ -6,13 +6,12 @@
</n-card> </n-card>
</div> </div>
<n-grid <n-grid
:class="isModal ? '' : 'mt-4'"
cols="1 s:1 m:1 l:3 xl:3 2xl:3" cols="1 s:1 m:1 l:3 xl:3 2xl:3"
responsive="screen" responsive="screen"
:x-gap="12" :x-gap="12"
> >
<n-gi span="1"> <n-gi span="1">
<n-card :segmented="{ content: true }" :bordered="false" size="small"> <n-card :segmented="{ content: true }" :bordered="false" size="small" class="proCard">
<template #header> <template #header>
<n-space> <n-space>
<n-button type="info" icon-placement="left" @click="openCreateDrawer"> <n-button type="info" icon-placement="left" @click="openCreateDrawer">
@ -85,7 +84,7 @@
</n-card> </n-card>
</n-gi> </n-gi>
<n-gi span="2"> <n-gi span="2">
<n-card :segmented="{ content: true }" :bordered="false" size="small"> <n-card :segmented="{ content: true }" :bordered="false" size="small" class="proCard">
<template #header> <template #header>
<n-space> <n-space>
<n-icon size="18"> <n-icon size="18">

View File

@ -1,6 +1,6 @@
<template> <template>
<div> <div>
<n-card :bordered="false" title="角色管理"> <n-card :bordered="false" class="proCard" title="角色管理">
<n-space vertical :size="12"> <n-space vertical :size="12">
<n-space> <n-space>
<n-button type="primary" @click="addTable"> <n-button type="primary" @click="addTable">

View File

@ -1,6 +1,6 @@
<template> <template>
<div> <div>
<n-grid cols="24 300:1 600:24" :x-gap="24"> <n-grid cols="24 300:1 600:24" :x-gap="12">
<n-grid-item span="6"> <n-grid-item span="6">
<n-card :bordered="false" size="small" class="proCard"> <n-card :bordered="false" size="small" class="proCard">
<n-thing <n-thing
@ -34,7 +34,9 @@
</div> </div>
</template> </template>
<script lang="ts"> <script lang="ts">
import { defineAsyncComponent, defineComponent, reactive, toRefs } from 'vue'; import { defineAsyncComponent, defineComponent, reactive, toRefs, onMounted } from 'vue';
import { useRouter } from 'vue-router';
import { pushHashRouterParameter } from '@/utils/urlUtils';
/** 异步加载的组件,用到的时候再加载组件 */ /** 异步加载的组件,用到的时候再加载组件 */
const BasicSetting = defineAsyncComponent(() => { const BasicSetting = defineAsyncComponent(() => {
return import('./BasicSetting.vue'); return import('./BasicSetting.vue');
@ -141,6 +143,7 @@
LoginSetting, LoginSetting,
}, },
setup() { setup() {
const router = useRouter();
const state = reactive({ const state = reactive({
type: 1, type: 1,
typeTitle: '基本设置', typeTitle: '基本设置',
@ -149,8 +152,26 @@
function switchType(e) { function switchType(e) {
state.type = e.key; state.type = e.key;
state.typeTitle = e.name; state.typeTitle = e.name;
pushHashRouterParameter(window.location.href, 'type', e.key);
} }
function setDefaultOption() {
const key = router.currentRoute.value.query.type as unknown as number;
if (key !== undefined && key > 0) {
for (const item of typeTabList) {
if (item.key == key) {
switchType(item);
}
}
}
}
onMounted(() => {
if (router.currentRoute.value.query?.type) {
setDefaultOption();
}
});
return { return {
...toRefs(state), ...toRefs(state),
switchType, switchType,

View File

@ -5,9 +5,9 @@
可代替后台管理系统设置的大量枚举值和配置统一标准化管理随时修改或增加 可代替后台管理系统设置的大量枚举值和配置统一标准化管理随时修改或增加
</n-card> </n-card>
</div> </div>
<n-grid class="mt-6" cols="1 s:1 m:1 l:4 xl:4 2xl:4" responsive="screen" :x-gap="12"> <n-grid cols="1 s:1 m:1 l:4 xl:4 2xl:4" responsive="screen" :x-gap="12">
<n-gi span="1"> <n-gi span="1">
<n-card :segmented="{ content: true }" :bordered="false" size="small"> <n-card :segmented="{ content: true }" :bordered="false" size="small" class="proCard">
<template #header> <template #header>
<n-space> <n-space>
<n-button type="info" icon-placement="left" @click="openCreateDrawer"> <n-button type="info" icon-placement="left" @click="openCreateDrawer">
@ -90,7 +90,7 @@
</n-card> </n-card>
</n-gi> </n-gi>
<n-gi span="3"> <n-gi span="3">
<n-card :segmented="{ content: true }" :bordered="false" size="small"> <n-card :segmented="{ content: true }" :bordered="false" size="small" class="proCard">
<template #header> <template #header>
<n-space> <n-space>
<n-icon size="18"> <n-icon size="18">

View File

@ -92,6 +92,34 @@
return adaModalWidth(840); return adaModalWidth(840);
}); });
//
function confirmForm(e) {
e.preventDefault();
formRef.value.validate((errors) => {
if (!errors) {
formBtnLoading.value = true;
Edit(formValue.value)
.then((_res) => {
message.success('操作成功');
closeForm();
emit('reloadTable');
})
.finally(() => {
formBtnLoading.value = false;
});
} else {
message.error('请填写完整信息');
}
});
}
//
function closeForm() {
showModal.value = false;
loading.value = false;
}
//
function openModal(state: State) { function openModal(state: State) {
showModal.value = true; showModal.value = true;
@ -121,33 +149,6 @@
}); });
} }
//
function confirmForm(e) {
e.preventDefault();
formRef.value.validate((errors) => {
if (!errors) {
formBtnLoading.value = true;
Edit(formValue.value)
.then((_res) => {
message.success('操作成功');
closeForm();
emit('reloadTable');
})
.finally(() => {
formBtnLoading.value = false;
});
} else {
message.error('请填写完整信息');
}
});
}
//
function closeForm() {
showModal.value = false;
loading.value = false;
}
defineExpose({ defineExpose({
openModal, openModal,
}); });

View File

@ -49,13 +49,13 @@
import { adaTableScrollX } from '@/utils/hotgo'; import { adaTableScrollX } from '@/utils/hotgo';
import Edit from './edit.vue'; import Edit from './edit.vue';
const dict = useDictStore();
const dialog = useDialog(); const dialog = useDialog();
const message = useMessage(); const message = useMessage();
const { hasPermission } = usePermission(); const { hasPermission } = usePermission();
const actionRef = ref(); const actionRef = ref();
const searchFormRef = ref<any>({}); const searchFormRef = ref<any>({});
const editRef = ref(); const editRef = ref();
const dict = useDictStore();
const checkedIds = ref([]); const checkedIds = ref([]);
@ -64,7 +64,7 @@
title: '操作', title: '操作',
key: 'action', key: 'action',
fixed: 'right', fixed: 'right',
render(record) { render(record: State) {
return h(TableAction as any, { return h(TableAction as any, {
style: 'button', style: 'button',
actions: [ actions: [

View File

@ -1,11 +1,9 @@
import { h, ref } from 'vue'; import { h, ref } from 'vue';
import { NTag } from 'naive-ui';
import { cloneDeep } from 'lodash-es'; import { cloneDeep } from 'lodash-es';
import { FormSchema } from '@/components/Form'; import { FormSchema } from '@/components/Form';
import { isNullObject } from '@/utils/is';
import { defRangeShortcuts } from '@/utils/dateUtil'; import { defRangeShortcuts } from '@/utils/dateUtil';
import { renderOptionTag } from '@/utils';
import { useDictStore } from '@/store/modules/dict'; import { useDictStore } from '@/store/modules/dict';
import type { FormRules } from 'naive-ui/es/form/src/interface';
const dict = useDictStore(); const dict = useDictStore();
@ -39,7 +37,7 @@ export function newState(state: State | Record<string, any> | null): State {
} }
// 表单验证规则 // 表单验证规则
export const rules: FormRules = { export const rules = {
name: { name: {
required: true, required: true,
trigger: ['blur', 'input'], trigger: ['blur', 'input'],
@ -137,23 +135,8 @@ export const columns = [
key: 'status', key: 'status',
align: 'left', align: 'left',
width: -1, width: -1,
render(row) { render(row: State) {
if (isNullObject(row.status)) { return renderOptionTag('sys_normal_disable', row.status);
return ``;
}
return h(
NTag,
{
style: {
marginRight: '6px',
},
type: dict.getType('sys_normal_disable', row.status),
bordered: false,
},
{
default: () => dict.getLabel('sys_normal_disable', row.status),
}
);
}, },
}, },
{ {
@ -167,4 +150,4 @@ export const columns = [
// 加载字典数据选项 // 加载字典数据选项
export function loadOptions() { export function loadOptions() {
dict.loadOptions(['sys_normal_disable']); dict.loadOptions(['sys_normal_disable']);
} }