summaryrefslogtreecommitdiffstats
path: root/modules
diff options
context:
space:
mode:
author赵智超 <1012112796@qq.com>2020-09-16 12:07:18 +0800
committerGitHub <noreply@github.com>2020-09-16 00:07:18 -0400
commita9decf0dacb56e57024ef7c5a0ade7fdcc56407e (patch)
treef6d1d48eaa324530b93af2780ff2297e11b39e25 /modules
parentd8b5235dedbb69812aeb43218a8d35938259a1c3 (diff)
downloadgitea-a9decf0dacb56e57024ef7c5a0ade7fdcc56407e.tar.gz
gitea-a9decf0dacb56e57024ef7c5a0ade7fdcc56407e.zip
Use a simple format for the big number on ui (#12822)
* Use a simple format for the big number on ui Signed-off-by: a1012112796 <1012112796@qq.com> * make fmt * Apply review suggestion @silverwind * Change name 2 * make fmt Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com>
Diffstat (limited to 'modules')
-rw-r--r--modules/base/tool.go24
-rw-r--r--modules/base/tool_test.go8
-rw-r--r--modules/templates/helper.go5
3 files changed, 35 insertions, 2 deletions
diff --git a/modules/base/tool.go b/modules/base/tool.go
index e1a1b661be..a21fd9b0f4 100644
--- a/modules/base/tool.go
+++ b/modules/base/tool.go
@@ -420,3 +420,27 @@ func SetupGiteaRoot() string {
}
return giteaRoot
}
+
+// FormatNumberSI format a number
+func FormatNumberSI(data interface{}) string {
+ var num int64
+ if num1, ok := data.(int64); ok {
+ num = num1
+ } else if num1, ok := data.(int); ok {
+ num = int64(num1)
+ } else {
+ return ""
+ }
+
+ if num < 1000 {
+ return fmt.Sprintf("%d", num)
+ } else if num < 1000000 {
+ num2 := float32(num) / float32(1000.0)
+ return fmt.Sprintf("%.1fk", num2)
+ } else if num < 1000000000 {
+ num2 := float32(num) / float32(1000000.0)
+ return fmt.Sprintf("%.1fM", num2)
+ }
+ num2 := float32(num) / float32(1000000000.0)
+ return fmt.Sprintf("%.1fG", num2)
+}
diff --git a/modules/base/tool_test.go b/modules/base/tool_test.go
index cadb851858..f765fd0db0 100644
--- a/modules/base/tool_test.go
+++ b/modules/base/tool_test.go
@@ -223,5 +223,13 @@ func TestIsTextFile(t *testing.T) {
assert.True(t, IsTextFile([]byte("lorem ipsum")))
}
+func TestFormatNumberSI(t *testing.T) {
+ assert.Equal(t, "125", FormatNumberSI(int(125)))
+ assert.Equal(t, "1.3k", FormatNumberSI(int64(1317)))
+ assert.Equal(t, "21.3M", FormatNumberSI(21317675))
+ assert.Equal(t, "45.7G", FormatNumberSI(45721317675))
+ assert.Equal(t, "", FormatNumberSI("test"))
+}
+
// TODO: IsImageFile(), currently no idea how to test
// TODO: IsPDFFile(), currently no idea how to test
diff --git a/modules/templates/helper.go b/modules/templates/helper.go
index 9e1c2fd381..63be27d987 100644
--- a/modules/templates/helper.go
+++ b/modules/templates/helper.go
@@ -120,8 +120,9 @@ func NewFuncMap() []template.FuncMap {
"DateFmtShort": func(t time.Time) string {
return t.Format("Jan 02, 2006")
},
- "SizeFmt": base.FileSize,
- "List": List,
+ "SizeFmt": base.FileSize,
+ "CountFmt": base.FormatNumberSI,
+ "List": List,
"SubStr": func(str string, start, length int) string {
if len(str) == 0 {
return ""