forked from YaoApp/yao
-
Notifications
You must be signed in to change notification settings - Fork 0
/
lang.go
98 lines (78 loc) · 2.14 KB
/
lang.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
package table
// Lang for applying a language pack
func (table *Table) Lang(trans func(widget string, inst string, value *string) bool) {
inst := table.Table
widget := "table"
trans(widget, inst, &table.Name)
trans(widget, inst, &table.Decription)
// Columns
for name, column := range table.Columns {
new := name
trans(widget, inst, &new)
trans(widget, inst, &column.Label)
// Props
transMap(widget, inst, column.Edit.Props, trans)
transMap(widget, inst, column.View.Props, trans)
transMap(widget, inst, column.Form.Props, trans)
delete(table.Columns, name)
table.Columns[new] = column
}
// Filters
for name, filter := range table.Filters {
new := name
trans(widget, inst, &new)
trans(widget, inst, &filter.Label)
delete(table.Filters, name)
// Props
transMap(widget, inst, filter.Input.Props, trans)
table.Filters[new] = filter
}
// List
transMap(widget, inst, table.List.Layout, trans)
transMap(widget, inst, table.List.Option, trans)
// Edit
transMap(widget, inst, table.Edit.Layout, trans)
transMap(widget, inst, table.Edit.Option, trans)
}
func transMap(widget string, inst string, values map[string]interface{}, trans func(widget string, inst string, value *string) bool) {
for key, value := range values {
switch value.(type) {
case string:
v := value.(string)
trans(widget, inst, &v)
values[key] = v
break
case []interface{}:
v := value.([]interface{})
transArr(widget, inst, v, trans)
values[key] = v
break
case map[string]interface{}:
v := value.(map[string]interface{})
transMap(widget, inst, v, trans)
values[key] = v
break
}
}
}
func transArr(widget string, inst string, values []interface{}, trans func(widget string, inst string, value *string) bool) {
for key, value := range values {
switch value.(type) {
case string:
v := value.(string)
trans(widget, inst, &v)
values[key] = v
break
case []interface{}:
v := value.([]interface{})
transArr(widget, inst, v, trans)
values[key] = v
break
case map[string]interface{}:
v := value.(map[string]interface{})
transMap(widget, inst, v, trans)
values[key] = v
break
}
}
}