imba-localization 0.3.8 → 0.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/localization.imba +17 -7
- package/package.json +1 -1
package/localization.imba
CHANGED
|
@@ -17,11 +17,11 @@ export class Localization
|
|
|
17
17
|
|
|
18
18
|
return new Proxy self, {
|
|
19
19
|
get: do(target, p, receiver)
|
|
20
|
+
return Reflect.get(target, p, receiver) if self[p] !== undefined
|
|
20
21
|
if !ready
|
|
21
|
-
console.log("Request before localization is ready", p)
|
|
22
|
+
console.log("Request before localization is ready:", p)
|
|
22
23
|
return
|
|
23
24
|
return if errors[p]
|
|
24
|
-
return Reflect.get(target, p, receiver) if self[p]
|
|
25
25
|
return target.languages[p] if target.languages[p]
|
|
26
26
|
return target.languages[active][p] if target.languages[active] and target.languages[active][p]
|
|
27
27
|
if !errors[p]
|
|
@@ -45,6 +45,7 @@ export class Localization
|
|
|
45
45
|
console.log('There is no Localization for the default language', default)
|
|
46
46
|
return
|
|
47
47
|
ready = true
|
|
48
|
+
errors = {}
|
|
48
49
|
onready! if onready isa Function
|
|
49
50
|
onchange(active) if onchange isa Function
|
|
50
51
|
|
|
@@ -81,8 +82,17 @@ tag language-selector
|
|
|
81
82
|
data = key
|
|
82
83
|
state.active = key
|
|
83
84
|
|
|
84
|
-
def
|
|
85
|
-
|
|
85
|
+
def flag language
|
|
86
|
+
let settings = language.$
|
|
87
|
+
return undefined if !settings
|
|
88
|
+
let flag = settings.flag
|
|
89
|
+
return undefined if !flag
|
|
90
|
+
return icons.replace('##',flag)
|
|
91
|
+
|
|
92
|
+
def name language
|
|
93
|
+
let settings = language.$
|
|
94
|
+
return undefined if !settings
|
|
95
|
+
return settings.name
|
|
86
96
|
|
|
87
97
|
def mouseleave e
|
|
88
98
|
return if passive
|
|
@@ -114,7 +124,7 @@ tag language-selector
|
|
|
114
124
|
|
|
115
125
|
<self [pos:rel] @mouseenter=mouseenter @mouseleave=mouseleave @click=click>
|
|
116
126
|
<div.container [pos:rel d:hcc] .active=#dropdown>
|
|
117
|
-
<img.flag src=
|
|
127
|
+
<img.flag src=flag(state[state.active])>
|
|
118
128
|
<div.name> state.$.name
|
|
119
129
|
<svg.arrow [ead:$ease] .active=#dropdown viewBox="0 0 256 256">
|
|
120
130
|
<{arrow}>
|
|
@@ -123,5 +133,5 @@ tag language-selector
|
|
|
123
133
|
<div$menu.menu [pos:abs w:100% > max-content o@off:0] ease>
|
|
124
134
|
for own key, value of state.languages
|
|
125
135
|
<div.item @click.trap=onselect(key) [d:none]=(key == state.active)>
|
|
126
|
-
<img.icon src=
|
|
127
|
-
<span.text> value
|
|
136
|
+
<img.icon src=flag(value)>
|
|
137
|
+
<span.text> name(value)
|