diff --git a/assets/icons/laptop.svg b/assets/icons/laptop.svg
new file mode 100644
index 0000000..9465da2
--- /dev/null
+++ b/assets/icons/laptop.svg
@@ -0,0 +1,10 @@
+
diff --git a/assets/icons/moon.svg b/assets/icons/moon.svg
new file mode 100644
index 0000000..d88604f
--- /dev/null
+++ b/assets/icons/moon.svg
@@ -0,0 +1,11 @@
+
+
+
+
diff --git a/assets/icons/sun.max.svg b/assets/icons/sun.max.svg
new file mode 100644
index 0000000..11daf1c
--- /dev/null
+++ b/assets/icons/sun.max.svg
@@ -0,0 +1,12 @@
+
+
+
+
diff --git a/assets/lotties/list.json b/assets/lotties/list.json
new file mode 100644
index 0000000..112dcff
--- /dev/null
+++ b/assets/lotties/list.json
@@ -0,0 +1 @@
+{"v":"4.8.0","meta":{"g":"LottieFiles AE 3.5.1","a":"","k":"","d":"","tc":""},"fr":29.9700012207031,"ip":0,"op":90.0000036657751,"w":320,"h":180,"nm":"Comp 1","ddd":0,"assets":[],"layers":[{"ddd":0,"ind":1,"ty":3,"nm":"Null 1","sr":1,"ks":{"o":{"a":0,"k":0,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[57.75,-4.875,0],"ix":2},"a":{"a":0,"k":[0,0,0],"ix":1},"s":{"a":0,"k":[185,185,100],"ix":6}},"ao":0,"ip":0,"op":300.00001221925,"st":0,"bm":0,"completed":true},{"ddd":0,"ind":2,"ty":4,"nm":"Shape Layer 3","parent":1,"sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":1,"k":[{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":0,"s":[50.316,21.361,0],"to":null,"ti":null},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":5,"s":[50.316,21.361,0],"to":null,"ti":null},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":11,"s":[40.19,21.361,0],"to":null,"ti":null},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":18,"s":[40.19,21.361,0],"to":null,"ti":null},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":26,"s":[40.19,77.69,0],"to":null,"ti":null},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":29,"s":[40.19,77.69,0],"to":null,"ti":null},{"t":34.0000013848484,"s":[50.316,77.69,0]}],"ix":2},"a":{"a":0,"k":[-124.75,-51,0],"ix":1},"s":{"a":0,"k":[126.582,126.582,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ty":"rc","d":1,"s":{"a":0,"k":[61.5,15.75],"ix":2},"p":{"a":0,"k":[0,0],"ix":3},"r":{"a":0,"k":4,"ix":4},"nm":"Rectangle Path 1","mn":"ADBE Vector Shape - Rect","hd":false,"_render":true},{"ty":"fl","c":{"a":0,"k":[0.451,0.3412,1,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false,"_render":true},{"ty":"tr","p":{"a":0,"k":[-125,-50.625],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform","_render":true}],"nm":"Rectangle 1","np":3,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false,"_render":true}],"ip":0,"op":300.00001221925,"st":0,"bm":0,"completed":true},{"ddd":0,"ind":3,"ty":4,"nm":"Shape Layer 2","parent":1,"sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":1,"k":[{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":0,"s":[50.316,49.525,0],"to":null,"ti":null},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":23,"s":[50.316,49.525,0],"to":null,"ti":null},{"t":27.0000010997325,"s":[50.316,21.361,0]}],"ix":2},"a":{"a":0,"k":[-124.75,-51,0],"ix":1},"s":{"a":0,"k":[126.582,126.582,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ty":"rc","d":1,"s":{"a":0,"k":[61.5,15.75],"ix":2},"p":{"a":0,"k":[0,0],"ix":3},"r":{"a":0,"k":4,"ix":4},"nm":"Rectangle Path 1","mn":"ADBE Vector Shape - Rect","hd":false,"_render":true},{"ty":"fl","c":{"a":0,"k":[0.451,0.3412,1,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false,"_render":true},{"ty":"tr","p":{"a":0,"k":[-125,-50.625],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform","_render":true}],"nm":"Rectangle 1","np":3,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false,"_render":true}],"ip":0,"op":300.00001221925,"st":0,"bm":0,"completed":true},{"ddd":0,"ind":4,"ty":4,"nm":"Shape Layer 1","parent":1,"sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":1,"k":[{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":0,"s":[50.316,77.69,0],"to":null,"ti":null},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":24,"s":[50.316,77.69,0],"to":null,"ti":null},{"t":27.0000010997325,"s":[50.316,49.525,0]}],"ix":2},"a":{"a":0,"k":[-124.75,-51,0],"ix":1},"s":{"a":0,"k":[126.582,126.582,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ty":"rc","d":1,"s":{"a":0,"k":[61.5,15.75],"ix":2},"p":{"a":0,"k":[0,0],"ix":3},"r":{"a":0,"k":4,"ix":4},"nm":"Rectangle Path 1","mn":"ADBE Vector Shape - Rect","hd":false,"_render":true},{"ty":"fl","c":{"a":0,"k":[0.451,0.3412,1,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false,"_render":true},{"ty":"tr","p":{"a":0,"k":[-125,-50.625],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform","_render":true}],"nm":"Rectangle 1","np":3,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false,"_render":true}],"ip":0,"op":300.00001221925,"st":0,"bm":0,"completed":true}],"markers":[],"__complete":true}
\ No newline at end of file
diff --git a/assets/lotties/radar.json b/assets/lotties/radar.json
index 7f97fef..2f3411e 100644
--- a/assets/lotties/radar.json
+++ b/assets/lotties/radar.json
@@ -1 +1,1123 @@
-{"v":"5.5.7","meta":{"g":"LottieFiles AE 0.1.20","a":"","k":"","d":"","tc":""},"fr":29.9700012207031,"ip":0,"op":90.0000036657751,"w":618,"h":618,"nm":"ladar","ddd":0,"assets":[{"id":"image_0","w":618,"h":618,"u":"","p":"","e":1},{"id":"comp_0","layers":[{"ddd":0,"ind":1,"ty":4,"nm":"Shape Layer 1","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[250,260.75,0],"ix":2},"a":{"a":0,"k":[0,11,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"d":1,"ty":"el","s":{"a":0,"k":[28.733,28.733],"ix":2},"p":{"a":0,"k":[0,0],"ix":3},"nm":"Ellipse Path 1","mn":"ADBE Vector Shape - Ellipse","hd":false},{"ty":"st","c":{"a":0,"k":[1,1,1,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":0,"ix":5},"lc":1,"lj":1,"ml":4,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"fl","c":{"a":0,"k":[0.4,0.4,1,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[0.367,10.367],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Ellipse 1","np":3,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false}],"ip":0,"op":24.00000097754,"st":0,"bm":0},{"ddd":0,"ind":2,"ty":4,"nm":"Shape Layer 2","sr":1,"ks":{"o":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":0,"s":[60]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":11,"s":[100]},{"t":20.0000008146167,"s":[60]}],"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[249.75,260.75,0],"ix":2},"a":{"a":0,"k":[0,11,0],"ix":1},"s":{"a":1,"k":[{"i":{"x":[0.667,0.667,0.667],"y":[1,1,1]},"o":{"x":[0.333,0.333,0.333],"y":[0,0,0]},"t":0,"s":[150,150,100]},{"i":{"x":[0.833,0.833,0.833],"y":[1,1,1]},"o":{"x":[0.167,0.167,0.167],"y":[0,0,0]},"t":11,"s":[199,199,100]},{"t":20.0000008146167,"s":[150,150,100]}],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"d":1,"ty":"el","s":{"a":0,"k":[28.733,28.733],"ix":2},"p":{"a":0,"k":[0,0],"ix":3},"nm":"Ellipse Path 1","mn":"ADBE Vector Shape - Ellipse","hd":false},{"ty":"st","c":{"a":0,"k":[1,1,1,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":0,"ix":5},"lc":1,"lj":1,"ml":4,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"fl","c":{"a":0,"k":[1,1,1,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[0.396,10.413],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Ellipse 1","np":3,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false}],"ip":0,"op":24.00000097754,"st":0,"bm":0}]}],"layers":[{"ddd":0,"ind":1,"ty":0,"nm":"Loca","refId":"comp_0","sr":1,"ks":{"o":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":68,"s":[0]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":73,"s":[100]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":84,"s":[100]},{"t":90.0000036657751,"s":[0]}],"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[85,315,0],"ix":2},"a":{"a":0,"k":[250,250,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"w":500,"h":500,"ip":68.0000027696968,"op":90.0000036657751,"st":68.0000027696968,"bm":0},{"ddd":0,"ind":2,"ty":0,"nm":"Loca","refId":"comp_0","sr":1,"ks":{"o":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":61,"s":[0]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":66,"s":[100]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":80,"s":[100]},{"t":86.0000035028518,"s":[0]}],"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[243,383,0],"ix":2},"a":{"a":0,"k":[250,250,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"w":500,"h":500,"ip":61.0000024845809,"op":88.0000035843135,"st":61.0000024845809,"bm":0},{"ddd":0,"ind":3,"ty":0,"nm":"Loca","refId":"comp_0","sr":1,"ks":{"o":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":34,"s":[0]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":39,"s":[100]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":53,"s":[100]},{"t":59.0000024031193,"s":[0]}],"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[401,399,0],"ix":2},"a":{"a":0,"k":[250,250,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"w":500,"h":500,"ip":34.0000013848484,"op":61.0000024845809,"st":34.0000013848484,"bm":0},{"ddd":0,"ind":4,"ty":0,"nm":"Loca","refId":"comp_0","sr":1,"ks":{"o":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":11,"s":[0]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":16,"s":[100]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":30,"s":[100]},{"t":36.0000014663101,"s":[0]}],"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[375,205,0],"ix":2},"a":{"a":0,"k":[250,250,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"w":500,"h":500,"ip":11.0000004480392,"op":38.0000015477717,"st":11.0000004480392,"bm":0},{"ddd":0,"ind":5,"ty":2,"nm":"ladar.png","cl":"png","refId":"image_0","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":0,"s":[0]},{"t":90.0000036657751,"s":[360]}],"ix":10},"p":{"a":0,"k":[309,309,0],"ix":2},"a":{"a":0,"k":[309,309,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":120.0000048877,"st":0,"bm":0}],"markers":[]}
\ No newline at end of file
+{
+ "v": "5.5.7",
+ "meta": {
+ "g": "LottieFiles AE 0.1.20",
+ "a": "",
+ "k": "",
+ "d": "",
+ "tc": ""
+ },
+ "fr": 29.9700012207031,
+ "ip": 0,
+ "op": 90.0000036657751,
+ "w": 618,
+ "h": 618,
+ "nm": "ladar",
+ "ddd": 0,
+ "assets": [
+ {
+ "id": "image_0",
+ "w": 618,
+ "h": 618,
+ "u": "",
+ "p": "",
+ "e": 1
+ },
+ {
+ "id": "comp_0",
+ "layers": [
+ {
+ "ddd": 0,
+ "ind": 1,
+ "ty": 4,
+ "nm": "Shape Layer 1",
+ "sr": 1,
+ "ks": {
+ "o": {
+ "a": 0,
+ "k": 100,
+ "ix": 11
+ },
+ "r": {
+ "a": 0,
+ "k": 0,
+ "ix": 10
+ },
+ "p": {
+ "a": 0,
+ "k": [
+ 250,
+ 260.75,
+ 0
+ ],
+ "ix": 2
+ },
+ "a": {
+ "a": 0,
+ "k": [
+ 0,
+ 11,
+ 0
+ ],
+ "ix": 1
+ },
+ "s": {
+ "a": 0,
+ "k": [
+ 100,
+ 100,
+ 100
+ ],
+ "ix": 6
+ }
+ },
+ "ao": 0,
+ "shapes": [
+ {
+ "ty": "gr",
+ "it": [
+ {
+ "d": 1,
+ "ty": "el",
+ "s": {
+ "a": 0,
+ "k": [
+ 28.733,
+ 28.733
+ ],
+ "ix": 2
+ },
+ "p": {
+ "a": 0,
+ "k": [
+ 0,
+ 0
+ ],
+ "ix": 3
+ },
+ "nm": "Ellipse Path 1",
+ "mn": "ADBE Vector Shape - Ellipse",
+ "hd": false
+ },
+ {
+ "ty": "st",
+ "c": {
+ "a": 0,
+ "k": [
+ 1,
+ 1,
+ 1,
+ 1
+ ],
+ "ix": 3
+ },
+ "o": {
+ "a": 0,
+ "k": 100,
+ "ix": 4
+ },
+ "w": {
+ "a": 0,
+ "k": 0,
+ "ix": 5
+ },
+ "lc": 1,
+ "lj": 1,
+ "ml": 4,
+ "bm": 0,
+ "nm": "Stroke 1",
+ "mn": "ADBE Vector Graphic - Stroke",
+ "hd": false
+ },
+ {
+ "ty": "fl",
+ "c": {
+ "a": 0,
+ "k": [
+ 0.4,
+ 0.4,
+ 1,
+ 1
+ ],
+ "ix": 4
+ },
+ "o": {
+ "a": 0,
+ "k": 100,
+ "ix": 5
+ },
+ "r": 1,
+ "bm": 0,
+ "nm": "Fill 1",
+ "mn": "ADBE Vector Graphic - Fill",
+ "hd": false
+ },
+ {
+ "ty": "tr",
+ "p": {
+ "a": 0,
+ "k": [
+ 0.367,
+ 10.367
+ ],
+ "ix": 2
+ },
+ "a": {
+ "a": 0,
+ "k": [
+ 0,
+ 0
+ ],
+ "ix": 1
+ },
+ "s": {
+ "a": 0,
+ "k": [
+ 100,
+ 100
+ ],
+ "ix": 3
+ },
+ "r": {
+ "a": 0,
+ "k": 0,
+ "ix": 6
+ },
+ "o": {
+ "a": 0,
+ "k": 100,
+ "ix": 7
+ },
+ "sk": {
+ "a": 0,
+ "k": 0,
+ "ix": 4
+ },
+ "sa": {
+ "a": 0,
+ "k": 0,
+ "ix": 5
+ },
+ "nm": "Transform"
+ }
+ ],
+ "nm": "Ellipse 1",
+ "np": 3,
+ "cix": 2,
+ "bm": 0,
+ "ix": 1,
+ "mn": "ADBE Vector Group",
+ "hd": false
+ }
+ ],
+ "ip": 0,
+ "op": 24.00000097754,
+ "st": 0,
+ "bm": 0
+ },
+ {
+ "ddd": 0,
+ "ind": 2,
+ "ty": 4,
+ "nm": "Shape Layer 2",
+ "sr": 1,
+ "ks": {
+ "o": {
+ "a": 1,
+ "k": [
+ {
+ "i": {
+ "x": [
+ 0.833
+ ],
+ "y": [
+ 0.833
+ ]
+ },
+ "o": {
+ "x": [
+ 0.167
+ ],
+ "y": [
+ 0.167
+ ]
+ },
+ "t": 0,
+ "s": [
+ 60
+ ]
+ },
+ {
+ "i": {
+ "x": [
+ 0.833
+ ],
+ "y": [
+ 0.833
+ ]
+ },
+ "o": {
+ "x": [
+ 0.167
+ ],
+ "y": [
+ 0.167
+ ]
+ },
+ "t": 11,
+ "s": [
+ 100
+ ]
+ },
+ {
+ "t": 20.0000008146167,
+ "s": [
+ 60
+ ]
+ }
+ ],
+ "ix": 11
+ },
+ "r": {
+ "a": 0,
+ "k": 0,
+ "ix": 10
+ },
+ "p": {
+ "a": 0,
+ "k": [
+ 249.75,
+ 260.75,
+ 0
+ ],
+ "ix": 2
+ },
+ "a": {
+ "a": 0,
+ "k": [
+ 0,
+ 11,
+ 0
+ ],
+ "ix": 1
+ },
+ "s": {
+ "a": 1,
+ "k": [
+ {
+ "i": {
+ "x": [
+ 0.667,
+ 0.667,
+ 0.667
+ ],
+ "y": [
+ 1,
+ 1,
+ 1
+ ]
+ },
+ "o": {
+ "x": [
+ 0.333,
+ 0.333,
+ 0.333
+ ],
+ "y": [
+ 0,
+ 0,
+ 0
+ ]
+ },
+ "t": 0,
+ "s": [
+ 150,
+ 150,
+ 100
+ ]
+ },
+ {
+ "i": {
+ "x": [
+ 0.833,
+ 0.833,
+ 0.833
+ ],
+ "y": [
+ 1,
+ 1,
+ 1
+ ]
+ },
+ "o": {
+ "x": [
+ 0.167,
+ 0.167,
+ 0.167
+ ],
+ "y": [
+ 0,
+ 0,
+ 0
+ ]
+ },
+ "t": 11,
+ "s": [
+ 199,
+ 199,
+ 100
+ ]
+ },
+ {
+ "t": 20.0000008146167,
+ "s": [
+ 150,
+ 150,
+ 100
+ ]
+ }
+ ],
+ "ix": 6
+ }
+ },
+ "ao": 0,
+ "shapes": [
+ {
+ "ty": "gr",
+ "it": [
+ {
+ "d": 1,
+ "ty": "el",
+ "s": {
+ "a": 0,
+ "k": [
+ 28.733,
+ 28.733
+ ],
+ "ix": 2
+ },
+ "p": {
+ "a": 0,
+ "k": [
+ 0,
+ 0
+ ],
+ "ix": 3
+ },
+ "nm": "Ellipse Path 1",
+ "mn": "ADBE Vector Shape - Ellipse",
+ "hd": false
+ },
+ {
+ "ty": "st",
+ "c": {
+ "a": 0,
+ "k": [
+ 1,
+ 1,
+ 1,
+ 1
+ ],
+ "ix": 3
+ },
+ "o": {
+ "a": 0,
+ "k": 100,
+ "ix": 4
+ },
+ "w": {
+ "a": 0,
+ "k": 0,
+ "ix": 5
+ },
+ "lc": 1,
+ "lj": 1,
+ "ml": 4,
+ "bm": 0,
+ "nm": "Stroke 1",
+ "mn": "ADBE Vector Graphic - Stroke",
+ "hd": false
+ },
+ {
+ "ty": "fl",
+ "c": {
+ "a": 0,
+ "k": [
+ 1,
+ 1,
+ 1,
+ 1
+ ],
+ "ix": 4
+ },
+ "o": {
+ "a": 0,
+ "k": 100,
+ "ix": 5
+ },
+ "r": 1,
+ "bm": 0,
+ "nm": "Fill 1",
+ "mn": "ADBE Vector Graphic - Fill",
+ "hd": false
+ },
+ {
+ "ty": "tr",
+ "p": {
+ "a": 0,
+ "k": [
+ 0.396,
+ 10.413
+ ],
+ "ix": 2
+ },
+ "a": {
+ "a": 0,
+ "k": [
+ 0,
+ 0
+ ],
+ "ix": 1
+ },
+ "s": {
+ "a": 0,
+ "k": [
+ 100,
+ 100
+ ],
+ "ix": 3
+ },
+ "r": {
+ "a": 0,
+ "k": 0,
+ "ix": 6
+ },
+ "o": {
+ "a": 0,
+ "k": 100,
+ "ix": 7
+ },
+ "sk": {
+ "a": 0,
+ "k": 0,
+ "ix": 4
+ },
+ "sa": {
+ "a": 0,
+ "k": 0,
+ "ix": 5
+ },
+ "nm": "Transform"
+ }
+ ],
+ "nm": "Ellipse 1",
+ "np": 3,
+ "cix": 2,
+ "bm": 0,
+ "ix": 1,
+ "mn": "ADBE Vector Group",
+ "hd": false
+ }
+ ],
+ "ip": 0,
+ "op": 24.00000097754,
+ "st": 0,
+ "bm": 0
+ }
+ ]
+ }
+ ],
+ "layers": [
+ {
+ "ddd": 0,
+ "ind": 1,
+ "ty": 0,
+ "nm": "Loca",
+ "refId": "comp_0",
+ "sr": 1,
+ "ks": {
+ "o": {
+ "a": 1,
+ "k": [
+ {
+ "i": {
+ "x": [
+ 0.833
+ ],
+ "y": [
+ 0.833
+ ]
+ },
+ "o": {
+ "x": [
+ 0.167
+ ],
+ "y": [
+ 0.167
+ ]
+ },
+ "t": 68,
+ "s": [
+ 0
+ ]
+ },
+ {
+ "i": {
+ "x": [
+ 0.833
+ ],
+ "y": [
+ 0.833
+ ]
+ },
+ "o": {
+ "x": [
+ 0.167
+ ],
+ "y": [
+ 0.167
+ ]
+ },
+ "t": 73,
+ "s": [
+ 100
+ ]
+ },
+ {
+ "i": {
+ "x": [
+ 0.833
+ ],
+ "y": [
+ 0.833
+ ]
+ },
+ "o": {
+ "x": [
+ 0.167
+ ],
+ "y": [
+ 0.167
+ ]
+ },
+ "t": 84,
+ "s": [
+ 100
+ ]
+ },
+ {
+ "t": 90.0000036657751,
+ "s": [
+ 0
+ ]
+ }
+ ],
+ "ix": 11
+ },
+ "r": {
+ "a": 0,
+ "k": 0,
+ "ix": 10
+ },
+ "p": {
+ "a": 0,
+ "k": [
+ 85,
+ 315,
+ 0
+ ],
+ "ix": 2
+ },
+ "a": {
+ "a": 0,
+ "k": [
+ 250,
+ 250,
+ 0
+ ],
+ "ix": 1
+ },
+ "s": {
+ "a": 0,
+ "k": [
+ 100,
+ 100,
+ 100
+ ],
+ "ix": 6
+ }
+ },
+ "ao": 0,
+ "w": 500,
+ "h": 500,
+ "ip": 68.0000027696968,
+ "op": 90.0000036657751,
+ "st": 68.0000027696968,
+ "bm": 0
+ },
+ {
+ "ddd": 0,
+ "ind": 2,
+ "ty": 0,
+ "nm": "Loca",
+ "refId": "comp_0",
+ "sr": 1,
+ "ks": {
+ "o": {
+ "a": 1,
+ "k": [
+ {
+ "i": {
+ "x": [
+ 0.833
+ ],
+ "y": [
+ 0.833
+ ]
+ },
+ "o": {
+ "x": [
+ 0.167
+ ],
+ "y": [
+ 0.167
+ ]
+ },
+ "t": 61,
+ "s": [
+ 0
+ ]
+ },
+ {
+ "i": {
+ "x": [
+ 0.833
+ ],
+ "y": [
+ 0.833
+ ]
+ },
+ "o": {
+ "x": [
+ 0.167
+ ],
+ "y": [
+ 0.167
+ ]
+ },
+ "t": 66,
+ "s": [
+ 100
+ ]
+ },
+ {
+ "i": {
+ "x": [
+ 0.833
+ ],
+ "y": [
+ 0.833
+ ]
+ },
+ "o": {
+ "x": [
+ 0.167
+ ],
+ "y": [
+ 0.167
+ ]
+ },
+ "t": 80,
+ "s": [
+ 100
+ ]
+ },
+ {
+ "t": 86.0000035028518,
+ "s": [
+ 0
+ ]
+ }
+ ],
+ "ix": 11
+ },
+ "r": {
+ "a": 0,
+ "k": 0,
+ "ix": 10
+ },
+ "p": {
+ "a": 0,
+ "k": [
+ 243,
+ 383,
+ 0
+ ],
+ "ix": 2
+ },
+ "a": {
+ "a": 0,
+ "k": [
+ 250,
+ 250,
+ 0
+ ],
+ "ix": 1
+ },
+ "s": {
+ "a": 0,
+ "k": [
+ 100,
+ 100,
+ 100
+ ],
+ "ix": 6
+ }
+ },
+ "ao": 0,
+ "w": 500,
+ "h": 500,
+ "ip": 61.0000024845809,
+ "op": 88.0000035843135,
+ "st": 61.0000024845809,
+ "bm": 0
+ },
+ {
+ "ddd": 0,
+ "ind": 3,
+ "ty": 0,
+ "nm": "Loca",
+ "refId": "comp_0",
+ "sr": 1,
+ "ks": {
+ "o": {
+ "a": 1,
+ "k": [
+ {
+ "i": {
+ "x": [
+ 0.833
+ ],
+ "y": [
+ 0.833
+ ]
+ },
+ "o": {
+ "x": [
+ 0.167
+ ],
+ "y": [
+ 0.167
+ ]
+ },
+ "t": 34,
+ "s": [
+ 0
+ ]
+ },
+ {
+ "i": {
+ "x": [
+ 0.833
+ ],
+ "y": [
+ 0.833
+ ]
+ },
+ "o": {
+ "x": [
+ 0.167
+ ],
+ "y": [
+ 0.167
+ ]
+ },
+ "t": 39,
+ "s": [
+ 100
+ ]
+ },
+ {
+ "i": {
+ "x": [
+ 0.833
+ ],
+ "y": [
+ 0.833
+ ]
+ },
+ "o": {
+ "x": [
+ 0.167
+ ],
+ "y": [
+ 0.167
+ ]
+ },
+ "t": 53,
+ "s": [
+ 100
+ ]
+ },
+ {
+ "t": 59.0000024031193,
+ "s": [
+ 0
+ ]
+ }
+ ],
+ "ix": 11
+ },
+ "r": {
+ "a": 0,
+ "k": 0,
+ "ix": 10
+ },
+ "p": {
+ "a": 0,
+ "k": [
+ 401,
+ 399,
+ 0
+ ],
+ "ix": 2
+ },
+ "a": {
+ "a": 0,
+ "k": [
+ 250,
+ 250,
+ 0
+ ],
+ "ix": 1
+ },
+ "s": {
+ "a": 0,
+ "k": [
+ 100,
+ 100,
+ 100
+ ],
+ "ix": 6
+ }
+ },
+ "ao": 0,
+ "w": 500,
+ "h": 500,
+ "ip": 34.0000013848484,
+ "op": 61.0000024845809,
+ "st": 34.0000013848484,
+ "bm": 0
+ },
+ {
+ "ddd": 0,
+ "ind": 4,
+ "ty": 0,
+ "nm": "Loca",
+ "refId": "comp_0",
+ "sr": 1,
+ "ks": {
+ "o": {
+ "a": 1,
+ "k": [
+ {
+ "i": {
+ "x": [
+ 0.833
+ ],
+ "y": [
+ 0.833
+ ]
+ },
+ "o": {
+ "x": [
+ 0.167
+ ],
+ "y": [
+ 0.167
+ ]
+ },
+ "t": 11,
+ "s": [
+ 0
+ ]
+ },
+ {
+ "i": {
+ "x": [
+ 0.833
+ ],
+ "y": [
+ 0.833
+ ]
+ },
+ "o": {
+ "x": [
+ 0.167
+ ],
+ "y": [
+ 0.167
+ ]
+ },
+ "t": 16,
+ "s": [
+ 100
+ ]
+ },
+ {
+ "i": {
+ "x": [
+ 0.833
+ ],
+ "y": [
+ 0.833
+ ]
+ },
+ "o": {
+ "x": [
+ 0.167
+ ],
+ "y": [
+ 0.167
+ ]
+ },
+ "t": 30,
+ "s": [
+ 100
+ ]
+ },
+ {
+ "t": 36.0000014663101,
+ "s": [
+ 0
+ ]
+ }
+ ],
+ "ix": 11
+ },
+ "r": {
+ "a": 0,
+ "k": 0,
+ "ix": 10
+ },
+ "p": {
+ "a": 0,
+ "k": [
+ 375,
+ 205,
+ 0
+ ],
+ "ix": 2
+ },
+ "a": {
+ "a": 0,
+ "k": [
+ 250,
+ 250,
+ 0
+ ],
+ "ix": 1
+ },
+ "s": {
+ "a": 0,
+ "k": [
+ 100,
+ 100,
+ 100
+ ],
+ "ix": 6
+ }
+ },
+ "ao": 0,
+ "w": 500,
+ "h": 500,
+ "ip": 11.0000004480392,
+ "op": 38.0000015477717,
+ "st": 11.0000004480392,
+ "bm": 0
+ },
+ {
+ "ddd": 0,
+ "ind": 5,
+ "ty": 2,
+ "nm": "ladar.png",
+ "cl": "png",
+ "refId": "image_0",
+ "sr": 1,
+ "ks": {
+ "o": {
+ "a": 0,
+ "k": 100,
+ "ix": 11
+ },
+ "r": {
+ "a": 1,
+ "k": [
+ {
+ "i": {
+ "x": [
+ 0.833
+ ],
+ "y": [
+ 0.833
+ ]
+ },
+ "o": {
+ "x": [
+ 0.167
+ ],
+ "y": [
+ 0.167
+ ]
+ },
+ "t": 0,
+ "s": [
+ 0
+ ]
+ },
+ {
+ "t": 90.0000036657751,
+ "s": [
+ 360
+ ]
+ }
+ ],
+ "ix": 10
+ },
+ "p": {
+ "a": 0,
+ "k": [
+ 309,
+ 309,
+ 0
+ ],
+ "ix": 2
+ },
+ "a": {
+ "a": 0,
+ "k": [
+ 309,
+ 309,
+ 0
+ ],
+ "ix": 1
+ },
+ "s": {
+ "a": 0,
+ "k": [
+ 100,
+ 100,
+ 100
+ ],
+ "ix": 6
+ }
+ },
+ "ao": 0,
+ "ip": 0,
+ "op": 120.0000048877,
+ "st": 0,
+ "bm": 0
+ }
+ ],
+ "markers": []
+}
\ No newline at end of file
diff --git a/assets/lotties/seaching.json b/assets/lotties/seaching.json
deleted file mode 100644
index faf6421..0000000
--- a/assets/lotties/seaching.json
+++ /dev/null
@@ -1 +0,0 @@
-{"v":"5.5.7","meta":{"g":"LottieFiles AE 0.1.21","a":"","k":"","d":"","tc":"#000000"},"fr":24,"ip":0,"op":104,"w":350,"h":250,"nm":"Search","ddd":0,"assets":[{"id":"comp_0","layers":[{"ddd":0,"ind":1,"ty":4,"nm":"Fields - 1","sr":1,"ks":{"o":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":2,"s":[0]},{"t":8,"s":[100]}],"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":1,"k":[{"i":{"x":0.23,"y":1},"o":{"x":0.77,"y":0},"t":0,"s":[176,47.951,0],"to":[0,0,0],"ti":[0,0,0]},{"t":25,"s":[176,127.951,0]}],"ix":2},"a":{"a":0,"k":[-12,18.951,0],"ix":1},"s":{"a":0,"k":[194,194,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[-1.711,0],[0,0],[0,-1.711],[0,0],[1.711,0],[0,0],[0,1.711]],"o":[[0,-1.711],[0,0],[1.711,0],[0,0],[0,1.711],[0,0],[-1.711,0],[0,0]],"v":[[-38.5,14.098],[-35.402,11],[11.773,11],[14.871,14.098],[14.871,14.098],[11.773,17.195],[-35.402,17.195],[-38.5,14.098]],"c":true},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.97,0.97,0.97,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 1","np":2,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[-1.711,0],[0,0],[0,-1.711],[0,0],[1.711,0],[0,0],[0,1.711],[0,0]],"o":[[0,0],[1.711,0],[0,0],[0,1.711],[0,0],[-1.711,0],[0,0],[0,-1.711]],"v":[[-35.402,21.777],[22.421,21.777],[25.519,24.875],[25.519,24.875],[22.421,27.973],[-35.402,27.973],[-38.5,24.875],[-38.5,24.875]],"c":true},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.97,0.97,0.97,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 2","np":2,"cix":2,"bm":0,"ix":2,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[-1.105,0],[0,0],[0,-1.105],[0,0],[1.105,0],[0,0],[0,1.105],[0,0]],"o":[[0,0],[1.105,0],[0,0],[0,1.105],[0,0],[-1.105,0],[0,0],[0,-1.105]],"v":[[-57.5,11],[-44.5,11],[-42.5,13],[-42.5,26],[-44.5,28],[-57.5,28],[-59.5,26],[-59.5,13]],"c":true},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.4,0.4,1,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 3","np":2,"cix":2,"bm":0,"ix":3,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[-2.352,0],[0,0],[0,-2.352],[0,0],[2.352,0],[0,0],[0,2.352],[0,0]],"o":[[0,0],[2.352,0],[0,0],[0,2.352],[0,0],[-2.352,0],[0,0],[0,-2.352]],"v":[[-62.241,3.333],[38.241,3.333],[42.5,7.593],[42.5,30.309],[38.241,34.568],[-62.241,34.568],[-66.5,30.309],[-66.5,7.593]],"c":true},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.99,0.99,0.99,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 4","np":2,"cix":2,"bm":0,"ix":4,"mn":"ADBE Vector Group","hd":false}],"ip":0,"op":222,"st":0,"bm":0},{"ddd":0,"ind":2,"ty":4,"nm":"Fields - 2","sr":1,"ks":{"o":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":14,"s":[100]},{"t":20,"s":[0]}],"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":1,"k":[{"i":{"x":0.23,"y":1},"o":{"x":0.77,"y":0},"t":0,"s":[176,127.951,0],"to":[0,0,0],"ti":[0,0,0]},{"t":25,"s":[176,197.951,0]}],"ix":2},"a":{"a":0,"k":[-12,18.951,0],"ix":1},"s":{"a":0,"k":[194,194,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[-1.711,0],[0,0],[0,-1.711],[0,0],[1.711,0],[0,0],[0,1.711]],"o":[[0,-1.711],[0,0],[1.711,0],[0,0],[0,1.711],[0,0],[-1.711,0],[0,0]],"v":[[-38.5,14.098],[-35.402,11],[11.773,11],[14.871,14.098],[14.871,14.098],[11.773,17.195],[-35.402,17.195],[-38.5,14.098]],"c":true},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.97,0.97,0.97,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 1","np":2,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[-1.711,0],[0,0],[0,-1.711],[0,0],[1.711,0],[0,0],[0,1.711],[0,0]],"o":[[0,0],[1.711,0],[0,0],[0,1.711],[0,0],[-1.711,0],[0,0],[0,-1.711]],"v":[[-35.402,21.777],[22.421,21.777],[25.519,24.875],[25.519,24.875],[22.421,27.973],[-35.402,27.973],[-38.5,24.875],[-38.5,24.875]],"c":true},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.97,0.97,0.97,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 2","np":2,"cix":2,"bm":0,"ix":2,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[-1.105,0],[0,0],[0,-1.105],[0,0],[1.105,0],[0,0],[0,1.105],[0,0]],"o":[[0,0],[1.105,0],[0,0],[0,1.105],[0,0],[-1.105,0],[0,0],[0,-1.105]],"v":[[-57.5,11],[-44.5,11],[-42.5,13],[-42.5,26],[-44.5,28],[-57.5,28],[-59.5,26],[-59.5,13]],"c":true},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.4,0.4,1,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 3","np":2,"cix":2,"bm":0,"ix":3,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[-2.352,0],[0,0],[0,-2.352],[0,0],[2.352,0],[0,0],[0,2.352],[0,0]],"o":[[0,0],[2.352,0],[0,0],[0,2.352],[0,0],[-2.352,0],[0,0],[0,-2.352]],"v":[[-62.241,3.333],[38.241,3.333],[42.5,7.593],[42.5,30.309],[38.241,34.568],[-62.241,34.568],[-66.5,30.309],[-66.5,7.593]],"c":true},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.99,0.99,0.99,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 4","np":2,"cix":2,"bm":0,"ix":4,"mn":"ADBE Vector Group","hd":false}],"ip":0,"op":222,"st":0,"bm":0}]}],"layers":[{"ddd":0,"ind":1,"ty":4,"nm":"Glass - 1","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.2],"y":[1]},"o":{"x":[0.74],"y":[0]},"t":0,"s":[0]},{"i":{"x":[0.2],"y":[1]},"o":{"x":[0.8],"y":[0]},"t":32,"s":[92]},{"i":{"x":[0.2],"y":[1]},"o":{"x":[0.8],"y":[0]},"t":64,"s":[2.99]},{"t":98,"s":[0]}],"ix":10},"p":{"a":1,"k":[{"i":{"x":0.2,"y":1},"o":{"x":0.74,"y":0},"t":0,"s":[288.578,98.008,0],"to":[0,0,0],"ti":[0,0,0]},{"i":{"x":0.2,"y":1},"o":{"x":0.8,"y":0},"t":32,"s":[74.578,167.008,0],"to":[0,0,0],"ti":[0,0,0]},{"i":{"x":0.2,"y":1},"o":{"x":0.8,"y":0},"t":64,"s":[249.631,165.989,0],"to":[0,0,0],"ti":[0,0,0]},{"t":98,"s":[288.578,98.008,0]}],"ix":2},"a":{"a":0,"k":[47.578,-14.992,0],"ix":1},"s":{"a":0,"k":[201,201,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[-0.779,-0.771],[0,0],[0.791,-0.783],[0,0],[0.779,0.771],[0,0],[-0.791,0.783]],"o":[[0.779,-0.771],[0,0],[0.79,0.783],[0,0],[-0.779,0.771],[0,0],[-0.79,-0.783],[0,0]],"v":[[54.493,-11.608],[57.306,-11.607],[64.563,-4.422],[64.562,-1.579],[61.005,1.938],[58.192,1.938],[50.935,-5.248],[50.936,-8.091]],"c":true},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.76,0.76,1,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 1","np":2,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0,0]],"o":[[0,0],[0,0]],"v":[[47.91,-14.59],[54.804,-7.695]],"c":false},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"st","c":{"a":0,"k":[0.76,0.76,1,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":5,"ix":5},"lc":1,"lj":1,"ml":4,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 2","np":2,"cix":2,"bm":0,"ix":2,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"d":1,"ty":"el","s":{"a":0,"k":[22.033,22.033],"ix":2},"p":{"a":0,"k":[41.016,-21.484],"ix":3},"nm":"Ellipse Path 1","mn":"ADBE Vector Shape - Ellipse","hd":false},{"ty":"st","c":{"a":0,"k":[0.76,0.76,1,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":5,"ix":5},"lc":1,"lj":1,"ml":4,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"fl","c":{"a":0,"k":[0.99,0.99,0.99,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 3","np":3,"cix":2,"bm":0,"ix":3,"mn":"ADBE Vector Group","hd":false}],"ip":0,"op":222,"st":0,"bm":0},{"ddd":0,"ind":2,"ty":0,"nm":"Loop Container - 1","refId":"comp_0","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[175,125,0],"ix":2},"a":{"a":0,"k":[175,125,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"hasMask":true,"masksProperties":[{"inv":false,"mode":"a","pt":{"a":0,"k":{"i":[[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0]],"v":[[300.914,68.5],[54,68.5],[54,180],[300.914,180]],"c":true},"ix":1},"o":{"a":0,"k":100,"ix":3},"x":{"a":0,"k":0,"ix":4},"nm":"Mask 1"}],"w":350,"h":250,"ip":65,"op":110,"st":65,"bm":0},{"ddd":0,"ind":3,"ty":0,"nm":"Loop Container - 2","refId":"comp_0","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[175,125,0],"ix":2},"a":{"a":0,"k":[175,125,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"hasMask":true,"masksProperties":[{"inv":false,"mode":"a","pt":{"a":0,"k":{"i":[[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0]],"v":[[300.914,68.5],[54,68.5],[54,180],[300.914,180]],"c":true},"ix":1},"o":{"a":0,"k":100,"ix":3},"x":{"a":0,"k":0,"ix":4},"nm":"Mask 1"}],"w":350,"h":250,"ip":32,"op":65,"st":32,"bm":0},{"ddd":0,"ind":4,"ty":0,"nm":"Loop Container - 3","refId":"comp_0","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[175,125,0],"ix":2},"a":{"a":0,"k":[175,125,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"hasMask":true,"masksProperties":[{"inv":false,"mode":"a","pt":{"a":0,"k":{"i":[[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0]],"v":[[300.914,68.5],[54,68.5],[54,180],[300.914,180]],"c":true},"ix":1},"o":{"a":0,"k":100,"ix":3},"x":{"a":0,"k":0,"ix":4},"nm":"Mask 1"}],"w":350,"h":250,"ip":0,"op":33,"st":0,"bm":0},{"ddd":0,"ind":5,"ty":4,"nm":"Sparkle - 2","sr":1,"ks":{"o":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":93,"s":[100]},{"t":103,"s":[0]}],"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.19],"y":[1]},"o":{"x":[0.81],"y":[0]},"t":78,"s":[0]},{"t":103,"s":[-180]}],"ix":10},"p":{"a":0,"k":[225.524,69.17,0],"ix":2},"a":{"a":0,"k":[32.024,-44.33,0],"ix":1},"s":{"a":1,"k":[{"i":{"x":[0.19,0.19,0.19],"y":[1,1,1]},"o":{"x":[0.81,0.81,0.81],"y":[0,0,0]},"t":78,"s":[0,0,100]},{"t":98,"s":[49,49,100]}],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0.337,1.205],[0,0],[0.127,0.038],[0,0],[-0.357,1.259],[-0.791,0.224],[0,0],[-0.035,0.13],[0,0],[-0.854,0.175],[-0.337,-1.205],[0,0],[-0.13,-0.031],[0,0],[-0.029,-1.028],[0.999,-0.329],[0,0],[0.041,-0.127],[0,0],[0.869,-0.167]],"o":[[-1.221,0.275],[0,0],[-0.043,-0.125],[0,0],[-1.259,-0.357],[0.224,-0.791],[0,0],[0.128,-0.045],[0,0],[0.225,-0.842],[1.221,-0.275],[0,0],[0.036,0.129],[0,0],[0.995,0.258],[0.039,1.051],[0,0],[-0.124,0.05],[0,0],[-0.217,0.858],[0,0]],"v":[[32.61,-30.16],[29.83,-31.82],[27.61,-39.6],[27.34,-39.86],[19.54,-41.99],[17.907,-44.917],[19.54,-46.55],[27.28,-48.77],[27.54,-49.05],[29.67,-56.84],[31.43,-58.5],[34.21,-56.84],[36.43,-49.06],[36.7,-48.8],[44.5,-46.67],[46.23,-44.5],[44.61,-42.17],[36.78,-39.94],[36.52,-39.66],[34.39,-31.87],[32.61,-30.19]],"c":true},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.1615,0.1615,0.9785,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 1","np":2,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false}],"ip":78,"op":110,"st":78,"bm":0},{"ddd":0,"ind":6,"ty":4,"nm":"Sparkle - 3","sr":1,"ks":{"o":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":57,"s":[100]},{"t":73,"s":[0]}],"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.19],"y":[1]},"o":{"x":[0.81],"y":[0]},"t":42,"s":[0]},{"t":73,"s":[-180]}],"ix":10},"p":{"a":0,"k":[295.024,175.67,0],"ix":2},"a":{"a":0,"k":[32.024,-44.33,0],"ix":1},"s":{"a":1,"k":[{"i":{"x":[0.19,0.19,0.19],"y":[1,1,1]},"o":{"x":[0.81,0.81,0.81],"y":[0,0,0]},"t":42,"s":[0,0,100]},{"t":62,"s":[49,49,100]}],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0.337,1.205],[0,0],[0.127,0.038],[0,0],[-0.357,1.259],[-0.791,0.224],[0,0],[-0.035,0.13],[0,0],[-0.854,0.175],[-0.337,-1.205],[0,0],[-0.13,-0.031],[0,0],[-0.029,-1.028],[0.999,-0.329],[0,0],[0.041,-0.127],[0,0],[0.869,-0.167]],"o":[[-1.221,0.275],[0,0],[-0.043,-0.125],[0,0],[-1.259,-0.357],[0.224,-0.791],[0,0],[0.128,-0.045],[0,0],[0.225,-0.842],[1.221,-0.275],[0,0],[0.036,0.129],[0,0],[0.995,0.258],[0.039,1.051],[0,0],[-0.124,0.05],[0,0],[-0.217,0.858],[0,0]],"v":[[32.61,-30.16],[29.83,-31.82],[27.61,-39.6],[27.34,-39.86],[19.54,-41.99],[17.907,-44.917],[19.54,-46.55],[27.28,-48.77],[27.54,-49.05],[29.67,-56.84],[31.43,-58.5],[34.21,-56.84],[36.43,-49.06],[36.7,-48.8],[44.5,-46.67],[46.23,-44.5],[44.61,-42.17],[36.78,-39.94],[36.52,-39.66],[34.39,-31.87],[32.61,-30.19]],"c":true},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.1615,0.1615,0.9785,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 1","np":2,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false}],"ip":42,"op":74,"st":42,"bm":0},{"ddd":0,"ind":7,"ty":4,"nm":"Sparkle - 4","sr":1,"ks":{"o":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":31,"s":[100]},{"t":47,"s":[0]}],"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.19],"y":[1]},"o":{"x":[0.81],"y":[0]},"t":16,"s":[0]},{"t":47,"s":[-180]}],"ix":10},"p":{"a":0,"k":[41.024,157.17,0],"ix":2},"a":{"a":0,"k":[32.024,-44.33,0],"ix":1},"s":{"a":1,"k":[{"i":{"x":[0.19,0.19,0.19],"y":[1,1,1]},"o":{"x":[0.81,0.81,0.81],"y":[0,0,0]},"t":16,"s":[0,0,100]},{"t":36,"s":[49,49,100]}],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0.337,1.205],[0,0],[0.127,0.038],[0,0],[-0.357,1.259],[-0.791,0.224],[0,0],[-0.035,0.13],[0,0],[-0.854,0.175],[-0.337,-1.205],[0,0],[-0.13,-0.031],[0,0],[-0.029,-1.028],[0.999,-0.329],[0,0],[0.041,-0.127],[0,0],[0.869,-0.167]],"o":[[-1.221,0.275],[0,0],[-0.043,-0.125],[0,0],[-1.259,-0.357],[0.224,-0.791],[0,0],[0.128,-0.045],[0,0],[0.225,-0.842],[1.221,-0.275],[0,0],[0.036,0.129],[0,0],[0.995,0.258],[0.039,1.051],[0,0],[-0.124,0.05],[0,0],[-0.217,0.858],[0,0]],"v":[[32.61,-30.16],[29.83,-31.82],[27.61,-39.6],[27.34,-39.86],[19.54,-41.99],[17.907,-44.917],[19.54,-46.55],[27.28,-48.77],[27.54,-49.05],[29.67,-56.84],[31.43,-58.5],[34.21,-56.84],[36.43,-49.06],[36.7,-48.8],[44.5,-46.67],[46.23,-44.5],[44.61,-42.17],[36.78,-39.94],[36.52,-39.66],[34.39,-31.87],[32.61,-30.19]],"c":true},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.1615,0.1615,0.9785,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 1","np":2,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false}],"ip":16,"op":48,"st":16,"bm":0}],"markers":[]}
\ No newline at end of file
diff --git a/lib/app/app_cubit/app_cubit.dart b/lib/app/app_cubit/app_cubit.dart
index 7df41ef..756fe39 100644
--- a/lib/app/app_cubit/app_cubit.dart
+++ b/lib/app/app_cubit/app_cubit.dart
@@ -4,6 +4,7 @@ import 'package:flutter_bloc/flutter_bloc.dart';
import 'package:freezed_annotation/freezed_annotation.dart';
import 'package:web3kit/core/core.dart';
import 'package:zup_app/core/cache.dart';
+import 'package:zup_app/core/enums/app_theme_mode.dart';
import 'package:zup_app/core/enums/networks.dart';
part 'app_cubit.freezed.dart';
@@ -13,6 +14,7 @@ class AppCubit extends Cubit {
AppCubit(this._wallet, this._cache) : super(const AppState.standard()) {
_setupStreams();
_isTestnetMode = _cache.getTestnetMode();
+ _themeMode = _cache.themeMode;
if (_isTestnetMode) {
updateAppNetwork(AppNetworks.sepolia);
@@ -25,6 +27,7 @@ class AppCubit extends Cubit {
AppNetworks _selectedNetwork = AppNetworks.allNetworks;
bool _isTestnetMode = false;
+ AppThemeMode _themeMode = AppThemeMode.system;
final StreamController _selectedNetworkStreamController = StreamController.broadcast();
@@ -33,6 +36,7 @@ class AppCubit extends Cubit {
AppNetworks get selectedNetwork => _selectedNetwork;
int get currentChainId => _selectedNetwork.chainId;
bool get isTestnetMode => _isTestnetMode;
+ AppThemeMode get currentThemeMode => _themeMode;
void _setupStreams() {
_wallet.signerStream.listen((signer) async {
@@ -48,6 +52,15 @@ class AppCubit extends Cubit {
}
}
+ Future updateAppThemeMode(AppThemeMode newThemeMode) async {
+ if (newThemeMode == _themeMode) return;
+
+ await _cache.saveThemeMode(newThemeMode);
+ _themeMode = newThemeMode;
+
+ emit(AppState.themeChanged(_themeMode));
+ }
+
void updateAppNetwork(AppNetworks newNetwork) async {
if (newNetwork == _selectedNetwork) return;
diff --git a/lib/app/app_cubit/app_state.dart b/lib/app/app_cubit/app_state.dart
index 332ca0d..e5414d8 100644
--- a/lib/app/app_cubit/app_state.dart
+++ b/lib/app/app_cubit/app_state.dart
@@ -6,4 +6,5 @@ class AppState with _$AppState {
const factory AppState.networkChanged(AppNetworks newNetwork) = _NetworkChanged;
const factory AppState.testnetModeChanged(bool isTestnetMode) = _TestnetModeChanged;
+ const factory AppState.themeChanged(AppThemeMode newThemeMode) = _ThemeChanged;
}
diff --git a/lib/app/app_layout.dart b/lib/app/app_layout.dart
index b55ecc9..d03c651 100644
--- a/lib/app/app_layout.dart
+++ b/lib/app/app_layout.dart
@@ -1,12 +1,14 @@
import 'package:flutter/material.dart';
import 'package:routefly/routefly.dart';
+import 'package:zup_app/app/app_cubit/app_cubit.dart';
import 'package:zup_app/core/cache.dart';
import 'package:zup_app/core/injections.dart';
import 'package:zup_app/widgets/app_bottom_navigation_bar.dart';
import 'package:zup_app/widgets/app_cookies_consent_widget.dart';
import 'package:zup_app/widgets/app_footer.dart';
import 'package:zup_app/widgets/app_header/app_header.dart';
-import 'package:zup_core/mixins/device_info_mixin.dart';
+import 'package:zup_core/zup_core.dart';
+import 'package:zup_ui_kit/zup_ui_kit.dart';
class AppPage extends StatefulWidget {
const AppPage({super.key});
@@ -20,6 +22,7 @@ class _AppPageState extends State with DeviceInfoMixin {
final double appBarHeight = 85;
final cache = inject();
+ final appCubit = inject();
final ScrollController appScrollController = inject(
instanceName: InjectInstanceNames.appScrollController,
@@ -51,33 +54,30 @@ class _AppPageState extends State with DeviceInfoMixin {
Widget build(BuildContext context) {
return SelectionArea(
child: Scaffold(
- backgroundColor: Colors.white,
+ backgroundColor: ZupThemeColors.background.themed(context.brightness),
bottomNavigationBar: shouldShowBottomNavigationBar ? const AppBottomNavigationBar() : null,
extendBody: shouldShowBottomNavigationBar,
- body: ScrollbarTheme(
- data: const ScrollbarThemeData(mainAxisMargin: 10, crossAxisMargin: 3, thickness: WidgetStatePropertyAll(5)),
- child: CustomScrollView(
- controller: appScrollController,
- shrinkWrap: true,
- physics: const ClampingScrollPhysics(),
- slivers: [
- SliverAppBar(
- clipBehavior: Clip.none,
- forceMaterialTransparency: true,
- pinned: true,
- titleSpacing: 0,
- title: AppHeader(height: appBarHeight),
- toolbarHeight: appBarHeight,
- ),
- const SliverFillRemaining(hasScrollBody: false, child: RouterOutlet(key: Key("screen"))),
- SliverToBoxAdapter(
- child: Padding(
- padding: EdgeInsets.only(bottom: shouldShowBottomNavigationBar ? AppBottomNavigationBar.height : 0),
- child: const AppFooter(),
- ),
+ body: CustomScrollView(
+ controller: appScrollController,
+ shrinkWrap: true,
+ physics: const ClampingScrollPhysics(),
+ slivers: [
+ SliverAppBar(
+ clipBehavior: Clip.none,
+ forceMaterialTransparency: true,
+ pinned: true,
+ titleSpacing: 0,
+ title: AppHeader(height: appBarHeight),
+ toolbarHeight: appBarHeight,
+ ),
+ const SliverFillRemaining(hasScrollBody: false, child: RouterOutlet(key: Key("screen"))),
+ SliverToBoxAdapter(
+ child: Padding(
+ padding: EdgeInsets.only(bottom: shouldShowBottomNavigationBar ? AppBottomNavigationBar.height : 0),
+ child: const AppFooter(),
),
- ],
- ),
+ ),
+ ],
),
),
);
diff --git a/lib/app/create/create_page_select_tokens_stage.dart b/lib/app/create/create_page_select_tokens_stage.dart
index d45aa84..d7a1978 100644
--- a/lib/app/create/create_page_select_tokens_stage.dart
+++ b/lib/app/create/create_page_select_tokens_stage.dart
@@ -144,7 +144,7 @@ class _CreatePageState extends State with DeviceInf
Badge(
alignment: const Alignment(1.05, -1.05),
smallSize: cache.getPoolSearchSettings().isDefault ? 0 : 6,
- backgroundColor: ZupColors.orange,
+ backgroundColor: ZupThemeColors.alert.themed(context.brightness),
child: ZupMiniButton(
key: const Key("pool-search-settings-button"),
onPressed: (buttonContext) => CreatePageSettingsDropdown.show(
@@ -156,10 +156,7 @@ class _CreatePageState extends State with DeviceInf
},
),
title: S.of(context).createPageSelectTokensStageSearchSettings,
- icon: Assets.icons.gear.svg(
- height: 18,
- colorFilter: const ColorFilter.mode(ZupColors.white, BlendMode.srcIn),
- ),
+ icon: Assets.icons.gear.svg(height: 18),
),
),
],
diff --git a/lib/app/create/deposit/deposit_page.dart b/lib/app/create/deposit/deposit_page.dart
index f73410e..bb72b47 100644
--- a/lib/app/create/deposit/deposit_page.dart
+++ b/lib/app/create/deposit/deposit_page.dart
@@ -79,7 +79,7 @@ class _DepositPageState extends State
final lottieRadar = inject(instanceName: InjectInstanceNames.lottieRadar);
final lottieNumbers = inject(instanceName: InjectInstanceNames.lottieNumbers);
final lottieMatching = inject(instanceName: InjectInstanceNames.lottieMatching);
- final lottieSearching = inject(instanceName: InjectInstanceNames.lottieSearching);
+ final lottieSearching = inject(instanceName: InjectInstanceNames.lottieList);
final baseTokenAmountController = TextEditingController();
final quoteTokenAmountController = TextEditingController();
@@ -439,8 +439,12 @@ class _DepositPageState extends State
const SizedBox(width: 14),
ZupPillButton(
key: const Key("deposit-settings-button"),
- backgroundColor: selectedSlippage.riskBackgroundColor,
- foregroundColor: selectedSlippage.riskForegroundColor,
+ backgroundColor:
+ selectedSlippage.riskBackgroundColor(context.brightness) ??
+ ZupThemeColors.tertiaryButtonBackground.themed(context.brightness),
+ foregroundColor:
+ selectedSlippage.riskForegroundColor(context.brightness) ??
+ ZupColors.brand.lighter(0.3),
title: selectedSlippage.value != DepositSettingsDto.defaultMaxSlippage
? S
.of(context)
@@ -466,7 +470,10 @@ class _DepositPageState extends State
),
),
icon: Assets.icons.gear.svg(
- colorFilter: const ColorFilter.mode(Colors.white, BlendMode.srcIn),
+ colorFilter: ColorFilter.mode(
+ ZupThemeColors.background.themed(context.brightness),
+ BlendMode.srcIn,
+ ),
height: 20,
width: 20,
),
@@ -495,7 +502,14 @@ class _DepositPageState extends State
);
}
- Widget _sectionTitle(String title) => Text(title, style: const TextStyle(fontSize: 17, fontWeight: FontWeight.w600));
+ Widget _sectionTitle(String title) => Text(
+ title,
+ style: TextStyle(
+ fontSize: 17,
+ fontWeight: FontWeight.w600,
+ color: ZupThemeColors.primaryText.themed(context.brightness),
+ ),
+ );
Widget _buildNoYieldsState({required PoolSearchFiltersDto filtersApplied}) => Center(
child: Column(
@@ -591,7 +605,7 @@ class _DepositPageState extends State
bool isGroupSearch = group0Id != null || group1Id != null;
return Container(
- color: ZupColors.white,
+ color: ZupThemeColors.background.themed(context.brightness),
child: Center(
child: ZupSteppedLoading(
stepDuration: Duration(seconds: isGroupSearch ? 8 : 6),
@@ -599,25 +613,37 @@ class _DepositPageState extends State
ZupSteppedLoadingStep(
title: S.of(context).depositPageLoadingStep1Title,
description: S.of(context).depositPageLoadingStep1Description,
- icon: lottieMatching,
+ icon: ColorFiltered(
+ colorFilter: const ColorFilter.mode(ZupColors.brand, BlendMode.srcIn),
+ child: lottieMatching,
+ ),
iconSize: 200,
),
ZupSteppedLoadingStep(
title: S.of(context).depositPageLoadingStep2Title,
description: S.of(context).depositPageLoadingStep2Description,
- icon: lottieRadar,
+ icon: ColorFiltered(
+ colorFilter: const ColorFilter.mode(ZupColors.brand, BlendMode.srcIn),
+ child: lottieRadar,
+ ),
iconSize: 200,
),
ZupSteppedLoadingStep(
title: S.of(context).depositPageLoadingStep3Title,
description: S.of(context).depositPageLoadingStep3Description,
- icon: lottieNumbers,
+ icon: ColorFiltered(
+ colorFilter: const ColorFilter.mode(ZupColors.brand, BlendMode.srcIn),
+ child: lottieNumbers,
+ ),
iconSize: 200,
),
ZupSteppedLoadingStep(
title: S.of(context).depositPageLoadingStep4Title,
description: S.of(context).depositPageLoadingStep4Description,
- icon: lottieSearching,
+ icon: ColorFiltered(
+ colorFilter: const ColorFilter.mode(ZupColors.brand, BlendMode.srcIn),
+ child: lottieSearching,
+ ),
iconSize: 200,
),
],
@@ -636,14 +662,21 @@ class _DepositPageState extends State
children: [
Container(
padding: const EdgeInsets.symmetric(vertical: 6, horizontal: 10),
- decoration: BoxDecoration(color: ZupColors.gray6, borderRadius: BorderRadius.circular(12)),
+ decoration: BoxDecoration(
+ color: ZupThemeColors.tertiaryButtonBackground.themed(context.brightness),
+ borderRadius: BorderRadius.circular(12),
+ ),
child: Wrap(
runSpacing: 10,
crossAxisAlignment: WrapCrossAlignment.center,
children: [
Text(
S.of(context).depositPageBestYieldsIn,
- style: const TextStyle(color: ZupColors.black, fontSize: 14, fontWeight: FontWeight.w600),
+ style: TextStyle(
+ color: ZupThemeColors.primaryText.themed(context.brightness),
+ fontSize: 14,
+ fontWeight: FontWeight.w600,
+ ),
),
const SizedBox(width: 5),
Row(
@@ -667,8 +700,8 @@ class _DepositPageState extends State
key: Key("${timeframe.name}-timeframe-button"),
child: Text(
timeframe.compactDaysLabel(context),
- style: const TextStyle(
- color: ZupColors.black,
+ style: TextStyle(
+ color: ZupThemeColors.primaryText.themed(context.brightness),
fontSize: 14,
fontWeight: FontWeight.w600,
),
@@ -698,9 +731,9 @@ class _DepositPageState extends State
SizedBox(
height: 150,
child: PageView.builder(
- physics: const NeverScrollableScrollPhysics(),
+ physics: isMobileSize(context) ? const BouncingScrollPhysics() : const NeverScrollableScrollPhysics(),
controller: yieldsPageController,
- pageSnapping: false,
+ pageSnapping: true,
padEnds: false,
scrollDirection: Axis.horizontal,
itemCount: yieldsPagesCount,
@@ -790,7 +823,9 @@ class _DepositPageState extends State
child: Padding(
padding: const EdgeInsets.symmetric(horizontal: 2),
child: CircleAvatar(
- backgroundColor: (currentYieldPage.truncate() == index) ? ZupColors.brand : ZupColors.gray5,
+ backgroundColor: (currentYieldPage.truncate() == index)
+ ? ZupColors.brand
+ : ZupThemeColors.disabledButtonBackground.themed(context.brightness),
),
),
).animatedHover(animationValue: index != currentYieldPage ? 4 : 1),
@@ -923,7 +958,11 @@ class _DepositPageState extends State
return areTokensReversed ? currentPrice.priceAsQuoteToken : currentPrice.priceAsBaseToken;
}.call().formatCurrency(useLessThan: true, maxDecimals: 4, isUSD: false)} ${quoteToken.symbol}",
- style: const TextStyle(fontSize: 17, fontWeight: FontWeight.w500),
+ style: TextStyle(
+ fontSize: 17,
+ fontWeight: FontWeight.w500,
+ color: ZupThemeColors.primaryText.themed(context.brightness),
+ ),
).redacted(enabled: poolTickSnapshot.data == null);
},
),
@@ -1152,7 +1191,7 @@ class _DepositPageState extends State
fixedIcon: true,
alignCenter: true,
hoverElevation: 0,
- backgroundColor: ZupColors.brand7,
+ backgroundColor: ZupColors.brand.withValues(alpha: 0.1),
foregroundColor: ZupColors.brand,
onPressed: (buttonContext) => ConnectModal().show(context),
);
diff --git a/lib/app/create/deposit/widgets/deposit_settings_dropdown_child.dart b/lib/app/create/deposit/widgets/deposit_settings_dropdown_child.dart
index 45ffdff..f4e0827 100644
--- a/lib/app/create/deposit/widgets/deposit_settings_dropdown_child.dart
+++ b/lib/app/create/deposit/widgets/deposit_settings_dropdown_child.dart
@@ -58,9 +58,9 @@ class _DepositSettingsDropdownChildState extends State changeSlippage(slippage ?? widget.selectedSlippage),
),
const SizedBox(width: 10),
Expanded(
- child: SizedBox(
- height: 34,
- child: Focus(
- onFocusChange: (hasFocus) {
- if (!hasFocus) {
- final value = double.tryParse(slippageTextController.text) ?? widget.selectedSlippage.value;
+ child: SizedBox(
+ height: 34,
+ child: Focus(
+ onFocusChange: (hasFocus) {
+ if (!hasFocus) {
+ final value = double.tryParse(slippageTextController.text) ?? widget.selectedSlippage.value;
- if (value > 50) {
- slippageTextController.text = "50";
+ if (value > 50) {
+ slippageTextController.text = "50";
- return changeSlippage(Slippage.custom(50));
- }
+ return changeSlippage(Slippage.custom(50));
+ }
- changeSlippage(value > 0 ? Slippage.custom(value) : widget.selectedSlippage);
- }
- },
- child: TextField(
- key: const Key("slippage-text-field"),
- maxLength: 5,
- keyboardType: const TextInputType.numberWithOptions(decimal: true),
- inputFormatters: [FilteringTextInputFormatter.allow(ZupRegex.decimalNumbers)],
- controller: slippageTextController,
- onChanged: (_) => setState(() {}),
- style: const TextStyle(fontWeight: FontWeight.w500),
- decoration: InputDecoration(
- counterText: "",
- error:
- (double.tryParse(slippageTextController.text) ?? 0) > 50 ? const SizedBox.shrink() : null,
- hintText: "0.1",
- hintStyle: const TextStyle(color: ZupColors.gray5),
- contentPadding: const EdgeInsets.symmetric(horizontal: 12),
- border: OutlineInputBorder(
- borderRadius: BorderRadius.circular(8),
- borderSide: const BorderSide(color: ZupColors.gray5),
- ),
- enabledBorder: OutlineInputBorder(
- borderRadius: BorderRadius.circular(8),
- borderSide: const BorderSide(color: ZupColors.gray5),
- ),
- suffixIcon: const Padding(
- padding: EdgeInsets.only(right: 12),
- child: Text(
- "%",
- style: TextStyle(
- color: ZupColors.gray,
- fontWeight: FontWeight.w300,
- fontSize: 14,
+ changeSlippage(value > 0 ? Slippage.custom(value) : widget.selectedSlippage);
+ }
+ },
+ child: TextField(
+ key: const Key("slippage-text-field"),
+ maxLength: 5,
+ keyboardType: const TextInputType.numberWithOptions(decimal: true),
+ inputFormatters: [FilteringTextInputFormatter.allow(ZupRegex.decimalNumbers)],
+ controller: slippageTextController,
+ onChanged: (_) => setState(() {}),
+ style: const TextStyle(fontWeight: FontWeight.w500),
+ decoration: InputDecoration(
+ counterText: "",
+ error: (double.tryParse(slippageTextController.text) ?? 0) > 50
+ ? const SizedBox.shrink()
+ : null,
+ hintText: "0.1",
+ hintStyle: TextStyle(color: ZupThemeColors.disabledText.themed(context.brightness)),
+ contentPadding: const EdgeInsets.symmetric(horizontal: 12),
+ border: OutlineInputBorder(
+ borderRadius: BorderRadius.circular(8),
+ borderSide: BorderSide(color: ZupThemeColors.borderOnBackground.themed(context.brightness)),
+ ),
+ enabledBorder: OutlineInputBorder(
+ borderRadius: BorderRadius.circular(8),
+ borderSide: BorderSide(color: ZupThemeColors.borderOnBackground.themed(context.brightness)),
+ ),
+ suffixIcon: const Padding(
+ padding: EdgeInsets.only(right: 12),
+ child: Text(
+ "%",
+ style: TextStyle(color: ZupColors.gray, fontWeight: FontWeight.w300, fontSize: 14),
),
),
+ suffixIconConstraints: const BoxConstraints(),
),
- suffixIconConstraints: const BoxConstraints(),
),
),
),
- ))
+ ),
],
),
const SizedBox(height: 10),
@@ -179,14 +183,16 @@ class _DepositSettingsDropdownChildState extends State 1200 ? const SizedBox.shrink() : null,
+ error: (int.tryParse(deadlineTextController.text) ?? 0) > 1200
+ ? const SizedBox.shrink()
+ : null,
border: OutlineInputBorder(
borderRadius: BorderRadius.circular(8),
- borderSide: const BorderSide(color: ZupColors.gray5),
+ borderSide: BorderSide(color: ZupThemeColors.borderOnBackground.themed(context.brightness)),
),
enabledBorder: OutlineInputBorder(
borderRadius: BorderRadius.circular(8),
- borderSide: const BorderSide(color: ZupColors.gray5),
+ borderSide: BorderSide(color: ZupThemeColors.borderOnBackground.themed(context.brightness)),
),
suffixIcon: Padding(
padding: const EdgeInsets.only(right: 12),
child: Text(
S.of(context).minutes,
- style: const TextStyle(
- color: ZupColors.gray,
- fontWeight: FontWeight.w400,
- fontSize: 14,
- ),
+ style: const TextStyle(color: ZupColors.gray, fontWeight: FontWeight.w400, fontSize: 14),
),
),
suffixIconConstraints: const BoxConstraints(),
@@ -302,9 +307,9 @@ class _DepositSettingsDropdownChildState extends State
- ZupModal.show(
- context,
- content: DepositSuccessModal(depositedYield: depositedYield),
- padding: const EdgeInsets.all(20),
- showAsBottomSheet: showAsBottomSheet,
- dismissible: true,
- size: const Size(370, 420),
- );
+ }) async => ZupModal.show(
+ context,
+ content: DepositSuccessModal(depositedYield: depositedYield),
+ padding: const EdgeInsets.all(20),
+ showAsBottomSheet: showAsBottomSheet,
+ dismissible: true,
+ size: const Size(370, 420),
+ );
@override
State createState() => _DepositSuccessModalState();
@@ -58,19 +58,13 @@ class _DepositSuccessModalState extends State {
mainAxisAlignment: MainAxisAlignment.center,
children: [
ZupMergedWidgets(
- firstWidget: TokenAvatar(
- asset: widget.depositedYield.token0,
- size: 70,
- ),
- secondWidget: TokenAvatar(
- asset: widget.depositedYield.token1,
- size: 70,
- ),
+ firstWidget: TokenAvatar(asset: widget.depositedYield.token0, size: 70),
+ secondWidget: TokenAvatar(asset: widget.depositedYield.token1, size: 70),
spacing: 0,
),
const SizedBox(width: 20),
Assets.icons.arrowRight.svg(
- colorFilter: const ColorFilter.mode(ZupColors.green, BlendMode.srcIn),
+ colorFilter: ColorFilter.mode(ZupThemeColors.success.themed(context.brightness), BlendMode.srcIn),
height: 24,
),
ConfettiWidget(
@@ -85,39 +79,54 @@ class _DepositSuccessModalState extends State {
particleDrag: 0.03,
),
const SizedBox(width: 20),
- zupCachedImage.build(widget.depositedYield.protocol.logo, radius: 50, height: 70, width: 70),
+ zupCachedImage.build(context, widget.depositedYield.protocol.logo, radius: 50, height: 70, width: 70),
],
),
const SizedBox(height: 30),
Text(
S.of(context).depositSuccessModalTitle,
- style: const TextStyle(fontWeight: FontWeight.w600, fontSize: 18, color: ZupColors.green),
+ style: TextStyle(
+ fontWeight: FontWeight.w600,
+ fontSize: 18,
+ color: ZupThemeColors.success.themed(context.brightness),
+ ),
),
const SizedBox(height: 7),
SizedBox(
- width: 320,
- child: RichText(
- textAlign: TextAlign.center,
- text: TextSpan(style: const TextStyle(color: ZupColors.gray, fontSize: 14), children: [
- TextSpan(text: "${S.of(context).depositSuccessModalDescriptionPart1} "),
- TextSpan(
- text: "${widget.depositedYield.token0.symbol}/${widget.depositedYield.token1.symbol}",
- style: const TextStyle(
- fontWeight: FontWeight.w700,
- color: ZupColors.black,
- ),
+ width: 320,
+ child: RichText(
+ textAlign: TextAlign.center,
+ text: TextSpan(
+ style: const TextStyle(color: ZupColors.gray, fontSize: 14),
+ children: [
+ TextSpan(text: "${S.of(context).depositSuccessModalDescriptionPart1} "),
+ TextSpan(
+ text: "${widget.depositedYield.token0.symbol}/${widget.depositedYield.token1.symbol}",
+ style: TextStyle(
+ fontWeight: FontWeight.w700,
+ color: ZupThemeColors.primaryText.themed(context.brightness),
),
- TextSpan(text: " ${S.of(context).depositSuccessModalDescriptionPart2} "),
- TextSpan(
- text: widget.depositedYield.protocol.name,
- style: const TextStyle(fontWeight: FontWeight.w700, color: ZupColors.black),
+ ),
+ TextSpan(text: " ${S.of(context).depositSuccessModalDescriptionPart2} "),
+ TextSpan(
+ text: widget.depositedYield.protocol.name,
+ style: TextStyle(
+ fontWeight: FontWeight.w700,
+ color: ZupThemeColors.primaryText.themed(context.brightness),
),
- TextSpan(text: " ${S.of(context).depositSuccessModalDescriptionPart3} "),
- TextSpan(
- text: widget.depositedYield.network.label,
- style: const TextStyle(fontWeight: FontWeight.w700, color: ZupColors.black),
+ ),
+ TextSpan(text: " ${S.of(context).depositSuccessModalDescriptionPart3} "),
+ TextSpan(
+ text: widget.depositedYield.network.label,
+ style: TextStyle(
+ fontWeight: FontWeight.w700,
+ color: ZupThemeColors.primaryText.themed(context.brightness),
),
- ]))),
+ ),
+ ],
+ ),
+ ),
+ ),
const SizedBox(height: 10),
ZupPrimaryButton(
key: const Key("view-position-button"),
@@ -127,6 +136,7 @@ class _DepositSuccessModalState extends State {
icon: Assets.icons.arrowUpRight.svg(),
backgroundColor: Colors.transparent,
foregroundColor: ZupColors.brand,
+ hoverColor: ZupColors.brand.withValues(alpha: 0.05),
hoverElevation: 0,
),
const Spacer(),
diff --git a/lib/app/create/deposit/widgets/preview_deposit_modal/preview_deposit_modal.dart b/lib/app/create/deposit/widgets/preview_deposit_modal/preview_deposit_modal.dart
index 6a02c0d..497a437 100644
--- a/lib/app/create/deposit/widgets/preview_deposit_modal/preview_deposit_modal.dart
+++ b/lib/app/create/deposit/widgets/preview_deposit_modal/preview_deposit_modal.dart
@@ -401,12 +401,10 @@ class _PreviewDepositModalState extends State with V3PoolCo
children: [
Row(
children: [
- SizedBox(
- height: 30,
- child: ZupMergedWidgets(
- firstWidget: TokenAvatar(asset: baseToken, size: 35),
- secondWidget: TokenAvatar(asset: quoteToken, size: 35),
- ),
+ ZupMergedWidgets(
+ spacing: 0,
+ firstWidget: TokenAvatar(asset: baseToken, size: 35),
+ secondWidget: TokenAvatar(asset: quoteToken, size: 35),
),
const SizedBox(width: 5),
Text(
@@ -421,7 +419,9 @@ class _PreviewDepositModalState extends State with V3PoolCo
title: isOutOfRange.any
? S.of(context).previewDepositModalOutOfRange
: S.of(context).previewDepositModalInRange,
- color: isOutOfRange.any ? ZupColors.orange : ZupColors.green,
+ color: isOutOfRange.any
+ ? ZupThemeColors.alert.themed(context.brightness)
+ : ZupThemeColors.success.themed(context.brightness),
);
},
),
@@ -466,8 +466,13 @@ class _PreviewDepositModalState extends State with V3PoolCo
const SizedBox(height: 10),
Row(
children: [
- if (baseToken.logoUrl.isEmpty)
- SizedBox(
+ zupCachedImage.build(
+ context,
+ baseToken.logoUrl,
+ height: 30,
+ width: 30,
+ radius: 50,
+ errorWidget: (context, error, stackTrace) => SizedBox(
height: 30,
width: 30,
child: CircleAvatar(
@@ -475,9 +480,8 @@ class _PreviewDepositModalState extends State with V3PoolCo
foregroundColor: ZupColors.brand,
child: Text(baseToken.name[0]),
),
- )
- else
- zupCachedImage.build(baseToken.logoUrl, height: 30, width: 30, radius: 50),
+ ),
+ ),
const SizedBox(width: 10),
Text(baseToken.symbol),
const Spacer(),
@@ -490,18 +494,22 @@ class _PreviewDepositModalState extends State with V3PoolCo
const SizedBox(height: 15),
Row(
children: [
- if (quoteToken.logoUrl.isEmpty)
- SizedBox(
+ zupCachedImage.build(
+ context,
+ quoteToken.logoUrl,
+ height: 30,
+ width: 30,
+ radius: 50,
+ errorWidget: (context, error, stackTrace) => SizedBox(
height: 30,
width: 30,
child: CircleAvatar(
backgroundColor: ZupColors.brand7,
foregroundColor: ZupColors.brand,
- child: Text(quoteToken.name[0]),
+ child: Text(baseToken.name[0]),
),
- )
- else
- zupCachedImage.build(quoteToken.logoUrl, height: 30, width: 30, radius: 50),
+ ),
+ ),
const SizedBox(width: 10),
Text(quoteToken.symbol),
const Spacer(),
@@ -523,10 +531,20 @@ class _PreviewDepositModalState extends State with V3PoolCo
child: _fieldColumn(
title: S.of(context).previewDepositModalProtocol,
image: zupCachedImage.build(
+ context,
widget.currentYield.protocol.logo,
width: 30,
height: 30,
radius: 100,
+ errorWidget: (context, error, stackTrace) => const SizedBox(
+ height: 26,
+ width: 26,
+ child: CircleAvatar(
+ backgroundColor: ZupColors.gray5,
+ foregroundColor: ZupColors.gray,
+ child: Text("?"),
+ ),
+ ),
),
value: widget.currentYield.protocol.name,
),
@@ -588,8 +606,8 @@ class _PreviewDepositModalState extends State with V3PoolCo
Widget rangeInfoCard({required bool isMinPrice}) => Container(
padding: const EdgeInsets.all(12),
decoration: BoxDecoration(
- color: ZupColors.brand.withValues(alpha: 0.02),
- border: Border.all(color: ZupColors.brand5, width: 0.5),
+ color: ZupThemeColors.tertiaryButtonBackground.themed(context.brightness),
+ border: Border.all(color: ZupThemeColors.borderOnBackground.themed(context.brightness), width: 0.5),
borderRadius: const BorderRadius.all(Radius.circular(12)),
),
child: Column(
@@ -624,7 +642,11 @@ class _PreviewDepositModalState extends State with V3PoolCo
}.call(),
maxLines: 1,
overflow: TextOverflow.clip,
- style: const TextStyle(fontWeight: FontWeight.w500, fontSize: 18, color: ZupColors.black),
+ style: TextStyle(
+ fontWeight: FontWeight.w500,
+ fontSize: 18,
+ color: ZupThemeColors.primaryText.themed(context.brightness),
+ ),
),
const SizedBox(height: 5),
Text(
diff --git a/lib/app/create/deposit/widgets/range_selector.dart b/lib/app/create/deposit/widgets/range_selector.dart
index a797454..3a60ee1 100644
--- a/lib/app/create/deposit/widgets/range_selector.dart
+++ b/lib/app/create/deposit/widgets/range_selector.dart
@@ -5,6 +5,7 @@ import 'package:zup_app/core/mixins/v3_pool_conversors_mixin.dart';
import 'package:zup_app/core/token_amount_input_formatter.dart';
import 'package:zup_app/gen/assets.gen.dart';
import 'package:zup_app/l10n/gen/app_localizations.dart';
+import 'package:zup_core/extensions/extensions.dart';
import 'package:zup_ui_kit/zup_ui_kit.dart';
enum RangeSelectorStateType {
@@ -12,24 +13,39 @@ enum RangeSelectorStateType {
warning,
error;
- Color get borderColor => [ZupColors.gray5, ZupColors.orange, ZupColors.red][index];
+ Color borderColor(BuildContext context) => [
+ ZupThemeColors.borderOnBackground.themed(context.brightness),
+ ZupThemeColors.alert.themed(context.brightness),
+ ZupThemeColors.error.themed(context.brightness),
+ ][index];
- double get borderSize => [0.5, 1.5, 1.5][index];
+ double borderSize(BuildContext context) => [context.brightness.isDark ? 1.0 : 0.5, 1.5, 1.5][index];
- Color get textColor => [ZupColors.gray, ZupColors.orange, ZupColors.red][index];
+ Color textColor(BuildContext context) => [
+ ZupColors.gray,
+ ZupThemeColors.alert.themed(context.brightness),
+ ZupThemeColors.error.themed(context.brightness),
+ ][index];
- Color get adjustmentIconBackgroundColor => [ZupColors.brand7, ZupColors.orange5, ZupColors.red5][index];
- Color get adjustmentIconForegroundColor => [ZupColors.brand, ZupColors.orange, ZupColors.red][index];
+ Color adjustmentIconBackgroundColor(BuildContext context) {
+ if (context.brightness.isDark) return ZupColors.black2;
+
+ return [ZupColors.brand7, ZupColors.orange5, ZupColors.red5][index];
+ }
+
+ Color adjustmentIconForegroundColor(BuildContext context) => [
+ ZupColors.brand,
+ ZupThemeColors.alert.themed(context.brightness),
+ ZupThemeColors.error.themed(context.brightness),
+ ][index];
}
enum RangeSelectorType {
minPrice,
maxPrice;
- String label(BuildContext context) => [
- S.of(context).rangeSelectorMinRange,
- S.of(context).rangeSelectorMaxRange,
- ][index];
+ String label(BuildContext context) =>
+ [S.of(context).rangeSelectorMinRange, S.of(context).rangeSelectorMaxRange][index];
String get infinityLabel => ["0", "∞"][index];
}
@@ -234,10 +250,11 @@ class _RangeSelectorState extends State with V3PoolConversorsMixi
padding: EdgeInsets.all(padding).copyWith(left: 0, bottom: 0),
decoration: BoxDecoration(
borderRadius: BorderRadius.circular(12),
+ color: ZupThemeColors.background.themed(context.brightness),
border: Border.all(
strokeAlign: 1,
- width: widget.state.type.borderSize,
- color: widget.state.type.borderColor,
+ width: widget.state.type.borderSize(context),
+ color: widget.state.type.borderColor(context),
),
),
child: Column(
@@ -247,7 +264,11 @@ class _RangeSelectorState extends State with V3PoolConversorsMixi
padding: EdgeInsets.only(left: padding),
child: Text(
widget.type.label(context),
- style: const TextStyle(color: ZupColors.black, fontSize: 17, fontWeight: FontWeight.w600),
+ style: TextStyle(
+ color: ZupThemeColors.primaryText.themed(context.brightness),
+ fontSize: 17,
+ fontWeight: FontWeight.w600,
+ ),
),
),
Padding(
@@ -276,12 +297,15 @@ class _RangeSelectorState extends State with V3PoolConversorsMixi
userTypedValue = value;
widget.onUserType?.call();
},
- style: const TextStyle(fontSize: 28),
- decoration: const InputDecoration(
+ style: TextStyle(
+ fontSize: 28,
+ color: ZupThemeColors.backgroundInverse.themed(context.brightness),
+ ),
+ decoration: InputDecoration(
enabledBorder: InputBorder.none,
focusedBorder: InputBorder.none,
- contentPadding: EdgeInsets.only(right: 20, left: 20),
- hintStyle: TextStyle(color: ZupColors.gray5),
+ contentPadding: const EdgeInsets.only(right: 20, left: 20),
+ hintStyle: TextStyle(color: ZupThemeColors.disabledText.themed(context.brightness)),
hintText: "0",
border: InputBorder.none,
),
@@ -298,9 +322,9 @@ class _RangeSelectorState extends State with V3PoolConversorsMixi
decoration: BoxDecoration(
gradient: LinearGradient(
colors: [
- ZupColors.white,
- ZupColors.white.withValues(alpha: 0.8),
- ZupColors.white.withValues(alpha: 0.0)
+ ZupThemeColors.background.themed(context.brightness),
+ ZupThemeColors.background.themed(context.brightness).withValues(alpha: 0.8),
+ ZupThemeColors.background.themed(context.brightness).withValues(alpha: 0.0),
],
stops: const [0.1, 0.5, 1.0],
begin: Alignment.centerRight,
@@ -319,7 +343,10 @@ class _RangeSelectorState extends State with V3PoolConversorsMixi
height: 50,
decoration: BoxDecoration(
gradient: LinearGradient(
- colors: [ZupColors.white, ZupColors.white.withValues(alpha: 0.0)],
+ colors: [
+ ZupThemeColors.background.themed(context.brightness),
+ ZupThemeColors.background.themed(context.brightness).withValues(alpha: 0.0),
+ ],
stops: const [0.5, 1.0],
begin: Alignment.centerLeft,
end: Alignment.centerRight,
@@ -327,7 +354,7 @@ class _RangeSelectorState extends State with V3PoolConversorsMixi
),
),
),
- )
+ ),
],
),
),
@@ -336,20 +363,24 @@ class _RangeSelectorState extends State with V3PoolConversorsMixi
ZupIconButton(
key: const Key("increase-button"),
icon: Assets.icons.plus.svg(),
- iconColor: widget.state.type.adjustmentIconForegroundColor,
- backgroundColor: widget.state.type.adjustmentIconBackgroundColor,
+ circle: false,
+ minimumHeight: 40,
+ padding: const EdgeInsets.all(12),
+ iconColor: widget.state.type.adjustmentIconForegroundColor(context),
+ backgroundColor: widget.state.type.adjustmentIconBackgroundColor(context),
onPressed: (_) => increaseOrDecrease(increasing: true),
),
const SizedBox(width: 8),
ZupIconButton(
key: const Key("decrease-button"),
- circle: true,
+ circle: false,
padding: const EdgeInsets.all(12),
+ minimumHeight: 40,
icon: Assets.icons.minus.svg(),
- backgroundColor: widget.state.type.adjustmentIconBackgroundColor,
- iconColor: widget.state.type.adjustmentIconForegroundColor,
+ backgroundColor: widget.state.type.adjustmentIconBackgroundColor(context),
+ iconColor: widget.state.type.adjustmentIconForegroundColor(context),
onPressed: (_) => increaseOrDecrease(increasing: false),
- )
+ ),
],
),
Padding(
@@ -362,9 +393,7 @@ class _RangeSelectorState extends State with V3PoolConversorsMixi
setState(() => showError = widget.state.message != null);
},
child: AnimatedOpacity(
- duration: Duration(
- milliseconds: widget.state.message == null ? 0 : 200,
- ),
+ duration: Duration(milliseconds: widget.state.message == null ? 0 : 200),
curve: Curves.decelerate,
opacity: () {
if (widget.state.message == null) return 0.0;
@@ -373,7 +402,7 @@ class _RangeSelectorState extends State with V3PoolConversorsMixi
}.call(),
child: Text(
widget.state.message ?? "",
- style: TextStyle(color: widget.state.type.textColor, fontSize: 14),
+ style: TextStyle(color: widget.state.type.textColor(context), fontSize: 14),
),
),
),
diff --git a/lib/app/create/deposit/widgets/token_amount_input_card/token_amount_input_card.dart b/lib/app/create/deposit/widgets/token_amount_input_card/token_amount_input_card.dart
index b8281ee..814fee2 100644
--- a/lib/app/create/deposit/widgets/token_amount_input_card/token_amount_input_card.dart
+++ b/lib/app/create/deposit/widgets/token_amount_input_card/token_amount_input_card.dart
@@ -65,10 +65,7 @@ class _TokenAmountInputCardState extends State with Single
refreshBalanceAnimationController = AnimationController(vsync: this, duration: const Duration(milliseconds: 100));
WidgetsBinding.instance.addPostFrameCallback((tester) {
- userBalanceCubit.updateNativeTokenAndFetch(
- isNative: widget.isNative,
- network: widget.network,
- );
+ userBalanceCubit.updateNativeTokenAndFetch(isNative: widget.isNative, network: widget.network);
});
super.initState();
@@ -79,10 +76,7 @@ class _TokenAmountInputCardState extends State with Single
if ((widget.isNative != oldWidget.isNative || widget.network != oldWidget.network) &&
(widget.token.addresses[widget.network.chainId] ?? "").lowercasedEquals(EthereumConstants.zeroAddress)) {
WidgetsBinding.instance.addPostFrameCallback(
- (_) => userBalanceCubit.updateNativeTokenAndFetch(
- isNative: widget.isNative,
- network: widget.network,
- ),
+ (_) => userBalanceCubit.updateNativeTokenAndFetch(isNative: widget.isNative, network: widget.network),
);
return super.didUpdateWidget(oldWidget);
@@ -108,17 +102,18 @@ class _TokenAmountInputCardState extends State with Single
Container(
padding: EdgeInsets.all(paddingValue).copyWith(left: 0),
decoration: BoxDecoration(
+ color: ZupThemeColors.background.themed(context.brightness),
borderRadius: BorderRadius.circular(12),
- border: Border.all(width: 0.5, color: ZupColors.gray5),
+ border: Border.all(
+ width: context.brightness.isDark ? 1.0 : 0.5,
+ color: ZupThemeColors.borderOnBackground.themed(context.brightness),
+ ),
),
child: Stack(
alignment: Alignment.center,
children: [
if (widget.disabledText != null)
- Text(
- widget.disabledText!,
- style: const TextStyle(color: ZupColors.gray, fontSize: 14),
- ),
+ Text(widget.disabledText!, style: const TextStyle(color: ZupColors.gray, fontSize: 14)),
IgnorePointer(
ignoring: widget.disabledText != null,
child: AnimatedOpacity(
@@ -140,17 +135,20 @@ class _TokenAmountInputCardState extends State with Single
clipBehavior: Clip.none,
controller: widget.controller,
onChanged: (value) => widget.onInput(double.tryParse(value) ?? 0),
- style: const TextStyle(fontSize: 28),
- inputFormatters: [
- TokenAmountInputFormatter(),
- ],
+ style: TextStyle(
+ fontSize: 28,
+ color: ZupThemeColors.backgroundInverse.themed(context.brightness),
+ ),
+ inputFormatters: [TokenAmountInputFormatter()],
decoration: InputDecoration(
contentPadding: EdgeInsets.only(right: paddingValue + 5, left: paddingValue),
focusedBorder: InputBorder.none,
enabledBorder: InputBorder.none,
border: InputBorder.none,
hintText: "0",
- hintStyle: const TextStyle(color: ZupColors.gray5),
+ hintStyle: TextStyle(
+ color: ZupThemeColors.disabledText.themed(context.brightness),
+ ),
),
),
Align(
@@ -163,9 +161,13 @@ class _TokenAmountInputCardState extends State with Single
decoration: BoxDecoration(
gradient: LinearGradient(
colors: [
- ZupColors.white,
- ZupColors.white.withValues(alpha: 0.8),
- ZupColors.white.withValues(alpha: 0.0)
+ ZupThemeColors.background.themed(context.brightness),
+ ZupThemeColors.background
+ .themed(context.brightness)
+ .withValues(alpha: 0.8),
+ ZupThemeColors.background
+ .themed(context.brightness)
+ .withValues(alpha: 0.0),
],
stops: const [0.1, 0.5, 1.0],
begin: Alignment.centerRight,
@@ -184,7 +186,12 @@ class _TokenAmountInputCardState extends State with Single
height: 50,
decoration: BoxDecoration(
gradient: LinearGradient(
- colors: [ZupColors.white, ZupColors.white.withValues(alpha: 0.0)],
+ colors: [
+ ZupThemeColors.background.themed(context.brightness),
+ ZupThemeColors.background
+ .themed(context.brightness)
+ .withValues(alpha: 0.0),
+ ],
stops: const [0.5, 1.0],
begin: Alignment.centerLeft,
end: Alignment.centerRight,
@@ -192,7 +199,7 @@ class _TokenAmountInputCardState extends State with Single
),
),
),
- )
+ ),
],
),
),
@@ -204,42 +211,43 @@ class _TokenAmountInputCardState extends State with Single
borderRadius: BorderRadius.circular(12),
border: Border.all(
width: 0.5,
- color: ZupColors.gray5,
+ color: ZupThemeColors.borderOnBackgroundSurface.themed(context.brightness),
),
),
child: PositionToken(token: widget.token),
- )
+ ),
],
),
const SizedBox(height: 5),
Row(
children: [
Padding(
- padding: EdgeInsets.only(left: paddingValue),
- child: StreamBuilder(
- stream: (() async* {
- yield await cubit!.getTokenPrice(token: widget.token, network: widget.network);
+ padding: EdgeInsets.only(left: paddingValue),
+ child: StreamBuilder(
+ stream: (() async* {
+ yield await cubit!.getTokenPrice(token: widget.token, network: widget.network);
- await for (final _ in Stream.periodic(const Duration(seconds: 30))) {
- yield await cubit!.getTokenPrice(token: widget.token, network: widget.network);
- }
- })(),
- builder: (context, snapshot) {
- if (!snapshot.hasData) return const ZupCircularLoadingIndicator(size: 10);
+ await for (final _ in Stream.periodic(const Duration(seconds: 30))) {
+ yield await cubit!.getTokenPrice(token: widget.token, network: widget.network);
+ }
+ })(),
+ builder: (context, snapshot) {
+ if (!snapshot.hasData) return const ZupCircularLoadingIndicator(size: 10);
- return Text(
- widget.controller.value.text.isEmpty
- ? "\$-"
- : ((double.tryParse(widget.controller.value.text) ?? 0) * snapshot.data!)
+ return Text(
+ widget.controller.value.text.isEmpty
+ ? "\$-"
+ : ((double.tryParse(widget.controller.value.text) ?? 0) * snapshot.data!)
.formatCurrency(),
- style: const TextStyle(
- fontSize: 15,
- fontWeight: FontWeight.w500,
- color: ZupColors.gray,
- ),
- );
- },
- )),
+ style: const TextStyle(
+ fontSize: 15,
+ fontWeight: FontWeight.w500,
+ color: ZupColors.gray,
+ ),
+ );
+ },
+ ),
+ ),
const Spacer(),
BlocProvider.value(
value: userBalanceCubit,
@@ -269,17 +277,12 @@ class _TokenAmountInputCardState extends State with Single
alignLeft: false,
icon: Assets.icons.walletBifold.svg(),
label: state.maybeWhen(
- orElse: () => userBalanceCubit.userBalance.toAmount(
- useLessThan: true,
- ),
+ orElse: () => userBalanceCubit.userBalance.toAmount(useLessThan: true),
loadingUserBalance: () => "........",
error: () => "Error",
),
).redacted(
- enabled: state.maybeWhen(
- orElse: () => false,
- loadingUserBalance: () => true,
- ),
+ enabled: state.maybeWhen(orElse: () => false, loadingUserBalance: () => true),
),
const SizedBox(width: 5),
ZupRefreshButton(
@@ -302,7 +305,7 @@ class _TokenAmountInputCardState extends State with Single
);
},
),
- )
+ ),
],
),
],
diff --git a/lib/app/create/widgets/create_page_settings_dropdown/create_page_settings_dropdown.dart b/lib/app/create/widgets/create_page_settings_dropdown/create_page_settings_dropdown.dart
index adf95af..1f1aff3 100644
--- a/lib/app/create/widgets/create_page_settings_dropdown/create_page_settings_dropdown.dart
+++ b/lib/app/create/widgets/create_page_settings_dropdown/create_page_settings_dropdown.dart
@@ -7,6 +7,7 @@ import 'package:zup_app/core/extensions/num_extension.dart';
import 'package:zup_app/core/injections.dart';
import 'package:zup_app/gen/assets.gen.dart';
import 'package:zup_app/l10n/gen/app_localizations.dart';
+import 'package:zup_core/extensions/extensions.dart';
import 'package:zup_ui_kit/zup_ui_kit.dart';
class CreatePageSettingsDropdown extends StatefulWidget {
@@ -14,15 +15,11 @@ class CreatePageSettingsDropdown extends StatefulWidget {
final void Function() onClose;
- static void show(
- BuildContext showBelowContext, {
- required void Function() onClose,
- }) =>
- ZupPopover.show(
- showBasedOnContext: showBelowContext,
- adjustment: const Offset(0, 10),
- child: CreatePageSettingsDropdown(onClose: onClose),
- );
+ static void show(BuildContext showBelowContext, {required void Function() onClose}) => ZupPopover.show(
+ showBasedOnContext: showBelowContext,
+ adjustment: const Offset(0, 10),
+ child: CreatePageSettingsDropdown(onClose: onClose),
+ );
@override
State createState() => _CreatePageSettingsDropdownState();
@@ -48,12 +45,13 @@ class _CreatePageSettingsDropdownState extends State
}
Widget sectionTitle(String title) => Text(
- title,
- style: const TextStyle(
- fontWeight: FontWeight.w600,
- fontSize: 15,
- ),
- );
+ title,
+ style: TextStyle(
+ fontWeight: FontWeight.w600,
+ fontSize: 15,
+ color: ZupThemeColors.primaryText.themed(context.brightness),
+ ),
+ );
@override
void initState() {
@@ -75,9 +73,9 @@ class _CreatePageSettingsDropdownState extends State
return Container(
padding: const EdgeInsets.all(10),
decoration: BoxDecoration(
- color: ZupColors.white,
+ color: ZupThemeColors.background.themed(context.brightness),
borderRadius: BorderRadius.circular(12),
- border: Border.all(color: ZupColors.gray5),
+ border: Border.all(color: ZupThemeColors.borderOnBackground.themed(context.brightness)),
),
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
@@ -108,22 +106,22 @@ class _CreatePageSettingsDropdownState extends State
debouncer.run(() async {
await cache.savePoolSearchSettings(
settings: cache.getPoolSearchSettings().copyWith(
- minLiquidityUSD:
- num.tryParse(value.replaceAll(",", "")) ?? PoolSearchSettingsDto.defaultMinLiquidityUSD,
- ),
+ minLiquidityUSD:
+ num.tryParse(value.replaceAll(",", "")) ?? PoolSearchSettingsDto.defaultMinLiquidityUSD,
+ ),
);
});
},
controller: minTVLController,
keyboardType: const TextInputType.numberWithOptions(decimal: false),
inputFormatters: [
- CurrencyTextInputFormatter.simpleCurrency(name: "", enableNegative: false, decimalDigits: 0)
+ CurrencyTextInputFormatter.simpleCurrency(name: "", enableNegative: false, decimalDigits: 0),
],
decoration: InputDecoration(
hintText: PoolSearchSettingsDto.defaultMinLiquidityUSD.formatCurrency(isUSD: false),
- hintStyle: const TextStyle(color: ZupColors.gray4),
+ hintStyle: TextStyle(color: ZupThemeColors.disabledText.themed(context.brightness)),
enabledBorder: OutlineInputBorder(
- borderSide: const BorderSide(color: ZupColors.gray5),
+ borderSide: BorderSide(color: ZupThemeColors.borderOnBackground.themed(context.brightness)),
borderRadius: BorderRadius.circular(8),
),
focusedBorder: OutlineInputBorder(
@@ -151,14 +149,14 @@ class _CreatePageSettingsDropdownState extends State
Assets.icons.exclamationmarkTriangle.svg(
width: 16,
height: 16,
- colorFilter: const ColorFilter.mode(ZupColors.orange, BlendMode.srcIn),
+ colorFilter: ColorFilter.mode(ZupThemeColors.alert.themed(context.brightness), BlendMode.srcIn),
),
const SizedBox(width: 10),
SizedBox(
width: 170,
child: Text(
S.of(context).createPageSettingsDropdownMiniumLiquidityLowWarning,
- style: const TextStyle(color: ZupColors.orange, fontSize: 14),
+ style: TextStyle(color: ZupThemeColors.alert.themed(context.brightness), fontSize: 14),
),
),
],
@@ -182,7 +180,14 @@ class _CreatePageSettingsDropdownState extends State
const SizedBox(height: 5),
Row(
children: [
- const Text("V4", style: TextStyle(fontWeight: FontWeight.w500, fontSize: 15)),
+ Text(
+ "V4",
+ style: TextStyle(
+ fontWeight: FontWeight.w500,
+ fontSize: 15,
+ color: ZupThemeColors.primaryText.themed(context.brightness),
+ ),
+ ),
const SizedBox(width: 5),
ZupSwitch(
key: const Key("pool-types-allowed-v4-switch"),
@@ -196,7 +201,13 @@ class _CreatePageSettingsDropdownState extends State
},
),
const SizedBox(width: 12),
- const Text("V3", style: TextStyle(fontWeight: FontWeight.w500)),
+ Text(
+ "V3",
+ style: TextStyle(
+ fontWeight: FontWeight.w500,
+ color: ZupThemeColors.primaryText.themed(context.brightness),
+ ),
+ ),
const SizedBox(width: 5),
ZupSwitch(
key: const Key("pool-types-allowed-v3-switch"),
diff --git a/lib/app/create/widgets/exchanges_filter_dropdown_button/exchanges_filter_dropdown_button.dart b/lib/app/create/widgets/exchanges_filter_dropdown_button/exchanges_filter_dropdown_button.dart
index 0092138..8386ef6 100644
--- a/lib/app/create/widgets/exchanges_filter_dropdown_button/exchanges_filter_dropdown_button.dart
+++ b/lib/app/create/widgets/exchanges_filter_dropdown_button/exchanges_filter_dropdown_button.dart
@@ -7,6 +7,7 @@ import 'package:zup_app/core/repositories/protocol_repository.dart';
import 'package:zup_app/gen/assets.gen.dart';
import 'package:zup_app/l10n/gen/app_localizations.dart';
import 'package:zup_app/widgets/zup_cached_image.dart';
+import 'package:zup_core/extensions/extensions.dart';
import 'package:zup_core/zup_singleton_cache.dart';
import 'package:zup_ui_kit/zup_ui_kit.dart';
@@ -25,17 +26,16 @@ class _ExchangesFilterDropdownButtonState extends State cubit!.protocols
- .where(
- (protocol) => !cache.blockedProtocolsIds.contains(protocol.rawId),
- )
- .length;
+ num get allowedProtocolsCount =>
+ cubit!.protocols.where((protocol) => !cache.blockedProtocolsIds.contains(protocol.rawId)).length;
Color get buttonForegroundColor {
- if (allowedProtocolsCount == 0 && cubit!.protocols.isNotEmpty) return ZupColors.red;
+ if (allowedProtocolsCount == 0 && cubit!.protocols.isNotEmpty) {
+ return ZupThemeColors.error.themed(context.brightness);
+ }
if (allowedProtocolsCount == cubit!.protocols.length) return ZupColors.gray;
- return ZupColors.brand;
+ return context.brightness.isLight ? ZupColors.brand : ZupColors.brand5;
}
String get protocolCounter {
@@ -61,77 +61,83 @@ class _ExchangesFilterDropdownButtonState extends State S.of(context).exchangesFilterDropdownButtonTitleNumered(
- exchangesCount: protocolCounter,
- ),
+ success: (protocols) =>
+ S.of(context).exchangesFilterDropdownButtonTitleNumered(exchangesCount: protocolCounter),
orElse: () => S.of(context).exchangesFilterDropdownButtonTitle,
),
height: 40,
- isLoading: state.maybeWhen(
- loading: () => true,
- orElse: () => false,
- ),
+ isLoading: state.maybeWhen(loading: () => true, orElse: () => false),
onPressed: state == const ExchangesFilterDropdownButtonState.loading()
? null
: (buttonContext) => state.whenOrNull(
- error: () async {
- WidgetsBinding.instance.addPostFrameCallback((_) {
- ScaffoldMessenger.of(context).showSnackBar(
- ZupSnackBar(
- context,
- message: S.of(context).exchangesFilterDropdownButtonErrorSnackBarMessage,
- type: ZupSnackBarType.error,
- maxWidth: 400,
- ),
+ error: () async {
+ WidgetsBinding.instance.addPostFrameCallback((_) {
+ ScaffoldMessenger.of(context).showSnackBar(
+ ZupSnackBar(
+ context,
+ message: S.of(context).exchangesFilterDropdownButtonErrorSnackBarMessage,
+ type: ZupSnackBarType.error,
+ maxWidth: 400,
+ ),
+ );
+ });
+ return null;
+ },
+ success: (protocols) => ZupCheckboxListPopover.show(
+ buttonContext,
+ positionAdjustment: const Offset(-130, 10),
+ allSelectionButtonText: (
+ clearAll: S.of(context).exchangesFilterDropdownButtonDropdownClearAll,
+ selectAll: S.of(context).exchangesFilterDropdownButtonDropdownSelectAll,
+ ),
+ searchHintText: S.of(context).exchangesFilterDropdownButtonDropdownSearchHint,
+ searchNotFoundStateText: (
+ description: S.of(context).exchangesFilterDropdownButtonDropdownNotFoundStateDescription,
+ title: S.of(context).exchangesFilterDropdownButtonDropdownNotFoundStateTitle,
+ ),
+ onValueChanged: (items) {
+ setState(() {
+ cache.saveBlockedProtocolIds(
+ blockedProtocolIds: items.where((item) => !item.isChecked).map((item) => item.id!).toList(),
);
});
- return null;
},
- success: (protocols) => ZupCheckboxListPopover.show(
- buttonContext,
- positionAdjustment: const Offset(-130, 10),
- allSelectionButtonText: (
- clearAll: S.of(context).exchangesFilterDropdownButtonDropdownClearAll,
- selectAll: S.of(context).exchangesFilterDropdownButtonDropdownSelectAll
- ),
- searchHintText: S.of(context).exchangesFilterDropdownButtonDropdownSearchHint,
- searchNotFoundStateText: (
- description: S.of(context).exchangesFilterDropdownButtonDropdownNotFoundStateDescription,
- title: S.of(context).exchangesFilterDropdownButtonDropdownNotFoundStateTitle
- ),
- onValueChanged: (items) {
- setState(
- () {
- cache.saveBlockedProtocolIds(
- blockedProtocolIds: items
- .where((item) => !item.isChecked)
- .map(
- (item) => item.id!,
- )
- .toList(),
- );
- },
- );
- },
- items: protocols
- .map(
- (protocol) => ZupCheckboxItem(
- id: protocol.rawId,
- title: protocol.name,
- icon: zupCachedImage.build(protocol.logo, radius: 50),
- isChecked: !cache.blockedProtocolsIds.contains(protocol.rawId),
- isDisabled: false,
+ items: protocols
+ .map(
+ (protocol) => ZupCheckboxItem(
+ id: protocol.rawId,
+ title: protocol.name,
+ icon: zupCachedImage.build(
+ context,
+ protocol.logo,
+ radius: 20,
+ height: 20,
+ width: 20,
+ backgroundColor: Colors.white,
+ errorWidget: (context, error, stackTrace) => const SizedBox(
+ height: 20,
+ width: 20,
+ child: CircleAvatar(
+ backgroundColor: ZupColors.gray5,
+ foregroundColor: ZupColors.gray,
+ child: Text("?"),
+ ),
+ ),
),
- )
- .toList(),
- ),
+ isChecked: !cache.blockedProtocolsIds.contains(protocol.rawId),
+ isDisabled: false,
+ ),
+ )
+ .toList(),
),
+ ),
);
},
);
diff --git a/lib/core/cache.dart b/lib/core/cache.dart
index cce223b..87640f8 100644
--- a/lib/core/cache.dart
+++ b/lib/core/cache.dart
@@ -3,6 +3,8 @@ import 'dart:convert';
import 'package:shared_preferences/shared_preferences.dart';
import 'package:zup_app/core/dtos/deposit_settings_dto.dart';
import 'package:zup_app/core/dtos/pool_search_settings_dto.dart';
+import 'package:zup_app/core/dtos/theme_mode_dto.dart';
+import 'package:zup_app/core/enums/app_theme_mode.dart';
enum CacheKey {
hidingClosedPositions,
@@ -10,6 +12,7 @@ enum CacheKey {
poolSearchSettings,
areCookiesConsented,
blockedProtocolsIds,
+ themeMode,
isTestnetMode;
String get key => name;
@@ -22,6 +25,16 @@ class Cache {
final SharedPreferencesWithCache _cache;
+ Future saveThemeMode(AppThemeMode themeMode) async {
+ await _cache.setString(CacheKey.themeMode.key, jsonEncode(ThemeModeDto(themeMode: themeMode).toJson()));
+ }
+
+ AppThemeMode get themeMode {
+ final storedThemeMode = _cache.getString(CacheKey.themeMode.key) ?? "{}";
+
+ return ThemeModeDto.fromJson(jsonDecode(storedThemeMode)).themeMode;
+ }
+
Future saveHidingClosedPositionsStatus({required bool status}) async {
await _cache.setBool(CacheKey.hidingClosedPositions.key, status);
}
diff --git a/lib/core/dtos/theme_mode_dto.dart b/lib/core/dtos/theme_mode_dto.dart
new file mode 100644
index 0000000..aadd55d
--- /dev/null
+++ b/lib/core/dtos/theme_mode_dto.dart
@@ -0,0 +1,19 @@
+import 'package:freezed_annotation/freezed_annotation.dart';
+import 'package:zup_app/core/enums/app_theme_mode.dart';
+
+part 'theme_mode_dto.freezed.dart';
+part 'theme_mode_dto.g.dart';
+
+@freezed
+sealed class ThemeModeDto with _$ThemeModeDto {
+ const ThemeModeDto._();
+
+ @JsonSerializable(explicitToJson: true)
+ factory ThemeModeDto({
+ @Default(AppThemeMode.system)
+ @JsonKey(name: 'theme_mode', unknownEnumValue: AppThemeMode.system)
+ AppThemeMode themeMode,
+ }) = _ThemeModeDto;
+
+ factory ThemeModeDto.fromJson(Map json) => _$ThemeModeDtoFromJson(json);
+}
diff --git a/lib/core/enums/app_theme_mode.dart b/lib/core/enums/app_theme_mode.dart
new file mode 100644
index 0000000..9385cce
--- /dev/null
+++ b/lib/core/enums/app_theme_mode.dart
@@ -0,0 +1,46 @@
+import 'package:flutter/material.dart';
+import 'package:zup_app/gen/assets.gen.dart';
+import 'package:zup_app/l10n/gen/app_localizations.dart';
+
+enum AppThemeMode {
+ light,
+ dark,
+ system;
+
+ bool get isLight => this == AppThemeMode.light;
+ bool get isDark => this == AppThemeMode.dark;
+ bool get isSystem => this == AppThemeMode.system;
+
+ String label(BuildContext context) {
+ switch (this) {
+ case AppThemeMode.light:
+ return S.of(context).light;
+ case AppThemeMode.dark:
+ return S.of(context).dark;
+ case AppThemeMode.system:
+ return S.of(context).system;
+ }
+ }
+
+ Widget icon() {
+ switch (this) {
+ case AppThemeMode.light:
+ return Assets.icons.sunMax.svg(height: 12, width: 12);
+ case AppThemeMode.dark:
+ return Assets.icons.moon.svg(height: 12, width: 12);
+ case AppThemeMode.system:
+ return Assets.icons.laptop.svg(height: 12, width: 12);
+ }
+ }
+
+ ThemeMode get flutterThemeMode {
+ switch (this) {
+ case AppThemeMode.light:
+ return ThemeMode.light;
+ case AppThemeMode.dark:
+ return ThemeMode.dark;
+ case AppThemeMode.system:
+ return ThemeMode.system;
+ }
+ }
+}
diff --git a/lib/core/injections.dart b/lib/core/injections.dart
index 68af3bf..1574f35 100644
--- a/lib/core/injections.dart
+++ b/lib/core/injections.dart
@@ -41,7 +41,7 @@ abstract class InjectInstanceNames {
static final lottieRadar = Assets.lotties.radar.path;
static final lottieNumbers = Assets.lotties.numbers.path;
static final lottieMatching = Assets.lotties.matching.path;
- static final lottieSearching = Assets.lotties.seaching.path;
+ static final lottieList = Assets.lotties.list.path;
static const zupAPIDio = 'zup_api_dio';
static const confettiController10s = 'confetti_controller_10s';
static const zupHolderFactory = 'zup_holder_factory';
@@ -117,8 +117,8 @@ Future setupInjections() async {
instanceName: InjectInstanceNames.lottieMatching,
);
inject.registerLazySingleton(
- () => Assets.lotties.seaching.lottie(),
- instanceName: InjectInstanceNames.lottieSearching,
+ () => Assets.lotties.list.lottie(),
+ instanceName: InjectInstanceNames.lottieList,
);
inject.registerLazySingleton(() => UniswapV4StateView());
diff --git a/lib/core/repositories/tokens_repository.dart b/lib/core/repositories/tokens_repository.dart
index aa94d1a..cb28103 100644
--- a/lib/core/repositories/tokens_repository.dart
+++ b/lib/core/repositories/tokens_repository.dart
@@ -14,9 +14,7 @@ class TokensRepository {
Future getTokenList(AppNetworks network) async {
final request = await _zupAPIDio.get(
"/tokens/list",
- queryParameters: {
- if (!network.isAllNetworks) "chainId": int.parse(network.chainInfo.hexChainId),
- },
+ queryParameters: {if (!network.isAllNetworks) "chainId": int.parse(network.chainInfo.hexChainId)},
);
return TokenListDto.fromJson(request.data);
@@ -29,20 +27,21 @@ class TokensRepository {
_searchTokenLastCancelToken = CancelToken();
- final response = await _zupAPIDio.get("/tokens/search", cancelToken: _searchTokenLastCancelToken, queryParameters: {
- if (!network.isAllNetworks) "chainId": network.chainId,
- "query": query,
- });
+ final response = await _zupAPIDio.get(
+ "/tokens/search",
+ cancelToken: _searchTokenLastCancelToken,
+ queryParameters: {if (!network.isAllNetworks) "chainId": network.chainId, "query": query},
+ );
_searchTokenLastCancelToken = null;
return (response.data as List).map((token) => TokenDto.fromJson(token)).toList();
}
Future getTokenPrice(String address, AppNetworks network) async {
- final response = await _zupAPIDio.get("/tokens/price", queryParameters: {
- "address": address,
- "chainId": network.chainId,
- });
+ final response = await _zupAPIDio.get(
+ "/tokens/price",
+ queryParameters: {"address": address, "chainId": network.chainId},
+ );
return TokenPriceDto.fromJson(response.data);
}
diff --git a/lib/core/slippage.dart b/lib/core/slippage.dart
index d1748ff..c1f019f 100644
--- a/lib/core/slippage.dart
+++ b/lib/core/slippage.dart
@@ -1,6 +1,6 @@
-import 'dart:ui';
-
import 'package:equatable/equatable.dart';
+import 'package:flutter/material.dart';
+import 'package:zup_core/extensions/extensions.dart';
import 'package:zup_ui_kit/zup_ui_kit.dart';
class Slippage extends Equatable {
@@ -11,7 +11,7 @@ class Slippage extends Equatable {
static const Slippage zeroPointOnePercent = Slippage._(0.1);
static const Slippage halfPercent = Slippage._(0.5);
static const Slippage onePercent = Slippage._(1.0);
- static custom(num value) => Slippage._(value);
+ static Slippage custom(num value) => Slippage._(value);
factory Slippage.fromValue(num value) {
if (value == zeroPointOnePercent.value) return zeroPointOnePercent;
@@ -21,18 +21,20 @@ class Slippage extends Equatable {
return custom(value);
}
- Color get riskBackgroundColor {
+ Color? riskBackgroundColor(Brightness brightness) {
+ if (brightness.isDark) return ZupColors.black3;
+
if (value > 10) return ZupColors.red6;
if (value > 1) return ZupColors.orange6;
- return ZupColors.gray6;
+ return null;
}
- Color get riskForegroundColor {
- if (value > 10) return ZupColors.red;
- if (value > 1) return ZupColors.orange;
+ Color? riskForegroundColor(Brightness brightness) {
+ if (value > 10) return ZupThemeColors.error.themed(brightness);
+ if (value > 1) return ZupThemeColors.alert.themed(brightness);
- return ZupColors.brand;
+ return null;
}
BigInt calculateMinTokenAmountFromSlippage(BigInt amount) {
diff --git a/lib/l10n/en.arb b/lib/l10n/en.arb
index 97c51fc..21fac94 100644
--- a/lib/l10n/en.arb
+++ b/lib/l10n/en.arb
@@ -9,6 +9,9 @@
}
},
"twentyFourHours": "24h",
+ "light": "Light",
+ "dark": "Dark",
+ "system": "System",
"week": "Week",
"weekCompact": "7d",
"appFooterTermsOfUse": "Terms of Use",
@@ -201,8 +204,8 @@
"depositPageLoadingStep3Title": "Yield optimizer at work…",
"depositPageLoadingStep3Description": "Scanning pools, calculating returns, and filtering the noise",
"depositPageBestYieldsIn": "Best Yields in",
- "depositPageLoadingStep4Title": "Fetching the Best yields for you...",
- "depositPageLoadingStep4Description": "Got it! Just adding a touch of sparkle to your perfect match!",
+ "depositPageLoadingStep4Title": "Organizing the best pools for you…",
+ "depositPageLoadingStep4Description": "Hang tight, we're filtering and organizing the best pools for you",
"depositPageErrorStateTitle": "Oops! Something went wrong!",
"depositPageErrorStateDescription": "We ran into a issue while trying to find the best pool. Give it another shot, and if it keeps happening, don’t hesitate to reach out to us!",
"depositPageEmptyStateTitle": "No Pools Found",
diff --git a/lib/l10n/gen/app_localizations.dart b/lib/l10n/gen/app_localizations.dart
index aaf2203..cba7dfa 100644
--- a/lib/l10n/gen/app_localizations.dart
+++ b/lib/l10n/gen/app_localizations.dart
@@ -105,6 +105,24 @@ abstract class S {
/// **'24h'**
String get twentyFourHours;
+ /// No description provided for @light.
+ ///
+ /// In en, this message translates to:
+ /// **'Light'**
+ String get light;
+
+ /// No description provided for @dark.
+ ///
+ /// In en, this message translates to:
+ /// **'Dark'**
+ String get dark;
+
+ /// No description provided for @system.
+ ///
+ /// In en, this message translates to:
+ /// **'System'**
+ String get system;
+
/// No description provided for @week.
///
/// In en, this message translates to:
@@ -633,13 +651,13 @@ abstract class S {
/// No description provided for @depositPageLoadingStep4Title.
///
/// In en, this message translates to:
- /// **'Fetching the Best yields for you...'**
+ /// **'Organizing the best pools for you…'**
String get depositPageLoadingStep4Title;
/// No description provided for @depositPageLoadingStep4Description.
///
/// In en, this message translates to:
- /// **'Got it! Just adding a touch of sparkle to your perfect match!'**
+ /// **'Hang tight, we\'re filtering and organizing the best pools for you'**
String get depositPageLoadingStep4Description;
/// No description provided for @depositPageErrorStateTitle.
diff --git a/lib/l10n/gen/app_localizations_en.dart b/lib/l10n/gen/app_localizations_en.dart
index cec3d1a..b21bec5 100644
--- a/lib/l10n/gen/app_localizations_en.dart
+++ b/lib/l10n/gen/app_localizations_en.dart
@@ -16,6 +16,15 @@ class SEn extends S {
@override
String get twentyFourHours => '24h';
+ @override
+ String get light => 'Light';
+
+ @override
+ String get dark => 'Dark';
+
+ @override
+ String get system => 'System';
+
@override
String get week => 'Week';
@@ -339,11 +348,11 @@ class SEn extends S {
@override
String get depositPageLoadingStep4Title =>
- 'Fetching the Best yields for you...';
+ 'Organizing the best pools for you…';
@override
String get depositPageLoadingStep4Description =>
- 'Got it! Just adding a touch of sparkle to your perfect match!';
+ 'Hang tight, we\'re filtering and organizing the best pools for you';
@override
String get depositPageErrorStateTitle => 'Oops! Something went wrong!';
diff --git a/lib/theme/theme.dart b/lib/theme/theme.dart
index bbec3d0..82eb674 100644
--- a/lib/theme/theme.dart
+++ b/lib/theme/theme.dart
@@ -1,41 +1,20 @@
import 'package:flutter/material.dart';
-import 'package:zup_app/theme/themes/zup_text_button_theme.dart';
import 'package:zup_ui_kit/zup_colors.dart';
+import 'package:zup_ui_kit/zup_theme.dart';
-abstract class ZupTheme {
+abstract class AppTheme {
static String get fontFamily => "SNPro";
+ static Color get primaryColor => ZupColors.brand;
- static ThemeData get lightTheme => ThemeData(
- fontFamily: ZupTheme.fontFamily,
- primaryColor: ZupColors.brand,
- badgeTheme: const BadgeThemeData(backgroundColor: ZupColors.brand, textColor: ZupColors.white),
- inputDecorationTheme: const InputDecorationTheme(
- focusedErrorBorder: OutlineInputBorder(
- borderRadius: BorderRadius.all(Radius.circular(8)),
- borderSide: BorderSide(color: ZupColors.red, width: 1.5),
- ),
- errorBorder: OutlineInputBorder(
- borderRadius: BorderRadius.all(Radius.circular(8)),
- borderSide: BorderSide(color: ZupColors.red, width: 1.5),
- ),
- focusedBorder: OutlineInputBorder(
- borderRadius: BorderRadius.all(Radius.circular(8)),
- borderSide: BorderSide(color: ZupColors.brand, width: 1.5),
- ),
- ),
- scrollbarTheme: const ScrollbarThemeData(
- mainAxisMargin: 10,
- crossAxisMargin: 3,
- thickness: WidgetStatePropertyAll(5),
- thumbVisibility: WidgetStatePropertyAll(false),
- ),
- scaffoldBackgroundColor: Colors.transparent,
- textButtonTheme: ZupTextButtonTheme.lightTheme,
+ static ThemeData get lightTheme => ZupTheme.lightTheme.copyWith(
+ primaryColor: primaryColor,
textSelectionTheme: const TextSelectionThemeData(selectionColor: ZupColors.brand5),
- textTheme: const TextTheme(
- titleSmall: TextStyle(fontSize: 17, fontWeight: FontWeight.w600, color: ZupColors.black),
- bodySmall: TextStyle(fontSize: 14, fontWeight: FontWeight.w400, color: ZupColors.black),
- bodyMedium: TextStyle(fontSize: 16, fontWeight: FontWeight.w500, color: ZupColors.black),
- ),
+ textTheme: ZupTheme.lightTheme.textTheme.apply(fontFamily: fontFamily),
+ );
+
+ static ThemeData get darkTheme => ZupTheme.darkTheme.copyWith(
+ primaryColor: primaryColor,
+ textTheme: ZupTheme.darkTheme.textTheme.apply(fontFamily: fontFamily),
+ textSelectionTheme: TextSelectionThemeData(selectionColor: ZupColors.brand.withValues(alpha: 0.3)),
);
}
diff --git a/lib/theme/themes/zup_text_button_theme.dart b/lib/theme/themes/zup_text_button_theme.dart
deleted file mode 100644
index 1a1dedf..0000000
--- a/lib/theme/themes/zup_text_button_theme.dart
+++ /dev/null
@@ -1,22 +0,0 @@
-import 'package:flutter/material.dart';
-import 'package:zup_app/theme/theme.dart';
-import 'package:zup_ui_kit/zup_colors.dart';
-
-abstract class ZupTextButtonTheme {
- static TextButtonThemeData get lightTheme => TextButtonThemeData(
- style: ButtonStyle(
- shape: const WidgetStatePropertyAll(RoundedRectangleBorder(
- borderRadius: BorderRadius.all(Radius.circular(8)),
- )),
- overlayColor: WidgetStatePropertyAll(ZupColors.brand.withValues(alpha: .05)),
- foregroundColor: WidgetStateProperty.resolveWith((states) {
- if (states.contains(WidgetState.disabled)) return ZupColors.gray5;
-
- return ZupColors.black;
- }),
- textStyle: WidgetStateProperty.resolveWith((states) {
- return TextStyle(fontSize: 17, fontWeight: FontWeight.normal, fontFamily: ZupTheme.fontFamily);
- }),
- ),
- );
-}
diff --git a/lib/widgets/app_bottom_navigation_bar.dart b/lib/widgets/app_bottom_navigation_bar.dart
index 088a6d3..f177fae 100644
--- a/lib/widgets/app_bottom_navigation_bar.dart
+++ b/lib/widgets/app_bottom_navigation_bar.dart
@@ -7,6 +7,7 @@ import 'package:zup_app/core/injections.dart';
import 'package:zup_app/core/zup_navigator.dart';
import 'package:zup_app/gen/assets.gen.dart';
import 'package:zup_app/l10n/gen/app_localizations.dart';
+import 'package:zup_core/zup_core.dart';
import 'package:zup_ui_kit/zup_ui_kit.dart';
class _AppBottomNavigationBarItem {
@@ -43,7 +44,10 @@ class _AppBottomNavigationBarState extends State {
label: S.of(context).appBottomNavigationBarNewPosition,
path: ZupNavigatorPaths.newPosition.path,
icon: Assets.icons.plus.svg(
- colorFilter: const ColorFilter.mode(ZupColors.gray, BlendMode.srcIn),
+ colorFilter: ColorFilter.mode(
+ ZupThemeColors.disabledButtonBackground.themed(context.brightness),
+ BlendMode.srcIn,
+ ),
height: 16,
),
navigateCallback: () => _navigator.navigateToNewPosition(),
@@ -52,7 +56,10 @@ class _AppBottomNavigationBarState extends State {
label: S.of(context).appBottomNavigationBarMyPositions,
path: "",
icon: Assets.icons.waterWaves.svg(
- colorFilter: const ColorFilter.mode(ZupColors.gray5, BlendMode.srcIn),
+ colorFilter: ColorFilter.mode(
+ ZupThemeColors.disabledButtonBackground.themed(context.brightness),
+ BlendMode.srcIn,
+ ),
height: 16,
),
navigateCallback: null,
@@ -94,21 +101,18 @@ class _AppBottomNavigationBarState extends State {
ClipRect(
child: BackdropFilter(
filter: ImageFilter.blur(sigmaX: 5, sigmaY: 5),
- child: Container(color: Colors.white.withValues(alpha: 0.85)),
+ child: Container(color: ZupThemeColors.background.themed(context.brightness).withValues(alpha: 0.85)),
),
),
Column(
children: [
- const Divider(
- color: ZupColors.gray6,
- height: 1,
- ),
+ Divider(color: ZupThemeColors.borderOnBackground.themed(context.brightness), thickness: 0.5, height: 1),
SizedBox(
height: AppBottomNavigationBar.height - 1,
child: BottomNavigationBar(
backgroundColor: Colors.transparent,
selectedItemColor: ZupColors.brand,
- unselectedItemColor: ZupColors.gray5,
+ unselectedItemColor: ZupThemeColors.disabledButtonBackground.themed(context.brightness),
selectedLabelStyle: const TextStyle(fontWeight: FontWeight.w400, fontSize: 12, height: 2.1),
unselectedLabelStyle: const TextStyle(fontWeight: FontWeight.w400, fontSize: 12, height: 2.1),
elevation: 0,
diff --git a/lib/widgets/app_cookies_consent_widget.dart b/lib/widgets/app_cookies_consent_widget.dart
index 36cf04c..7568848 100644
--- a/lib/widgets/app_cookies_consent_widget.dart
+++ b/lib/widgets/app_cookies_consent_widget.dart
@@ -3,6 +3,7 @@ import 'package:zup_app/core/cache.dart';
import 'package:zup_app/core/injections.dart';
import 'package:zup_app/core/zup_links.dart';
import 'package:zup_app/l10n/gen/app_localizations.dart';
+import 'package:zup_core/extensions/extensions.dart';
import 'package:zup_ui_kit/zup_ui_kit.dart';
class AppCookieConsentWidget extends StatelessWidget {
@@ -18,8 +19,8 @@ class AppCookieConsentWidget extends StatelessWidget {
return Container(
padding: const EdgeInsets.all(15),
decoration: BoxDecoration(
- color: ZupColors.white,
- border: Border.all(color: ZupColors.gray5),
+ color: ZupThemeColors.background.themed(context.brightness),
+ border: Border.all(color: ZupThemeColors.borderOnBackground.themed(context.brightness)),
borderRadius: BorderRadius.circular(12),
),
width: 300,
@@ -29,37 +30,42 @@ class AppCookieConsentWidget extends StatelessWidget {
mainAxisSize: MainAxisSize.min,
children: [
Text.rich(
- TextSpan(children: [
- TextSpan(
- text: S.of(context).appCookiesConsentWidgetDescription,
- style: const TextStyle(color: ZupColors.gray, fontSize: 14),
- ),
- const TextSpan(text: " "),
- WidgetSpan(
- child: SizedBox(
- height: 17,
- child: TextButton(
- key: const Key("privacy-policy-button"),
- onPressed: () {
- zupLinks.launchPrivacyPolicy();
- },
- style: ButtonStyle(
- visualDensity: VisualDensity.compact,
- minimumSize: WidgetStateProperty.all(Size.zero),
- splashFactory: NoSplash.splashFactory,
- backgroundColor: WidgetStateProperty.all(Colors.transparent),
- overlayColor: WidgetStateProperty.all(Colors.transparent),
- padding: WidgetStateProperty.all(EdgeInsets.zero),
- ),
- child: Text(
- S.of(context).privacyPolicy,
- style: const TextStyle(decoration: TextDecoration.underline, fontSize: 14),
+ TextSpan(
+ children: [
+ TextSpan(
+ text: S.of(context).appCookiesConsentWidgetDescription,
+ style: const TextStyle(color: ZupColors.gray, fontSize: 14),
+ ),
+ const TextSpan(text: " "),
+ WidgetSpan(
+ child: SizedBox(
+ height: 17,
+ child: TextButton(
+ key: const Key("privacy-policy-button"),
+ onPressed: () {
+ zupLinks.launchPrivacyPolicy();
+ },
+ style: ButtonStyle(
+ visualDensity: VisualDensity.compact,
+ minimumSize: WidgetStateProperty.all(Size.zero),
+ splashFactory: NoSplash.splashFactory,
+ backgroundColor: WidgetStateProperty.all(Colors.transparent),
+ overlayColor: WidgetStateProperty.all(Colors.transparent),
+ padding: WidgetStateProperty.all(EdgeInsets.zero),
+ ),
+ child: Text(
+ S.of(context).privacyPolicy,
+ style: const TextStyle(
+ decoration: TextDecoration.underline,
+ fontSize: 14,
+ color: ZupColors.brand,
+ ),
+ ),
),
),
),
- style: const TextStyle(color: ZupColors.black, fontSize: 14),
- ),
- ]),
+ ],
+ ),
),
const SizedBox(height: 20),
ZupPrimaryButton(
@@ -67,8 +73,9 @@ class AppCookieConsentWidget extends StatelessWidget {
height: 40,
title: S.of(context).understood,
hoverElevation: 0,
- backgroundColor: ZupColors.brand6,
+ backgroundColor: ZupColors.brand.withValues(alpha: 0.1),
foregroundColor: ZupColors.brand,
+ hoverColor: ZupColors.brand.withValues(alpha: 0.1),
onPressed: (buttonContext) {
onAccept();
cache.saveCookiesConsentStatus(status: true);
diff --git a/lib/widgets/app_footer.dart b/lib/widgets/app_footer.dart
index 13d0f06..d926ccd 100644
--- a/lib/widgets/app_footer.dart
+++ b/lib/widgets/app_footer.dart
@@ -3,6 +3,7 @@ import 'package:zup_app/core/injections.dart';
import 'package:zup_app/core/zup_links.dart';
import 'package:zup_app/gen/assets.gen.dart';
import 'package:zup_app/l10n/gen/app_localizations.dart';
+import 'package:zup_core/extensions/extensions.dart';
import 'package:zup_core/mixins/device_info_mixin.dart';
import 'package:zup_ui_kit/zup_ui_kit.dart';
@@ -17,69 +18,69 @@ enum _AppFooterButton {
contactUs;
Key get key => switch (this) {
- github => const Key("github-button"),
- twitter => const Key("twitter-button"),
- telegram => const Key("telegram-button"),
- termsOfUse => const Key("terms-of-use-button"),
- privacyPolicy => const Key("privacy-policy-button"),
- docs => const Key("docs-button"),
- faq => const Key("faq-button"),
- contactUs => const Key("contact-us-button")
- };
+ github => const Key("github-button"),
+ twitter => const Key("twitter-button"),
+ telegram => const Key("telegram-button"),
+ termsOfUse => const Key("terms-of-use-button"),
+ privacyPolicy => const Key("privacy-policy-button"),
+ docs => const Key("docs-button"),
+ faq => const Key("faq-button"),
+ contactUs => const Key("contact-us-button"),
+ };
String title(BuildContext context) => switch (this) {
- _AppFooterButton.github => "",
- _AppFooterButton.twitter => "",
- _AppFooterButton.telegram => "",
- _AppFooterButton.termsOfUse => S.of(context).appFooterTermsOfUse,
- _AppFooterButton.privacyPolicy => S.of(context).privacyPolicy,
- _AppFooterButton.docs => S.of(context).appFooterDocs,
- _AppFooterButton.faq => S.of(context).appFooterFAQ,
- _AppFooterButton.contactUs => S.of(context).appFooterContactUs
- };
+ _AppFooterButton.github => "",
+ _AppFooterButton.twitter => "",
+ _AppFooterButton.telegram => "",
+ _AppFooterButton.termsOfUse => S.of(context).appFooterTermsOfUse,
+ _AppFooterButton.privacyPolicy => S.of(context).privacyPolicy,
+ _AppFooterButton.docs => S.of(context).appFooterDocs,
+ _AppFooterButton.faq => S.of(context).appFooterFAQ,
+ _AppFooterButton.contactUs => S.of(context).appFooterContactUs,
+ };
Widget? icon() => switch (this) {
- _AppFooterButton.github => Assets.logos.github.svg(
- height: 20,
- colorFilter: const ColorFilter.mode(ZupColors.gray4, BlendMode.srcIn),
- ),
- _AppFooterButton.twitter => Assets.logos.x.svg(
- height: 20,
- colorFilter: const ColorFilter.mode(ZupColors.gray4, BlendMode.srcIn),
- ),
- _AppFooterButton.telegram => Assets.logos.telegram.svg(
- height: 22,
- colorFilter: const ColorFilter.mode(ZupColors.gray4, BlendMode.srcIn),
- ),
- _ => null
- };
+ _AppFooterButton.github => Assets.logos.github.svg(
+ height: 20,
+ colorFilter: const ColorFilter.mode(ZupColors.gray4, BlendMode.srcIn),
+ ),
+ _AppFooterButton.twitter => Assets.logos.x.svg(
+ height: 20,
+ colorFilter: const ColorFilter.mode(ZupColors.gray4, BlendMode.srcIn),
+ ),
+ _AppFooterButton.telegram => Assets.logos.telegram.svg(
+ height: 22,
+ colorFilter: const ColorFilter.mode(ZupColors.gray4, BlendMode.srcIn),
+ ),
+ _ => null,
+ };
Function() onTap(ZupLinks zupLinks) => switch (this) {
- _AppFooterButton.github => () {
- zupLinks.launchZupGithub();
- },
- _AppFooterButton.twitter => () {
- zupLinks.launchZupTwitter();
- },
- _AppFooterButton.telegram => () {
- zupLinks.launchZupTelegram();
- },
- _AppFooterButton.termsOfUse => () {
- zupLinks.launchTermsOfUse();
- },
- _AppFooterButton.privacyPolicy => () {
- zupLinks.launchPrivacyPolicy();
- },
- _AppFooterButton.docs => () {
- zupLinks.launchZupDocs();
- },
- _AppFooterButton.faq => () {
- zupLinks.launchZupFAQ();
- },
- _AppFooterButton.contactUs => () {
- zupLinks.launchZupContactUs();
- },
- };
+ _AppFooterButton.github => () {
+ zupLinks.launchZupGithub();
+ },
+ _AppFooterButton.twitter => () {
+ zupLinks.launchZupTwitter();
+ },
+ _AppFooterButton.telegram => () {
+ zupLinks.launchZupTelegram();
+ },
+ _AppFooterButton.termsOfUse => () {
+ zupLinks.launchTermsOfUse();
+ },
+ _AppFooterButton.privacyPolicy => () {
+ zupLinks.launchPrivacyPolicy();
+ },
+ _AppFooterButton.docs => () {
+ zupLinks.launchZupDocs();
+ },
+ _AppFooterButton.faq => () {
+ zupLinks.launchZupFAQ();
+ },
+ _AppFooterButton.contactUs => () {
+ zupLinks.launchZupContactUs();
+ },
+ };
}
class AppFooter extends StatefulWidget {
@@ -101,7 +102,7 @@ class _AppFooterState extends State with DeviceInfoMixin {
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
- const Divider(color: ZupColors.gray5, thickness: 0.5),
+ Divider(color: context.brightness.isDark ? ZupColors.black4 : ZupColors.gray5, thickness: 0.5),
const SizedBox(height: 20),
isMobileSize(context) ? _buildMobileFooter() : _buildDesktopFooter(),
],
@@ -110,147 +111,132 @@ class _AppFooterState extends State with DeviceInfoMixin {
}
Widget _buildMobileFooter() => Column(
- crossAxisAlignment: CrossAxisAlignment.start,
+ crossAxisAlignment: CrossAxisAlignment.start,
+ children: [
+ Row(
children: [
- Row(
- children: [
- Assets.logos.zupGray.svg(height: 30),
- const Spacer(),
- GestureDetector(
- key: _AppFooterButton.github.key,
- onTap: _AppFooterButton.github.onTap(_zupLinks),
- child: _AppFooterButton.github.icon(),
- ),
- _spacing(),
- GestureDetector(
- key: _AppFooterButton.twitter.key,
- onTap: _AppFooterButton.twitter.onTap(_zupLinks),
- child: _AppFooterButton.twitter.icon(),
- ),
- _spacing(),
- GestureDetector(
- key: _AppFooterButton.telegram.key,
- onTap: _AppFooterButton.telegram.onTap(_zupLinks),
- child: _AppFooterButton.telegram.icon(),
- ),
- ],
+ Assets.logos.zupGray.svg(height: 30),
+ const Spacer(),
+ GestureDetector(
+ key: _AppFooterButton.github.key,
+ onTap: _AppFooterButton.github.onTap(_zupLinks),
+ child: _AppFooterButton.github.icon(),
),
- const SizedBox(height: 40),
- Wrap(
- runSpacing: 10,
- spacing: 20,
- children: [
- GestureDetector(
- key: _AppFooterButton.termsOfUse.key,
- onTap: _AppFooterButton.termsOfUse.onTap(_zupLinks),
- child: Text(
- _AppFooterButton.termsOfUse.title(context),
- style: const TextStyle(
- fontSize: 14,
- color: ZupColors.gray,
- ),
- ),
- ),
- GestureDetector(
- key: _AppFooterButton.privacyPolicy.key,
- onTap: _AppFooterButton.privacyPolicy.onTap(_zupLinks),
- child: Text(
- _AppFooterButton.privacyPolicy.title(context),
- style: const TextStyle(
- fontSize: 14,
- color: ZupColors.gray,
- ),
- ),
- ),
- GestureDetector(
- key: _AppFooterButton.docs.key,
- onTap: _AppFooterButton.docs.onTap(_zupLinks),
- child: Text(
- _AppFooterButton.docs.title(context),
- style: const TextStyle(
- fontSize: 14,
- color: ZupColors.gray,
- ),
- ),
- ),
- GestureDetector(
- key: _AppFooterButton.faq.key,
- onTap: _AppFooterButton.faq.onTap(_zupLinks),
- child: Text(
- _AppFooterButton.faq.title(context),
- style: const TextStyle(
- fontSize: 14,
- color: ZupColors.gray,
- ),
- ),
- ),
- GestureDetector(
- key: _AppFooterButton.contactUs.key,
- onTap: _AppFooterButton.contactUs.onTap(_zupLinks),
- child: Text(
- _AppFooterButton.contactUs.title(context),
- style: const TextStyle(
- fontSize: 14,
- color: ZupColors.gray,
- ),
- ),
- ),
- ],
+ _spacing(),
+ GestureDetector(
+ key: _AppFooterButton.twitter.key,
+ onTap: _AppFooterButton.twitter.onTap(_zupLinks),
+ child: _AppFooterButton.twitter.icon(),
+ ),
+ _spacing(),
+ GestureDetector(
+ key: _AppFooterButton.telegram.key,
+ onTap: _AppFooterButton.telegram.onTap(_zupLinks),
+ child: _AppFooterButton.telegram.icon(),
),
],
- );
-
- Widget _buildDesktopFooter() => Row(
+ ),
+ const SizedBox(height: 40),
+ Wrap(
+ runSpacing: 10,
+ spacing: 20,
children: [
- Assets.logos.zupGray.svg(height: 25),
- const SizedBox(width: 40),
- ZupLightButton(
+ GestureDetector(
key: _AppFooterButton.termsOfUse.key,
- onPressed: _AppFooterButton.termsOfUse.onTap(_zupLinks),
- child: Text(_AppFooterButton.termsOfUse.title(context), style: const TextStyle(fontSize: 14)),
+ onTap: _AppFooterButton.termsOfUse.onTap(_zupLinks),
+ child: Text(
+ _AppFooterButton.termsOfUse.title(context),
+ style: const TextStyle(fontSize: 14, color: ZupColors.gray),
+ ),
),
- _spacing(),
- ZupLightButton(
+ GestureDetector(
key: _AppFooterButton.privacyPolicy.key,
- onPressed: _AppFooterButton.privacyPolicy.onTap(_zupLinks),
- child: Text(_AppFooterButton.privacyPolicy.title(context), style: const TextStyle(fontSize: 14)),
+ onTap: _AppFooterButton.privacyPolicy.onTap(_zupLinks),
+ child: Text(
+ _AppFooterButton.privacyPolicy.title(context),
+ style: const TextStyle(fontSize: 14, color: ZupColors.gray),
+ ),
),
- _spacing(),
- ZupLightButton(
+ GestureDetector(
key: _AppFooterButton.docs.key,
- onPressed: _AppFooterButton.docs.onTap(_zupLinks),
- child: Text(_AppFooterButton.docs.title(context), style: const TextStyle(fontSize: 14)),
+ onTap: _AppFooterButton.docs.onTap(_zupLinks),
+ child: Text(
+ _AppFooterButton.docs.title(context),
+ style: const TextStyle(fontSize: 14, color: ZupColors.gray),
+ ),
),
- _spacing(),
- ZupLightButton(
+ GestureDetector(
key: _AppFooterButton.faq.key,
- onPressed: _AppFooterButton.faq.onTap(_zupLinks),
- child: Text(_AppFooterButton.faq.title(context), style: const TextStyle(fontSize: 14)),
+ onTap: _AppFooterButton.faq.onTap(_zupLinks),
+ child: Text(
+ _AppFooterButton.faq.title(context),
+ style: const TextStyle(fontSize: 14, color: ZupColors.gray),
+ ),
),
- _spacing(),
- ZupLightButton(
+ GestureDetector(
key: _AppFooterButton.contactUs.key,
- onPressed: _AppFooterButton.contactUs.onTap(_zupLinks),
- child: Text(_AppFooterButton.contactUs.title(context), style: const TextStyle(fontSize: 14)),
- ),
- const Spacer(),
- ZupLightButton(
- key: _AppFooterButton.github.key,
- onPressed: _AppFooterButton.github.onTap(_zupLinks),
- child: _AppFooterButton.github.icon() ?? const SizedBox.shrink(),
- ),
- _spacing(),
- ZupLightButton(
- key: _AppFooterButton.twitter.key,
- onPressed: _AppFooterButton.twitter.onTap(_zupLinks),
- child: _AppFooterButton.twitter.icon() ?? const SizedBox.shrink(),
- ),
- _spacing(),
- ZupLightButton(
- key: _AppFooterButton.telegram.key,
- onPressed: _AppFooterButton.telegram.onTap(_zupLinks),
- child: _AppFooterButton.telegram.icon() ?? const SizedBox.shrink(),
+ onTap: _AppFooterButton.contactUs.onTap(_zupLinks),
+ child: Text(
+ _AppFooterButton.contactUs.title(context),
+ style: const TextStyle(fontSize: 14, color: ZupColors.gray),
+ ),
),
],
- );
+ ),
+ ],
+ );
+
+ Widget _buildDesktopFooter() => Row(
+ children: [
+ Assets.logos.zupGray.svg(height: 25),
+ const SizedBox(width: 40),
+ ZupLightButton(
+ key: _AppFooterButton.termsOfUse.key,
+ onPressed: _AppFooterButton.termsOfUse.onTap(_zupLinks),
+ child: Text(_AppFooterButton.termsOfUse.title(context), style: const TextStyle(fontSize: 14)),
+ ),
+ _spacing(),
+ ZupLightButton(
+ key: _AppFooterButton.privacyPolicy.key,
+ onPressed: _AppFooterButton.privacyPolicy.onTap(_zupLinks),
+ child: Text(_AppFooterButton.privacyPolicy.title(context), style: const TextStyle(fontSize: 14)),
+ ),
+ _spacing(),
+ ZupLightButton(
+ key: _AppFooterButton.docs.key,
+ onPressed: _AppFooterButton.docs.onTap(_zupLinks),
+ child: Text(_AppFooterButton.docs.title(context), style: const TextStyle(fontSize: 14)),
+ ),
+ _spacing(),
+ ZupLightButton(
+ key: _AppFooterButton.faq.key,
+ onPressed: _AppFooterButton.faq.onTap(_zupLinks),
+ child: Text(_AppFooterButton.faq.title(context), style: const TextStyle(fontSize: 14)),
+ ),
+ _spacing(),
+ ZupLightButton(
+ key: _AppFooterButton.contactUs.key,
+ onPressed: _AppFooterButton.contactUs.onTap(_zupLinks),
+ child: Text(_AppFooterButton.contactUs.title(context), style: const TextStyle(fontSize: 14)),
+ ),
+ const Spacer(),
+ ZupLightButton(
+ key: _AppFooterButton.github.key,
+ onPressed: _AppFooterButton.github.onTap(_zupLinks),
+ child: _AppFooterButton.github.icon() ?? const SizedBox.shrink(),
+ ),
+ _spacing(),
+ ZupLightButton(
+ key: _AppFooterButton.twitter.key,
+ onPressed: _AppFooterButton.twitter.onTap(_zupLinks),
+ child: _AppFooterButton.twitter.icon() ?? const SizedBox.shrink(),
+ ),
+ _spacing(),
+ ZupLightButton(
+ key: _AppFooterButton.telegram.key,
+ onPressed: _AppFooterButton.telegram.onTap(_zupLinks),
+ child: _AppFooterButton.telegram.icon() ?? const SizedBox.shrink(),
+ ),
+ ],
+ );
}
diff --git a/lib/widgets/app_header/app_header.dart b/lib/widgets/app_header/app_header.dart
index c1b5946..b7dbfc3 100644
--- a/lib/widgets/app_header/app_header.dart
+++ b/lib/widgets/app_header/app_header.dart
@@ -12,7 +12,7 @@ import 'package:zup_app/core/zup_navigator.dart';
import 'package:zup_app/gen/assets.gen.dart';
import 'package:zup_app/widgets/app_header/app_header_tab_button.dart';
import 'package:zup_app/widgets/app_settings_dropdown.dart';
-import 'package:zup_core/mixins/device_info_mixin.dart';
+import 'package:zup_core/zup_core.dart';
import 'package:zup_ui_kit/zup_ui_kit.dart';
class AppHeader extends StatefulWidget {
@@ -61,11 +61,7 @@ class _AppHeaderState extends State with DeviceInfoMixin {
message: "Testnet",
location: BannerLocation.topEnd,
color: ZupColors.brand6,
- shadow: const BoxShadow(
- color: ZupColors.gray6,
- offset: Offset(0, 1),
- blurRadius: 2,
- ),
+ shadow: const BoxShadow(color: ZupColors.gray6, offset: Offset(0, 1), blurRadius: 2),
textStyle: const TextStyle(fontSize: 10, color: ZupColors.brand, fontWeight: FontWeight.w600),
child: buildAppBar,
);
@@ -77,76 +73,92 @@ class _AppHeaderState extends State with DeviceInfoMixin {
}
Widget get buildAppBar => SizedBox(
- height: widget.height,
- child: Stack(
- alignment: Alignment.center,
- children: [
- ClipRect(
- child: BackdropFilter(
- filter: ImageFilter.blur(sigmaX: 5, sigmaY: 5),
- child: Container(color: Colors.white.withValues(alpha: 0.85)),
+ height: widget.height,
+ child: Stack(
+ alignment: Alignment.center,
+ children: [
+ ClipRect(
+ child: BackdropFilter(
+ filter: ImageFilter.blur(sigmaX: 5, sigmaY: 5),
+ child: Container(color: ZupThemeColors.background.themed(context.brightness).withValues(alpha: 0.85)),
+ ),
+ ),
+ Padding(
+ padding: const EdgeInsets.only(left: 30, right: 15),
+ child: Row(
+ crossAxisAlignment: CrossAxisAlignment.center,
+ children: [
+ MouseRegion(
+ cursor: SystemMouseCursors.click,
+ child: GestureDetector(
+ key: const Key("logo-button"),
+ onTap: () => navigator.navigateToInitial(),
+ child: Assets.logos.zup.svg(
+ height: 30,
+ colorFilter: context.brightness.isLight
+ ? null
+ : const ColorFilter.mode(ZupColors.brand, BlendMode.srcIn),
+ ),
+ ),
),
- ),
- Padding(
- padding: const EdgeInsets.only(left: 30, right: 15),
- child: Row(
- crossAxisAlignment: CrossAxisAlignment.center,
- children: [
- MouseRegion(
- cursor: SystemMouseCursors.click,
- child: GestureDetector(
- key: const Key("logo-button"),
- onTap: () => navigator.navigateToInitial(),
- child: Assets.logos.zup.svg(height: 30),
+ const SizedBox(width: 26),
+ if (!isTabletSize(context)) ...[
+ AppHeaderTabButton(
+ key: const Key("new-position-button"),
+ title: "New Position",
+ icon: Assets.icons.plusDiamond.svg(
+ colorFilter: ColorFilter.mode(
+ ZupThemeColors.primaryText.themed(context.brightness),
+ BlendMode.srcIn,
),
),
- const SizedBox(width: 26),
- if (!isTabletSize(context)) ...[
- AppHeaderTabButton(
- key: const Key("new-position-button"),
- title: "New Position",
- icon: Assets.icons.plusDiamond.svg(),
- selected: navigator.currentRoute.isNewPosition,
- onPressed: () => navigator.navigateToNewPosition(),
- ),
- const SizedBox(width: 10),
- AppHeaderTabButton(
- key: const Key("my-positions-button"),
- title: "My Positions (Soon)",
- icon: Assets.icons.waterWaves.svg(),
- selected: false,
- onPressed: null, // () => navigator.navigateToMyPositions(),
- ),
- ],
- const Spacer(),
- NetworkSwitcher(
- compact: isMobileSize(context),
- initialNetworkIndex: currentModeNetworks.indexOf(appCubit.selectedNetwork),
- onSelect: (item, index) => appCubit.updateAppNetwork(currentModeNetworks[index]),
- networks: List.generate(
- currentModeNetworks.length,
- (index) => NetworkSwitcherItem(
- title: currentModeNetworks[index].label,
- icon: currentModeNetworks[index].icon,
- chainInfo:
- currentModeNetworks[index].isAllNetworks ? null : currentModeNetworks[index].chainInfo,
- ),
+ selected: navigator.currentRoute.isNewPosition,
+ onPressed: () => navigator.navigateToNewPosition(),
+ ),
+ const SizedBox(width: 10),
+ AppHeaderTabButton(
+ key: const Key("my-positions-button"),
+ title: "My Positions (Soon)",
+ icon: Assets.icons.waterWaves.svg(
+ colorFilter: ColorFilter.mode(
+ ZupThemeColors.primaryText.themed(context.brightness),
+ BlendMode.srcIn,
),
),
- const SizedBox(width: 12),
- ConnectButton(compact: isMobileSize(context)),
- const SizedBox(width: 12),
- ZupIconButton(
- iconColor: ZupColors.brand,
- icon: Transform.rotate(angle: pi / 2, child: Assets.icons.ellipsis.svg(height: 3.5)),
- onPressed: (context) {
- AppSettingsDropdown.show(context);
- },
- padding: const EdgeInsets.symmetric(horizontal: 10, vertical: 20)),
- ],
+ selected: false,
+ onPressed: null, // () => navigator.navigateToMyPositions(),
+ ),
+ ],
+ const Spacer(),
+ NetworkSwitcher(
+ compact: isMobileSize(context),
+ initialNetworkIndex: currentModeNetworks.indexOf(appCubit.selectedNetwork),
+ onSelect: (item, index) => appCubit.updateAppNetwork(currentModeNetworks[index]),
+ networks: List.generate(
+ currentModeNetworks.length,
+ (index) => NetworkSwitcherItem(
+ title: currentModeNetworks[index].label,
+ icon: currentModeNetworks[index].icon,
+ chainInfo: currentModeNetworks[index].isAllNetworks ? null : currentModeNetworks[index].chainInfo,
+ ),
+ ),
+ ),
+ const SizedBox(width: 12),
+ ConnectButton(compact: isMobileSize(context)),
+ const SizedBox(width: 12),
+ ZupIconButton(
+ iconColor: context.brightness.isLight ? ZupColors.brand : ZupColors.white,
+
+ icon: Transform.rotate(angle: pi / 2, child: Assets.icons.ellipsis.svg(height: 3.5)),
+ onPressed: (context) {
+ AppSettingsDropdown.show(context);
+ },
+ padding: const EdgeInsets.symmetric(horizontal: 10, vertical: 20),
),
- ),
- ],
+ ],
+ ),
),
- );
+ ],
+ ),
+ );
}
diff --git a/lib/widgets/app_header/app_header_tab_button.dart b/lib/widgets/app_header/app_header_tab_button.dart
index 4cdc30b..42370bc 100644
--- a/lib/widgets/app_header/app_header_tab_button.dart
+++ b/lib/widgets/app_header/app_header_tab_button.dart
@@ -1,14 +1,9 @@
import 'package:flutter/material.dart';
-import 'package:zup_ui_kit/zup_colors.dart';
+import 'package:zup_core/extensions/extensions.dart';
+import 'package:zup_ui_kit/zup_theme_colors.dart';
class AppHeaderTabButton extends StatefulWidget {
- const AppHeaderTabButton({
- super.key,
- required this.title,
- this.selected = true,
- this.icon,
- required this.onPressed,
- });
+ const AppHeaderTabButton({super.key, required this.title, this.selected = true, this.icon, required this.onPressed});
final String title;
final bool selected;
@@ -23,13 +18,26 @@ class _AppHeaderTabButtonState extends State {
bool isHovering = false;
TextStyle? get _textStyle {
- if (widget.selected) return Theme.of(context).textTheme.titleSmall;
- if (isHovering) return Theme.of(context).textTheme.titleSmall?.copyWith(fontWeight: FontWeight.w500);
+ if (widget.selected) {
+ return TextStyle(
+ fontSize: 15,
+ fontWeight: FontWeight.w600,
+ color: ZupThemeColors.primaryText.themed(context.brightness),
+ );
+ }
+ if (isHovering) {
+ return TextStyle(
+ fontSize: 15,
+ fontWeight: FontWeight.w500,
+ color: ZupThemeColors.primaryText.themed(context.brightness),
+ );
+ }
- return Theme.of(context).textTheme.titleSmall?.copyWith(
- fontWeight: FontWeight.w500,
- color: ZupColors.gray5,
- );
+ return TextStyle(
+ fontSize: 15,
+ fontWeight: FontWeight.w500,
+ color: ZupThemeColors.disabledText.themed(context.brightness),
+ );
}
@override
@@ -37,16 +45,24 @@ class _AppHeaderTabButtonState extends State {
return TextButton.icon(
onPressed: widget.onPressed,
onHover: (value) => setState(() => isHovering = value),
+ style: ButtonStyle(
+ surfaceTintColor: WidgetStateProperty.all(Colors.red),
+ backgroundColor: WidgetStateProperty.all(Colors.transparent),
+ overlayColor: WidgetStateProperty.resolveWith((states) {
+ if (states.contains(WidgetState.hovered)) {
+ return ZupThemeColors.hoverOnTertiaryButton.themed(context.brightness);
+ }
+
+ return Colors.transparent;
+ }),
+ ),
icon: AnimatedContainer(
width: (widget.selected || isHovering) ? 20 : 0,
curve: Curves.decelerate,
duration: const Duration(milliseconds: 300),
child: widget.icon,
),
- label: Text(
- widget.title,
- style: _textStyle,
- ),
+ label: Text(widget.title, style: _textStyle),
);
}
}
diff --git a/lib/widgets/app_settings_dropdown.dart b/lib/widgets/app_settings_dropdown.dart
index 11c4959..30da0af 100644
--- a/lib/widgets/app_settings_dropdown.dart
+++ b/lib/widgets/app_settings_dropdown.dart
@@ -1,18 +1,20 @@
import 'package:flutter/material.dart';
import 'package:flutter_bloc/flutter_bloc.dart';
import 'package:zup_app/app/app_cubit/app_cubit.dart';
+import 'package:zup_app/core/enums/app_theme_mode.dart';
import 'package:zup_app/core/injections.dart';
import 'package:zup_app/l10n/gen/app_localizations.dart';
+import 'package:zup_core/extensions/extensions.dart';
import 'package:zup_ui_kit/zup_ui_kit.dart';
class AppSettingsDropdown extends StatefulWidget {
const AppSettingsDropdown({super.key});
static void show(BuildContext showBelowContext) => ZupPopover.show(
- showBasedOnContext: showBelowContext,
- adjustment: const Offset(0, 16),
- child: const AppSettingsDropdown(),
- );
+ showBasedOnContext: showBelowContext,
+ adjustment: const Offset(0, 16),
+ child: const AppSettingsDropdown(),
+ );
@override
State createState() => _AppSettingsDropdownState();
@@ -24,50 +26,77 @@ class _AppSettingsDropdownState extends State {
@override
Widget build(BuildContext context) {
return Container(
- padding: const EdgeInsets.all(12),
+ // width: 240,
+ padding: const EdgeInsets.all(20),
decoration: BoxDecoration(
- color: ZupColors.white,
+ color: ZupThemeColors.background.themed(context.brightness),
borderRadius: BorderRadius.circular(12),
- border: Border.all(color: ZupColors.gray5),
+ border: Border.all(color: ZupThemeColors.borderOnBackground.themed(context.brightness)),
),
- child: Column(
- mainAxisSize: MainAxisSize.min,
- children: [
- Flexible(
- fit: FlexFit.loose,
- child: Row(
- spacing: 10,
- mainAxisSize: MainAxisSize.min,
- mainAxisAlignment: MainAxisAlignment.start,
- crossAxisAlignment: CrossAxisAlignment.center,
- children: [
- MouseRegion(
- cursor: SystemMouseCursors.click,
- child: GestureDetector(
- key: const Key("testnet-mode-text"),
- onTap: () => appCubit.toggleTestnetMode(),
- child: Text(
- S.of(context).appSettingsDropdownTestnetMode,
- style: const TextStyle(fontSize: 14),
- ),
- ),
- ),
- const SizedBox(width: 28),
- BlocBuilder(
- bloc: appCubit,
- builder: (context, state) {
- return ZupSwitch(
- key: const Key("testnet-mode-switch"),
- value: appCubit.isTestnetMode,
- onChanged: (value) => appCubit.toggleTestnetMode(),
- size: 42,
+ child: BlocBuilder(
+ bloc: appCubit,
+ builder: (context, state) {
+ return Column(
+ mainAxisSize: MainAxisSize.min,
+ crossAxisAlignment: CrossAxisAlignment.start,
+ spacing: 16,
+ children: [
+ const Text("Theme Mode", style: TextStyle(fontSize: 14, fontWeight: FontWeight.w600)),
+ SizedBox(
+ width: 180,
+ child: ZupPopupMenuButton(
+ buttonHeight: 40,
+ initialSelectedIndex: appCubit.currentThemeMode.index,
+ items: AppThemeMode.values.map((themeMode) {
+ return ZupPopupMenuItem(
+ title: themeMode.label(context),
+ icon: Padding(
+ padding: const EdgeInsets.all(5),
+ child: ColorFiltered(
+ colorFilter: ColorFilter.mode(
+ ZupThemeColors.iconColor.themed(context.brightness),
+ BlendMode.srcIn,
+ ),
+ child: themeMode.icon(),
+ ),
+ ),
);
+ }).toList(),
+
+ onSelected: (int selectedIndex) {
+ final newThemeMode = AppThemeMode.values[selectedIndex];
+ appCubit.updateAppThemeMode(newThemeMode);
},
),
- ],
- ),
- ),
- ],
+ ),
+
+ Row(
+ // spacing: 10,
+ mainAxisSize: MainAxisSize.min,
+ mainAxisAlignment: MainAxisAlignment.start,
+ crossAxisAlignment: CrossAxisAlignment.center,
+ children: [
+ MouseRegion(
+ cursor: SystemMouseCursors.click,
+ child: GestureDetector(
+ key: const Key("testnet-mode-text"),
+ onTap: () => appCubit.toggleTestnetMode(),
+ child: Text(S.of(context).appSettingsDropdownTestnetMode, style: const TextStyle(fontSize: 14)),
+ ),
+ ),
+ // const SizedBox(width: 20),
+ const Spacer(),
+ ZupSwitch(
+ key: const Key("testnet-mode-switch"),
+ value: appCubit.isTestnetMode,
+ onChanged: (value) => appCubit.toggleTestnetMode(),
+ size: 42,
+ ),
+ ],
+ ),
+ ],
+ );
+ },
),
);
}
diff --git a/lib/widgets/token_avatar.dart b/lib/widgets/token_avatar.dart
index fa2b99a..c057a06 100644
--- a/lib/widgets/token_avatar.dart
+++ b/lib/widgets/token_avatar.dart
@@ -15,22 +15,23 @@ class TokenAvatar extends StatelessWidget {
final zupCachedImage = inject();
Widget genericAvatar() => SizedBox(
- height: size,
- width: size,
- child: FittedBox(
- child: CircleAvatar(
- backgroundColor: ZupColors.brand7,
- foregroundColor: ZupColors.brand,
- child: Text(asset.name.isNotEmpty ? asset.name[0] : ""),
- ),
- ),
- );
+ height: size,
+ width: size,
+ child: FittedBox(
+ child: CircleAvatar(
+ backgroundColor: ZupColors.brand7,
+ foregroundColor: ZupColors.brand,
+ child: Text(asset.name.isNotEmpty ? asset.name[0] : ""),
+ ),
+ ),
+ );
@override
Widget build(BuildContext context) {
return asset.logoUrl.isEmpty
? genericAvatar()
: zupCachedImage.build(
+ context,
asset.logoUrl,
height: size,
width: size,
diff --git a/lib/widgets/token_card.dart b/lib/widgets/token_card.dart
index 3fb5cab..f6d78e8 100644
--- a/lib/widgets/token_card.dart
+++ b/lib/widgets/token_card.dart
@@ -3,6 +3,7 @@ import 'package:zup_app/core/dtos/token_dto.dart';
import 'package:zup_app/core/injections.dart';
import 'package:zup_app/widgets/token_avatar.dart';
import 'package:zup_app/widgets/zup_cached_image.dart';
+import 'package:zup_core/extensions/extensions.dart';
import 'package:zup_ui_kit/zup_ui_kit.dart';
class TokenCard extends StatefulWidget {
@@ -17,75 +18,46 @@ class TokenCard extends StatefulWidget {
class _TokenCardState extends State {
bool isHovering = false;
- bool shouldScale = false;
final zupCachedImage = inject();
@override
Widget build(BuildContext context) {
- return AnimatedScale(
- duration: const Duration(milliseconds: 100),
- onEnd: () async => setState(() => shouldScale = false),
- scale: shouldScale ? 0.98 : 1,
- child: InkWell(
- onTap: () {
- setState(() => shouldScale = true);
-
- widget.onClick();
- },
- focusColor: Colors.transparent,
- hoverColor: Colors.transparent,
- splashColor: Colors.transparent,
- highlightColor: Colors.transparent,
- onHover: (value) => setState(() => isHovering = value),
- child: AnimatedContainer(
- padding: const EdgeInsets.all(16),
- duration: const Duration(milliseconds: 100),
- height: 80,
- width: double.infinity,
- decoration: BoxDecoration(
- borderRadius: BorderRadius.circular(12),
- border: Border.all(
- color: isHovering ? ZupColors.brand : ZupColors.gray5,
- width: isHovering ? 1.5 : 0.5,
- ),
- color: Colors.white,
- ),
- child: Row(
- children: [
- TokenAvatar(asset: widget.asset, size: 35),
- const SizedBox(width: 10),
- Expanded(
- child: Column(
- crossAxisAlignment: CrossAxisAlignment.start,
- mainAxisAlignment: MainAxisAlignment.center,
+ return ZupSelectableCard(
+ onPressed: () {
+ widget.onClick();
+ },
+ onHoverChanged: (value) {
+ setState(() => isHovering = value);
+ },
+ child: Row(
+ children: [
+ TokenAvatar(asset: widget.asset, size: 35),
+ const SizedBox(width: 10),
+ Expanded(
+ child: Column(
+ crossAxisAlignment: CrossAxisAlignment.start,
+ mainAxisAlignment: MainAxisAlignment.center,
+ children: [
+ Row(
children: [
- Row(
- children: [
- Text(
- widget.asset.symbol,
- style: TextStyle(
- fontSize: 17,
- fontWeight: FontWeight.w600,
- color: isHovering ? ZupColors.brand : ZupColors.black,
- ),
- ),
- ],
- ),
- Row(
- children: [
- Text(
- widget.asset.name,
- style: const TextStyle(fontSize: 14, color: ZupColors.gray),
- ),
- ],
+ Text(
+ widget.asset.symbol,
+ style: TextStyle(
+ fontSize: 17,
+ fontWeight: FontWeight.w600,
+ color: isHovering ? ZupColors.brand : ZupThemeColors.primaryText.themed(context.brightness),
+ ),
),
],
),
- )
- ],
+ Row(
+ children: [Text(widget.asset.name, style: const TextStyle(fontSize: 14, color: ZupColors.gray))],
+ ),
+ ],
+ ),
),
- ),
+ ],
),
);
}
diff --git a/lib/widgets/token_group_card.dart b/lib/widgets/token_group_card.dart
index 57dc801..568a680 100644
--- a/lib/widgets/token_group_card.dart
+++ b/lib/widgets/token_group_card.dart
@@ -5,9 +5,11 @@ import 'package:zup_app/core/injections.dart';
import 'package:zup_app/gen/assets.gen.dart';
import 'package:zup_app/widgets/token_avatar.dart';
import 'package:zup_app/widgets/zup_cached_image.dart';
+import 'package:zup_core/extensions/extensions.dart';
import 'package:zup_ui_kit/zup_circular_loading_indicator.dart';
import 'package:zup_ui_kit/zup_colors.dart';
import 'package:zup_ui_kit/zup_selectable_card.dart';
+import 'package:zup_ui_kit/zup_theme_colors.dart';
import 'package:zup_ui_kit/zup_tooltip.dart';
class TokenGroupCard extends StatefulWidget {
@@ -29,12 +31,12 @@ class _TokenGroupCardState extends State {
return ZupSelectableCard(
onPressed: () => widget.onClick(),
onHoverChanged: (value) => setState(() => isHovering = value),
- boxShadow: const [],
child: Row(
mainAxisAlignment: MainAxisAlignment.start,
crossAxisAlignment: CrossAxisAlignment.center,
children: [
zupCachedImage.build(
+ context,
widget.group.logoUrl,
height: 35,
width: 35,
@@ -70,8 +72,8 @@ class _TokenGroupCardState extends State {
data: ScrollbarThemeData(
thumbVisibility: WidgetStateProperty.all(true),
thickness: WidgetStateProperty.all(4.0),
- thumbColor: WidgetStateProperty.all(ZupColors.gray5),
- trackColor: WidgetStateProperty.all(ZupColors.gray5),
+ thumbColor: WidgetStateProperty.all(context.brightness.isDark ? ZupColors.black5 : ZupColors.gray5),
+ trackColor: WidgetStateProperty.all(context.brightness.isDark ? ZupColors.black5 : ZupColors.gray5),
mainAxisMargin: 10,
),
child: GridView.builder(
@@ -85,7 +87,10 @@ class _TokenGroupCardState extends State {
child: Container(
padding: const EdgeInsets.all(5),
decoration: BoxDecoration(
- border: Border.all(color: ZupColors.gray5),
+ border: Border.all(
+ color: ZupThemeColors.borderOnBackgroundSurface.themed(context.brightness),
+ width: 0.5,
+ ),
borderRadius: BorderRadius.circular(12),
),
child: Row(
diff --git a/lib/widgets/token_selector_button/token_selector_button.dart b/lib/widgets/token_selector_button/token_selector_button.dart
index 4322f5b..59f6f39 100644
--- a/lib/widgets/token_selector_button/token_selector_button.dart
+++ b/lib/widgets/token_selector_button/token_selector_button.dart
@@ -8,7 +8,7 @@ import 'package:zup_app/widgets/token_avatar.dart';
import 'package:zup_app/widgets/token_selector_button/token_selector_button_controller.dart';
import 'package:zup_app/widgets/token_selector_modal/token_selector_modal.dart';
import 'package:zup_app/widgets/zup_cached_image.dart';
-import 'package:zup_core/mixins/device_info_mixin.dart';
+import 'package:zup_core/zup_core.dart';
import 'package:zup_ui_kit/zup_ui_kit.dart';
class TokenSelectorButton extends StatefulWidget {
@@ -29,16 +29,40 @@ class _TokenSelectorButtonState extends State with DeviceIn
bool isHovering = false;
- Color get getTextColor {
+ Color get textColor {
if (isHovering || !hasSelection) return ZupColors.brand;
- return ZupColors.black;
+
+ return ZupThemeColors.primaryText.themed(context.brightness);
}
- Color get getChevronColor {
- if (isHovering || selectedToken == null) return ZupColors.brand;
+ Color get chevronColor {
+ if (isHovering || !hasSelection) return ZupColors.brand;
+
return ZupColors.gray;
}
+ Color get backgroundColor {
+ if (hasSelection) {
+ return context.brightness.isDark ? ZupColors.black3 : ZupColors.gray6;
+ }
+
+ return context.brightness.isDark ? ZupColors.brand.withValues(alpha: 0.08) : ZupColors.brand6;
+ }
+
+ Color get hoverColor {
+ if (hasSelection) return context.brightness.isDark ? ZupColors.black3 : ZupColors.gray6;
+
+ return context.brightness.isDark
+ ? ZupColors.brand5.withValues(alpha: 0.05)
+ : ZupColors.gray6.withValues(alpha: 0.2);
+ }
+
+ Color get splashColor {
+ if (hasSelection) return context.brightness.isDark ? ZupColors.black4 : ZupColors.gray5.withValues(alpha: 0.4);
+
+ return ZupColors.brand5.withValues(alpha: context.brightness.isDark ? 0.1 : 0.5);
+ }
+
@override
Widget build(BuildContext context) {
return StreamBuilder(
@@ -50,11 +74,9 @@ class _TokenSelectorButtonState extends State with DeviceIn
onEnter: (event) => setState(() => isHovering = true),
onExit: (event) => setState(() => isHovering = false),
child: MaterialButton(
- color: hasSelection ? ZupColors.gray6.withValues(alpha: 0.6) : ZupColors.brand6,
- hoverColor: hasSelection ? ZupColors.gray6 : ZupColors.gray6.withValues(alpha: 0.2),
- splashColor: hasSelection
- ? ZupColors.gray5.withValues(alpha: 0.4)
- : ZupColors.brand5.withValues(alpha: 0.5),
+ color: backgroundColor,
+ hoverColor: hoverColor,
+ splashColor: splashColor,
focusElevation: 0,
highlightElevation: 0,
elevation: 0,
@@ -83,6 +105,7 @@ class _TokenSelectorButtonState extends State with DeviceIn
if (selectedToken != null) TokenAvatar(asset: selectedToken!, size: 30),
if (selectedGroup != null)
zupCachedImage.build(
+ context,
selectedGroup!.logoUrl,
height: 30,
width: 30,
@@ -108,7 +131,7 @@ class _TokenSelectorButtonState extends State with DeviceIn
}(),
style: TextStyle(
fontSize: 17,
- color: getTextColor,
+ color: textColor,
fontWeight: !hasSelection ? FontWeight.w500 : null,
),
),
@@ -119,7 +142,7 @@ class _TokenSelectorButtonState extends State with DeviceIn
curve: Curves.easeOutBack,
turns: isHovering ? 0.5 : 0,
child: Assets.icons.chevronDown.svg(
- colorFilter: ColorFilter.mode(getChevronColor, BlendMode.srcIn),
+ colorFilter: ColorFilter.mode(chevronColor, BlendMode.srcIn),
height: 8,
),
),
diff --git a/lib/widgets/token_selector_modal/token_selector_modal.dart b/lib/widgets/token_selector_modal/token_selector_modal.dart
index 542d718..2f920da 100644
--- a/lib/widgets/token_selector_modal/token_selector_modal.dart
+++ b/lib/widgets/token_selector_modal/token_selector_modal.dart
@@ -11,6 +11,7 @@ import 'package:zup_app/widgets/token_card.dart';
import 'package:zup_app/widgets/token_group_card.dart';
import 'package:zup_app/widgets/token_selector_modal/token_selector_modal_cubit.dart';
import 'package:zup_app/widgets/zup_skeletonizer.dart';
+import 'package:zup_core/extensions/extensions.dart';
import 'package:zup_core/mixins/device_info_mixin.dart';
import 'package:zup_ui_kit/zup_ui_kit.dart';
@@ -106,56 +107,53 @@ class _TokenSelectorModalState extends State with DeviceInfo
Widget build(BuildContext context) {
return BlocBuilder(
builder: (context, state) {
- return ScrollbarTheme(
- data: const ScrollbarThemeData(mainAxisMargin: 20, crossAxisMargin: 3),
- child: CustomScrollView(
- physics: const ClampingScrollPhysics(),
- slivers: [
- SliverAppBar(
- leading: const SizedBox.shrink(),
- backgroundColor: Colors.white,
- surfaceTintColor: Colors.white,
- titleSpacing: 20,
- toolbarHeight: _appCubit.selectedNetwork.isAllNetworks ? 100 : 60,
- automaticallyImplyLeading: false,
- leadingWidth: 0,
- floating: true,
- snap: true,
- title: Column(
- children: [
- ZupTextField(
- key: const Key("search-token-field"),
- hintText: _appCubit.selectedNetwork.isAllNetworks
- ? S.of(context).tokenSelectorModalSearchTitleAllNetworks
- : S.of(context).tokenSelectorModalSearchTitle,
- onChanged: (query) {
- _debouncer.run(() async {
- if (query.isEmpty) return _cubit.fetchTokenList();
- _cubit.searchToken(query);
- });
- },
+ return CustomScrollView(
+ physics: const ClampingScrollPhysics(),
+ slivers: [
+ SliverAppBar(
+ leading: const SizedBox.shrink(),
+ backgroundColor: ZupThemeColors.background.themed(context.brightness),
+ surfaceTintColor: ZupThemeColors.background.themed(context.brightness),
+ titleSpacing: 20,
+ toolbarHeight: _appCubit.selectedNetwork.isAllNetworks ? 100 : 60,
+ automaticallyImplyLeading: false,
+ leadingWidth: 0,
+ floating: true,
+ snap: true,
+ title: Column(
+ children: [
+ ZupTextField(
+ key: const Key("search-token-field"),
+ hintText: _appCubit.selectedNetwork.isAllNetworks
+ ? S.of(context).tokenSelectorModalSearchTitleAllNetworks
+ : S.of(context).tokenSelectorModalSearchTitle,
+ onChanged: (query) {
+ _debouncer.run(() async {
+ if (query.isEmpty) return _cubit.fetchTokenList();
+ _cubit.searchToken(query);
+ });
+ },
+ ),
+ if (_appCubit.selectedNetwork.isAllNetworks) ...[
+ const SizedBox(height: 8),
+ Text(
+ maxLines: 4,
+ S.of(context).tokenSelectorModalSearchAlertForAllNetworks,
+ style: const TextStyle(color: ZupColors.gray, fontSize: 12),
),
- if (_appCubit.selectedNetwork.isAllNetworks) ...[
- const SizedBox(height: 8),
- Text(
- maxLines: 4,
- S.of(context).tokenSelectorModalSearchAlertForAllNetworks,
- style: const TextStyle(color: ZupColors.gray, fontSize: 12),
- ),
- ],
],
- ),
- ),
- ...state.maybeWhen(
- orElse: () => _buildSuccessOrLoadingSlivers(state),
- error: () => _buildErrorStateSlivers(),
- searchSuccess: (_) => _buildSearchSuccessOrSearchLoadingSlivers(state),
- searchLoading: () => _buildSearchSuccessOrSearchLoadingSlivers(state),
- searchNotFound: (searchedTerm) => _buildSearchNotFoundSlivers(searchedTerm),
- searchError: (searchedTerm) => _buildSearchErrorSlivers(searchedTerm),
+ ],
),
- ],
- ),
+ ),
+ ...state.maybeWhen(
+ orElse: () => _buildSuccessOrLoadingSlivers(state),
+ error: () => _buildErrorStateSlivers(),
+ searchSuccess: (_) => _buildSearchSuccessOrSearchLoadingSlivers(state),
+ searchLoading: () => _buildSearchSuccessOrSearchLoadingSlivers(state),
+ searchNotFound: (searchedTerm) => _buildSearchNotFoundSlivers(searchedTerm),
+ searchError: (searchedTerm) => _buildSearchErrorSlivers(searchedTerm),
+ ),
+ ],
);
},
);
@@ -220,7 +218,10 @@ class _TokenSelectorModalState extends State with DeviceInfo
),
TextSpan(
text: " \"$searchedTerm\"",
- style: const TextStyle(color: ZupColors.black, fontWeight: FontWeight.w600),
+ style: TextStyle(
+ color: ZupThemeColors.primaryText.themed(context.brightness),
+ fontWeight: FontWeight.w600,
+ ),
),
],
),
@@ -234,7 +235,7 @@ class _TokenSelectorModalState extends State with DeviceInfo
ZupSkeletonizer(
enabled: state == const TokenSelectorModalState.searchLoading(),
child: _buildSliverSectionTitle(S.of(context).searchResults, topPadding: 10),
- ).sliver(),
+ ).sliver(context),
SliverPadding(
padding: EdgeInsets.symmetric(horizontal: _horizontalPadding),
sliver: state.maybeWhen(
@@ -257,7 +258,7 @@ class _TokenSelectorModalState extends State with DeviceInfo
),
),
),
- ).sliver(),
+ ).sliver(context),
),
),
];
@@ -310,7 +311,7 @@ class _TokenSelectorModalState extends State with DeviceInfo
),
),
),
- ).sliver(),
+ ).sliver(context),
success: (tokenList) => SliverList.builder(
itemCount: tokenList.popularTokens.length,
itemBuilder: (context, index) {
diff --git a/lib/widgets/yield_card.dart b/lib/widgets/yield_card.dart
index 856a74f..8bf4742 100644
--- a/lib/widgets/yield_card.dart
+++ b/lib/widgets/yield_card.dart
@@ -10,6 +10,7 @@ import 'package:zup_app/core/injections.dart';
import 'package:zup_app/l10n/gen/app_localizations.dart';
import 'package:zup_app/widgets/token_avatar.dart';
import 'package:zup_app/widgets/zup_cached_image.dart';
+import 'package:zup_core/extensions/extensions.dart';
import 'package:zup_ui_kit/zup_ui_kit.dart';
class YieldCard extends StatefulWidget {
@@ -41,7 +42,11 @@ class _YieldCardState extends State {
Widget get yieldText => Text(
widget.currentYield.yieldTimeframed(widget.timeFrame).formatPercent,
- style: const TextStyle(fontSize: 26, fontWeight: FontWeight.w600, color: ZupColors.black),
+ style: TextStyle(
+ fontSize: 26,
+ fontWeight: FontWeight.w600,
+ color: ZupThemeColors.backgroundInverse.themed(context.brightness),
+ ),
);
@override
@@ -50,11 +55,10 @@ class _YieldCardState extends State {
isSelected: widget.isSelected,
selectionAnimationDuration: selectionAnimationDuration,
- boxShadow: const [],
onPressed: () {
return widget.onChangeSelection(widget.isSelected ? null : widget.currentYield);
},
- padding: const EdgeInsets.all(10).copyWith(right: 0, top: 0, bottom: 0),
+ padding: const EdgeInsets.all(10).copyWith(right: 2, top: 2, bottom: 0),
child: Stack(
children: [
if (appCubit.selectedNetwork.isAllNetworks)
@@ -64,27 +68,14 @@ class _YieldCardState extends State {
child: ZupTooltip.text(
message: S.of(context).yieldCardThisPoolIsAtNetwork(network: widget.currentYield.network.label),
trailingIcon: widget.currentYield.network.icon,
- child: AnimatedContainer(
- duration: selectionAnimationDuration,
+ child: Container(
height: 40,
padding: const EdgeInsets.all(6),
width: 40,
decoration: BoxDecoration(
- boxShadow: [
- BoxShadow(
- blurStyle: BlurStyle.inner,
- color: widget.isSelected ? ZupColors.brand5 : ZupColors.gray5,
- blurRadius: 2,
- spreadRadius: -2,
- offset: const Offset(0, 0),
- ),
- BoxShadow(
- color: widget.isSelected ? ZupColors.brand7 : ZupColors.white,
- blurRadius: 5,
- spreadRadius: -1,
- offset: const Offset(2, -2),
- ),
- ],
+ color: widget.isSelected
+ ? ZupColors.brand.withValues(alpha: 0.1)
+ : (context.brightness.isDark ? ZupColors.black2 : ZupColors.gray6),
borderRadius: BorderRadius.circular(8),
),
child: widget.currentYield.network.icon,
@@ -96,7 +87,10 @@ class _YieldCardState extends State {
children: [
Padding(
padding: const EdgeInsets.only(top: 10),
- child: Text(S.of(context).yieldCardYearlyYield, style: const TextStyle(fontSize: 14)),
+ child: Text(
+ S.of(context).yieldCardYearlyYield,
+ style: TextStyle(fontSize: 14, color: ZupThemeColors.primaryText.themed(context.brightness)),
+ ),
),
Row(
mainAxisSize: MainAxisSize.min,
@@ -110,9 +104,9 @@ class _YieldCardState extends State {
begin: Offset(1.1, 1.1),
end: Offset(1, 1),
),
- const ShimmerEffect(
- duration: Duration(seconds: 2),
- color: ZupColors.white,
+ ShimmerEffect(
+ duration: const Duration(seconds: 2),
+ color: ZupThemeColors.shimmer.themed(context.brightness),
curve: Curves.decelerate,
angle: 90,
size: 1,
@@ -133,11 +127,12 @@ class _YieldCardState extends State {
Row(
mainAxisSize: MainAxisSize.min,
children: [
- AnimatedContainer(
+ Container(
padding: const EdgeInsets.all(6),
- duration: selectionAnimationDuration,
decoration: BoxDecoration(
- color: widget.isSelected ? ZupColors.brand5 : ZupColors.gray6,
+ color: widget.isSelected
+ ? (context.brightness.isDark ? ZupColors.brand.withValues(alpha: 0.1) : ZupColors.brand5)
+ : (context.brightness.isDark ? ZupColors.black2 : ZupColors.gray6),
borderRadius: BorderRadius.circular(8),
),
child: Row(
@@ -151,7 +146,11 @@ class _YieldCardState extends State {
const SizedBox(width: 10),
Text(
"${widget.currentYield.token0.symbol}/${widget.currentYield.token1.symbol}",
- style: const TextStyle(fontSize: 14, fontWeight: FontWeight.w600),
+ style: TextStyle(
+ fontSize: 14,
+ fontWeight: FontWeight.w600,
+ color: ZupThemeColors.primaryText.themed(context.brightness),
+ ),
),
],
),
@@ -161,6 +160,7 @@ class _YieldCardState extends State {
const SizedBox(width: 10),
if (widget.currentYield.protocol.logo.isNotEmpty)
zupCachedImage.build(
+ context,
widget.currentYield.protocol.logo,
height: 25,
width: 25,
@@ -185,7 +185,11 @@ class _YieldCardState extends State {
widget.currentYield.protocol.name,
overflow: TextOverflow.ellipsis,
maxLines: 1,
- style: const TextStyle(fontSize: 14, fontWeight: FontWeight.w600),
+ style: TextStyle(
+ fontSize: 14,
+ fontWeight: FontWeight.w600,
+ color: ZupThemeColors.backgroundInverse.themed(context.brightness),
+ ),
),
),
),
diff --git a/lib/widgets/zup_cached_image.dart b/lib/widgets/zup_cached_image.dart
index b5ebc4a..cb02398 100644
--- a/lib/widgets/zup_cached_image.dart
+++ b/lib/widgets/zup_cached_image.dart
@@ -1,4 +1,5 @@
import 'package:flutter/material.dart';
+import 'package:zup_core/extensions/extensions.dart';
import 'package:zup_ui_kit/zup_ui_kit.dart';
class ZupCachedImage {
@@ -11,34 +12,38 @@ class ZupCachedImage {
}
Widget build(
+ BuildContext context,
String url, {
double? height,
double? width,
double? radius,
Widget? placeholder,
+ Color? backgroundColor,
ImageErrorWidgetBuilder? errorWidget,
}) {
return Container(
key: ValueKey(url),
decoration: BoxDecoration(
borderRadius: BorderRadius.circular(radius ?? 0),
- border: Border.all(width: 0.5, color: ZupColors.gray5),
+ border: Border.all(width: 0.5, color: ZupThemeColors.borderOnBackground.themed(context.brightness)),
),
// cache not implemented yet because of web issue rendering images from other domains (https://github.com/Baseflow/flutter_cached_network_image/issues/972)
child: ClipRRect(
borderRadius: BorderRadius.circular(radius ?? 0),
- child: Image.network(
- _parseImageUrl(url),
- height: height,
- width: width,
-
- fit: BoxFit.cover,
- errorBuilder: errorWidget,
- frameBuilder: (context, child, frame, wasSynchronouslyLoaded) {
- if (frame == null) return placeholder ?? ZupCircularLoadingIndicator(size: height ?? 20);
- return child;
- },
- webHtmlElementStrategy: WebHtmlElementStrategy.fallback,
+ child: Container(
+ color: backgroundColor,
+ child: Image.network(
+ _parseImageUrl(url),
+ height: height,
+ width: width,
+ fit: BoxFit.cover,
+ errorBuilder: errorWidget,
+ frameBuilder: (context, child, frame, wasSynchronouslyLoaded) {
+ if (frame == null) return placeholder ?? ZupCircularLoadingIndicator(size: height ?? 20);
+ return child;
+ },
+ webHtmlElementStrategy: WebHtmlElementStrategy.fallback,
+ ),
),
),
);
diff --git a/lib/widgets/zup_page_title.dart b/lib/widgets/zup_page_title.dart
index edcf818..55ce105 100644
--- a/lib/widgets/zup_page_title.dart
+++ b/lib/widgets/zup_page_title.dart
@@ -1,16 +1,27 @@
import 'package:flutter/material.dart';
+import 'package:zup_core/extensions/extensions.dart';
import 'package:zup_core/mixins/device_info_mixin.dart';
+import 'package:zup_ui_kit/zup_ui_kit.dart';
-class ZupPageTitle extends StatelessWidget with DeviceInfoMixin {
+class ZupPageTitle extends StatefulWidget {
const ZupPageTitle(this.title, {super.key});
final String title;
+ @override
+ State createState() => _ZupPageTitleState();
+}
+
+class _ZupPageTitleState extends State with DeviceInfoMixin {
@override
Widget build(BuildContext context) {
return Text(
- title,
- style: TextStyle(fontSize: isMobileSize(context) ? 28 : 28, fontWeight: FontWeight.w600),
+ widget.title,
+ style: TextStyle(
+ fontSize: isMobileSize(context) ? 28 : 28,
+ fontWeight: FontWeight.w600,
+ color: ZupThemeColors.primaryText.themed(context.brightness),
+ ),
);
}
}
diff --git a/lib/widgets/zup_skeletonizer.dart b/lib/widgets/zup_skeletonizer.dart
index 13ccd04..e2ac180 100644
--- a/lib/widgets/zup_skeletonizer.dart
+++ b/lib/widgets/zup_skeletonizer.dart
@@ -1,27 +1,36 @@
import 'package:flutter/material.dart';
import 'package:skeletonizer/skeletonizer.dart';
+import 'package:zup_core/extensions/extensions.dart';
import 'package:zup_ui_kit/zup_colors.dart';
-class ZupSkeletonizer extends StatelessWidget {
+class ZupSkeletonizer extends StatefulWidget {
const ZupSkeletonizer({super.key, required this.child, this.enabled = true});
- final effect = const SoldColorEffect(color: ZupColors.gray6);
-
- Widget sliver() => SliverSkeletonizer(
- effect: effect,
- enabled: enabled,
- child: child,
- );
-
final Widget child;
final bool enabled;
+ final darkModeEffect = const SoldColorEffect(color: ZupColors.black4);
+ final lightMode = const SoldColorEffect(color: ZupColors.gray6);
+
+ Widget sliver(BuildContext context) {
+ return SliverSkeletonizer(
+ effect: context.brightness.isDark ? darkModeEffect : lightMode,
+ enabled: enabled,
+ child: child,
+ );
+ }
+
+ @override
+ State createState() => _ZupSkeletonizerState();
+}
+
+class _ZupSkeletonizerState extends State {
@override
Widget build(BuildContext context) {
return Skeletonizer(
- enabled: enabled,
- effect: effect,
- child: child,
+ enabled: widget.enabled,
+ effect: context.brightness.isDark ? widget.darkModeEffect : widget.lightMode,
+ child: widget.child,
);
}
}
diff --git a/lib/zup_app.dart b/lib/zup_app.dart
index bb65188..fdde840 100644
--- a/lib/zup_app.dart
+++ b/lib/zup_app.dart
@@ -1,7 +1,9 @@
import 'package:flutter/material.dart';
+import 'package:flutter_bloc/flutter_bloc.dart';
import 'package:flutter_localizations/flutter_localizations.dart';
import 'package:routefly/routefly.dart';
import 'package:web3kit/web3kit.dart';
+import 'package:zup_app/app/app_cubit/app_cubit.dart';
import 'package:zup_app/core/enums/zup_navigator_paths.dart';
import 'package:zup_app/core/injections.dart';
import 'package:zup_app/l10n/gen/app_localizations.dart';
@@ -16,32 +18,40 @@ class ZupApp extends StatelessWidget {
ZupApp({super.key});
final navigatorKey = inject>();
+ final appCubit = inject();
@override
Widget build(BuildContext context) {
- return MaterialApp.router(
- title: "Zup | Liquidity Pools Aggregator",
- debugShowCheckedModeBanner: false,
- localizationsDelegates: const [
- GlobalMaterialLocalizations.delegate,
- GlobalWidgetsLocalizations.delegate,
- S.delegate,
- Web3KitLocalizations.delegate,
- ],
- routerConfig: Routefly.routerConfig(
- routes: routes,
- initialPath: ZupNavigatorPaths.initial.path,
- navigatorKey: navigatorKey,
- routeBuilder: (_, settings, child) {
- return PageRouteBuilder(
- settings: settings,
- transitionDuration: Duration.zero,
- reverseTransitionDuration: Duration.zero,
- pageBuilder: (_, __, ___) => child,
- );
- },
- ),
- theme: ZupTheme.lightTheme,
+ return BlocBuilder(
+ bloc: appCubit,
+ builder: (context, state) {
+ return MaterialApp.router(
+ title: "Zup | Liquidity Pools Aggregator",
+ debugShowCheckedModeBanner: false,
+ localizationsDelegates: const [
+ GlobalMaterialLocalizations.delegate,
+ GlobalWidgetsLocalizations.delegate,
+ S.delegate,
+ Web3KitLocalizations.delegate,
+ ],
+ routerConfig: Routefly.routerConfig(
+ routes: routes,
+ initialPath: ZupNavigatorPaths.initial.path,
+ navigatorKey: navigatorKey,
+ routeBuilder: (_, settings, child) {
+ return PageRouteBuilder(
+ settings: settings,
+ transitionDuration: Duration.zero,
+ reverseTransitionDuration: Duration.zero,
+ pageBuilder: (_, __, ___) => child,
+ );
+ },
+ ),
+ theme: AppTheme.lightTheme,
+ darkTheme: AppTheme.darkTheme,
+ themeMode: appCubit.currentThemeMode.flutterThemeMode,
+ );
+ },
);
}
}
diff --git a/macos/.gitignore b/macos/.gitignore
deleted file mode 100644
index 746adbb..0000000
--- a/macos/.gitignore
+++ /dev/null
@@ -1,7 +0,0 @@
-# Flutter-related
-**/Flutter/ephemeral/
-**/Pods/
-
-# Xcode-related
-**/dgph
-**/xcuserdata/
diff --git a/macos/Flutter/Flutter-Debug.xcconfig b/macos/Flutter/Flutter-Debug.xcconfig
deleted file mode 100644
index 4b81f9b..0000000
--- a/macos/Flutter/Flutter-Debug.xcconfig
+++ /dev/null
@@ -1,2 +0,0 @@
-#include? "Pods/Target Support Files/Pods-Runner/Pods-Runner.debug.xcconfig"
-#include "ephemeral/Flutter-Generated.xcconfig"
diff --git a/macos/Flutter/Flutter-Release.xcconfig b/macos/Flutter/Flutter-Release.xcconfig
deleted file mode 100644
index 5caa9d1..0000000
--- a/macos/Flutter/Flutter-Release.xcconfig
+++ /dev/null
@@ -1,2 +0,0 @@
-#include? "Pods/Target Support Files/Pods-Runner/Pods-Runner.release.xcconfig"
-#include "ephemeral/Flutter-Generated.xcconfig"
diff --git a/macos/Flutter/GeneratedPluginRegistrant.swift b/macos/Flutter/GeneratedPluginRegistrant.swift
deleted file mode 100644
index 95fd923..0000000
--- a/macos/Flutter/GeneratedPluginRegistrant.swift
+++ /dev/null
@@ -1,22 +0,0 @@
-//
-// Generated file. Do not edit.
-//
-
-import FlutterMacOS
-import Foundation
-
-import firebase_analytics
-import firebase_core
-import path_provider_foundation
-import shared_preferences_foundation
-import sqflite_darwin
-import url_launcher_macos
-
-func RegisterGeneratedPlugins(registry: FlutterPluginRegistry) {
- FLTFirebaseAnalyticsPlugin.register(with: registry.registrar(forPlugin: "FLTFirebaseAnalyticsPlugin"))
- FLTFirebaseCorePlugin.register(with: registry.registrar(forPlugin: "FLTFirebaseCorePlugin"))
- PathProviderPlugin.register(with: registry.registrar(forPlugin: "PathProviderPlugin"))
- SharedPreferencesPlugin.register(with: registry.registrar(forPlugin: "SharedPreferencesPlugin"))
- SqflitePlugin.register(with: registry.registrar(forPlugin: "SqflitePlugin"))
- UrlLauncherPlugin.register(with: registry.registrar(forPlugin: "UrlLauncherPlugin"))
-}
diff --git a/macos/Podfile b/macos/Podfile
deleted file mode 100644
index b52666a..0000000
--- a/macos/Podfile
+++ /dev/null
@@ -1,43 +0,0 @@
-platform :osx, '10.15'
-
-# CocoaPods analytics sends network stats synchronously affecting flutter build latency.
-ENV['COCOAPODS_DISABLE_STATS'] = 'true'
-
-project 'Runner', {
- 'Debug' => :debug,
- 'Profile' => :release,
- 'Release' => :release,
-}
-
-def flutter_root
- generated_xcode_build_settings_path = File.expand_path(File.join('..', 'Flutter', 'ephemeral', 'Flutter-Generated.xcconfig'), __FILE__)
- unless File.exist?(generated_xcode_build_settings_path)
- raise "#{generated_xcode_build_settings_path} must exist. If you're running pod install manually, make sure \"flutter pub get\" is executed first"
- end
-
- File.foreach(generated_xcode_build_settings_path) do |line|
- matches = line.match(/FLUTTER_ROOT\=(.*)/)
- return matches[1].strip if matches
- end
- raise "FLUTTER_ROOT not found in #{generated_xcode_build_settings_path}. Try deleting Flutter-Generated.xcconfig, then run \"flutter pub get\""
-end
-
-require File.expand_path(File.join('packages', 'flutter_tools', 'bin', 'podhelper'), flutter_root)
-
-flutter_macos_podfile_setup
-
-target 'Runner' do
- use_frameworks!
- use_modular_headers!
-
- flutter_install_all_macos_pods File.dirname(File.realpath(__FILE__))
- target 'RunnerTests' do
- inherit! :search_paths
- end
-end
-
-post_install do |installer|
- installer.pods_project.targets.each do |target|
- flutter_additional_macos_build_settings(target)
- end
-end
diff --git a/macos/Podfile.lock b/macos/Podfile.lock
deleted file mode 100644
index 52a7343..0000000
--- a/macos/Podfile.lock
+++ /dev/null
@@ -1,168 +0,0 @@
-PODS:
- - Firebase/Analytics (11.10.0):
- - Firebase/Core
- - Firebase/Core (11.10.0):
- - Firebase/CoreOnly
- - FirebaseAnalytics (~> 11.10.0)
- - Firebase/CoreOnly (11.10.0):
- - FirebaseCore (~> 11.10.0)
- - firebase_analytics (11.4.6):
- - Firebase/Analytics (= 11.10.0)
- - firebase_core
- - FlutterMacOS
- - firebase_core (3.13.1):
- - Firebase/CoreOnly (~> 11.10.0)
- - FlutterMacOS
- - FirebaseAnalytics (11.10.0):
- - FirebaseAnalytics/AdIdSupport (= 11.10.0)
- - FirebaseCore (~> 11.10.0)
- - FirebaseInstallations (~> 11.0)
- - GoogleUtilities/AppDelegateSwizzler (~> 8.0)
- - GoogleUtilities/MethodSwizzler (~> 8.0)
- - GoogleUtilities/Network (~> 8.0)
- - "GoogleUtilities/NSData+zlib (~> 8.0)"
- - nanopb (~> 3.30910.0)
- - FirebaseAnalytics/AdIdSupport (11.10.0):
- - FirebaseCore (~> 11.10.0)
- - FirebaseInstallations (~> 11.0)
- - GoogleAppMeasurement (= 11.10.0)
- - GoogleUtilities/AppDelegateSwizzler (~> 8.0)
- - GoogleUtilities/MethodSwizzler (~> 8.0)
- - GoogleUtilities/Network (~> 8.0)
- - "GoogleUtilities/NSData+zlib (~> 8.0)"
- - nanopb (~> 3.30910.0)
- - FirebaseCore (11.10.0):
- - FirebaseCoreInternal (~> 11.10.0)
- - GoogleUtilities/Environment (~> 8.0)
- - GoogleUtilities/Logger (~> 8.0)
- - FirebaseCoreInternal (11.10.0):
- - "GoogleUtilities/NSData+zlib (~> 8.0)"
- - FirebaseInstallations (11.10.0):
- - FirebaseCore (~> 11.10.0)
- - GoogleUtilities/Environment (~> 8.0)
- - GoogleUtilities/UserDefaults (~> 8.0)
- - PromisesObjC (~> 2.4)
- - FlutterMacOS (1.0.0)
- - GoogleAppMeasurement (11.10.0):
- - GoogleAppMeasurement/AdIdSupport (= 11.10.0)
- - GoogleUtilities/AppDelegateSwizzler (~> 8.0)
- - GoogleUtilities/MethodSwizzler (~> 8.0)
- - GoogleUtilities/Network (~> 8.0)
- - "GoogleUtilities/NSData+zlib (~> 8.0)"
- - nanopb (~> 3.30910.0)
- - GoogleAppMeasurement/AdIdSupport (11.10.0):
- - GoogleAppMeasurement/WithoutAdIdSupport (= 11.10.0)
- - GoogleUtilities/AppDelegateSwizzler (~> 8.0)
- - GoogleUtilities/MethodSwizzler (~> 8.0)
- - GoogleUtilities/Network (~> 8.0)
- - "GoogleUtilities/NSData+zlib (~> 8.0)"
- - nanopb (~> 3.30910.0)
- - GoogleAppMeasurement/WithoutAdIdSupport (11.10.0):
- - GoogleUtilities/AppDelegateSwizzler (~> 8.0)
- - GoogleUtilities/MethodSwizzler (~> 8.0)
- - GoogleUtilities/Network (~> 8.0)
- - "GoogleUtilities/NSData+zlib (~> 8.0)"
- - nanopb (~> 3.30910.0)
- - GoogleUtilities/AppDelegateSwizzler (8.0.2):
- - GoogleUtilities/Environment
- - GoogleUtilities/Logger
- - GoogleUtilities/Network
- - GoogleUtilities/Privacy
- - GoogleUtilities/Environment (8.0.2):
- - GoogleUtilities/Privacy
- - GoogleUtilities/Logger (8.0.2):
- - GoogleUtilities/Environment
- - GoogleUtilities/Privacy
- - GoogleUtilities/MethodSwizzler (8.0.2):
- - GoogleUtilities/Logger
- - GoogleUtilities/Privacy
- - GoogleUtilities/Network (8.0.2):
- - GoogleUtilities/Logger
- - "GoogleUtilities/NSData+zlib"
- - GoogleUtilities/Privacy
- - GoogleUtilities/Reachability
- - "GoogleUtilities/NSData+zlib (8.0.2)":
- - GoogleUtilities/Privacy
- - GoogleUtilities/Privacy (8.0.2)
- - GoogleUtilities/Reachability (8.0.2):
- - GoogleUtilities/Logger
- - GoogleUtilities/Privacy
- - GoogleUtilities/UserDefaults (8.0.2):
- - GoogleUtilities/Logger
- - GoogleUtilities/Privacy
- - nanopb (3.30910.0):
- - nanopb/decode (= 3.30910.0)
- - nanopb/encode (= 3.30910.0)
- - nanopb/decode (3.30910.0)
- - nanopb/encode (3.30910.0)
- - path_provider_foundation (0.0.1):
- - Flutter
- - FlutterMacOS
- - PromisesObjC (2.4.0)
- - shared_preferences_foundation (0.0.1):
- - Flutter
- - FlutterMacOS
- - sqflite_darwin (0.0.4):
- - Flutter
- - FlutterMacOS
- - url_launcher_macos (0.0.1):
- - FlutterMacOS
-
-DEPENDENCIES:
- - firebase_analytics (from `Flutter/ephemeral/.symlinks/plugins/firebase_analytics/macos`)
- - firebase_core (from `Flutter/ephemeral/.symlinks/plugins/firebase_core/macos`)
- - FlutterMacOS (from `Flutter/ephemeral`)
- - path_provider_foundation (from `Flutter/ephemeral/.symlinks/plugins/path_provider_foundation/darwin`)
- - shared_preferences_foundation (from `Flutter/ephemeral/.symlinks/plugins/shared_preferences_foundation/darwin`)
- - sqflite_darwin (from `Flutter/ephemeral/.symlinks/plugins/sqflite_darwin/darwin`)
- - url_launcher_macos (from `Flutter/ephemeral/.symlinks/plugins/url_launcher_macos/macos`)
-
-SPEC REPOS:
- trunk:
- - Firebase
- - FirebaseAnalytics
- - FirebaseCore
- - FirebaseCoreInternal
- - FirebaseInstallations
- - GoogleAppMeasurement
- - GoogleUtilities
- - nanopb
- - PromisesObjC
-
-EXTERNAL SOURCES:
- firebase_analytics:
- :path: Flutter/ephemeral/.symlinks/plugins/firebase_analytics/macos
- firebase_core:
- :path: Flutter/ephemeral/.symlinks/plugins/firebase_core/macos
- FlutterMacOS:
- :path: Flutter/ephemeral
- path_provider_foundation:
- :path: Flutter/ephemeral/.symlinks/plugins/path_provider_foundation/darwin
- shared_preferences_foundation:
- :path: Flutter/ephemeral/.symlinks/plugins/shared_preferences_foundation/darwin
- sqflite_darwin:
- :path: Flutter/ephemeral/.symlinks/plugins/sqflite_darwin/darwin
- url_launcher_macos:
- :path: Flutter/ephemeral/.symlinks/plugins/url_launcher_macos/macos
-
-SPEC CHECKSUMS:
- Firebase: 1fe1c0a7d9aaea32efe01fbea5f0ebd8d70e53a2
- firebase_analytics: 42038ac430b2701716daba1fe06325c2e922aaa0
- firebase_core: 2a91d5383968c70446b882d94e2fa54d11a28661
- FirebaseAnalytics: 4e42333f02cf78ed93703a5c36f36dd518aebdef
- FirebaseCore: 8344daef5e2661eb004b177488d6f9f0f24251b7
- FirebaseCoreInternal: ef4505d2afb1d0ebbc33162cb3795382904b5679
- FirebaseInstallations: 9980995bdd06ec8081dfb6ab364162bdd64245c3
- FlutterMacOS: 8f6f14fa908a6fb3fba0cd85dbd81ec4b251fb24
- GoogleAppMeasurement: 36684bfb3ee034e2b42b4321eb19da3a1b81e65d
- GoogleUtilities: 26a3abef001b6533cf678d3eb38fd3f614b7872d
- nanopb: fad817b59e0457d11a5dfbde799381cd727c1275
- path_provider_foundation: 2b6b4c569c0fb62ec74538f866245ac84301af46
- PromisesObjC: f5707f49cb48b9636751c5b2e7d227e43fba9f47
- shared_preferences_foundation: fcdcbc04712aee1108ac7fda236f363274528f78
- sqflite_darwin: 5a7236e3b501866c1c9befc6771dfd73ffb8702d
- url_launcher_macos: c82c93949963e55b228a30115bd219499a6fe404
-
-PODFILE CHECKSUM: 9ebaf0ce3d369aaa26a9ea0e159195ed94724cf3
-
-COCOAPODS: 1.15.2
diff --git a/macos/Runner.xcodeproj/project.pbxproj b/macos/Runner.xcodeproj/project.pbxproj
deleted file mode 100644
index 218a865..0000000
--- a/macos/Runner.xcodeproj/project.pbxproj
+++ /dev/null
@@ -1,801 +0,0 @@
-// !$*UTF8*$!
-{
- archiveVersion = 1;
- classes = {
- };
- objectVersion = 54;
- objects = {
-
-/* Begin PBXAggregateTarget section */
- 33CC111A2044C6BA0003C045 /* Flutter Assemble */ = {
- isa = PBXAggregateTarget;
- buildConfigurationList = 33CC111B2044C6BA0003C045 /* Build configuration list for PBXAggregateTarget "Flutter Assemble" */;
- buildPhases = (
- 33CC111E2044C6BF0003C045 /* ShellScript */,
- );
- dependencies = (
- );
- name = "Flutter Assemble";
- productName = FLX;
- };
-/* End PBXAggregateTarget section */
-
-/* Begin PBXBuildFile section */
- 15CB9D8326975C77408397B2 /* Pods_Runner.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = A530B86EFFB833D0BAE9AA34 /* Pods_Runner.framework */; };
- 331C80D8294CF71000263BE5 /* RunnerTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = 331C80D7294CF71000263BE5 /* RunnerTests.swift */; };
- 335BBD1B22A9A15E00E9071D /* GeneratedPluginRegistrant.swift in Sources */ = {isa = PBXBuildFile; fileRef = 335BBD1A22A9A15E00E9071D /* GeneratedPluginRegistrant.swift */; };
- 33CC10F12044A3C60003C045 /* AppDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = 33CC10F02044A3C60003C045 /* AppDelegate.swift */; };
- 33CC10F32044A3C60003C045 /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 33CC10F22044A3C60003C045 /* Assets.xcassets */; };
- 33CC10F62044A3C60003C045 /* MainMenu.xib in Resources */ = {isa = PBXBuildFile; fileRef = 33CC10F42044A3C60003C045 /* MainMenu.xib */; };
- 33CC11132044BFA00003C045 /* MainFlutterWindow.swift in Sources */ = {isa = PBXBuildFile; fileRef = 33CC11122044BFA00003C045 /* MainFlutterWindow.swift */; };
- F0AF148DAEEE9D9946DD1916 /* Pods_RunnerTests.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = CA238D3145A5B27A417CE15C /* Pods_RunnerTests.framework */; };
-/* End PBXBuildFile section */
-
-/* Begin PBXContainerItemProxy section */
- 331C80D9294CF71000263BE5 /* PBXContainerItemProxy */ = {
- isa = PBXContainerItemProxy;
- containerPortal = 33CC10E52044A3C60003C045 /* Project object */;
- proxyType = 1;
- remoteGlobalIDString = 33CC10EC2044A3C60003C045;
- remoteInfo = Runner;
- };
- 33CC111F2044C79F0003C045 /* PBXContainerItemProxy */ = {
- isa = PBXContainerItemProxy;
- containerPortal = 33CC10E52044A3C60003C045 /* Project object */;
- proxyType = 1;
- remoteGlobalIDString = 33CC111A2044C6BA0003C045;
- remoteInfo = FLX;
- };
-/* End PBXContainerItemProxy section */
-
-/* Begin PBXCopyFilesBuildPhase section */
- 33CC110E2044A8840003C045 /* Bundle Framework */ = {
- isa = PBXCopyFilesBuildPhase;
- buildActionMask = 2147483647;
- dstPath = "";
- dstSubfolderSpec = 10;
- files = (
- );
- name = "Bundle Framework";
- runOnlyForDeploymentPostprocessing = 0;
- };
-/* End PBXCopyFilesBuildPhase section */
-
-/* Begin PBXFileReference section */
- 331C80D5294CF71000263BE5 /* RunnerTests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = RunnerTests.xctest; sourceTree = BUILT_PRODUCTS_DIR; };
- 331C80D7294CF71000263BE5 /* RunnerTests.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = RunnerTests.swift; sourceTree = ""; };
- 332F444CF4985A25300EDECE /* Pods-Runner.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Runner.debug.xcconfig"; path = "Target Support Files/Pods-Runner/Pods-Runner.debug.xcconfig"; sourceTree = ""; };
- 333000ED22D3DE5D00554162 /* Warnings.xcconfig */ = {isa = PBXFileReference; lastKnownFileType = text.xcconfig; path = Warnings.xcconfig; sourceTree = ""; };
- 335BBD1A22A9A15E00E9071D /* GeneratedPluginRegistrant.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = GeneratedPluginRegistrant.swift; sourceTree = ""; };
- 33CC10ED2044A3C60003C045 /* zup_app.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = zup_app.app; sourceTree = BUILT_PRODUCTS_DIR; };
- 33CC10F02044A3C60003C045 /* AppDelegate.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AppDelegate.swift; sourceTree = ""; };
- 33CC10F22044A3C60003C045 /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; name = Assets.xcassets; path = Runner/Assets.xcassets; sourceTree = ""; };
- 33CC10F52044A3C60003C045 /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.xib; name = Base; path = Base.lproj/MainMenu.xib; sourceTree = ""; };
- 33CC10F72044A3C60003C045 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; name = Info.plist; path = Runner/Info.plist; sourceTree = ""; };
- 33CC11122044BFA00003C045 /* MainFlutterWindow.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MainFlutterWindow.swift; sourceTree = ""; };
- 33CEB47222A05771004F2AC0 /* Flutter-Debug.xcconfig */ = {isa = PBXFileReference; lastKnownFileType = text.xcconfig; path = "Flutter-Debug.xcconfig"; sourceTree = ""; };
- 33CEB47422A05771004F2AC0 /* Flutter-Release.xcconfig */ = {isa = PBXFileReference; lastKnownFileType = text.xcconfig; path = "Flutter-Release.xcconfig"; sourceTree = ""; };
- 33CEB47722A0578A004F2AC0 /* Flutter-Generated.xcconfig */ = {isa = PBXFileReference; lastKnownFileType = text.xcconfig; name = "Flutter-Generated.xcconfig"; path = "ephemeral/Flutter-Generated.xcconfig"; sourceTree = ""; };
- 33E51913231747F40026EE4D /* DebugProfile.entitlements */ = {isa = PBXFileReference; lastKnownFileType = text.plist.entitlements; path = DebugProfile.entitlements; sourceTree = ""; };
- 33E51914231749380026EE4D /* Release.entitlements */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.entitlements; path = Release.entitlements; sourceTree = ""; };
- 33E5194F232828860026EE4D /* AppInfo.xcconfig */ = {isa = PBXFileReference; lastKnownFileType = text.xcconfig; path = AppInfo.xcconfig; sourceTree = ""; };
- 4592737312A5F65AD4049DFF /* Pods-RunnerTests.profile.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-RunnerTests.profile.xcconfig"; path = "Target Support Files/Pods-RunnerTests/Pods-RunnerTests.profile.xcconfig"; sourceTree = ""; };
- 5B6FD3A7524BBAE934CA6814 /* Pods-Runner.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Runner.release.xcconfig"; path = "Target Support Files/Pods-Runner/Pods-Runner.release.xcconfig"; sourceTree = ""; };
- 69A2F9FE8B7479B1E318E929 /* Pods-RunnerTests.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-RunnerTests.debug.xcconfig"; path = "Target Support Files/Pods-RunnerTests/Pods-RunnerTests.debug.xcconfig"; sourceTree = ""; };
- 7AFA3C8E1D35360C0083082E /* Release.xcconfig */ = {isa = PBXFileReference; lastKnownFileType = text.xcconfig; path = Release.xcconfig; sourceTree = ""; };
- 9740EEB21CF90195004384FC /* Debug.xcconfig */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.xcconfig; path = Debug.xcconfig; sourceTree = ""; };
- A530B86EFFB833D0BAE9AA34 /* Pods_Runner.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_Runner.framework; sourceTree = BUILT_PRODUCTS_DIR; };
- CA238D3145A5B27A417CE15C /* Pods_RunnerTests.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_RunnerTests.framework; sourceTree = BUILT_PRODUCTS_DIR; };
- D2CF58941E5865C61A7B5555 /* Pods-RunnerTests.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-RunnerTests.release.xcconfig"; path = "Target Support Files/Pods-RunnerTests/Pods-RunnerTests.release.xcconfig"; sourceTree = ""; };
- EE4922412C30BC2B37464DA7 /* Pods-Runner.profile.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Runner.profile.xcconfig"; path = "Target Support Files/Pods-Runner/Pods-Runner.profile.xcconfig"; sourceTree = ""; };
-/* End PBXFileReference section */
-
-/* Begin PBXFrameworksBuildPhase section */
- 331C80D2294CF70F00263BE5 /* Frameworks */ = {
- isa = PBXFrameworksBuildPhase;
- buildActionMask = 2147483647;
- files = (
- F0AF148DAEEE9D9946DD1916 /* Pods_RunnerTests.framework in Frameworks */,
- );
- runOnlyForDeploymentPostprocessing = 0;
- };
- 33CC10EA2044A3C60003C045 /* Frameworks */ = {
- isa = PBXFrameworksBuildPhase;
- buildActionMask = 2147483647;
- files = (
- 15CB9D8326975C77408397B2 /* Pods_Runner.framework in Frameworks */,
- );
- runOnlyForDeploymentPostprocessing = 0;
- };
-/* End PBXFrameworksBuildPhase section */
-
-/* Begin PBXGroup section */
- 331C80D6294CF71000263BE5 /* RunnerTests */ = {
- isa = PBXGroup;
- children = (
- 331C80D7294CF71000263BE5 /* RunnerTests.swift */,
- );
- path = RunnerTests;
- sourceTree = "";
- };
- 33BA886A226E78AF003329D5 /* Configs */ = {
- isa = PBXGroup;
- children = (
- 33E5194F232828860026EE4D /* AppInfo.xcconfig */,
- 9740EEB21CF90195004384FC /* Debug.xcconfig */,
- 7AFA3C8E1D35360C0083082E /* Release.xcconfig */,
- 333000ED22D3DE5D00554162 /* Warnings.xcconfig */,
- );
- path = Configs;
- sourceTree = "";
- };
- 33CC10E42044A3C60003C045 = {
- isa = PBXGroup;
- children = (
- 33FAB671232836740065AC1E /* Runner */,
- 33CEB47122A05771004F2AC0 /* Flutter */,
- 331C80D6294CF71000263BE5 /* RunnerTests */,
- 33CC10EE2044A3C60003C045 /* Products */,
- D73912EC22F37F3D000D13A0 /* Frameworks */,
- 9CFEA47A3D5A436D85897BFA /* Pods */,
- );
- sourceTree = "";
- };
- 33CC10EE2044A3C60003C045 /* Products */ = {
- isa = PBXGroup;
- children = (
- 33CC10ED2044A3C60003C045 /* zup_app.app */,
- 331C80D5294CF71000263BE5 /* RunnerTests.xctest */,
- );
- name = Products;
- sourceTree = "";
- };
- 33CC11242044D66E0003C045 /* Resources */ = {
- isa = PBXGroup;
- children = (
- 33CC10F22044A3C60003C045 /* Assets.xcassets */,
- 33CC10F42044A3C60003C045 /* MainMenu.xib */,
- 33CC10F72044A3C60003C045 /* Info.plist */,
- );
- name = Resources;
- path = ..;
- sourceTree = "";
- };
- 33CEB47122A05771004F2AC0 /* Flutter */ = {
- isa = PBXGroup;
- children = (
- 335BBD1A22A9A15E00E9071D /* GeneratedPluginRegistrant.swift */,
- 33CEB47222A05771004F2AC0 /* Flutter-Debug.xcconfig */,
- 33CEB47422A05771004F2AC0 /* Flutter-Release.xcconfig */,
- 33CEB47722A0578A004F2AC0 /* Flutter-Generated.xcconfig */,
- );
- path = Flutter;
- sourceTree = "";
- };
- 33FAB671232836740065AC1E /* Runner */ = {
- isa = PBXGroup;
- children = (
- 33CC10F02044A3C60003C045 /* AppDelegate.swift */,
- 33CC11122044BFA00003C045 /* MainFlutterWindow.swift */,
- 33E51913231747F40026EE4D /* DebugProfile.entitlements */,
- 33E51914231749380026EE4D /* Release.entitlements */,
- 33CC11242044D66E0003C045 /* Resources */,
- 33BA886A226E78AF003329D5 /* Configs */,
- );
- path = Runner;
- sourceTree = "";
- };
- 9CFEA47A3D5A436D85897BFA /* Pods */ = {
- isa = PBXGroup;
- children = (
- 332F444CF4985A25300EDECE /* Pods-Runner.debug.xcconfig */,
- 5B6FD3A7524BBAE934CA6814 /* Pods-Runner.release.xcconfig */,
- EE4922412C30BC2B37464DA7 /* Pods-Runner.profile.xcconfig */,
- 69A2F9FE8B7479B1E318E929 /* Pods-RunnerTests.debug.xcconfig */,
- D2CF58941E5865C61A7B5555 /* Pods-RunnerTests.release.xcconfig */,
- 4592737312A5F65AD4049DFF /* Pods-RunnerTests.profile.xcconfig */,
- );
- name = Pods;
- path = Pods;
- sourceTree = "";
- };
- D73912EC22F37F3D000D13A0 /* Frameworks */ = {
- isa = PBXGroup;
- children = (
- A530B86EFFB833D0BAE9AA34 /* Pods_Runner.framework */,
- CA238D3145A5B27A417CE15C /* Pods_RunnerTests.framework */,
- );
- name = Frameworks;
- sourceTree = "";
- };
-/* End PBXGroup section */
-
-/* Begin PBXNativeTarget section */
- 331C80D4294CF70F00263BE5 /* RunnerTests */ = {
- isa = PBXNativeTarget;
- buildConfigurationList = 331C80DE294CF71000263BE5 /* Build configuration list for PBXNativeTarget "RunnerTests" */;
- buildPhases = (
- EA662CA530A613C695D59F67 /* [CP] Check Pods Manifest.lock */,
- 331C80D1294CF70F00263BE5 /* Sources */,
- 331C80D2294CF70F00263BE5 /* Frameworks */,
- 331C80D3294CF70F00263BE5 /* Resources */,
- );
- buildRules = (
- );
- dependencies = (
- 331C80DA294CF71000263BE5 /* PBXTargetDependency */,
- );
- name = RunnerTests;
- productName = RunnerTests;
- productReference = 331C80D5294CF71000263BE5 /* RunnerTests.xctest */;
- productType = "com.apple.product-type.bundle.unit-test";
- };
- 33CC10EC2044A3C60003C045 /* Runner */ = {
- isa = PBXNativeTarget;
- buildConfigurationList = 33CC10FB2044A3C60003C045 /* Build configuration list for PBXNativeTarget "Runner" */;
- buildPhases = (
- 7CB112F0043EB6BA7D173E81 /* [CP] Check Pods Manifest.lock */,
- 33CC10E92044A3C60003C045 /* Sources */,
- 33CC10EA2044A3C60003C045 /* Frameworks */,
- 33CC10EB2044A3C60003C045 /* Resources */,
- 33CC110E2044A8840003C045 /* Bundle Framework */,
- 3399D490228B24CF009A79C7 /* ShellScript */,
- 7181433E971A2A21E7636301 /* [CP] Embed Pods Frameworks */,
- );
- buildRules = (
- );
- dependencies = (
- 33CC11202044C79F0003C045 /* PBXTargetDependency */,
- );
- name = Runner;
- productName = Runner;
- productReference = 33CC10ED2044A3C60003C045 /* zup_app.app */;
- productType = "com.apple.product-type.application";
- };
-/* End PBXNativeTarget section */
-
-/* Begin PBXProject section */
- 33CC10E52044A3C60003C045 /* Project object */ = {
- isa = PBXProject;
- attributes = {
- BuildIndependentTargetsInParallel = YES;
- LastSwiftUpdateCheck = 0920;
- LastUpgradeCheck = 1510;
- ORGANIZATIONNAME = "";
- TargetAttributes = {
- 331C80D4294CF70F00263BE5 = {
- CreatedOnToolsVersion = 14.0;
- TestTargetID = 33CC10EC2044A3C60003C045;
- };
- 33CC10EC2044A3C60003C045 = {
- CreatedOnToolsVersion = 9.2;
- LastSwiftMigration = 1100;
- ProvisioningStyle = Automatic;
- SystemCapabilities = {
- com.apple.Sandbox = {
- enabled = 1;
- };
- };
- };
- 33CC111A2044C6BA0003C045 = {
- CreatedOnToolsVersion = 9.2;
- ProvisioningStyle = Manual;
- };
- };
- };
- buildConfigurationList = 33CC10E82044A3C60003C045 /* Build configuration list for PBXProject "Runner" */;
- compatibilityVersion = "Xcode 9.3";
- developmentRegion = en;
- hasScannedForEncodings = 0;
- knownRegions = (
- en,
- Base,
- );
- mainGroup = 33CC10E42044A3C60003C045;
- productRefGroup = 33CC10EE2044A3C60003C045 /* Products */;
- projectDirPath = "";
- projectRoot = "";
- targets = (
- 33CC10EC2044A3C60003C045 /* Runner */,
- 331C80D4294CF70F00263BE5 /* RunnerTests */,
- 33CC111A2044C6BA0003C045 /* Flutter Assemble */,
- );
- };
-/* End PBXProject section */
-
-/* Begin PBXResourcesBuildPhase section */
- 331C80D3294CF70F00263BE5 /* Resources */ = {
- isa = PBXResourcesBuildPhase;
- buildActionMask = 2147483647;
- files = (
- );
- runOnlyForDeploymentPostprocessing = 0;
- };
- 33CC10EB2044A3C60003C045 /* Resources */ = {
- isa = PBXResourcesBuildPhase;
- buildActionMask = 2147483647;
- files = (
- 33CC10F32044A3C60003C045 /* Assets.xcassets in Resources */,
- 33CC10F62044A3C60003C045 /* MainMenu.xib in Resources */,
- );
- runOnlyForDeploymentPostprocessing = 0;
- };
-/* End PBXResourcesBuildPhase section */
-
-/* Begin PBXShellScriptBuildPhase section */
- 3399D490228B24CF009A79C7 /* ShellScript */ = {
- isa = PBXShellScriptBuildPhase;
- alwaysOutOfDate = 1;
- buildActionMask = 2147483647;
- files = (
- );
- inputFileListPaths = (
- );
- inputPaths = (
- );
- outputFileListPaths = (
- );
- outputPaths = (
- );
- runOnlyForDeploymentPostprocessing = 0;
- shellPath = /bin/sh;
- shellScript = "echo \"$PRODUCT_NAME.app\" > \"$PROJECT_DIR\"/Flutter/ephemeral/.app_filename && \"$FLUTTER_ROOT\"/packages/flutter_tools/bin/macos_assemble.sh embed\n";
- };
- 33CC111E2044C6BF0003C045 /* ShellScript */ = {
- isa = PBXShellScriptBuildPhase;
- buildActionMask = 2147483647;
- files = (
- );
- inputFileListPaths = (
- Flutter/ephemeral/FlutterInputs.xcfilelist,
- );
- inputPaths = (
- Flutter/ephemeral/tripwire,
- );
- outputFileListPaths = (
- Flutter/ephemeral/FlutterOutputs.xcfilelist,
- );
- outputPaths = (
- );
- runOnlyForDeploymentPostprocessing = 0;
- shellPath = /bin/sh;
- shellScript = "\"$FLUTTER_ROOT\"/packages/flutter_tools/bin/macos_assemble.sh && touch Flutter/ephemeral/tripwire";
- };
- 7181433E971A2A21E7636301 /* [CP] Embed Pods Frameworks */ = {
- isa = PBXShellScriptBuildPhase;
- buildActionMask = 2147483647;
- files = (
- );
- inputFileListPaths = (
- "${PODS_ROOT}/Target Support Files/Pods-Runner/Pods-Runner-frameworks-${CONFIGURATION}-input-files.xcfilelist",
- );
- name = "[CP] Embed Pods Frameworks";
- outputFileListPaths = (
- "${PODS_ROOT}/Target Support Files/Pods-Runner/Pods-Runner-frameworks-${CONFIGURATION}-output-files.xcfilelist",
- );
- runOnlyForDeploymentPostprocessing = 0;
- shellPath = /bin/sh;
- shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-Runner/Pods-Runner-frameworks.sh\"\n";
- showEnvVarsInLog = 0;
- };
- 7CB112F0043EB6BA7D173E81 /* [CP] Check Pods Manifest.lock */ = {
- isa = PBXShellScriptBuildPhase;
- buildActionMask = 2147483647;
- files = (
- );
- inputFileListPaths = (
- );
- inputPaths = (
- "${PODS_PODFILE_DIR_PATH}/Podfile.lock",
- "${PODS_ROOT}/Manifest.lock",
- );
- name = "[CP] Check Pods Manifest.lock";
- outputFileListPaths = (
- );
- outputPaths = (
- "$(DERIVED_FILE_DIR)/Pods-Runner-checkManifestLockResult.txt",
- );
- runOnlyForDeploymentPostprocessing = 0;
- shellPath = /bin/sh;
- shellScript = "diff \"${PODS_PODFILE_DIR_PATH}/Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n# This output is used by Xcode 'outputs' to avoid re-running this script phase.\necho \"SUCCESS\" > \"${SCRIPT_OUTPUT_FILE_0}\"\n";
- showEnvVarsInLog = 0;
- };
- EA662CA530A613C695D59F67 /* [CP] Check Pods Manifest.lock */ = {
- isa = PBXShellScriptBuildPhase;
- buildActionMask = 2147483647;
- files = (
- );
- inputFileListPaths = (
- );
- inputPaths = (
- "${PODS_PODFILE_DIR_PATH}/Podfile.lock",
- "${PODS_ROOT}/Manifest.lock",
- );
- name = "[CP] Check Pods Manifest.lock";
- outputFileListPaths = (
- );
- outputPaths = (
- "$(DERIVED_FILE_DIR)/Pods-RunnerTests-checkManifestLockResult.txt",
- );
- runOnlyForDeploymentPostprocessing = 0;
- shellPath = /bin/sh;
- shellScript = "diff \"${PODS_PODFILE_DIR_PATH}/Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n# This output is used by Xcode 'outputs' to avoid re-running this script phase.\necho \"SUCCESS\" > \"${SCRIPT_OUTPUT_FILE_0}\"\n";
- showEnvVarsInLog = 0;
- };
-/* End PBXShellScriptBuildPhase section */
-
-/* Begin PBXSourcesBuildPhase section */
- 331C80D1294CF70F00263BE5 /* Sources */ = {
- isa = PBXSourcesBuildPhase;
- buildActionMask = 2147483647;
- files = (
- 331C80D8294CF71000263BE5 /* RunnerTests.swift in Sources */,
- );
- runOnlyForDeploymentPostprocessing = 0;
- };
- 33CC10E92044A3C60003C045 /* Sources */ = {
- isa = PBXSourcesBuildPhase;
- buildActionMask = 2147483647;
- files = (
- 33CC11132044BFA00003C045 /* MainFlutterWindow.swift in Sources */,
- 33CC10F12044A3C60003C045 /* AppDelegate.swift in Sources */,
- 335BBD1B22A9A15E00E9071D /* GeneratedPluginRegistrant.swift in Sources */,
- );
- runOnlyForDeploymentPostprocessing = 0;
- };
-/* End PBXSourcesBuildPhase section */
-
-/* Begin PBXTargetDependency section */
- 331C80DA294CF71000263BE5 /* PBXTargetDependency */ = {
- isa = PBXTargetDependency;
- target = 33CC10EC2044A3C60003C045 /* Runner */;
- targetProxy = 331C80D9294CF71000263BE5 /* PBXContainerItemProxy */;
- };
- 33CC11202044C79F0003C045 /* PBXTargetDependency */ = {
- isa = PBXTargetDependency;
- target = 33CC111A2044C6BA0003C045 /* Flutter Assemble */;
- targetProxy = 33CC111F2044C79F0003C045 /* PBXContainerItemProxy */;
- };
-/* End PBXTargetDependency section */
-
-/* Begin PBXVariantGroup section */
- 33CC10F42044A3C60003C045 /* MainMenu.xib */ = {
- isa = PBXVariantGroup;
- children = (
- 33CC10F52044A3C60003C045 /* Base */,
- );
- name = MainMenu.xib;
- path = Runner;
- sourceTree = "";
- };
-/* End PBXVariantGroup section */
-
-/* Begin XCBuildConfiguration section */
- 331C80DB294CF71000263BE5 /* Debug */ = {
- isa = XCBuildConfiguration;
- baseConfigurationReference = 69A2F9FE8B7479B1E318E929 /* Pods-RunnerTests.debug.xcconfig */;
- buildSettings = {
- BUNDLE_LOADER = "$(TEST_HOST)";
- CURRENT_PROJECT_VERSION = 1;
- GENERATE_INFOPLIST_FILE = YES;
- MARKETING_VERSION = 1.0;
- PRODUCT_BUNDLE_IDENTIFIER = com.example.zupApp.RunnerTests;
- PRODUCT_NAME = "$(TARGET_NAME)";
- SWIFT_VERSION = 5.0;
- TEST_HOST = "$(BUILT_PRODUCTS_DIR)/zup_app.app/$(BUNDLE_EXECUTABLE_FOLDER_PATH)/zup_app";
- };
- name = Debug;
- };
- 331C80DC294CF71000263BE5 /* Release */ = {
- isa = XCBuildConfiguration;
- baseConfigurationReference = D2CF58941E5865C61A7B5555 /* Pods-RunnerTests.release.xcconfig */;
- buildSettings = {
- BUNDLE_LOADER = "$(TEST_HOST)";
- CURRENT_PROJECT_VERSION = 1;
- GENERATE_INFOPLIST_FILE = YES;
- MARKETING_VERSION = 1.0;
- PRODUCT_BUNDLE_IDENTIFIER = com.example.zupApp.RunnerTests;
- PRODUCT_NAME = "$(TARGET_NAME)";
- SWIFT_VERSION = 5.0;
- TEST_HOST = "$(BUILT_PRODUCTS_DIR)/zup_app.app/$(BUNDLE_EXECUTABLE_FOLDER_PATH)/zup_app";
- };
- name = Release;
- };
- 331C80DD294CF71000263BE5 /* Profile */ = {
- isa = XCBuildConfiguration;
- baseConfigurationReference = 4592737312A5F65AD4049DFF /* Pods-RunnerTests.profile.xcconfig */;
- buildSettings = {
- BUNDLE_LOADER = "$(TEST_HOST)";
- CURRENT_PROJECT_VERSION = 1;
- GENERATE_INFOPLIST_FILE = YES;
- MARKETING_VERSION = 1.0;
- PRODUCT_BUNDLE_IDENTIFIER = com.example.zupApp.RunnerTests;
- PRODUCT_NAME = "$(TARGET_NAME)";
- SWIFT_VERSION = 5.0;
- TEST_HOST = "$(BUILT_PRODUCTS_DIR)/zup_app.app/$(BUNDLE_EXECUTABLE_FOLDER_PATH)/zup_app";
- };
- name = Profile;
- };
- 338D0CE9231458BD00FA5F75 /* Profile */ = {
- isa = XCBuildConfiguration;
- baseConfigurationReference = 7AFA3C8E1D35360C0083082E /* Release.xcconfig */;
- buildSettings = {
- ALWAYS_SEARCH_USER_PATHS = NO;
- ASSETCATALOG_COMPILER_GENERATE_SWIFT_ASSET_SYMBOL_EXTENSIONS = YES;
- CLANG_ANALYZER_NONNULL = YES;
- CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE;
- CLANG_CXX_LANGUAGE_STANDARD = "gnu++14";
- CLANG_CXX_LIBRARY = "libc++";
- CLANG_ENABLE_MODULES = YES;
- CLANG_ENABLE_OBJC_ARC = YES;
- CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
- CLANG_WARN_BOOL_CONVERSION = YES;
- CLANG_WARN_CONSTANT_CONVERSION = YES;
- CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
- CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
- CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
- CLANG_WARN_EMPTY_BODY = YES;
- CLANG_WARN_ENUM_CONVERSION = YES;
- CLANG_WARN_INFINITE_RECURSION = YES;
- CLANG_WARN_INT_CONVERSION = YES;
- CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
- CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
- CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
- CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
- CLANG_WARN_SUSPICIOUS_MOVE = YES;
- CODE_SIGN_IDENTITY = "-";
- COPY_PHASE_STRIP = NO;
- DEAD_CODE_STRIPPING = YES;
- DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym";
- ENABLE_NS_ASSERTIONS = NO;
- ENABLE_STRICT_OBJC_MSGSEND = YES;
- ENABLE_USER_SCRIPT_SANDBOXING = NO;
- GCC_C_LANGUAGE_STANDARD = gnu11;
- GCC_NO_COMMON_BLOCKS = YES;
- GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
- GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
- GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
- GCC_WARN_UNUSED_FUNCTION = YES;
- GCC_WARN_UNUSED_VARIABLE = YES;
- MACOSX_DEPLOYMENT_TARGET = 10.14;
- MTL_ENABLE_DEBUG_INFO = NO;
- SDKROOT = macosx;
- SWIFT_COMPILATION_MODE = wholemodule;
- SWIFT_OPTIMIZATION_LEVEL = "-O";
- };
- name = Profile;
- };
- 338D0CEA231458BD00FA5F75 /* Profile */ = {
- isa = XCBuildConfiguration;
- baseConfigurationReference = 33E5194F232828860026EE4D /* AppInfo.xcconfig */;
- buildSettings = {
- ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
- CLANG_ENABLE_MODULES = YES;
- CODE_SIGN_ENTITLEMENTS = Runner/DebugProfile.entitlements;
- CODE_SIGN_STYLE = Automatic;
- COMBINE_HIDPI_IMAGES = YES;
- INFOPLIST_FILE = Runner/Info.plist;
- LD_RUNPATH_SEARCH_PATHS = (
- "$(inherited)",
- "@executable_path/../Frameworks",
- );
- PROVISIONING_PROFILE_SPECIFIER = "";
- SWIFT_VERSION = 5.0;
- };
- name = Profile;
- };
- 338D0CEB231458BD00FA5F75 /* Profile */ = {
- isa = XCBuildConfiguration;
- buildSettings = {
- CODE_SIGN_STYLE = Manual;
- PRODUCT_NAME = "$(TARGET_NAME)";
- };
- name = Profile;
- };
- 33CC10F92044A3C60003C045 /* Debug */ = {
- isa = XCBuildConfiguration;
- baseConfigurationReference = 9740EEB21CF90195004384FC /* Debug.xcconfig */;
- buildSettings = {
- ALWAYS_SEARCH_USER_PATHS = NO;
- ASSETCATALOG_COMPILER_GENERATE_SWIFT_ASSET_SYMBOL_EXTENSIONS = YES;
- CLANG_ANALYZER_NONNULL = YES;
- CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE;
- CLANG_CXX_LANGUAGE_STANDARD = "gnu++14";
- CLANG_CXX_LIBRARY = "libc++";
- CLANG_ENABLE_MODULES = YES;
- CLANG_ENABLE_OBJC_ARC = YES;
- CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
- CLANG_WARN_BOOL_CONVERSION = YES;
- CLANG_WARN_CONSTANT_CONVERSION = YES;
- CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
- CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
- CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
- CLANG_WARN_EMPTY_BODY = YES;
- CLANG_WARN_ENUM_CONVERSION = YES;
- CLANG_WARN_INFINITE_RECURSION = YES;
- CLANG_WARN_INT_CONVERSION = YES;
- CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
- CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
- CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
- CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
- CLANG_WARN_SUSPICIOUS_MOVE = YES;
- CODE_SIGN_IDENTITY = "-";
- COPY_PHASE_STRIP = NO;
- DEAD_CODE_STRIPPING = YES;
- DEBUG_INFORMATION_FORMAT = dwarf;
- ENABLE_STRICT_OBJC_MSGSEND = YES;
- ENABLE_TESTABILITY = YES;
- ENABLE_USER_SCRIPT_SANDBOXING = NO;
- GCC_C_LANGUAGE_STANDARD = gnu11;
- GCC_DYNAMIC_NO_PIC = NO;
- GCC_NO_COMMON_BLOCKS = YES;
- GCC_OPTIMIZATION_LEVEL = 0;
- GCC_PREPROCESSOR_DEFINITIONS = (
- "DEBUG=1",
- "$(inherited)",
- );
- GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
- GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
- GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
- GCC_WARN_UNUSED_FUNCTION = YES;
- GCC_WARN_UNUSED_VARIABLE = YES;
- MACOSX_DEPLOYMENT_TARGET = 10.14;
- MTL_ENABLE_DEBUG_INFO = YES;
- ONLY_ACTIVE_ARCH = YES;
- SDKROOT = macosx;
- SWIFT_ACTIVE_COMPILATION_CONDITIONS = DEBUG;
- SWIFT_OPTIMIZATION_LEVEL = "-Onone";
- };
- name = Debug;
- };
- 33CC10FA2044A3C60003C045 /* Release */ = {
- isa = XCBuildConfiguration;
- baseConfigurationReference = 7AFA3C8E1D35360C0083082E /* Release.xcconfig */;
- buildSettings = {
- ALWAYS_SEARCH_USER_PATHS = NO;
- ASSETCATALOG_COMPILER_GENERATE_SWIFT_ASSET_SYMBOL_EXTENSIONS = YES;
- CLANG_ANALYZER_NONNULL = YES;
- CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE;
- CLANG_CXX_LANGUAGE_STANDARD = "gnu++14";
- CLANG_CXX_LIBRARY = "libc++";
- CLANG_ENABLE_MODULES = YES;
- CLANG_ENABLE_OBJC_ARC = YES;
- CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
- CLANG_WARN_BOOL_CONVERSION = YES;
- CLANG_WARN_CONSTANT_CONVERSION = YES;
- CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
- CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
- CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
- CLANG_WARN_EMPTY_BODY = YES;
- CLANG_WARN_ENUM_CONVERSION = YES;
- CLANG_WARN_INFINITE_RECURSION = YES;
- CLANG_WARN_INT_CONVERSION = YES;
- CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
- CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
- CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
- CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
- CLANG_WARN_SUSPICIOUS_MOVE = YES;
- CODE_SIGN_IDENTITY = "-";
- COPY_PHASE_STRIP = NO;
- DEAD_CODE_STRIPPING = YES;
- DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym";
- ENABLE_NS_ASSERTIONS = NO;
- ENABLE_STRICT_OBJC_MSGSEND = YES;
- ENABLE_USER_SCRIPT_SANDBOXING = NO;
- GCC_C_LANGUAGE_STANDARD = gnu11;
- GCC_NO_COMMON_BLOCKS = YES;
- GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
- GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
- GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
- GCC_WARN_UNUSED_FUNCTION = YES;
- GCC_WARN_UNUSED_VARIABLE = YES;
- MACOSX_DEPLOYMENT_TARGET = 10.14;
- MTL_ENABLE_DEBUG_INFO = NO;
- SDKROOT = macosx;
- SWIFT_COMPILATION_MODE = wholemodule;
- SWIFT_OPTIMIZATION_LEVEL = "-O";
- };
- name = Release;
- };
- 33CC10FC2044A3C60003C045 /* Debug */ = {
- isa = XCBuildConfiguration;
- baseConfigurationReference = 33E5194F232828860026EE4D /* AppInfo.xcconfig */;
- buildSettings = {
- ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
- CLANG_ENABLE_MODULES = YES;
- CODE_SIGN_ENTITLEMENTS = Runner/DebugProfile.entitlements;
- CODE_SIGN_STYLE = Automatic;
- COMBINE_HIDPI_IMAGES = YES;
- INFOPLIST_FILE = Runner/Info.plist;
- LD_RUNPATH_SEARCH_PATHS = (
- "$(inherited)",
- "@executable_path/../Frameworks",
- );
- PROVISIONING_PROFILE_SPECIFIER = "";
- SWIFT_OPTIMIZATION_LEVEL = "-Onone";
- SWIFT_VERSION = 5.0;
- };
- name = Debug;
- };
- 33CC10FD2044A3C60003C045 /* Release */ = {
- isa = XCBuildConfiguration;
- baseConfigurationReference = 33E5194F232828860026EE4D /* AppInfo.xcconfig */;
- buildSettings = {
- ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
- CLANG_ENABLE_MODULES = YES;
- CODE_SIGN_ENTITLEMENTS = Runner/Release.entitlements;
- CODE_SIGN_STYLE = Automatic;
- COMBINE_HIDPI_IMAGES = YES;
- INFOPLIST_FILE = Runner/Info.plist;
- LD_RUNPATH_SEARCH_PATHS = (
- "$(inherited)",
- "@executable_path/../Frameworks",
- );
- PROVISIONING_PROFILE_SPECIFIER = "";
- SWIFT_VERSION = 5.0;
- };
- name = Release;
- };
- 33CC111C2044C6BA0003C045 /* Debug */ = {
- isa = XCBuildConfiguration;
- buildSettings = {
- CODE_SIGN_STYLE = Manual;
- PRODUCT_NAME = "$(TARGET_NAME)";
- };
- name = Debug;
- };
- 33CC111D2044C6BA0003C045 /* Release */ = {
- isa = XCBuildConfiguration;
- buildSettings = {
- CODE_SIGN_STYLE = Automatic;
- PRODUCT_NAME = "$(TARGET_NAME)";
- };
- name = Release;
- };
-/* End XCBuildConfiguration section */
-
-/* Begin XCConfigurationList section */
- 331C80DE294CF71000263BE5 /* Build configuration list for PBXNativeTarget "RunnerTests" */ = {
- isa = XCConfigurationList;
- buildConfigurations = (
- 331C80DB294CF71000263BE5 /* Debug */,
- 331C80DC294CF71000263BE5 /* Release */,
- 331C80DD294CF71000263BE5 /* Profile */,
- );
- defaultConfigurationIsVisible = 0;
- defaultConfigurationName = Release;
- };
- 33CC10E82044A3C60003C045 /* Build configuration list for PBXProject "Runner" */ = {
- isa = XCConfigurationList;
- buildConfigurations = (
- 33CC10F92044A3C60003C045 /* Debug */,
- 33CC10FA2044A3C60003C045 /* Release */,
- 338D0CE9231458BD00FA5F75 /* Profile */,
- );
- defaultConfigurationIsVisible = 0;
- defaultConfigurationName = Release;
- };
- 33CC10FB2044A3C60003C045 /* Build configuration list for PBXNativeTarget "Runner" */ = {
- isa = XCConfigurationList;
- buildConfigurations = (
- 33CC10FC2044A3C60003C045 /* Debug */,
- 33CC10FD2044A3C60003C045 /* Release */,
- 338D0CEA231458BD00FA5F75 /* Profile */,
- );
- defaultConfigurationIsVisible = 0;
- defaultConfigurationName = Release;
- };
- 33CC111B2044C6BA0003C045 /* Build configuration list for PBXAggregateTarget "Flutter Assemble" */ = {
- isa = XCConfigurationList;
- buildConfigurations = (
- 33CC111C2044C6BA0003C045 /* Debug */,
- 33CC111D2044C6BA0003C045 /* Release */,
- 338D0CEB231458BD00FA5F75 /* Profile */,
- );
- defaultConfigurationIsVisible = 0;
- defaultConfigurationName = Release;
- };
-/* End XCConfigurationList section */
- };
- rootObject = 33CC10E52044A3C60003C045 /* Project object */;
-}
diff --git a/macos/Runner.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist b/macos/Runner.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist
deleted file mode 100644
index 18d9810..0000000
--- a/macos/Runner.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist
+++ /dev/null
@@ -1,8 +0,0 @@
-
-
-
-
- IDEDidComputeMac32BitWarning
-
-
-
diff --git a/macos/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme b/macos/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme
deleted file mode 100644
index eac947f..0000000
--- a/macos/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme
+++ /dev/null
@@ -1,99 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/macos/Runner.xcworkspace/contents.xcworkspacedata b/macos/Runner.xcworkspace/contents.xcworkspacedata
deleted file mode 100644
index 21a3cc1..0000000
--- a/macos/Runner.xcworkspace/contents.xcworkspacedata
+++ /dev/null
@@ -1,10 +0,0 @@
-
-
-
-
-
-
-
diff --git a/macos/Runner.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist b/macos/Runner.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist
deleted file mode 100644
index 18d9810..0000000
--- a/macos/Runner.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist
+++ /dev/null
@@ -1,8 +0,0 @@
-
-
-
-
- IDEDidComputeMac32BitWarning
-
-
-
diff --git a/macos/Runner/AppDelegate.swift b/macos/Runner/AppDelegate.swift
deleted file mode 100644
index b3c1761..0000000
--- a/macos/Runner/AppDelegate.swift
+++ /dev/null
@@ -1,13 +0,0 @@
-import Cocoa
-import FlutterMacOS
-
-@main
-class AppDelegate: FlutterAppDelegate {
- override func applicationShouldTerminateAfterLastWindowClosed(_ sender: NSApplication) -> Bool {
- return true
- }
-
- override func applicationSupportsSecureRestorableState(_ app: NSApplication) -> Bool {
- return true
- }
-}
diff --git a/macos/Runner/Assets.xcassets/AppIcon.appiconset/Contents.json b/macos/Runner/Assets.xcassets/AppIcon.appiconset/Contents.json
deleted file mode 100644
index a2ec33f..0000000
--- a/macos/Runner/Assets.xcassets/AppIcon.appiconset/Contents.json
+++ /dev/null
@@ -1,68 +0,0 @@
-{
- "images" : [
- {
- "size" : "16x16",
- "idiom" : "mac",
- "filename" : "app_icon_16.png",
- "scale" : "1x"
- },
- {
- "size" : "16x16",
- "idiom" : "mac",
- "filename" : "app_icon_32.png",
- "scale" : "2x"
- },
- {
- "size" : "32x32",
- "idiom" : "mac",
- "filename" : "app_icon_32.png",
- "scale" : "1x"
- },
- {
- "size" : "32x32",
- "idiom" : "mac",
- "filename" : "app_icon_64.png",
- "scale" : "2x"
- },
- {
- "size" : "128x128",
- "idiom" : "mac",
- "filename" : "app_icon_128.png",
- "scale" : "1x"
- },
- {
- "size" : "128x128",
- "idiom" : "mac",
- "filename" : "app_icon_256.png",
- "scale" : "2x"
- },
- {
- "size" : "256x256",
- "idiom" : "mac",
- "filename" : "app_icon_256.png",
- "scale" : "1x"
- },
- {
- "size" : "256x256",
- "idiom" : "mac",
- "filename" : "app_icon_512.png",
- "scale" : "2x"
- },
- {
- "size" : "512x512",
- "idiom" : "mac",
- "filename" : "app_icon_512.png",
- "scale" : "1x"
- },
- {
- "size" : "512x512",
- "idiom" : "mac",
- "filename" : "app_icon_1024.png",
- "scale" : "2x"
- }
- ],
- "info" : {
- "version" : 1,
- "author" : "xcode"
- }
-}
diff --git a/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_1024.png b/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_1024.png
deleted file mode 100644
index 82b6f9d..0000000
Binary files a/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_1024.png and /dev/null differ
diff --git a/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_128.png b/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_128.png
deleted file mode 100644
index 13b35eb..0000000
Binary files a/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_128.png and /dev/null differ
diff --git a/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_16.png b/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_16.png
deleted file mode 100644
index 0a3f5fa..0000000
Binary files a/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_16.png and /dev/null differ
diff --git a/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_256.png b/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_256.png
deleted file mode 100644
index bdb5722..0000000
Binary files a/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_256.png and /dev/null differ
diff --git a/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_32.png b/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_32.png
deleted file mode 100644
index f083318..0000000
Binary files a/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_32.png and /dev/null differ
diff --git a/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_512.png b/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_512.png
deleted file mode 100644
index 326c0e7..0000000
Binary files a/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_512.png and /dev/null differ
diff --git a/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_64.png b/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_64.png
deleted file mode 100644
index 2f1632c..0000000
Binary files a/macos/Runner/Assets.xcassets/AppIcon.appiconset/app_icon_64.png and /dev/null differ
diff --git a/macos/Runner/Base.lproj/MainMenu.xib b/macos/Runner/Base.lproj/MainMenu.xib
deleted file mode 100644
index 80e867a..0000000
--- a/macos/Runner/Base.lproj/MainMenu.xib
+++ /dev/null
@@ -1,343 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/macos/Runner/Configs/AppInfo.xcconfig b/macos/Runner/Configs/AppInfo.xcconfig
deleted file mode 100644
index de7520b..0000000
--- a/macos/Runner/Configs/AppInfo.xcconfig
+++ /dev/null
@@ -1,14 +0,0 @@
-// Application-level settings for the Runner target.
-//
-// This may be replaced with something auto-generated from metadata (e.g., pubspec.yaml) in the
-// future. If not, the values below would default to using the project name when this becomes a
-// 'flutter create' template.
-
-// The application's name. By default this is also the title of the Flutter window.
-PRODUCT_NAME = zup_app
-
-// The application's bundle identifier
-PRODUCT_BUNDLE_IDENTIFIER = com.example.zupApp
-
-// The copyright displayed in application information
-PRODUCT_COPYRIGHT = Copyright © 2024 com.example. All rights reserved.
diff --git a/macos/Runner/Configs/Debug.xcconfig b/macos/Runner/Configs/Debug.xcconfig
deleted file mode 100644
index 36b0fd9..0000000
--- a/macos/Runner/Configs/Debug.xcconfig
+++ /dev/null
@@ -1,2 +0,0 @@
-#include "../../Flutter/Flutter-Debug.xcconfig"
-#include "Warnings.xcconfig"
diff --git a/macos/Runner/Configs/Release.xcconfig b/macos/Runner/Configs/Release.xcconfig
deleted file mode 100644
index dff4f49..0000000
--- a/macos/Runner/Configs/Release.xcconfig
+++ /dev/null
@@ -1,2 +0,0 @@
-#include "../../Flutter/Flutter-Release.xcconfig"
-#include "Warnings.xcconfig"
diff --git a/macos/Runner/Configs/Warnings.xcconfig b/macos/Runner/Configs/Warnings.xcconfig
deleted file mode 100644
index 42bcbf4..0000000
--- a/macos/Runner/Configs/Warnings.xcconfig
+++ /dev/null
@@ -1,13 +0,0 @@
-WARNING_CFLAGS = -Wall -Wconditional-uninitialized -Wnullable-to-nonnull-conversion -Wmissing-method-return-type -Woverlength-strings
-GCC_WARN_UNDECLARED_SELECTOR = YES
-CLANG_UNDEFINED_BEHAVIOR_SANITIZER_NULLABILITY = YES
-CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE
-CLANG_WARN__DUPLICATE_METHOD_MATCH = YES
-CLANG_WARN_PRAGMA_PACK = YES
-CLANG_WARN_STRICT_PROTOTYPES = YES
-CLANG_WARN_COMMA = YES
-GCC_WARN_STRICT_SELECTOR_MATCH = YES
-CLANG_WARN_OBJC_REPEATED_USE_OF_WEAK = YES
-CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES
-GCC_WARN_SHADOW = YES
-CLANG_WARN_UNREACHABLE_CODE = YES
diff --git a/macos/Runner/DebugProfile.entitlements b/macos/Runner/DebugProfile.entitlements
deleted file mode 100644
index 08c3ab1..0000000
--- a/macos/Runner/DebugProfile.entitlements
+++ /dev/null
@@ -1,14 +0,0 @@
-
-
-
-
- com.apple.security.app-sandbox
-
- com.apple.security.cs.allow-jit
-
- com.apple.security.network.server
-
- com.apple.security.network.client
-
-
-
diff --git a/macos/Runner/Info.plist b/macos/Runner/Info.plist
deleted file mode 100644
index 4789daa..0000000
--- a/macos/Runner/Info.plist
+++ /dev/null
@@ -1,32 +0,0 @@
-
-
-
-
- CFBundleDevelopmentRegion
- $(DEVELOPMENT_LANGUAGE)
- CFBundleExecutable
- $(EXECUTABLE_NAME)
- CFBundleIconFile
-
- CFBundleIdentifier
- $(PRODUCT_BUNDLE_IDENTIFIER)
- CFBundleInfoDictionaryVersion
- 6.0
- CFBundleName
- $(PRODUCT_NAME)
- CFBundlePackageType
- APPL
- CFBundleShortVersionString
- $(FLUTTER_BUILD_NAME)
- CFBundleVersion
- $(FLUTTER_BUILD_NUMBER)
- LSMinimumSystemVersion
- $(MACOSX_DEPLOYMENT_TARGET)
- NSHumanReadableCopyright
- $(PRODUCT_COPYRIGHT)
- NSMainNibFile
- MainMenu
- NSPrincipalClass
- NSApplication
-
-
diff --git a/macos/Runner/MainFlutterWindow.swift b/macos/Runner/MainFlutterWindow.swift
deleted file mode 100644
index 3cc05eb..0000000
--- a/macos/Runner/MainFlutterWindow.swift
+++ /dev/null
@@ -1,15 +0,0 @@
-import Cocoa
-import FlutterMacOS
-
-class MainFlutterWindow: NSWindow {
- override func awakeFromNib() {
- let flutterViewController = FlutterViewController()
- let windowFrame = self.frame
- self.contentViewController = flutterViewController
- self.setFrame(windowFrame, display: true)
-
- RegisterGeneratedPlugins(registry: flutterViewController)
-
- super.awakeFromNib()
- }
-}
diff --git a/macos/Runner/Release.entitlements b/macos/Runner/Release.entitlements
deleted file mode 100644
index 852fa1a..0000000
--- a/macos/Runner/Release.entitlements
+++ /dev/null
@@ -1,8 +0,0 @@
-
-
-
-
- com.apple.security.app-sandbox
-
-
-
diff --git a/macos/RunnerTests/RunnerTests.swift b/macos/RunnerTests/RunnerTests.swift
deleted file mode 100644
index 61f3bd1..0000000
--- a/macos/RunnerTests/RunnerTests.swift
+++ /dev/null
@@ -1,12 +0,0 @@
-import Cocoa
-import FlutterMacOS
-import XCTest
-
-class RunnerTests: XCTestCase {
-
- func testExample() {
- // If you add code to the Runner application, consider adding tests here.
- // See https://developer.apple.com/documentation/xctest for more information about using XCTest.
- }
-
-}
diff --git a/pubspec.lock b/pubspec.lock
index 956c4fc..8e6c9f0 100644
--- a/pubspec.lock
+++ b/pubspec.lock
@@ -13,10 +13,10 @@ packages:
dependency: transitive
description:
name: _flutterfire_internals
- sha256: "214e6f07e2a44f45972e0365c7b537eaeaddb4598db0778dd4ac64b4acd3f5b1"
+ sha256: ff0a84a2734d9e1089f8aedd5c0af0061b82fb94e95260d943404e0ef2134b11
url: "https://pub.dev"
source: hosted
- version: "1.3.55"
+ version: "1.3.59"
analyzer:
dependency: transitive
description:
@@ -173,10 +173,10 @@ packages:
dependency: transitive
description:
name: checked_yaml
- sha256: feb6bed21949061731a7a75fc5d2aa727cf160b91af9a3e464c5e3a32e28b5ff
+ sha256: "959525d3162f249993882720d52b7e0c833978df229be20702b33d48d91de70f"
url: "https://pub.dev"
source: hosted
- version: "2.0.3"
+ version: "2.0.4"
clock:
dependency: "direct main"
description:
@@ -285,19 +285,19 @@ packages:
dependency: "direct main"
description:
name: envied
- sha256: a4e2b1d0caa479b5d61332ae516518c175a6d09328a35a0bc0a53894cc5d7e4d
+ sha256: f8c347589ab13bed975aa2f6f95630570aa1a358c7e6c8894686e80e4bc60b14
url: "https://pub.dev"
source: hosted
- version: "1.1.1"
+ version: "1.2.0"
envied_generator:
dependency: "direct dev"
description:
path: "packages/envied_generator"
ref: HEAD
- resolved-ref: "5cc9172f320f5b4293417358d57e039bf8e90c25"
+ resolved-ref: "2ab7cb5865242369b84f0e2dfd07a660ae0db15b"
url: "https://github.com/petercinibulk/envied.git"
source: git
- version: "1.1.1"
+ version: "1.2.0"
equatable:
dependency: "direct main"
description:
@@ -334,50 +334,50 @@ packages:
dependency: "direct main"
description:
name: firebase_analytics
- sha256: b5b31727ad7c7f41e139637d1d582e435fd14054abcbd162c64476f90737105c
+ sha256: "4f85b161772e1d54a66893ef131c0a44bd9e552efa78b33d5f4f60d2caa5c8a3"
url: "https://pub.dev"
source: hosted
- version: "11.4.6"
+ version: "11.6.0"
firebase_analytics_platform_interface:
dependency: transitive
description:
name: firebase_analytics_platform_interface
- sha256: "86817ee7db6377e09830467932c31644713d8e8915cefff64610ad735612bc7d"
+ sha256: a44b6d1155ed5cae7641e3de7163111cfd9f6f6c954ca916dc6a3bdfa86bf845
url: "https://pub.dev"
source: hosted
- version: "4.3.6"
+ version: "4.4.3"
firebase_analytics_web:
dependency: transitive
description:
name: firebase_analytics_web
- sha256: "4914e184a6aa37811d976db59f95fa8fda1d58db49ab7f73d4d8aac9dd9b19b7"
+ sha256: c7d1ed1f86ae64215757518af5576ff88341c8ce5741988c05cc3b2e07b0b273
url: "https://pub.dev"
source: hosted
- version: "0.5.10+12"
+ version: "0.5.10+16"
firebase_core:
dependency: "direct main"
description:
name: firebase_core
- sha256: "8cfe3c900512399ce8d50fcc817e5758ff8615eeb6fa5c846a4cc47bbf6353b6"
+ sha256: "7be63a3f841fc9663342f7f3a011a42aef6a61066943c90b1c434d79d5c995c5"
url: "https://pub.dev"
source: hosted
- version: "3.13.1"
+ version: "3.15.2"
firebase_core_platform_interface:
dependency: transitive
description:
name: firebase_core_platform_interface
- sha256: d7253d255ff10f85cfd2adaba9ac17bae878fa3ba577462451163bd9f1d1f0bf
+ sha256: "5dbc900677dcbe5873d22ad7fbd64b047750124f1f9b7ebe2a33b9ddccc838eb"
url: "https://pub.dev"
source: hosted
- version: "5.4.0"
+ version: "6.0.0"
firebase_core_web:
dependency: transitive
description:
name: firebase_core_web
- sha256: ddd72baa6f727e5b23f32d9af23d7d453d67946f380bd9c21daf474ee0f7326e
+ sha256: "0ed0dc292e8f9ac50992e2394e9d336a0275b6ae400d64163fdf0a8a8b556c37"
url: "https://pub.dev"
source: hosted
- version: "2.23.0"
+ version: "2.24.1"
fixnum:
dependency: transitive
description:
@@ -842,10 +842,10 @@ packages:
dependency: transitive
description:
name: posix
- sha256: f0d7856b6ca1887cfa6d1d394056a296ae33489db914e365e2044fdada449e62
+ sha256: "6323a5b0fa688b6a010df4905a56b00181479e6d10534cecfecede2aa55add61"
url: "https://pub.dev"
source: hosted
- version: "6.0.2"
+ version: "6.0.3"
provider:
dependency: transitive
description:
@@ -979,10 +979,10 @@ packages:
dependency: transitive
description:
name: shelf_web_socket
- sha256: cc36c297b52866d203dbf9332263c94becc2fe0ceaa9681d07b6ef9807023b67
+ sha256: "3632775c8e90d6c9712f883e633716432a27758216dfb61bd86a8321c0580925"
url: "https://pub.dev"
source: hosted
- version: "2.0.1"
+ version: "3.0.0"
skeletonizer:
dependency: "direct main"
description:
@@ -1048,10 +1048,10 @@ packages:
dependency: transitive
description:
name: sqflite_common
- sha256: "84731e8bfd8303a3389903e01fb2141b6e59b5973cacbb0929021df08dddbe8b"
+ sha256: "6ef422a4525ecc601db6c0a2233ff448c731307906e92cabc9ba292afaae16a6"
url: "https://pub.dev"
source: hosted
- version: "2.5.5"
+ version: "2.5.6"
sqflite_darwin:
dependency: transitive
description:
@@ -1104,10 +1104,10 @@ packages:
dependency: transitive
description:
name: synchronized
- sha256: "0669c70faae6270521ee4f05bffd2919892d42d1276e6c495be80174b6bc0ef6"
+ sha256: c254ade258ec8282947a0acbbc90b9575b4f19673533ee46f2f6e9b3aeefd7c0
url: "https://pub.dev"
source: hosted
- version: "3.3.1"
+ version: "3.4.0"
term_glyph:
dependency: transitive
description:
@@ -1152,10 +1152,10 @@ packages:
dependency: "direct main"
description:
name: url_launcher
- sha256: "9d06212b1362abc2f0f0d78e6f09f726608c74e3b9462e8368bb03314aa8d603"
+ sha256: f6a7e5c4835bb4e3026a04793a4199ca2d14c739ec378fdfe23fc8075d0439f8
url: "https://pub.dev"
source: hosted
- version: "6.3.1"
+ version: "6.3.2"
url_launcher_android:
dependency: transitive
description:
@@ -1224,10 +1224,10 @@ packages:
dependency: transitive
description:
name: vector_graphics
- sha256: "44cc7104ff32563122a929e4620cf3efd584194eec6d1d913eb5ba593dbcf6de"
+ sha256: a4f059dc26fc8295b5921376600a194c4ec7d55e72f2fe4c7d2831e103d461e6
url: "https://pub.dev"
source: hosted
- version: "1.1.18"
+ version: "1.1.19"
vector_graphics_codec:
dependency: transitive
description:
@@ -1240,10 +1240,10 @@ packages:
dependency: transitive
description:
name: vector_graphics_compiler
- sha256: "1b4b9e706a10294258727674a340ae0d6e64a7231980f9f9a3d12e4b42407aad"
+ sha256: "557a315b7d2a6dbb0aaaff84d857967ce6bdc96a63dc6ee2a57ce5a6ee5d3331"
url: "https://pub.dev"
source: hosted
- version: "1.1.16"
+ version: "1.1.17"
vector_math:
dependency: transitive
description:
@@ -1264,10 +1264,10 @@ packages:
dependency: transitive
description:
name: watcher
- sha256: "69da27e49efa56a15f8afe8f4438c4ec02eff0a117df1b22ea4aad194fe1c104"
+ sha256: "0b7fd4a0bbc4b92641dbf20adfd7e3fd1398fe17102d94b674234563e110088a"
url: "https://pub.dev"
source: hosted
- version: "1.1.1"
+ version: "1.1.2"
web:
dependency: transitive
description:
@@ -1281,7 +1281,7 @@ packages:
description:
path: "."
ref: main
- resolved-ref: "3f66c1d786bec0f4135b4a12ddad02983073cb1f"
+ resolved-ref: "13ec43de31406f3f5195f6747474ccb50eacdf8e"
url: "https://github.com/Zup-Protocol/web3kit.git"
source: git
version: "0.0.1"
@@ -1330,7 +1330,7 @@ packages:
description:
path: "."
ref: main
- resolved-ref: "7c9bde523f7fc3d7d15d2fddcd2161faf1589e8d"
+ resolved-ref: "09478e486c087bc87714fe7e0ab554bc34eb07a2"
url: "https://github.com/Zup-Protocol/zup-core.git"
source: git
version: "0.0.1"
@@ -1339,7 +1339,7 @@ packages:
description:
path: "."
ref: main
- resolved-ref: "034a680b84ef0436dd8c83e44291016b6abe92b9"
+ resolved-ref: "311aa04082ab0b85f2e8dc351777176338a227ea"
url: "https://github.com/Zup-Protocol/zup-ui-kit.git"
source: git
version: "0.0.1"
diff --git a/pubspec.yaml b/pubspec.yaml
index 63e0a00..40e560b 100644
--- a/pubspec.yaml
+++ b/pubspec.yaml
@@ -55,12 +55,12 @@ dependencies:
async: ^2.13.0
# dependency_overrides:
-# zup_core:
-# path: ../zup-core
-# web3kit:
-# path: ../web3kit
-# zup_ui_kit:
-# path: ../zup-ui-kit
+# zup_core:
+# path: ../zup-core
+# web3kit:
+# path: ../web3kit
+# zup_ui_kit:
+# path: ../zup-ui-kit
dev_dependencies:
flutter_test:
diff --git a/test/app/app_cubit_test.dart b/test/app/app_cubit_test.dart
index 69b2db5..288e7dc 100644
--- a/test/app/app_cubit_test.dart
+++ b/test/app/app_cubit_test.dart
@@ -5,6 +5,7 @@ import 'package:mocktail/mocktail.dart';
import 'package:web3kit/web3kit.dart';
import 'package:zup_app/app/app_cubit/app_cubit.dart';
import 'package:zup_app/core/cache.dart';
+import 'package:zup_app/core/enums/app_theme_mode.dart';
import 'package:zup_app/core/enums/networks.dart';
import '../mocks.dart';
@@ -16,95 +17,109 @@ void main() {
setUp(() async {
registerFallbackValue(const ChainInfo(hexChainId: ""));
+ registerFallbackValue(AppThemeMode.system);
await Web3Kit.initializeForTest();
wallet = WalletMock();
cache = CacheMock();
when(() => wallet.signerStream).thenAnswer((_) => const Stream.empty());
when(() => cache.getTestnetMode()).thenReturn(false);
+ when(() => cache.themeMode).thenReturn(AppThemeMode.system);
when(() => cache.saveTestnetMode(isTestnetMode: any(named: "isTestnetMode"))).thenAnswer((_) => Future.value());
+ when(() => cache.saveThemeMode(any())).thenAnswer((_) async {});
sut = AppCubit(wallet, cache);
});
- test("When calling the `selectedNetwork` after initializing the cubit, it should return the initial selected network",
- () {
- expect(sut.selectedNetwork, AppNetworks.allNetworks);
- });
+ test(
+ "When calling the `selectedNetwork` after initializing the cubit, it should return the initial selected network",
+ () {
+ expect(sut.selectedNetwork, AppNetworks.allNetworks);
+ },
+ );
- test("""When an event is emitted that the signer changed,
+ test(
+ """When an event is emitted that the signer changed,
and the current signer is not in the selected network,
- it should ask to change the network""", () async {
- final wallet0 = WalletMock();
- final signerStreamController = StreamController.broadcast();
- final signerStream = signerStreamController.stream;
- final signer = SignerMock();
- const signerNetwork = "0x7521";
-
- when(() => wallet0.signerStream).thenAnswer((_) => signerStream);
- when(() => wallet0.connectedNetwork).thenAnswer((_) async => const ChainInfo(hexChainId: signerNetwork));
- when(() => wallet0.switchOrAddNetwork(any())).thenAnswer((_) async {});
-
- final sut0 = AppCubit(wallet0, cache)..updateAppNetwork(AppNetworks.sepolia);
-
- signerStreamController.add(signer);
-
- await Future.delayed(const Duration(milliseconds: 100));
-
- verify(
- () => wallet0.switchOrAddNetwork(
- ChainInfo(
- hexChainId: sut0.selectedNetwork.chainInfo.hexChainId,
- chainName: sut0.selectedNetwork.chainInfo.chainName,
- blockExplorerUrls: sut0.selectedNetwork.chainInfo.blockExplorerUrls,
- nativeCurrency: sut0.selectedNetwork.chainInfo.nativeCurrency,
- rpcUrls: sut0.selectedNetwork.chainInfo.rpcUrls,
- iconsURLs: sut0.selectedNetwork.chainInfo.iconsURLs,
+ it should ask to change the network""",
+ () async {
+ final wallet0 = WalletMock();
+ final signerStreamController = StreamController.broadcast();
+ final signerStream = signerStreamController.stream;
+ final signer = SignerMock();
+ const signerNetwork = "0x7521";
+
+ when(() => wallet0.signerStream).thenAnswer((_) => signerStream);
+ when(() => wallet0.connectedNetwork).thenAnswer((_) async => const ChainInfo(hexChainId: signerNetwork));
+ when(() => wallet0.switchOrAddNetwork(any())).thenAnswer((_) async {});
+
+ final sut0 = AppCubit(wallet0, cache)..updateAppNetwork(AppNetworks.sepolia);
+
+ signerStreamController.add(signer);
+
+ await Future.delayed(const Duration(milliseconds: 100));
+
+ verify(
+ () => wallet0.switchOrAddNetwork(
+ ChainInfo(
+ hexChainId: sut0.selectedNetwork.chainInfo.hexChainId,
+ chainName: sut0.selectedNetwork.chainInfo.chainName,
+ blockExplorerUrls: sut0.selectedNetwork.chainInfo.blockExplorerUrls,
+ nativeCurrency: sut0.selectedNetwork.chainInfo.nativeCurrency,
+ rpcUrls: sut0.selectedNetwork.chainInfo.rpcUrls,
+ iconsURLs: sut0.selectedNetwork.chainInfo.iconsURLs,
+ ),
),
- ),
- ).called(1);
- });
+ ).called(1);
+ },
+ );
- test("""When an event is emitted that the signer changed,
+ test(
+ """When an event is emitted that the signer changed,
and the current signer is in the selected network,
- it should not ask to change the network""", () async {
- final wallet0 = WalletMock();
- final signerStreamController = StreamController.broadcast();
- final signerStream = signerStreamController.stream;
- final signer = SignerMock();
- final signerNetwork = AppNetworks.sepolia.chainInfo.hexChainId;
+ it should not ask to change the network""",
+ () async {
+ final wallet0 = WalletMock();
+ final signerStreamController = StreamController.broadcast();
+ final signerStream = signerStreamController.stream;
+ final signer = SignerMock();
+ final signerNetwork = AppNetworks.sepolia.chainInfo.hexChainId;
- when(() => wallet0.signerStream).thenAnswer((_) => signerStream);
- when(() => wallet0.connectedNetwork).thenAnswer((_) async => ChainInfo(hexChainId: signerNetwork));
- when(() => wallet0.switchOrAddNetwork(any())).thenAnswer((_) async {});
+ when(() => wallet0.signerStream).thenAnswer((_) => signerStream);
+ when(() => wallet0.connectedNetwork).thenAnswer((_) async => ChainInfo(hexChainId: signerNetwork));
+ when(() => wallet0.switchOrAddNetwork(any())).thenAnswer((_) async {});
- AppCubit(wallet0, cache).updateAppNetwork(AppNetworks.sepolia);
+ AppCubit(wallet0, cache).updateAppNetwork(AppNetworks.sepolia);
- signerStreamController.add(signer);
+ signerStreamController.add(signer);
- await Future.delayed(const Duration(milliseconds: 100));
+ await Future.delayed(const Duration(milliseconds: 100));
- verifyNever(() => wallet0.switchOrAddNetwork(any()));
- });
+ verifyNever(() => wallet0.switchOrAddNetwork(any()));
+ },
+ );
- test("""When an event is emitted that the signer changed,
- but the signer is null, it should not ask to change the network""", () async {
- final wallet0 = WalletMock();
- final signerStreamController = StreamController.broadcast();
- final signerStream = signerStreamController.stream;
+ test(
+ """When an event is emitted that the signer changed,
+ but the signer is null, it should not ask to change the network""",
+ () async {
+ final wallet0 = WalletMock();
+ final signerStreamController = StreamController.broadcast();
+ final signerStream = signerStreamController.stream;
- when(() => wallet0.signerStream).thenAnswer((_) => signerStream);
- when(() => wallet0.connectedNetwork).thenAnswer((_) async => const ChainInfo(hexChainId: ""));
- when(() => wallet0.switchOrAddNetwork(any())).thenAnswer((_) async {});
+ when(() => wallet0.signerStream).thenAnswer((_) => signerStream);
+ when(() => wallet0.connectedNetwork).thenAnswer((_) async => const ChainInfo(hexChainId: ""));
+ when(() => wallet0.switchOrAddNetwork(any())).thenAnswer((_) async {});
- AppCubit(wallet0, cache).updateAppNetwork(AppNetworks.sepolia);
+ AppCubit(wallet0, cache).updateAppNetwork(AppNetworks.sepolia);
- signerStreamController.add(null);
+ signerStreamController.add(null);
- await Future.delayed(const Duration(milliseconds: 100));
+ await Future.delayed(const Duration(milliseconds: 100));
- verifyNever(() => wallet0.switchOrAddNetwork(any()));
- });
+ verifyNever(() => wallet0.switchOrAddNetwork(any()));
+ },
+ );
test("When calling `updateAppNetwork` it should update the selected network variable", () async {
sut.updateAppNetwork(AppNetworks.sepolia);
@@ -112,16 +127,19 @@ void main() {
expect(sut.selectedNetwork, AppNetworks.sepolia);
});
- test("""When calling `updateAppNetwork` it should emit the state `networkChanged` with the new network
- but it should finish with the event `standard` """, () async {
- const network = AppNetworks.sepolia;
+ test(
+ """When calling `updateAppNetwork` it should emit the state `networkChanged` with the new network
+ but it should finish with the event `standard` """,
+ () async {
+ const network = AppNetworks.sepolia;
- expectLater(sut.stream, emitsInOrder([const AppState.networkChanged(network), const AppState.standard()]));
+ expectLater(sut.stream, emitsInOrder([const AppState.networkChanged(network), const AppState.standard()]));
- sut.updateAppNetwork(network);
+ sut.updateAppNetwork(network);
- expect(sut.state, const AppState.standard());
- });
+ expect(sut.state, const AppState.standard());
+ },
+ );
test("When changing the network, it should add an event to the network stream", () {
const network = AppNetworks.sepolia;
@@ -135,30 +153,36 @@ void main() {
expect(sut.isTestnetMode, false);
});
- test("When initializing the cubit, it should set the `isTestnetMode` variable to the one saved in the cache",
- () async {
- when(() => cache.getTestnetMode()).thenReturn(true);
+ test(
+ "When initializing the cubit, it should set the `isTestnetMode` variable to the one saved in the cache",
+ () async {
+ when(() => cache.getTestnetMode()).thenReturn(true);
- final sut0 = AppCubit(wallet, cache);
+ final sut0 = AppCubit(wallet, cache);
- expect(sut0.isTestnetMode, true);
- });
+ expect(sut0.isTestnetMode, true);
+ },
+ );
- test("If the cached testnet mode is true when initializing the cubit, the initial selected network should be sepolia",
- () async {
- when(() => cache.getTestnetMode()).thenReturn(true);
- final sut0 = AppCubit(wallet, cache);
+ test(
+ "If the cached testnet mode is true when initializing the cubit, the initial selected network should be sepolia",
+ () async {
+ when(() => cache.getTestnetMode()).thenReturn(true);
+ final sut0 = AppCubit(wallet, cache);
- expect(sut0.selectedNetwork, AppNetworks.sepolia);
- });
+ expect(sut0.selectedNetwork, AppNetworks.sepolia);
+ },
+ );
- test("If the cached testnet mode is true when initializing the cubit, the state testnetModeChanged should be emitted",
- () async {
- when(() => cache.getTestnetMode()).thenReturn(true);
+ test(
+ "If the cached testnet mode is true when initializing the cubit, the state testnetModeChanged should be emitted",
+ () async {
+ when(() => cache.getTestnetMode()).thenReturn(true);
- final sut0 = AppCubit(wallet, cache);
- expect(sut0.state, const AppState.testnetModeChanged(true));
- });
+ final sut0 = AppCubit(wallet, cache);
+ expect(sut0.state, const AppState.testnetModeChanged(true));
+ },
+ );
test("When calling `toggleTestnetMode` it should update the `isTestnetMode` variable to the opposite", () async {
final currentTestnetMode = sut.isTestnetMode;
@@ -167,94 +191,131 @@ void main() {
expect(sut.isTestnetMode, !currentTestnetMode);
});
- test("""When calling `toggleTestnetMode` for true it should emit a `networkChanged`
- for the sepolia network and change the selected network variable""", () async {
- expectLater(
- sut.stream,
- emitsInOrder(
- [const AppState.networkChanged(AppNetworks.sepolia), const AppState.standard()],
- ),
- );
+ test(
+ """When calling `toggleTestnetMode` for true it should emit a `networkChanged`
+ for the sepolia network and change the selected network variable""",
+ () async {
+ expectLater(
+ sut.stream,
+ emitsInOrder([const AppState.networkChanged(AppNetworks.sepolia), const AppState.standard()]),
+ );
- await sut.toggleTestnetMode(); // assuming it starts by default as false
+ await sut.toggleTestnetMode(); // assuming it starts by default as false
- expect(sut.selectedNetwork, AppNetworks.sepolia);
- });
+ expect(sut.selectedNetwork, AppNetworks.sepolia);
+ },
+ );
+
+ test(
+ """When calling `toggleTestnetMode` for false it should emit a `networkChanged`
+ for a mainnet network and update the selected network variable""",
+ () async {
+ when(() => cache.getTestnetMode()).thenReturn(true);
- test("""When calling `toggleTestnetMode` for false it should emit a `networkChanged`
- for a mainnet network and update the selected network variable""", () async {
- when(() => cache.getTestnetMode()).thenReturn(true);
+ final sut0 = AppCubit(wallet, cache);
- final sut0 = AppCubit(wallet, cache);
+ expectLater(
+ sut0.stream,
+ emitsInOrder([const AppState.networkChanged(AppNetworks.allNetworks), const AppState.standard()]),
+ );
- expectLater(
- sut0.stream,
- emitsInOrder(
- [const AppState.networkChanged(AppNetworks.allNetworks), const AppState.standard()],
- ),
- );
+ await sut0.toggleTestnetMode();
- await sut0.toggleTestnetMode();
+ expect(sut0.selectedNetwork, AppNetworks.allNetworks);
+ },
+ );
- expect(sut0.selectedNetwork, AppNetworks.allNetworks);
- });
+ test(
+ "When calling `toggleTestnetMode` it should save the `isTestnetMode` variable in the cache after toggling",
+ () async {
+ final oldTestnetMode = sut.isTestnetMode;
- test("When calling `toggleTestnetMode` it should save the `isTestnetMode` variable in the cache after toggling",
- () async {
- final oldTestnetMode = sut.isTestnetMode;
+ await sut.toggleTestnetMode();
- await sut.toggleTestnetMode();
+ verify(() => cache.saveTestnetMode(isTestnetMode: !oldTestnetMode)).called(1);
+ },
+ );
- verify(() => cache.saveTestnetMode(isTestnetMode: !oldTestnetMode)).called(1);
- });
+ test(
+ """When calling `toggleTestnetMode` for true and there is a signer with a different connected
+ network, it should try to switch the wallet network for the default testnet network""",
+ () async {
+ final signer = SignerMock();
+ when(() => wallet.signer).thenReturn(signer);
+ when(() => wallet.connectedNetwork).thenAnswer((_) async => const ChainInfo(hexChainId: "0x32"));
- test("""When calling `toggleTestnetMode` for true and there is a signer with a different connected
- network, it should try to switch the wallet network for the default testnet network""", () async {
- final signer = SignerMock();
- when(() => wallet.signer).thenReturn(signer);
- when(() => wallet.connectedNetwork).thenAnswer((_) async => const ChainInfo(
- hexChainId: "0x32",
- ));
+ await sut.toggleTestnetMode(); // assuming it starts by default as false
- await sut.toggleTestnetMode(); // assuming it starts by default as false
+ verify(() => wallet.switchOrAddNetwork(AppNetworks.sepolia.chainInfo)).called(1);
+ },
+ );
- verify(() => wallet.switchOrAddNetwork(AppNetworks.sepolia.chainInfo)).called(1);
- });
+ test(
+ "When calling `toggleTestnetMode` from false to true it should emit the `testnetModeChanged` state with the new value",
+ () async {
+ expectLater(sut.stream, emitsInOrder([anything, anything, const AppState.testnetModeChanged(true)]));
+
+ await sut.toggleTestnetMode(); // assuming it starts by default as false
+ },
+ );
test(
- "When calling `toggleTestnetMode` from false to true it should emit the `testnetModeChanged` state with the new value",
- () async {
- expectLater(
- sut.stream,
- emitsInOrder([
- anything,
- anything,
- const AppState.testnetModeChanged(true),
- ]));
+ "When calling `toggleTestnetMode` from true to false it should emit the `testnetModeChanged` state with the new value",
+ () async {
+ when(() => cache.getTestnetMode()).thenReturn(true);
+ final sut0 = AppCubit(wallet, cache);
- await sut.toggleTestnetMode(); // assuming it starts by default as false
- });
+ expectLater(sut0.stream, emitsInOrder([anything, anything, const AppState.testnetModeChanged(false)]));
+ await sut0.toggleTestnetMode();
+ },
+ );
+
+ test(
+ "When calling `currentChainId` it should get exactly the chain id of the current selected network in the cubit",
+ () async {
+ sut.updateAppNetwork(AppNetworks.scroll);
+ expect(sut.currentChainId, AppNetworks.scroll.chainId);
+ },
+ );
test(
- "When calling `toggleTestnetMode` from true to false it should emit the `testnetModeChanged` state with the new value",
- () async {
- when(() => cache.getTestnetMode()).thenReturn(true);
- final sut0 = AppCubit(wallet, cache);
+ "When initializing the cubit, it should immediately get the cached theme mode and assign it to the variable",
+ () {
+ const cachedValue = AppThemeMode.dark;
+ when(() => cache.themeMode).thenReturn(cachedValue);
+ final sut0 = AppCubit(wallet, cache);
- expectLater(
- sut0.stream,
- emitsInOrder([
- anything,
- anything,
- const AppState.testnetModeChanged(false),
- ]));
+ expect(sut0.currentThemeMode, cachedValue);
+ },
+ );
+
+ test(
+ "When calling 'updateAppThemeMode' and passing the same as the current, it should not save in the cache",
+ () async {
+ await sut.updateAppThemeMode(sut.currentThemeMode);
+
+ verifyNever(() => cache.saveThemeMode(sut.currentThemeMode));
+ },
+ );
- await sut0.toggleTestnetMode();
+ test(
+ "When calling 'updateAppThemeMode' and passing a different as the current, it should save in the cache",
+ () async {
+ await sut.updateAppThemeMode(AppThemeMode.dark);
+
+ verify(() => cache.saveThemeMode(AppThemeMode.dark)).called(1);
+ },
+ );
+
+ test("When calling 'updateAppThemeMode' it should emit the `themeChanged` state with the new value", () async {
+ expectLater(sut.stream, emitsInOrder([const AppState.themeChanged(AppThemeMode.dark)]));
+
+ await sut.updateAppThemeMode(AppThemeMode.dark);
});
- test("When calling `currentChainId` it should get exactly the chain id of the current selected network in the cubit",
- () async {
- sut.updateAppNetwork(AppNetworks.scroll);
- expect(sut.currentChainId, AppNetworks.scroll.chainId);
+ test("When calling 'updateAppThemeMode' it should update the `currentThemeMode` variable", () async {
+ await sut.updateAppThemeMode(AppThemeMode.dark);
+
+ expect(sut.currentThemeMode, AppThemeMode.dark);
});
}
diff --git a/test/app/create/deposit/deposit_page_test.dart b/test/app/create/deposit/deposit_page_test.dart
index a60a0ae..d2846bb 100644
--- a/test/app/create/deposit/deposit_page_test.dart
+++ b/test/app/create/deposit/deposit_page_test.dart
@@ -99,8 +99,8 @@ void main() {
instanceName: InjectInstanceNames.lottieMatching,
);
inject.registerFactory(
- () => Assets.lotties.seaching.lottie(animate: false),
- instanceName: InjectInstanceNames.lottieSearching,
+ () => Assets.lotties.list.lottie(animate: false),
+ instanceName: InjectInstanceNames.lottieList,
);
inject.registerFactory(
() => ScrollController(),
diff --git a/test/app/create/deposit/goldens/deposit_page_24h_timeframe_hover.png b/test/app/create/deposit/goldens/deposit_page_24h_timeframe_hover.png
index d3533ab..5db6ee3 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_24h_timeframe_hover.png and b/test/app/create/deposit/goldens/deposit_page_24h_timeframe_hover.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_30d_timeframe.png b/test/app/create/deposit/goldens/deposit_page_30d_timeframe.png
index ec80025..4df6120 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_30d_timeframe.png and b/test/app/create/deposit/goldens/deposit_page_30d_timeframe.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_30d_timeframe_hover.png b/test/app/create/deposit/goldens/deposit_page_30d_timeframe_hover.png
index c6285fa..0215aa6 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_30d_timeframe_hover.png and b/test/app/create/deposit/goldens/deposit_page_30d_timeframe_hover.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_5_percent_set_to_full_range.png b/test/app/create/deposit/goldens/deposit_page_5_percent_set_to_full_range.png
index 6c94c78..3065345 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_5_percent_set_to_full_range.png and b/test/app/create/deposit/goldens/deposit_page_5_percent_set_to_full_range.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_5_percent_set_to_full_range_reverse_tokens.png b/test/app/create/deposit/goldens/deposit_page_5_percent_set_to_full_range_reverse_tokens.png
index b5fea83..e1a4cd3 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_5_percent_set_to_full_range_reverse_tokens.png and b/test/app/create/deposit/goldens/deposit_page_5_percent_set_to_full_range_reverse_tokens.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_7d_timeframe.png b/test/app/create/deposit/goldens/deposit_page_7d_timeframe.png
index 063c248..35b7dac 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_7d_timeframe.png and b/test/app/create/deposit/goldens/deposit_page_7d_timeframe.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_7d_timeframe_hover.png b/test/app/create/deposit/goldens/deposit_page_7d_timeframe_hover.png
index 36c735d..0f5caea 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_7d_timeframe_hover.png and b/test/app/create/deposit/goldens/deposit_page_7d_timeframe_hover.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_90d_timeframe.png b/test/app/create/deposit/goldens/deposit_page_90d_timeframe.png
index 887035b..ce292d7 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_90d_timeframe.png and b/test/app/create/deposit/goldens/deposit_page_90d_timeframe.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_90d_timeframe_back_to_24h.png b/test/app/create/deposit/goldens/deposit_page_90d_timeframe_back_to_24h.png
index 93b05b0..c92e34b 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_90d_timeframe_back_to_24h.png and b/test/app/create/deposit/goldens/deposit_page_90d_timeframe_back_to_24h.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_90d_timeframe_hover.png b/test/app/create/deposit/goldens/deposit_page_90d_timeframe_hover.png
index 9bfde2f..80b7af0 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_90d_timeframe_hover.png and b/test/app/create/deposit/goldens/deposit_page_90d_timeframe_hover.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_base_token_input_enabled_after_loading.png b/test/app/create/deposit/goldens/deposit_page_base_token_input_enabled_after_loading.png
index fab4258..d74cc21 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_base_token_input_enabled_after_loading.png and b/test/app/create/deposit/goldens/deposit_page_base_token_input_enabled_after_loading.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_base_token_input_loading.png b/test/app/create/deposit/goldens/deposit_page_base_token_input_loading.png
index c656d76..91a9c33 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_base_token_input_loading.png and b/test/app/create/deposit/goldens/deposit_page_base_token_input_loading.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_calculate_price.png b/test/app/create/deposit/goldens/deposit_page_calculate_price.png
index 6c94c78..3065345 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_calculate_price.png and b/test/app/create/deposit/goldens/deposit_page_calculate_price.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_calculate_price_reversed.png b/test/app/create/deposit/goldens/deposit_page_calculate_price_reversed.png
index b5fea83..e1a4cd3 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_calculate_price_reversed.png and b/test/app/create/deposit/goldens/deposit_page_calculate_price_reversed.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_deposit_settings_button_orange.png b/test/app/create/deposit/goldens/deposit_page_deposit_settings_button_orange.png
index e6887f4..e904d1c 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_deposit_settings_button_orange.png and b/test/app/create/deposit/goldens/deposit_page_deposit_settings_button_orange.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_deposit_settings_button_red.png b/test/app/create/deposit/goldens/deposit_page_deposit_settings_button_red.png
index 9034e0e..e56b1a4 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_deposit_settings_button_red.png and b/test/app/create/deposit/goldens/deposit_page_deposit_settings_button_red.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_deposit_settings_button_slippage_title.png b/test/app/create/deposit/goldens/deposit_page_deposit_settings_button_slippage_title.png
index 957565f..3f9d20b 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_deposit_settings_button_slippage_title.png and b/test/app/create/deposit/goldens/deposit_page_deposit_settings_button_slippage_title.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_deposit_settings_button_zup_purple_gray.png b/test/app/create/deposit/goldens/deposit_page_deposit_settings_button_zup_purple_gray.png
index 9bea3b0..6717491 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_deposit_settings_button_zup_purple_gray.png and b/test/app/create/deposit/goldens/deposit_page_deposit_settings_button_zup_purple_gray.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_deposit_settings_dropdown.png b/test/app/create/deposit/goldens/deposit_page_deposit_settings_dropdown.png
index 090174d..002bea2 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_deposit_settings_dropdown.png and b/test/app/create/deposit/goldens/deposit_page_deposit_settings_dropdown.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_deposit_settings_dropdown_reopening.png b/test/app/create/deposit/goldens/deposit_page_deposit_settings_dropdown_reopening.png
index a297ba2..8a1a88b 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_deposit_settings_dropdown_reopening.png and b/test/app/create/deposit/goldens/deposit_page_deposit_settings_dropdown_reopening.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_enough_balance_deposit_button.png b/test/app/create/deposit/goldens/deposit_page_enough_balance_deposit_button.png
index 76d9234..0342f55 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_enough_balance_deposit_button.png and b/test/app/create/deposit/goldens/deposit_page_enough_balance_deposit_button.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_error.png b/test/app/create/deposit/goldens/deposit_page_error.png
index ca6e8c0..f9c9fbe 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_error.png and b/test/app/create/deposit/goldens/deposit_page_error.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_input_base_token_amount.png b/test/app/create/deposit/goldens/deposit_page_input_base_token_amount.png
index 5da54f6..63e98df 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_input_base_token_amount.png and b/test/app/create/deposit/goldens/deposit_page_input_base_token_amount.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_input_base_token_amount_and_change_range.png b/test/app/create/deposit/goldens/deposit_page_input_base_token_amount_and_change_range.png
index ae674cb..0591330 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_input_base_token_amount_and_change_range.png and b/test/app/create/deposit/goldens/deposit_page_input_base_token_amount_and_change_range.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_input_base_token_amount_and_reverse.png b/test/app/create/deposit/goldens/deposit_page_input_base_token_amount_and_reverse.png
index 1e303fb..7500213 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_input_base_token_amount_and_reverse.png and b/test/app/create/deposit/goldens/deposit_page_input_base_token_amount_and_reverse.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_input_base_token_amount_and_reverse_back.png b/test/app/create/deposit/goldens/deposit_page_input_base_token_amount_and_reverse_back.png
index ef5ed54..df92331 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_input_base_token_amount_and_reverse_back.png and b/test/app/create/deposit/goldens/deposit_page_input_base_token_amount_and_reverse_back.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_input_base_token_amount_reverse_tokens_and_change_range.png b/test/app/create/deposit/goldens/deposit_page_input_base_token_amount_reverse_tokens_and_change_range.png
index 8b218c2..1cab7f7 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_input_base_token_amount_reverse_tokens_and_change_range.png and b/test/app/create/deposit/goldens/deposit_page_input_base_token_amount_reverse_tokens_and_change_range.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_input_base_token_amount_reversed.png b/test/app/create/deposit/goldens/deposit_page_input_base_token_amount_reversed.png
index f885fb8..90578dd 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_input_base_token_amount_reversed.png and b/test/app/create/deposit/goldens/deposit_page_input_base_token_amount_reversed.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_input_base_token_amount_then_reverse_tokens_then_set_max_price_out_of_range.png b/test/app/create/deposit/goldens/deposit_page_input_base_token_amount_then_reverse_tokens_then_set_max_price_out_of_range.png
index 1b66c06..c989741 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_input_base_token_amount_then_reverse_tokens_then_set_max_price_out_of_range.png and b/test/app/create/deposit/goldens/deposit_page_input_base_token_amount_then_reverse_tokens_then_set_max_price_out_of_range.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_input_base_token_amount_then_set_max_price_out_of_range.png b/test/app/create/deposit/goldens/deposit_page_input_base_token_amount_then_set_max_price_out_of_range.png
index 66e45e4..cb97a1d 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_input_base_token_amount_then_set_max_price_out_of_range.png and b/test/app/create/deposit/goldens/deposit_page_input_base_token_amount_then_set_max_price_out_of_range.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_input_quote_token_amount.png b/test/app/create/deposit/goldens/deposit_page_input_quote_token_amount.png
index 6b61a02..e63cb7a 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_input_quote_token_amount.png and b/test/app/create/deposit/goldens/deposit_page_input_quote_token_amount.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_input_quote_token_amount_and_change_range.png b/test/app/create/deposit/goldens/deposit_page_input_quote_token_amount_and_change_range.png
index 50aabf1..b79d4fa 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_input_quote_token_amount_and_change_range.png and b/test/app/create/deposit/goldens/deposit_page_input_quote_token_amount_and_change_range.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_input_quote_token_amount_and_reverse.png b/test/app/create/deposit/goldens/deposit_page_input_quote_token_amount_and_reverse.png
index ef1a0cc..5e040ae 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_input_quote_token_amount_and_reverse.png and b/test/app/create/deposit/goldens/deposit_page_input_quote_token_amount_and_reverse.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_input_quote_token_amount_and_reverse_back.png b/test/app/create/deposit/goldens/deposit_page_input_quote_token_amount_and_reverse_back.png
index 4b45567..4ebf888 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_input_quote_token_amount_and_reverse_back.png and b/test/app/create/deposit/goldens/deposit_page_input_quote_token_amount_and_reverse_back.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_input_quote_token_amount_reverse_tokens_and_change_range.png b/test/app/create/deposit/goldens/deposit_page_input_quote_token_amount_reverse_tokens_and_change_range.png
index 1b8701d..0fbcafd 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_input_quote_token_amount_reverse_tokens_and_change_range.png and b/test/app/create/deposit/goldens/deposit_page_input_quote_token_amount_reverse_tokens_and_change_range.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_input_quote_token_amount_reversed.png b/test/app/create/deposit/goldens/deposit_page_input_quote_token_amount_reversed.png
index 22d2a38..68c7d94 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_input_quote_token_amount_reversed.png and b/test/app/create/deposit/goldens/deposit_page_input_quote_token_amount_reversed.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_input_quote_token_amount_then_reverse_tokens_then_set_min_price_out_of_range.png b/test/app/create/deposit/goldens/deposit_page_input_quote_token_amount_then_reverse_tokens_then_set_min_price_out_of_range.png
index 36773e0..feeedf7 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_input_quote_token_amount_then_reverse_tokens_then_set_min_price_out_of_range.png and b/test/app/create/deposit/goldens/deposit_page_input_quote_token_amount_then_reverse_tokens_then_set_min_price_out_of_range.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_input_quote_token_amount_then_set_min_price_out_of_range.png b/test/app/create/deposit/goldens/deposit_page_input_quote_token_amount_then_set_min_price_out_of_range.png
index 8d539ff..102f55d 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_input_quote_token_amount_then_set_min_price_out_of_range.png and b/test/app/create/deposit/goldens/deposit_page_input_quote_token_amount_then_set_min_price_out_of_range.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_input_range_then_input_base_token_amount.png b/test/app/create/deposit/goldens/deposit_page_input_range_then_input_base_token_amount.png
index 8384557..ac06ca4 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_input_range_then_input_base_token_amount.png and b/test/app/create/deposit/goldens/deposit_page_input_range_then_input_base_token_amount.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_input_range_then_input_quote_token_amount.png b/test/app/create/deposit/goldens/deposit_page_input_range_then_input_quote_token_amount.png
index d81f5bc..539703c 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_input_range_then_input_quote_token_amount.png and b/test/app/create/deposit/goldens/deposit_page_input_range_then_input_quote_token_amount.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_input_range_then_reverse_tokens_then_input_base_token_amount.png b/test/app/create/deposit/goldens/deposit_page_input_range_then_reverse_tokens_then_input_base_token_amount.png
index 1b8701d..0fbcafd 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_input_range_then_reverse_tokens_then_input_base_token_amount.png and b/test/app/create/deposit/goldens/deposit_page_input_range_then_reverse_tokens_then_input_base_token_amount.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_input_range_then_reverse_tokens_then_input_quote_token_amount.png b/test/app/create/deposit/goldens/deposit_page_input_range_then_reverse_tokens_then_input_quote_token_amount.png
index 8b218c2..1cab7f7 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_input_range_then_reverse_tokens_then_input_quote_token_amount.png and b/test/app/create/deposit/goldens/deposit_page_input_range_then_reverse_tokens_then_input_quote_token_amount.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_invalid_range_deposit_section.png b/test/app/create/deposit/goldens/deposit_page_invalid_range_deposit_section.png
index ac16386..90aad1c 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_invalid_range_deposit_section.png and b/test/app/create/deposit/goldens/deposit_page_invalid_range_deposit_section.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_loading.png b/test/app/create/deposit/goldens/deposit_page_loading.png
index 2975c80..bbd24d1 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_loading.png and b/test/app/create/deposit/goldens/deposit_page_loading.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_max_price_less_than_min_price.png b/test/app/create/deposit/goldens/deposit_page_max_price_less_than_min_price.png
index ba0c0ae..67bab00 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_max_price_less_than_min_price.png and b/test/app/create/deposit/goldens/deposit_page_max_price_less_than_min_price.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_max_price_out_of_range.png b/test/app/create/deposit/goldens/deposit_page_max_price_out_of_range.png
index be6c190..47dc179 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_max_price_out_of_range.png and b/test/app/create/deposit/goldens/deposit_page_max_price_out_of_range.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_max_price_set_to_full_range.png b/test/app/create/deposit/goldens/deposit_page_max_price_set_to_full_range.png
index 6c94c78..3065345 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_max_price_set_to_full_range.png and b/test/app/create/deposit/goldens/deposit_page_max_price_set_to_full_range.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_max_price_set_to_infinity.png b/test/app/create/deposit/goldens/deposit_page_max_price_set_to_infinity.png
index 9943f27..d6cd8fb 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_max_price_set_to_infinity.png and b/test/app/create/deposit/goldens/deposit_page_max_price_set_to_infinity.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_max_range_out_of_range_deposit_button.png b/test/app/create/deposit/goldens/deposit_page_max_range_out_of_range_deposit_button.png
index a963ad2..f2c599e 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_max_range_out_of_range_deposit_button.png and b/test/app/create/deposit/goldens/deposit_page_max_range_out_of_range_deposit_button.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_min_and_max_price_set_to_full_range.png b/test/app/create/deposit/goldens/deposit_page_min_and_max_price_set_to_full_range.png
index 6c94c78..3065345 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_min_and_max_price_set_to_full_range.png and b/test/app/create/deposit/goldens/deposit_page_min_and_max_price_set_to_full_range.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_min_price_out_of_range.png b/test/app/create/deposit/goldens/deposit_page_min_price_out_of_range.png
index d57fd8c..88f4f72 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_min_price_out_of_range.png and b/test/app/create/deposit/goldens/deposit_page_min_price_out_of_range.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_min_price_out_of_range_reversed.png b/test/app/create/deposit/goldens/deposit_page_min_price_out_of_range_reversed.png
index eded629..4873a9c 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_min_price_out_of_range_reversed.png and b/test/app/create/deposit/goldens/deposit_page_min_price_out_of_range_reversed.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_min_price_out_of_range_reversed_in_range.png b/test/app/create/deposit/goldens/deposit_page_min_price_out_of_range_reversed_in_range.png
index aed6935..2feb5d8 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_min_price_out_of_range_reversed_in_range.png and b/test/app/create/deposit/goldens/deposit_page_min_price_out_of_range_reversed_in_range.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_min_price_set_to_full_range.png b/test/app/create/deposit/goldens/deposit_page_min_price_set_to_full_range.png
index 6c94c78..3065345 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_min_price_set_to_full_range.png and b/test/app/create/deposit/goldens/deposit_page_min_price_set_to_full_range.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_min_range_out_of_range_deposit_button.png b/test/app/create/deposit/goldens/deposit_page_min_range_out_of_range_deposit_button.png
index 828ecd0..9028c5a 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_min_range_out_of_range_deposit_button.png and b/test/app/create/deposit/goldens/deposit_page_min_range_out_of_range_deposit_button.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_no_amount_deposit_button.png b/test/app/create/deposit/goldens/deposit_page_no_amount_deposit_button.png
index 1437194..5c0a797 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_no_amount_deposit_button.png and b/test/app/create/deposit/goldens/deposit_page_no_amount_deposit_button.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_no_yields_filtered_by_min_liquidity.png b/test/app/create/deposit/goldens/deposit_page_no_yields_filtered_by_min_liquidity.png
index 8ac83d1..e19fb29 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_no_yields_filtered_by_min_liquidity.png and b/test/app/create/deposit/goldens/deposit_page_no_yields_filtered_by_min_liquidity.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_not_connected.png b/test/app/create/deposit/goldens/deposit_page_not_connected.png
index b79055d..0a136d1 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_not_connected.png and b/test/app/create/deposit/goldens/deposit_page_not_connected.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_not_connected_deposit_button_click.png b/test/app/create/deposit/goldens/deposit_page_not_connected_deposit_button_click.png
index 21ba558..b865836 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_not_connected_deposit_button_click.png and b/test/app/create/deposit/goldens/deposit_page_not_connected_deposit_button_click.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_not_enough_base_token_balance_deposit_button.png b/test/app/create/deposit/goldens/deposit_page_not_enough_base_token_balance_deposit_button.png
index 51b1ad8..9d93c07 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_not_enough_base_token_balance_deposit_button.png and b/test/app/create/deposit/goldens/deposit_page_not_enough_base_token_balance_deposit_button.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_not_enough_base_token_balance_deposit_button_after_connecting.png b/test/app/create/deposit/goldens/deposit_page_not_enough_base_token_balance_deposit_button_after_connecting.png
index 0446b7b..560dc6c 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_not_enough_base_token_balance_deposit_button_after_connecting.png and b/test/app/create/deposit/goldens/deposit_page_not_enough_base_token_balance_deposit_button_after_connecting.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_not_enough_quote_token_balance_deposit_button.png b/test/app/create/deposit/goldens/deposit_page_not_enough_quote_token_balance_deposit_button.png
index 265cd80..24c2583 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_not_enough_quote_token_balance_deposit_button.png and b/test/app/create/deposit/goldens/deposit_page_not_enough_quote_token_balance_deposit_button.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_not_enough_quote_token_balance_deposit_button_after_connecting.png b/test/app/create/deposit/goldens/deposit_page_not_enough_quote_token_balance_deposit_button_after_connecting.png
index 442717d..65658d6 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_not_enough_quote_token_balance_deposit_button_after_connecting.png and b/test/app/create/deposit/goldens/deposit_page_not_enough_quote_token_balance_deposit_button_after_connecting.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_odd_pools_last_page.png b/test/app/create/deposit/goldens/deposit_page_odd_pools_last_page.png
index a9603bd..3c4eff0 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_odd_pools_last_page.png and b/test/app/create/deposit/goldens/deposit_page_odd_pools_last_page.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_pool_tick_update_deposit_amount.png b/test/app/create/deposit/goldens/deposit_page_pool_tick_update_deposit_amount.png
index 029e6a9..5987faa 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_pool_tick_update_deposit_amount.png and b/test/app/create/deposit/goldens/deposit_page_pool_tick_update_deposit_amount.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_pools_page_1_24h_timeframe.png b/test/app/create/deposit/goldens/deposit_page_pools_page_1_24h_timeframe.png
index 0c518a2..fc8aa4e 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_pools_page_1_24h_timeframe.png and b/test/app/create/deposit/goldens/deposit_page_pools_page_1_24h_timeframe.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_pools_page_1_30d_timeframe.png b/test/app/create/deposit/goldens/deposit_page_pools_page_1_30d_timeframe.png
index dcf9a83..229945c 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_pools_page_1_30d_timeframe.png and b/test/app/create/deposit/goldens/deposit_page_pools_page_1_30d_timeframe.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_pools_page_1_7d_timeframe.png b/test/app/create/deposit/goldens/deposit_page_pools_page_1_7d_timeframe.png
index 0b43e5c..b476194 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_pools_page_1_7d_timeframe.png and b/test/app/create/deposit/goldens/deposit_page_pools_page_1_7d_timeframe.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_pools_page_1_90d_timeframe.png b/test/app/create/deposit/goldens/deposit_page_pools_page_1_90d_timeframe.png
index 0f49f2d..104e1e0 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_pools_page_1_90d_timeframe.png and b/test/app/create/deposit/goldens/deposit_page_pools_page_1_90d_timeframe.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_pools_page_2_24h_timeframe.png b/test/app/create/deposit/goldens/deposit_page_pools_page_2_24h_timeframe.png
index 8ed3b57..68209b2 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_pools_page_2_24h_timeframe.png and b/test/app/create/deposit/goldens/deposit_page_pools_page_2_24h_timeframe.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_pools_page_2_30d_timeframe.png b/test/app/create/deposit/goldens/deposit_page_pools_page_2_30d_timeframe.png
index 076c35e..60c5dde 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_pools_page_2_30d_timeframe.png and b/test/app/create/deposit/goldens/deposit_page_pools_page_2_30d_timeframe.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_pools_page_2_7d_timeframe.png b/test/app/create/deposit/goldens/deposit_page_pools_page_2_7d_timeframe.png
index 1e1a646..ba99362 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_pools_page_2_7d_timeframe.png and b/test/app/create/deposit/goldens/deposit_page_pools_page_2_7d_timeframe.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_pools_page_2_90d_timeframe.png b/test/app/create/deposit/goldens/deposit_page_pools_page_2_90d_timeframe.png
index 651cacd..eec31e2 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_pools_page_2_90d_timeframe.png and b/test/app/create/deposit/goldens/deposit_page_pools_page_2_90d_timeframe.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_pools_page_indicator_click.png b/test/app/create/deposit/goldens/deposit_page_pools_page_indicator_click.png
index a8f36b9..b89740b 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_pools_page_indicator_click.png and b/test/app/create/deposit/goldens/deposit_page_pools_page_indicator_click.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_pools_page_indicator_hover.png b/test/app/create/deposit/goldens/deposit_page_pools_page_indicator_hover.png
index 907c3d8..8e43e1a 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_pools_page_indicator_hover.png and b/test/app/create/deposit/goldens/deposit_page_pools_page_indicator_hover.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_preview_modal.png b/test/app/create/deposit/goldens/deposit_page_preview_modal.png
index bbd1059..3180b01 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_preview_modal.png and b/test/app/create/deposit/goldens/deposit_page_preview_modal.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_quote_token_input_enabled_after_loading.png b/test/app/create/deposit/goldens/deposit_page_quote_token_input_enabled_after_loading.png
index 10ddff7..b6d6931 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_quote_token_input_enabled_after_loading.png and b/test/app/create/deposit/goldens/deposit_page_quote_token_input_enabled_after_loading.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_quote_token_input_loading.png b/test/app/create/deposit/goldens/deposit_page_quote_token_input_loading.png
index ec94e1d..d37eff7 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_quote_token_input_loading.png and b/test/app/create/deposit/goldens/deposit_page_quote_token_input_loading.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_range_section_mobile.png b/test/app/create/deposit/goldens/deposit_page_range_section_mobile.png
index d44dbbb..cce63c8 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_range_section_mobile.png and b/test/app/create/deposit/goldens/deposit_page_range_section_mobile.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_reset_scroll_position_on_timeframe_change.png b/test/app/create/deposit/goldens/deposit_page_reset_scroll_position_on_timeframe_change.png
index e1c4e03..5f44a12 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_reset_scroll_position_on_timeframe_change.png and b/test/app/create/deposit/goldens/deposit_page_reset_scroll_position_on_timeframe_change.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_reverse_tokens.png b/test/app/create/deposit/goldens/deposit_page_reverse_tokens.png
index 618b18e..ac9b724 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_reverse_tokens.png and b/test/app/create/deposit/goldens/deposit_page_reverse_tokens.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_reverse_tokens_back.png b/test/app/create/deposit/goldens/deposit_page_reverse_tokens_back.png
index 16daf4a..6a2ff1d 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_reverse_tokens_back.png and b/test/app/create/deposit/goldens/deposit_page_reverse_tokens_back.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_select_yield_scroll.png b/test/app/create/deposit/goldens/deposit_page_select_yield_scroll.png
index 570277a..63ec0d3 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_select_yield_scroll.png and b/test/app/create/deposit/goldens/deposit_page_select_yield_scroll.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_selected_yield_stream.png b/test/app/create/deposit/goldens/deposit_page_selected_yield_stream.png
index 16daf4a..6a2ff1d 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_selected_yield_stream.png and b/test/app/create/deposit/goldens/deposit_page_selected_yield_stream.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_set_20_percent_range.png b/test/app/create/deposit/goldens/deposit_page_set_20_percent_range.png
index df7580c..28473aa 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_set_20_percent_range.png and b/test/app/create/deposit/goldens/deposit_page_set_20_percent_range.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_set_20_percent_range_reverse_tokens.png b/test/app/create/deposit/goldens/deposit_page_set_20_percent_range_reverse_tokens.png
index 4a3d9de..3145513 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_set_20_percent_range_reverse_tokens.png and b/test/app/create/deposit/goldens/deposit_page_set_20_percent_range_reverse_tokens.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_set_50_percent_range.png b/test/app/create/deposit/goldens/deposit_page_set_50_percent_range.png
index 2bbbfeb..a3b0b49 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_set_50_percent_range.png and b/test/app/create/deposit/goldens/deposit_page_set_50_percent_range.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_set_50_percent_range_reverse_tokens.png b/test/app/create/deposit/goldens/deposit_page_set_50_percent_range_reverse_tokens.png
index 89c42ec..4651926 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_set_50_percent_range_reverse_tokens.png and b/test/app/create/deposit/goldens/deposit_page_set_50_percent_range_reverse_tokens.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_set_5_percent_range.png b/test/app/create/deposit/goldens/deposit_page_set_5_percent_range.png
index ecadfea..5eae335 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_set_5_percent_range.png and b/test/app/create/deposit/goldens/deposit_page_set_5_percent_range.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_set_5_percent_range_reverse_tokens.png b/test/app/create/deposit/goldens/deposit_page_set_5_percent_range_reverse_tokens.png
index 08773bc..69f3936 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_set_5_percent_range_reverse_tokens.png and b/test/app/create/deposit/goldens/deposit_page_set_5_percent_range_reverse_tokens.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_set_percentage_range_then_type_max_price_reverse_tokens.png b/test/app/create/deposit/goldens/deposit_page_set_percentage_range_then_type_max_price_reverse_tokens.png
index dd0f5bc..eabee8d 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_set_percentage_range_then_type_max_price_reverse_tokens.png and b/test/app/create/deposit/goldens/deposit_page_set_percentage_range_then_type_max_price_reverse_tokens.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_set_percentage_range_then_type_min_price_reverse_tokens.png b/test/app/create/deposit/goldens/deposit_page_set_percentage_range_then_type_min_price_reverse_tokens.png
index ef9013f..67c1e81 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_set_percentage_range_then_type_min_price_reverse_tokens.png and b/test/app/create/deposit/goldens/deposit_page_set_percentage_range_then_type_min_price_reverse_tokens.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_success.png b/test/app/create/deposit/goldens/deposit_page_success.png
index 93b05b0..c92e34b 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_success.png and b/test/app/create/deposit/goldens/deposit_page_success.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_success_filtered_by_min_liquidity.png b/test/app/create/deposit/goldens/deposit_page_success_filtered_by_min_liquidity.png
index df60690..389b2eb 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_success_filtered_by_min_liquidity.png and b/test/app/create/deposit/goldens/deposit_page_success_filtered_by_min_liquidity.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_success_filtered_by_min_liquidity_local_filter_set.png b/test/app/create/deposit/goldens/deposit_page_success_filtered_by_min_liquidity_local_filter_set.png
index 72c666d..dcd9a29 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_success_filtered_by_min_liquidity_local_filter_set.png and b/test/app/create/deposit/goldens/deposit_page_success_filtered_by_min_liquidity_local_filter_set.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_success_mobile.png b/test/app/create/deposit/goldens/deposit_page_success_mobile.png
index 1360cec..5db84e0 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_success_mobile.png and b/test/app/create/deposit/goldens/deposit_page_success_mobile.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_success_not_filtered_by_min_liquidity.png b/test/app/create/deposit/goldens/deposit_page_success_not_filtered_by_min_liquidity.png
index abce625..5e5368e 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_success_not_filtered_by_min_liquidity.png and b/test/app/create/deposit/goldens/deposit_page_success_not_filtered_by_min_liquidity.png differ
diff --git a/test/app/create/deposit/goldens/deposit_page_timeframe_tooltip.png b/test/app/create/deposit/goldens/deposit_page_timeframe_tooltip.png
index 76375c5..4180e59 100644
Binary files a/test/app/create/deposit/goldens/deposit_page_timeframe_tooltip.png and b/test/app/create/deposit/goldens/deposit_page_timeframe_tooltip.png differ
diff --git a/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_custom_slippage.png b/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_custom_slippage.png
index 46a6cc7..85c9b79 100644
Binary files a/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_custom_slippage.png and b/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_custom_slippage.png differ
diff --git a/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_custom_slippage_greater_than_50_adjust.png b/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_custom_slippage_greater_than_50_adjust.png
index 3630328..fb78b89 100644
Binary files a/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_custom_slippage_greater_than_50_adjust.png and b/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_custom_slippage_greater_than_50_adjust.png differ
diff --git a/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_custom_slippage_greater_than_50_error.png b/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_custom_slippage_greater_than_50_error.png
index 23e5005..9f68740 100644
Binary files a/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_custom_slippage_greater_than_50_error.png and b/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_custom_slippage_greater_than_50_error.png differ
diff --git a/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_custom_slippage_lower_than_50.png b/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_custom_slippage_lower_than_50.png
index 4ad22fb..758179b 100644
Binary files a/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_custom_slippage_lower_than_50.png and b/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_custom_slippage_lower_than_50.png differ
diff --git a/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_deadline.png b/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_deadline.png
index 0adc931..ff9ed64 100644
Binary files a/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_deadline.png and b/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_deadline.png differ
diff --git a/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_deadline_greater_than_1200.png b/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_deadline_greater_than_1200.png
index 4723687..ae253ca 100644
Binary files a/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_deadline_greater_than_1200.png and b/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_deadline_greater_than_1200.png differ
diff --git a/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_deadline_greater_than_1200_error.png b/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_deadline_greater_than_1200_error.png
index 1f23d0c..a9bc890 100644
Binary files a/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_deadline_greater_than_1200_error.png and b/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_deadline_greater_than_1200_error.png differ
diff --git a/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_deadline_lower_than_1200.png b/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_deadline_lower_than_1200.png
index ffc5555..89b15d6 100644
Binary files a/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_deadline_lower_than_1200.png and b/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_deadline_lower_than_1200.png differ
diff --git a/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_deadline_not_numbers.png b/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_deadline_not_numbers.png
index bb16fa4..471e337 100644
Binary files a/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_deadline_not_numbers.png and b/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_deadline_not_numbers.png differ
diff --git a/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_deadline_tooltip.png b/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_deadline_tooltip.png
index 1830ecf..61b35c4 100644
Binary files a/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_deadline_tooltip.png and b/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_deadline_tooltip.png differ
diff --git a/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_front_running_warning.png b/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_front_running_warning.png
index d54278b..a9951bc 100644
Binary files a/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_front_running_warning.png and b/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_front_running_warning.png differ
diff --git a/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_one_percent_slippage.png b/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_one_percent_slippage.png
index 49e84f4..e9bcd55 100644
Binary files a/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_one_percent_slippage.png and b/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_one_percent_slippage.png differ
diff --git a/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_slippage_clear_textfield_after_selecting_default.png b/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_slippage_clear_textfield_after_selecting_default.png
index afb516f..383ec4b 100644
Binary files a/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_slippage_clear_textfield_after_selecting_default.png and b/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_slippage_clear_textfield_after_selecting_default.png differ
diff --git a/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_slippage_textfield_disallowed_characters.png b/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_slippage_textfield_disallowed_characters.png
index 616b1b8..1980bdc 100644
Binary files a/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_slippage_textfield_disallowed_characters.png and b/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_slippage_textfield_disallowed_characters.png differ
diff --git a/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_slippage_tooltip.png b/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_slippage_tooltip.png
index 36246ec..ecd7200 100644
Binary files a/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_slippage_tooltip.png and b/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_slippage_tooltip.png differ
diff --git a/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_zero_point_five_percent_slippage.png b/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_zero_point_five_percent_slippage.png
index afb516f..383ec4b 100644
Binary files a/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_zero_point_five_percent_slippage.png and b/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_zero_point_five_percent_slippage.png differ
diff --git a/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_zero_point_one_percent_slippage.png b/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_zero_point_one_percent_slippage.png
index 8b43eac..1843752 100644
Binary files a/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_zero_point_one_percent_slippage.png and b/test/app/create/deposit/widgets/goldens/deposit_settings_dropdown_child_zero_point_one_percent_slippage.png differ
diff --git a/test/app/create/deposit/widgets/goldens/deposit_success_modal.png b/test/app/create/deposit/widgets/goldens/deposit_success_modal.png
index 014822e..319ad5e 100644
Binary files a/test/app/create/deposit/widgets/goldens/deposit_success_modal.png and b/test/app/create/deposit/widgets/goldens/deposit_success_modal.png differ
diff --git a/test/app/create/deposit/widgets/goldens/deposit_success_modal_bottom_sheet.png b/test/app/create/deposit/widgets/goldens/deposit_success_modal_bottom_sheet.png
index a7c04b8..bd41c02 100644
Binary files a/test/app/create/deposit/widgets/goldens/deposit_success_modal_bottom_sheet.png and b/test/app/create/deposit/widgets/goldens/deposit_success_modal_bottom_sheet.png differ
diff --git a/test/app/create/deposit/widgets/goldens/deposit_success_modal_close_button_tap.png b/test/app/create/deposit/widgets/goldens/deposit_success_modal_close_button_tap.png
index c2e7da7..ae1eed3 100644
Binary files a/test/app/create/deposit/widgets/goldens/deposit_success_modal_close_button_tap.png and b/test/app/create/deposit/widgets/goldens/deposit_success_modal_close_button_tap.png differ
diff --git a/test/app/create/deposit/widgets/goldens/range_selector_decrease_price.png b/test/app/create/deposit/widgets/goldens/range_selector_decrease_price.png
index 8f1671a..e0b73b0 100644
Binary files a/test/app/create/deposit/widgets/goldens/range_selector_decrease_price.png and b/test/app/create/deposit/widgets/goldens/range_selector_decrease_price.png differ
diff --git a/test/app/create/deposit/widgets/goldens/range_selector_error_state.png b/test/app/create/deposit/widgets/goldens/range_selector_error_state.png
index c55a06b..bee884c 100644
Binary files a/test/app/create/deposit/widgets/goldens/range_selector_error_state.png and b/test/app/create/deposit/widgets/goldens/range_selector_error_state.png differ
diff --git a/test/app/create/deposit/widgets/goldens/range_selector_increase_price.png b/test/app/create/deposit/widgets/goldens/range_selector_increase_price.png
index b16fd32..cd40b73 100644
Binary files a/test/app/create/deposit/widgets/goldens/range_selector_increase_price.png and b/test/app/create/deposit/widgets/goldens/range_selector_increase_price.png differ
diff --git a/test/app/create/deposit/widgets/goldens/range_selector_initial_price.png b/test/app/create/deposit/widgets/goldens/range_selector_initial_price.png
index e08f679..37f94a0 100644
Binary files a/test/app/create/deposit/widgets/goldens/range_selector_initial_price.png and b/test/app/create/deposit/widgets/goldens/range_selector_initial_price.png differ
diff --git a/test/app/create/deposit/widgets/goldens/range_selector_is_infinity_decrease_price.png b/test/app/create/deposit/widgets/goldens/range_selector_is_infinity_decrease_price.png
index ad5f1d5..94452da 100644
Binary files a/test/app/create/deposit/widgets/goldens/range_selector_is_infinity_decrease_price.png and b/test/app/create/deposit/widgets/goldens/range_selector_is_infinity_decrease_price.png differ
diff --git a/test/app/create/deposit/widgets/goldens/range_selector_is_infinity_decrease_price_reversed.png b/test/app/create/deposit/widgets/goldens/range_selector_is_infinity_decrease_price_reversed.png
index ad5f1d5..94452da 100644
Binary files a/test/app/create/deposit/widgets/goldens/range_selector_is_infinity_decrease_price_reversed.png and b/test/app/create/deposit/widgets/goldens/range_selector_is_infinity_decrease_price_reversed.png differ
diff --git a/test/app/create/deposit/widgets/goldens/range_selector_is_infinity_increase_price.png b/test/app/create/deposit/widgets/goldens/range_selector_is_infinity_increase_price.png
index 5aa5a7c..2cc7b8a 100644
Binary files a/test/app/create/deposit/widgets/goldens/range_selector_is_infinity_increase_price.png and b/test/app/create/deposit/widgets/goldens/range_selector_is_infinity_increase_price.png differ
diff --git a/test/app/create/deposit/widgets/goldens/range_selector_is_infinity_increase_price_reversed.png b/test/app/create/deposit/widgets/goldens/range_selector_is_infinity_increase_price_reversed.png
index 5aa5a7c..2cc7b8a 100644
Binary files a/test/app/create/deposit/widgets/goldens/range_selector_is_infinity_increase_price_reversed.png and b/test/app/create/deposit/widgets/goldens/range_selector_is_infinity_increase_price_reversed.png differ
diff --git a/test/app/create/deposit/widgets/goldens/range_selector_is_reversed_decrease_price.png b/test/app/create/deposit/widgets/goldens/range_selector_is_reversed_decrease_price.png
index 30a86d8..b7aa0a5 100644
Binary files a/test/app/create/deposit/widgets/goldens/range_selector_is_reversed_decrease_price.png and b/test/app/create/deposit/widgets/goldens/range_selector_is_reversed_decrease_price.png differ
diff --git a/test/app/create/deposit/widgets/goldens/range_selector_is_reversed_increase_price.png b/test/app/create/deposit/widgets/goldens/range_selector_is_reversed_increase_price.png
index b9c3d5b..acac6e5 100644
Binary files a/test/app/create/deposit/widgets/goldens/range_selector_is_reversed_increase_price.png and b/test/app/create/deposit/widgets/goldens/range_selector_is_reversed_increase_price.png differ
diff --git a/test/app/create/deposit/widgets/goldens/range_selector_is_reversed_typed_price.png b/test/app/create/deposit/widgets/goldens/range_selector_is_reversed_typed_price.png
index 188dc57..604d02b 100644
Binary files a/test/app/create/deposit/widgets/goldens/range_selector_is_reversed_typed_price.png and b/test/app/create/deposit/widgets/goldens/range_selector_is_reversed_typed_price.png differ
diff --git a/test/app/create/deposit/widgets/goldens/range_selector_max_price.png b/test/app/create/deposit/widgets/goldens/range_selector_max_price.png
index fed3172..0797999 100644
Binary files a/test/app/create/deposit/widgets/goldens/range_selector_max_price.png and b/test/app/create/deposit/widgets/goldens/range_selector_max_price.png differ
diff --git a/test/app/create/deposit/widgets/goldens/range_selector_max_price_infinity.png b/test/app/create/deposit/widgets/goldens/range_selector_max_price_infinity.png
index 71e6956..9795605 100644
Binary files a/test/app/create/deposit/widgets/goldens/range_selector_max_price_infinity.png and b/test/app/create/deposit/widgets/goldens/range_selector_max_price_infinity.png differ
diff --git a/test/app/create/deposit/widgets/goldens/range_selector_min_price.png b/test/app/create/deposit/widgets/goldens/range_selector_min_price.png
index 985523c..cb7bdfb 100644
Binary files a/test/app/create/deposit/widgets/goldens/range_selector_min_price.png and b/test/app/create/deposit/widgets/goldens/range_selector_min_price.png differ
diff --git a/test/app/create/deposit/widgets/goldens/range_selector_min_price_infinity.png b/test/app/create/deposit/widgets/goldens/range_selector_min_price_infinity.png
index ad5f1d5..94452da 100644
Binary files a/test/app/create/deposit/widgets/goldens/range_selector_min_price_infinity.png and b/test/app/create/deposit/widgets/goldens/range_selector_min_price_infinity.png differ
diff --git a/test/app/create/deposit/widgets/goldens/range_selector_reversed.png b/test/app/create/deposit/widgets/goldens/range_selector_reversed.png
index 985523c..cb7bdfb 100644
Binary files a/test/app/create/deposit/widgets/goldens/range_selector_reversed.png and b/test/app/create/deposit/widgets/goldens/range_selector_reversed.png differ
diff --git a/test/app/create/deposit/widgets/goldens/range_selector_update_infinity_price_max_price.png b/test/app/create/deposit/widgets/goldens/range_selector_update_infinity_price_max_price.png
index 71e6956..9795605 100644
Binary files a/test/app/create/deposit/widgets/goldens/range_selector_update_infinity_price_max_price.png and b/test/app/create/deposit/widgets/goldens/range_selector_update_infinity_price_max_price.png differ
diff --git a/test/app/create/deposit/widgets/goldens/range_selector_update_infinity_price_min_price.png b/test/app/create/deposit/widgets/goldens/range_selector_update_infinity_price_min_price.png
index ad5f1d5..94452da 100644
Binary files a/test/app/create/deposit/widgets/goldens/range_selector_update_infinity_price_min_price.png and b/test/app/create/deposit/widgets/goldens/range_selector_update_infinity_price_min_price.png differ
diff --git a/test/app/create/deposit/widgets/goldens/range_selector_warning_state.png b/test/app/create/deposit/widgets/goldens/range_selector_warning_state.png
index 22a288d..ec03c9b 100644
Binary files a/test/app/create/deposit/widgets/goldens/range_selector_warning_state.png and b/test/app/create/deposit/widgets/goldens/range_selector_warning_state.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_approve_success.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_approve_success.png
index a89c361..6e2ad4e 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_approve_success.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_approve_success.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_approve_success_close_other_snackbar.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_approve_success_close_other_snackbar.png
index a89c361..6e2ad4e 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_approve_success_close_other_snackbar.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_approve_success_close_other_snackbar.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_approve_token0_state.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_approve_token0_state.png
index d9caebd..b890375 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_approve_token0_state.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_approve_token0_state.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_approve_token1_state.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_approve_token1_state.png
index eb6aad1..0315402 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_approve_token1_state.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_approve_token1_state.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_approving_token.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_approving_token.png
index 9bee408..9f6256b 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_approving_token.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_approving_token.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_cubit_close_approval_success_snackbar.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_cubit_close_approval_success_snackbar.png
index c6a11ce..4142c45 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_cubit_close_approval_success_snackbar.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_cubit_close_approval_success_snackbar.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_cubit_close_approving_snackbar.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_cubit_close_approving_snackbar.png
index f47e802..9a85546 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_cubit_close_approving_snackbar.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_cubit_close_approving_snackbar.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_cubit_close_deposit_success_modal.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_cubit_close_deposit_success_modal.png
index 014822e..319ad5e 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_cubit_close_deposit_success_modal.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_cubit_close_deposit_success_modal.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_cubit_close_depositing_snackbar.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_cubit_close_depositing_snackbar.png
index d7824a5..5ec8810 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_cubit_close_depositing_snackbar.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_cubit_close_depositing_snackbar.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_current_price.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_current_price.png
index 5e08f4c..6241bf3 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_current_price.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_current_price.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_current_price_reversed.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_current_price_reversed.png
index fb881b1..2915afa 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_current_price_reversed.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_current_price_reversed.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_current_price_stream.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_current_price_stream.png
index 5e08f4c..6241bf3 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_current_price_stream.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_current_price_stream.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_deposit_state.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_deposit_state.png
index de6de2f..76cac48 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_deposit_state.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_deposit_state.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_deposit_success_modal.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_deposit_success_modal.png
index 014822e..319ad5e 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_deposit_success_modal.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_deposit_success_modal.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_depositing.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_depositing.png
index e40a748..0a8c0ff 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_depositing.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_depositing.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_in_range.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_in_range.png
index ecc587b..c883e86 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_in_range.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_in_range.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_in_range_min_and_max_price.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_in_range_min_and_max_price.png
index 272f6dd..5fa934a 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_in_range_min_and_max_price.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_in_range_min_and_max_price.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_loading.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_loading.png
index 053ef89..989442e 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_loading.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_loading.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_max_price_infinity.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_max_price_infinity.png
index 133fd16..8a7a84c 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_max_price_infinity.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_max_price_infinity.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_min_price_infinity.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_min_price_infinity.png
index 22b7fed..4c933fb 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_min_price_infinity.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_min_price_infinity.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_out_of_range_max_price.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_out_of_range_max_price.png
index 56529cc..623db87 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_out_of_range_max_price.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_out_of_range_max_price.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_out_of_range_min_price.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_out_of_range_min_price.png
index cd9ecac..42b084e 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_out_of_range_min_price.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_out_of_range_min_price.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_range_prices.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_range_prices.png
index e9fb310..7932452 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_range_prices.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_range_prices.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_range_prices_reversed.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_range_prices_reversed.png
index 185722f..6f68b8f 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_range_prices_reversed.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_range_prices_reversed.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_range_prices_reversed_manually.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_range_prices_reversed_manually.png
index 6dc8749..79c2bce 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_range_prices_reversed_manually.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_range_prices_reversed_manually.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_range_prices_reversed_manually_reversed.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_range_prices_reversed_manually_reversed.png
index b7e8576..687e84b 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_range_prices_reversed_manually_reversed.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_range_prices_reversed_manually_reversed.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_reversed.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_reversed.png
index 185722f..6f68b8f 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_reversed.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_reversed.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_reversed_manually.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_reversed_manually.png
index fb881b1..2915afa 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_reversed_manually.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_reversed_manually.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_show_desktop.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_show_desktop.png
index 148a964..f884b90 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_show_desktop.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_show_desktop.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_show_mobile.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_show_mobile.png
index 1cb8b2b..90534ed 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_show_mobile.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_show_mobile.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_slippage_check_error.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_slippage_check_error.png
index e033411..7d14d05 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_slippage_check_error.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_slippage_check_error.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_token_amounts_change.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_token_amounts_change.png
index 2a1cb5f..71ab6c7 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_token_amounts_change.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_token_amounts_change.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_transaction_error.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_transaction_error.png
index b40719b..6c80556 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_transaction_error.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_transaction_error.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_unreversed_manually.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_unreversed_manually.png
index 5e08f4c..6241bf3 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_unreversed_manually.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_unreversed_manually.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_waiting_transaction.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_waiting_transaction.png
index a1a0243..97a6398 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_waiting_transaction.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_waiting_transaction.png differ
diff --git a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_waiting_transaction_button.png b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_waiting_transaction_button.png
index 012bc49..466d8d0 100644
Binary files a/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_waiting_transaction_button.png and b/test/app/create/deposit/widgets/preview_deposit_modal/goldens/preview_deposit_modal_waiting_transaction_button.png differ
diff --git a/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_connected.png b/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_connected.png
index 394ab0a..4434b04 100644
Binary files a/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_connected.png and b/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_connected.png differ
diff --git a/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_disabled.png b/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_disabled.png
index 21d16e9..07af6af 100644
Binary files a/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_disabled.png and b/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_disabled.png differ
diff --git a/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_large_number_left_border.png b/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_large_number_left_border.png
index d19adf8..08b30f9 100644
Binary files a/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_large_number_left_border.png and b/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_large_number_left_border.png differ
diff --git a/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_large_number_right_border.png b/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_large_number_right_border.png
index 367683f..43b418e 100644
Binary files a/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_large_number_right_border.png and b/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_large_number_right_border.png differ
diff --git a/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_non_number.png b/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_non_number.png
index 71d3e31..26a3610 100644
Binary files a/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_non_number.png and b/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_non_number.png differ
diff --git a/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_not_connected.png b/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_not_connected.png
index 3729e3c..97632fb 100644
Binary files a/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_not_connected.png and b/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_not_connected.png differ
diff --git a/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_refresh.png b/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_refresh.png
index eb66fa3..45c83f9 100644
Binary files a/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_refresh.png and b/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_refresh.png differ
diff --git a/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_signer_changes.png b/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_signer_changes.png
index 394ab0a..4434b04 100644
Binary files a/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_signer_changes.png and b/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_signer_changes.png differ
diff --git a/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_signer_changes_not_null.png b/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_signer_changes_not_null.png
index 394ab0a..4434b04 100644
Binary files a/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_signer_changes_not_null.png and b/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_signer_changes_not_null.png differ
diff --git a/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_update_token.png b/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_update_token.png
index e6ac881..df80723 100644
Binary files a/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_update_token.png and b/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_update_token.png differ
diff --git a/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_usd_equivalent.png b/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_usd_equivalent.png
index 259cc15..8d99c51 100644
Binary files a/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_usd_equivalent.png and b/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_usd_equivalent.png differ
diff --git a/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_user_balance_click.png b/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_user_balance_click.png
index 4d41159..3f107ff 100644
Binary files a/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_user_balance_click.png and b/test/app/create/deposit/widgets/token_amount_input_card/goldens/token_amount_card_user_balance_click.png differ
diff --git a/test/app/create/deposit/widgets/token_amount_input_card/token_amount_input_card_test.dart b/test/app/create/deposit/widgets/token_amount_input_card/token_amount_input_card_test.dart
index 0adfc09..56ee9b9 100644
--- a/test/app/create/deposit/widgets/token_amount_input_card/token_amount_input_card_test.dart
+++ b/test/app/create/deposit/widgets/token_amount_input_card/token_amount_input_card_test.dart
@@ -40,8 +40,9 @@ void main() {
when(() => signer.address).thenAnswer((_) => Future.value("0x99E3CfADCD8Feecb5DdF91f88998cFfB3145F78c"));
when(() => wallet.tokenBalance(any(), rpcUrl: any(named: "rpcUrl"))).thenAnswer((_) => Future.value(12.1));
when(() => wallet.signerStream).thenAnswer((_) => const Stream.empty());
- when(() => wallet.nativeOrTokenBalance(any(), rpcUrl: any(named: "rpcUrl")))
- .thenAnswer((_) => Future.value(43727653762.1));
+ when(
+ () => wallet.nativeOrTokenBalance(any(), rpcUrl: any(named: "rpcUrl")),
+ ).thenAnswer((_) => Future.value(43727653762.1));
});
tearDown(() async {
@@ -49,115 +50,134 @@ void main() {
await inject.reset();
});
- Future goldenBuilder(
- {Key? key,
- TextEditingController? controller,
- AppNetworks network = AppNetworks.sepolia,
- Function(double)? onInput,
- TokenDto? token,
- String? disabledText,
- bool isNative = false}) async =>
- await goldenDeviceBuilder(
- Center(
- child: Column(
- mainAxisSize: MainAxisSize.min,
- children: [
- SizedBox(
- width: 500,
- child: TokenAmountInputCard(
- key: key,
- isNative: isNative,
- controller: controller ?? TextEditingController(),
- network: network,
- onInput: (value) => onInput?.call(value),
- token: token ?? TokenDto.fixture(),
- disabledText: disabledText,
- ),
- ),
- ],
+ Future goldenBuilder({
+ Key? key,
+ TextEditingController? controller,
+ AppNetworks network = AppNetworks.sepolia,
+ Function(double)? onInput,
+ TokenDto? token,
+ String? disabledText,
+ bool isNative = false,
+ }) async => await goldenDeviceBuilder(
+ Center(
+ child: Column(
+ mainAxisSize: MainAxisSize.min,
+ children: [
+ SizedBox(
+ width: 500,
+ child: TokenAmountInputCard(
+ key: key,
+ isNative: isNative,
+ controller: controller ?? TextEditingController(),
+ network: network,
+ onInput: (value) => onInput?.call(value),
+ token: token ?? TokenDto.fixture(),
+ disabledText: disabledText,
+ ),
),
- ),
- );
+ ],
+ ),
+ ),
+ );
- zGoldenTest("When there is not a connected wallet, it should not show the user balance",
- goldenFileName: "token_amount_card_not_connected", (tester) async {
- await tester.runAsync(() async {
- when(() => wallet.signer).thenReturn(null);
+ zGoldenTest(
+ "When there is not a connected wallet, it should not show the user balance",
+ goldenFileName: "token_amount_card_not_connected",
+ (tester) async {
+ await tester.runAsync(() async {
+ when(() => wallet.signer).thenReturn(null);
- await tester.pumpDeviceBuilder(await goldenBuilder());
- await tester.pumpAndSettle();
- });
- });
+ await tester.pumpDeviceBuilder(await goldenBuilder());
+ await tester.pumpAndSettle();
+ });
+ },
+ );
- zGoldenTest(""""
+ zGoldenTest(
+ """"
When an event that the signer changes is emitted,
and the signer was null,
it should get the balance of the new connected wallet
and display it
- """, goldenFileName: "token_amount_card_signer_changes", (tester) async {
- await tester.runAsync(() async {
- final signerStreamController = StreamController.broadcast();
+ """,
+ goldenFileName: "token_amount_card_signer_changes",
+ (tester) async {
+ await tester.runAsync(() async {
+ final signerStreamController = StreamController.broadcast();
- when(() => wallet.signerStream).thenAnswer((_) => signerStreamController.stream);
- when(() => wallet.signer).thenReturn(null);
+ when(() => wallet.signerStream).thenAnswer((_) => signerStreamController.stream);
+ when(() => wallet.signer).thenReturn(null);
- await tester.pumpDeviceBuilder(await goldenBuilder());
+ await tester.pumpDeviceBuilder(await goldenBuilder());
- signerStreamController.add(signer);
- when(() => wallet.signer).thenReturn(signer);
+ signerStreamController.add(signer);
+ when(() => wallet.signer).thenReturn(signer);
- await tester.pumpAndSettle();
+ await tester.pumpAndSettle();
- verify(() => wallet.nativeOrTokenBalance(any(), rpcUrl: any(named: "rpcUrl"))).called(1);
- });
- });
+ verify(() => wallet.nativeOrTokenBalance(any(), rpcUrl: any(named: "rpcUrl"))).called(1);
+ });
+ },
+ );
- zGoldenTest(""""
+ zGoldenTest(
+ """"
When an event that the signer changes is emitted,
and the signer was not null,
it should get the balance of the new connected wallet
and display it
- """, goldenFileName: "token_amount_card_signer_changes_not_null", (tester) async {
- await tester.runAsync(() async {
- final signer1 = signer;
- final signer2 = SignerMock();
+ """,
+ goldenFileName: "token_amount_card_signer_changes_not_null",
+ (tester) async {
+ await tester.runAsync(() async {
+ final signer1 = signer;
+ final signer2 = SignerMock();
- final signerStreamController = StreamController.broadcast();
+ final signerStreamController = StreamController.broadcast();
- when(() => wallet.signerStream).thenAnswer((_) => signerStreamController.stream);
- when(() => wallet.signer).thenReturn(signer1);
- when(() => signer2.address).thenAnswer((_) => Future.value("0x99E3CfADCD8Feecb5DdF91f88998cFfB3145F78c"));
- when(() => wallet.nativeOrTokenBalance(any(), rpcUrl: any(named: "rpcUrl")))
- .thenAnswer((_) => Future.value(43727653762.1));
+ when(() => wallet.signerStream).thenAnswer((_) => signerStreamController.stream);
+ when(() => wallet.signer).thenReturn(signer1);
+ when(() => signer2.address).thenAnswer((_) => Future.value("0x99E3CfADCD8Feecb5DdF91f88998cFfB3145F78c"));
+ when(
+ () => wallet.nativeOrTokenBalance(any(), rpcUrl: any(named: "rpcUrl")),
+ ).thenAnswer((_) => Future.value(43727653762.1));
- await tester.pumpDeviceBuilder(await goldenBuilder());
- await tester.pumpAndSettle();
+ await tester.pumpDeviceBuilder(await goldenBuilder());
+ await tester.pumpAndSettle();
- signerStreamController.add(signer2);
- when(() => wallet.signer).thenReturn(signer2);
+ signerStreamController.add(signer2);
+ when(() => wallet.signer).thenReturn(signer2);
- await tester.pumpAndSettle();
- verify(() => wallet.nativeOrTokenBalance(any(), rpcUrl: any(named: "rpcUrl"))).called(1);
- });
- });
+ await tester.pumpAndSettle();
+ verify(() => wallet.nativeOrTokenBalance(any(), rpcUrl: any(named: "rpcUrl"))).called(1);
+ });
+ },
+ );
- zGoldenTest("""When there is a connected wallet,
- it should get the user balance and show it in a button""", goldenFileName: "token_amount_card_connected",
- (tester) async {
- await tester.runAsync(() async {
- when(() => wallet.signer).thenReturn(signer);
+ zGoldenTest(
+ """When there is a connected wallet,
+ it should get the user balance and show it in a button""",
+ goldenFileName: "token_amount_card_connected",
+ (tester) async {
+ await tester.runAsync(() async {
+ when(() => wallet.signer).thenReturn(signer);
- await tester.pumpDeviceBuilder(await goldenBuilder());
- });
- });
+ await tester.pumpDeviceBuilder(await goldenBuilder());
+ });
+ },
+ );
- zGoldenTest("""When the disabled text param is passed,
+ zGoldenTest(
+ """When the disabled text param is passed,
the card should be disabled and with the text passed
- """, goldenFileName: "token_amount_card_disabled", (tester) async {
- await tester.runAsync(() async {
- await tester.pumpDeviceBuilder(await goldenBuilder(disabledText: "This card is disabled"));
- });
- });
+ """,
+ goldenFileName: "token_amount_card_disabled",
+ (tester) async {
+ await tester.runAsync(() async {
+ await tester.pumpDeviceBuilder(await goldenBuilder(disabledText: "This card is disabled"));
+ });
+ },
+ );
zGoldenTest("When inputting something in the textfield, it should callback with the value", (tester) async {
await tester.runAsync(() async {
@@ -172,36 +192,44 @@ void main() {
});
});
- zGoldenTest("When inputting a non-number in the textfield, it should not accept",
- goldenFileName: "token_amount_card_non_number", (tester) async {
- await tester.runAsync(() async {
- await tester.pumpDeviceBuilder(await goldenBuilder());
+ zGoldenTest(
+ "When inputting a non-number in the textfield, it should not accept",
+ goldenFileName: "token_amount_card_non_number",
+ (tester) async {
+ await tester.runAsync(() async {
+ await tester.pumpDeviceBuilder(await goldenBuilder());
- await tester.enterText(find.byType(TextField), "abcdefgj");
- await tester.pumpAndSettle();
- });
- });
+ await tester.enterText(find.byType(TextField), "abcdefgj");
+ await tester.pumpAndSettle();
+ });
+ },
+ );
- zGoldenTest("When clicking in the user balance button, it should input the balance",
- goldenFileName: "token_amount_card_user_balance_click", (tester) async {
- await tester.runAsync(() async {
- when(() => wallet.tokenBalance(any(), rpcUrl: any(named: "rpcUrl")))
- .thenAnswer((_) => Future.value(43727653762.1));
+ zGoldenTest(
+ "When clicking in the user balance button, it should input the balance",
+ goldenFileName: "token_amount_card_user_balance_click",
+ (tester) async {
+ await tester.runAsync(() async {
+ when(
+ () => wallet.tokenBalance(any(), rpcUrl: any(named: "rpcUrl")),
+ ).thenAnswer((_) => Future.value(43727653762.1));
- await tester.pumpDeviceBuilder(await goldenBuilder());
+ await tester.pumpDeviceBuilder(await goldenBuilder());
- await tester.tap(find.byKey(const Key("user-balance-button")));
- await tester.pumpAndSettle();
- });
- });
+ await tester.tap(find.byKey(const Key("user-balance-button")));
+ await tester.pumpAndSettle();
+ });
+ },
+ );
zGoldenTest("When clicking in the user balance button, it should callback with the balance", (tester) async {
await tester.runAsync(() async {
const expectedValue = 43727653762.1;
double? actualValue;
- when(() => wallet.nativeOrTokenBalance(any(), rpcUrl: any(named: "rpcUrl")))
- .thenAnswer((_) => Future.value(expectedValue));
+ when(
+ () => wallet.nativeOrTokenBalance(any(), rpcUrl: any(named: "rpcUrl")),
+ ).thenAnswer((_) => Future.value(expectedValue));
await tester.pumpDeviceBuilder(await goldenBuilder(onInput: (value) => actualValue = value));
@@ -212,21 +240,26 @@ void main() {
});
});
- zGoldenTest("When clicking in the refresh button, it should get the token amount again, ignoring the cache",
- goldenFileName: "token_amount_card_refresh", (tester) async {
- await tester.runAsync(() async {
- when(() => wallet.nativeOrTokenBalance(any(), rpcUrl: any(named: "rpcUrl")))
- .thenAnswer((_) => Future.value(43727653762.1));
+ zGoldenTest(
+ "When clicking in the refresh button, it should get the token amount again, ignoring the cache",
+ goldenFileName: "token_amount_card_refresh",
+ (tester) async {
+ await tester.runAsync(() async {
+ when(
+ () => wallet.nativeOrTokenBalance(any(), rpcUrl: any(named: "rpcUrl")),
+ ).thenAnswer((_) => Future.value(43727653762.1));
- await tester.pumpDeviceBuilder(await goldenBuilder());
+ await tester.pumpDeviceBuilder(await goldenBuilder());
- when(() => wallet.nativeOrTokenBalance(any(), rpcUrl: any(named: "rpcUrl")))
- .thenAnswer((_) => Future.value(12345.43));
- await tester.tap(find.byKey(const Key("refresh-balance-button")));
+ when(
+ () => wallet.nativeOrTokenBalance(any(), rpcUrl: any(named: "rpcUrl")),
+ ).thenAnswer((_) => Future.value(12345.43));
+ await tester.tap(find.byKey(const Key("refresh-balance-button")));
- await tester.pumpAndSettle();
- });
- });
+ await tester.pumpAndSettle();
+ });
+ },
+ );
zGoldenTest(
"When updating the widget with a different token, it should update the token in the cubit and get the balance again",
@@ -242,6 +275,7 @@ void main() {
await tester.pumpDeviceBuilder(await goldenBuilder(key: key));
await tester.pumpDeviceBuilder(await goldenBuilder(key: key, token: newToken));
+ await tester.pumpAndSettle();
verify(() => wallet.nativeOrTokenBalance(newTokenAddress, rpcUrl: any(named: "rpcUrl"))).called(1);
});
@@ -266,6 +300,7 @@ void main() {
await tester.pumpDeviceBuilder(await goldenBuilder(key: key, network: oldNetwork, token: token));
await tester.pumpDeviceBuilder(await goldenBuilder(key: key, network: newNetwork, token: token));
+ await tester.pumpAndSettle();
verify(
() => wallet.nativeOrTokenBalance(token.addresses[newNetwork.chainId]!, rpcUrl: newNetwork.rpcUrl),
@@ -298,12 +333,15 @@ void main() {
await tester.pumpDeviceBuilder(
await goldenBuilder(key: key, token: oldToken, isNative: true, network: oldTokenNetwork),
);
+ await tester.pumpAndSettle();
await tester.pumpDeviceBuilder(
await goldenBuilder(key: key, token: newToken, isNative: true, network: newTokenNetwork),
);
+ await tester.pumpAndSettle();
- verify(() => wallet.nativeOrTokenBalance(EthereumConstants.zeroAddress, rpcUrl: newTokenNetwork.rpcUrl))
- .called(1);
+ verify(
+ () => wallet.nativeOrTokenBalance(EthereumConstants.zeroAddress, rpcUrl: newTokenNetwork.rpcUrl),
+ ).called(1);
});
},
);
@@ -335,6 +373,7 @@ void main() {
await tester.pumpDeviceBuilder(
await goldenBuilder(key: key, token: newToken, isNative: false, network: newTokenNetwork),
);
+ await tester.pumpAndSettle();
verify(() => wallet.nativeOrTokenBalance(newTokenAddress, rpcUrl: newTokenNetwork.rpcUrl)).called(1);
});
@@ -368,18 +407,14 @@ void main() {
},
);
- zGoldenTest(
- "When instanciating the widget, it should update the native token variable in the cubit",
- (tester) async {
- await tester.runAsync(() async {
- await tester.pumpDeviceBuilder(await goldenBuilder(isNative: true));
- await tester.pumpAndSettle();
+ zGoldenTest("When instanciating the widget, it should update the native token variable in the cubit", (tester) async {
+ await tester.runAsync(() async {
+ await tester.pumpDeviceBuilder(await goldenBuilder(isNative: true));
+ await tester.pumpAndSettle();
- verify(() => wallet.nativeOrTokenBalance(EthereumConstants.zeroAddress, rpcUrl: any(named: "rpcUrl")))
- .called(1);
- });
- },
- );
+ verify(() => wallet.nativeOrTokenBalance(EthereumConstants.zeroAddress, rpcUrl: any(named: "rpcUrl"))).called(1);
+ });
+ });
zGoldenTest(
"When the wallet emits a new signer, and the current token isNative, it should fetch the native balance",
@@ -397,10 +432,15 @@ void main() {
signerStreamController.add(SignerMock());
await tester.pumpAndSettle();
- verify(() => wallet.nativeOrTokenBalance(EthereumConstants.zeroAddress, rpcUrl: any(named: "rpcUrl")))
- .called(1);
- verifyNever(() =>
- wallet.nativeOrTokenBalance(any(that: isNot(EthereumConstants.zeroAddress)), rpcUrl: any(named: "rpcUrl")));
+ verify(
+ () => wallet.nativeOrTokenBalance(EthereumConstants.zeroAddress, rpcUrl: any(named: "rpcUrl")),
+ ).called(1);
+ verifyNever(
+ () => wallet.nativeOrTokenBalance(
+ any(that: isNot(EthereumConstants.zeroAddress)),
+ rpcUrl: any(named: "rpcUrl"),
+ ),
+ );
});
},
);
@@ -424,26 +464,31 @@ void main() {
signerStreamController.add(SignerMock());
await tester.pumpAndSettle();
- verify(() => wallet.nativeOrTokenBalance(token.addresses[network.chainId]!, rpcUrl: any(named: "rpcUrl")))
- .called(1);
+ verify(
+ () => wallet.nativeOrTokenBalance(token.addresses[network.chainId]!, rpcUrl: any(named: "rpcUrl")),
+ ).called(1);
verifyNever(() => wallet.nativeOrTokenBalance(EthereumConstants.zeroAddress, rpcUrl: any(named: "rpcUrl")));
});
},
);
- zGoldenTest("When typing an amount, it should show the USD equivalent of the amount",
- goldenFileName: "token_amount_card_usd_equivalent", (tester) async {
- await tester.runAsync(() async {
- const tokenUSDPrice = 121.85;
- const tokenAmount = 1.2;
+ zGoldenTest(
+ "When typing an amount, it should show the USD equivalent of the amount",
+ goldenFileName: "token_amount_card_usd_equivalent",
+ (tester) async {
+ await tester.runAsync(() async {
+ const tokenUSDPrice = 121.85;
+ const tokenAmount = 1.2;
- when(() => tokensRepository.getTokenPrice(any(), any()))
- .thenAnswer((_) async => TokenPriceDto(usdPrice: tokenUSDPrice, address: ""));
+ when(
+ () => tokensRepository.getTokenPrice(any(), any()),
+ ).thenAnswer((_) async => TokenPriceDto(usdPrice: tokenUSDPrice, address: ""));
- await tester.pumpDeviceBuilder(await goldenBuilder(controller: TextEditingController(text: "$tokenAmount")));
- await tester.pumpAndSettle();
+ await tester.pumpDeviceBuilder(await goldenBuilder(controller: TextEditingController(text: "$tokenAmount")));
+ await tester.pumpAndSettle();
- expect(find.text("\$${(tokenAmount * tokenUSDPrice).toStringAsFixed(2)}"), findsOneWidget);
- });
- });
+ expect(find.text("\$${(tokenAmount * tokenUSDPrice).toStringAsFixed(2)}"), findsOneWidget);
+ });
+ },
+ );
}
diff --git a/test/app/create/goldens/create_page_initial_stage.png b/test/app/create/goldens/create_page_initial_stage.png
index f77a6e2..1e06158 100644
Binary files a/test/app/create/goldens/create_page_initial_stage.png and b/test/app/create/goldens/create_page_initial_stage.png differ
diff --git a/test/app/create/goldens/create_page_select_tokens_stage_change_a_token_to_same_token_as_b.png b/test/app/create/goldens/create_page_select_tokens_stage_change_a_token_to_same_token_as_b.png
index 15d3fed..2611b4f 100644
Binary files a/test/app/create/goldens/create_page_select_tokens_stage_change_a_token_to_same_token_as_b.png and b/test/app/create/goldens/create_page_select_tokens_stage_change_a_token_to_same_token_as_b.png differ
diff --git a/test/app/create/goldens/create_page_select_tokens_stage_change_b_token_to_same_token_as_a.png b/test/app/create/goldens/create_page_select_tokens_stage_change_b_token_to_same_token_as_a.png
index 0af79fd..2ce3956 100644
Binary files a/test/app/create/goldens/create_page_select_tokens_stage_change_b_token_to_same_token_as_a.png and b/test/app/create/goldens/create_page_select_tokens_stage_change_b_token_to_same_token_as_a.png differ
diff --git a/test/app/create/goldens/create_page_select_tokens_stage_default_a_token.png b/test/app/create/goldens/create_page_select_tokens_stage_default_a_token.png
index f77a6e2..1e06158 100644
Binary files a/test/app/create/goldens/create_page_select_tokens_stage_default_a_token.png and b/test/app/create/goldens/create_page_select_tokens_stage_default_a_token.png differ
diff --git a/test/app/create/goldens/create_page_select_tokens_stage_mobile.png b/test/app/create/goldens/create_page_select_tokens_stage_mobile.png
index b411768..4a38194 100644
Binary files a/test/app/create/goldens/create_page_select_tokens_stage_mobile.png and b/test/app/create/goldens/create_page_select_tokens_stage_mobile.png differ
diff --git a/test/app/create/goldens/create_page_select_tokens_stage_pool_search_settings_add_badge.png b/test/app/create/goldens/create_page_select_tokens_stage_pool_search_settings_add_badge.png
index 4745c21..d0c9828 100644
Binary files a/test/app/create/goldens/create_page_select_tokens_stage_pool_search_settings_add_badge.png and b/test/app/create/goldens/create_page_select_tokens_stage_pool_search_settings_add_badge.png differ
diff --git a/test/app/create/goldens/create_page_select_tokens_stage_pool_search_settings_default.png b/test/app/create/goldens/create_page_select_tokens_stage_pool_search_settings_default.png
index 029ca05..243eaf4 100644
Binary files a/test/app/create/goldens/create_page_select_tokens_stage_pool_search_settings_default.png and b/test/app/create/goldens/create_page_select_tokens_stage_pool_search_settings_default.png differ
diff --git a/test/app/create/goldens/create_page_select_tokens_stage_pool_search_settings_not_default.png b/test/app/create/goldens/create_page_select_tokens_stage_pool_search_settings_not_default.png
index 4745c21..d0c9828 100644
Binary files a/test/app/create/goldens/create_page_select_tokens_stage_pool_search_settings_not_default.png and b/test/app/create/goldens/create_page_select_tokens_stage_pool_search_settings_not_default.png differ
diff --git a/test/app/create/goldens/create_page_select_tokens_stage_pool_search_settings_open.png b/test/app/create/goldens/create_page_select_tokens_stage_pool_search_settings_open.png
index 5d2032e..ed02df2 100644
Binary files a/test/app/create/goldens/create_page_select_tokens_stage_pool_search_settings_open.png and b/test/app/create/goldens/create_page_select_tokens_stage_pool_search_settings_open.png differ
diff --git a/test/app/create/goldens/create_page_select_tokens_stage_pool_search_settings_remove_badge.png b/test/app/create/goldens/create_page_select_tokens_stage_pool_search_settings_remove_badge.png
index 029ca05..243eaf4 100644
Binary files a/test/app/create/goldens/create_page_select_tokens_stage_pool_search_settings_remove_badge.png and b/test/app/create/goldens/create_page_select_tokens_stage_pool_search_settings_remove_badge.png differ
diff --git a/test/app/create/goldens/create_page_select_tokens_stage_reset_tokens_from_network.png b/test/app/create/goldens/create_page_select_tokens_stage_reset_tokens_from_network.png
index 4745c21..d0c9828 100644
Binary files a/test/app/create/goldens/create_page_select_tokens_stage_reset_tokens_from_network.png and b/test/app/create/goldens/create_page_select_tokens_stage_reset_tokens_from_network.png differ
diff --git a/test/app/create/goldens/create_page_select_tokens_stage_token_a_selected_disabled_button.png b/test/app/create/goldens/create_page_select_tokens_stage_token_a_selected_disabled_button.png
index 15d3fed..2611b4f 100644
Binary files a/test/app/create/goldens/create_page_select_tokens_stage_token_a_selected_disabled_button.png and b/test/app/create/goldens/create_page_select_tokens_stage_token_a_selected_disabled_button.png differ
diff --git a/test/app/create/goldens/create_page_select_tokens_stage_token_enabled_button.png b/test/app/create/goldens/create_page_select_tokens_stage_token_enabled_button.png
index 2ee692a..8d49097 100644
Binary files a/test/app/create/goldens/create_page_select_tokens_stage_token_enabled_button.png and b/test/app/create/goldens/create_page_select_tokens_stage_token_enabled_button.png differ
diff --git a/test/app/create/widgets/exchanges_filter_dropdown_button/exchanges_filter_dropdown_button_test.dart b/test/app/create/widgets/exchanges_filter_dropdown_button/exchanges_filter_dropdown_button_test.dart
index 073d8ae..b6d1fd4 100644
--- a/test/app/create/widgets/exchanges_filter_dropdown_button/exchanges_filter_dropdown_button_test.dart
+++ b/test/app/create/widgets/exchanges_filter_dropdown_button/exchanges_filter_dropdown_button_test.dart
@@ -39,24 +39,29 @@ void main() {
zupSingletonCache.clear();
});
- Future goldenBuilder() async => await goldenDeviceBuilder(
- const Center(child: ExchangesFilterDropdownButton()),
- );
+ Future goldenBuilder() async =>
+ await goldenDeviceBuilder(const Center(child: ExchangesFilterDropdownButton()));
- zGoldenTest("""When the widget is created, it should call the cubit to get the exchanges
- and show a preview of the exchanges count""", goldenFileName: "exchanges_filter_dropdown_button", (tester) async {
- when(() => protocolRepository.getAllSupportedProtocols()).thenAnswer((_) async => [
+ zGoldenTest(
+ """When the widget is created, it should call the cubit to get the exchanges
+ and show a preview of the exchanges count""",
+ goldenFileName: "exchanges_filter_dropdown_button",
+ (tester) async {
+ when(() => protocolRepository.getAllSupportedProtocols()).thenAnswer(
+ (_) async => [
const ProtocolDto(name: "C"),
const ProtocolDto(name: "A"),
const ProtocolDto(name: "B"),
const ProtocolDto(name: "A"),
- ]);
+ ],
+ );
- await tester.pumpDeviceBuilder(await goldenBuilder());
- await tester.pumpAndSettle();
+ await tester.pumpDeviceBuilder(await goldenBuilder());
+ await tester.pumpAndSettle();
- verify(() => protocolRepository.getAllSupportedProtocols()).called(1);
- });
+ verify(() => protocolRepository.getAllSupportedProtocols()).called(1);
+ },
+ );
zGoldenTest(
"""When the widget is created, it should call the cubit to get the exchanges.
@@ -67,12 +72,14 @@ void main() {
final blockedProtocolsIds = ["32983", "sag", "nnnn", "dale"];
when(() => cache.blockedProtocolsIds).thenReturn(blockedProtocolsIds);
- when(() => protocolRepository.getAllSupportedProtocols()).thenAnswer((_) async => [
- ProtocolDto(name: "C", rawId: blockedProtocolsIds[0]),
- ProtocolDto(name: "A", rawId: blockedProtocolsIds[1]),
- ProtocolDto(name: "B", rawId: blockedProtocolsIds[2]),
- const ProtocolDto(name: "A", rawId: "some other id not blocked"),
- ]);
+ when(() => protocolRepository.getAllSupportedProtocols()).thenAnswer(
+ (_) async => [
+ ProtocolDto(name: "C", rawId: blockedProtocolsIds[0]),
+ ProtocolDto(name: "A", rawId: blockedProtocolsIds[1]),
+ ProtocolDto(name: "B", rawId: blockedProtocolsIds[2]),
+ const ProtocolDto(name: "A", rawId: "some other id not blocked"),
+ ],
+ );
await tester.pumpDeviceBuilder(await goldenBuilder());
await tester.pumpAndSettle();
@@ -166,9 +173,9 @@ void main() {
const ProtocolDto(name: "D", rawId: "some other id not blocked"),
];
- when(() => cache.saveBlockedProtocolIds(blockedProtocolIds: any(named: "blockedProtocolIds"))).thenAnswer(
- (_) async => {},
- );
+ when(
+ () => cache.saveBlockedProtocolIds(blockedProtocolIds: any(named: "blockedProtocolIds")),
+ ).thenAnswer((_) async => {});
when(() => cache.blockedProtocolsIds).thenReturn(blockedProtocolsIds);
when(() => protocolRepository.getAllSupportedProtocols()).thenAnswer((_) async => allProtocols);
@@ -182,11 +189,9 @@ void main() {
await tester.pumpAndSettle();
verify(
- () => cache.saveBlockedProtocolIds(blockedProtocolIds: [
- blockedProtocolsIds[0],
- "some other id not blocked",
- blockedProtocolsIds[2],
- ]),
+ () => cache.saveBlockedProtocolIds(
+ blockedProtocolIds: [blockedProtocolsIds[0], "some other id not blocked", blockedProtocolsIds[2]],
+ ),
).called(1);
},
);
@@ -204,9 +209,9 @@ void main() {
const ProtocolDto(name: "D", rawId: "some other id not blocked"),
];
- when(() => cache.saveBlockedProtocolIds(blockedProtocolIds: any(named: "blockedProtocolIds"))).thenAnswer(
- (_) async => {},
- );
+ when(
+ () => cache.saveBlockedProtocolIds(blockedProtocolIds: any(named: "blockedProtocolIds")),
+ ).thenAnswer((_) async => {});
when(() => cache.blockedProtocolsIds).thenReturn(blockedProtocolsIds);
when(() => protocolRepository.getAllSupportedProtocols()).thenAnswer((_) async => allProtocols);
@@ -219,9 +224,7 @@ void main() {
await tester.tap(find.byKey(const Key("checkbox-item-0")));
await tester.pumpAndSettle();
- verify(
- () => cache.saveBlockedProtocolIds(blockedProtocolIds: ["nnnn"]),
- ).called(1);
+ verify(() => cache.saveBlockedProtocolIds(blockedProtocolIds: ["nnnn"])).called(1);
},
);
}
diff --git a/test/app/create/widgets/exchanges_filter_dropdown_button/goldens/exchanges_filter_dropdown_button.png b/test/app/create/widgets/exchanges_filter_dropdown_button/goldens/exchanges_filter_dropdown_button.png
index 5ef1e99..bbcb7ca 100644
Binary files a/test/app/create/widgets/exchanges_filter_dropdown_button/goldens/exchanges_filter_dropdown_button.png and b/test/app/create/widgets/exchanges_filter_dropdown_button/goldens/exchanges_filter_dropdown_button.png differ
diff --git a/test/app/create/widgets/exchanges_filter_dropdown_button/goldens/exchanges_filter_dropdown_button_blocked_exchanges_counter.png b/test/app/create/widgets/exchanges_filter_dropdown_button/goldens/exchanges_filter_dropdown_button_blocked_exchanges_counter.png
index 5c14597..160b349 100644
Binary files a/test/app/create/widgets/exchanges_filter_dropdown_button/goldens/exchanges_filter_dropdown_button_blocked_exchanges_counter.png and b/test/app/create/widgets/exchanges_filter_dropdown_button/goldens/exchanges_filter_dropdown_button_blocked_exchanges_counter.png differ
diff --git a/test/app/create/widgets/exchanges_filter_dropdown_button/goldens/exchanges_filter_dropdown_button_click.png b/test/app/create/widgets/exchanges_filter_dropdown_button/goldens/exchanges_filter_dropdown_button_click.png
index 6047457..2db2a1a 100644
Binary files a/test/app/create/widgets/exchanges_filter_dropdown_button/goldens/exchanges_filter_dropdown_button_click.png and b/test/app/create/widgets/exchanges_filter_dropdown_button/goldens/exchanges_filter_dropdown_button_click.png differ
diff --git a/test/app/create/widgets/exchanges_filter_dropdown_button/goldens/exchanges_filter_dropdown_button_click_with_blocked_exchanges.png b/test/app/create/widgets/exchanges_filter_dropdown_button/goldens/exchanges_filter_dropdown_button_click_with_blocked_exchanges.png
index 963cf9a..3203530 100644
Binary files a/test/app/create/widgets/exchanges_filter_dropdown_button/goldens/exchanges_filter_dropdown_button_click_with_blocked_exchanges.png and b/test/app/create/widgets/exchanges_filter_dropdown_button/goldens/exchanges_filter_dropdown_button_click_with_blocked_exchanges.png differ
diff --git a/test/app/create/widgets/exchanges_filter_dropdown_button/goldens/exchanges_filter_dropdown_button_error_click.png b/test/app/create/widgets/exchanges_filter_dropdown_button/goldens/exchanges_filter_dropdown_button_error_click.png
index cf703ac..165e054 100644
Binary files a/test/app/create/widgets/exchanges_filter_dropdown_button/goldens/exchanges_filter_dropdown_button_error_click.png and b/test/app/create/widgets/exchanges_filter_dropdown_button/goldens/exchanges_filter_dropdown_button_error_click.png differ
diff --git a/test/app/create/widgets/exchanges_filter_dropdown_button/goldens/exchanges_filter_dropdown_button_error_counter.png b/test/app/create/widgets/exchanges_filter_dropdown_button/goldens/exchanges_filter_dropdown_button_error_counter.png
index 79c6c06..d47f892 100644
Binary files a/test/app/create/widgets/exchanges_filter_dropdown_button/goldens/exchanges_filter_dropdown_button_error_counter.png and b/test/app/create/widgets/exchanges_filter_dropdown_button/goldens/exchanges_filter_dropdown_button_error_counter.png differ
diff --git a/test/app/create/widgets/goldens/create_page_setting_dropdown_min_liquidity_non_numeric.png b/test/app/create/widgets/goldens/create_page_setting_dropdown_min_liquidity_non_numeric.png
index f399b79..24c1d1a 100644
Binary files a/test/app/create/widgets/goldens/create_page_setting_dropdown_min_liquidity_non_numeric.png and b/test/app/create/widgets/goldens/create_page_setting_dropdown_min_liquidity_non_numeric.png differ
diff --git a/test/app/create/widgets/goldens/create_page_settings_dropdown.png b/test/app/create/widgets/goldens/create_page_settings_dropdown.png
index 8d2ed69..02d2439 100644
Binary files a/test/app/create/widgets/goldens/create_page_settings_dropdown.png and b/test/app/create/widgets/goldens/create_page_settings_dropdown.png differ
diff --git a/test/app/create/widgets/goldens/create_page_settings_dropdown_low_min_tvl_warning.png b/test/app/create/widgets/goldens/create_page_settings_dropdown_low_min_tvl_warning.png
index 88cf67b..d98d333 100644
Binary files a/test/app/create/widgets/goldens/create_page_settings_dropdown_low_min_tvl_warning.png and b/test/app/create/widgets/goldens/create_page_settings_dropdown_low_min_tvl_warning.png differ
diff --git a/test/app/create/widgets/goldens/create_page_settings_dropdown_min_liquidity_tooltip.png b/test/app/create/widgets/goldens/create_page_settings_dropdown_min_liquidity_tooltip.png
index 63d3ca9..6c29457 100644
Binary files a/test/app/create/widgets/goldens/create_page_settings_dropdown_min_liquidity_tooltip.png and b/test/app/create/widgets/goldens/create_page_settings_dropdown_min_liquidity_tooltip.png differ
diff --git a/test/app/create/widgets/goldens/create_page_settings_dropdown_min_liquidity_warning_field.png b/test/app/create/widgets/goldens/create_page_settings_dropdown_min_liquidity_warning_field.png
index fcc6d03..3e24f47 100644
Binary files a/test/app/create/widgets/goldens/create_page_settings_dropdown_min_liquidity_warning_field.png and b/test/app/create/widgets/goldens/create_page_settings_dropdown_min_liquidity_warning_field.png differ
diff --git a/test/app/create/widgets/goldens/create_page_settings_dropdown_pool_types_tooltip_hover.png b/test/app/create/widgets/goldens/create_page_settings_dropdown_pool_types_tooltip_hover.png
index 501f6fe..93348f0 100644
Binary files a/test/app/create/widgets/goldens/create_page_settings_dropdown_pool_types_tooltip_hover.png and b/test/app/create/widgets/goldens/create_page_settings_dropdown_pool_types_tooltip_hover.png differ
diff --git a/test/app/create/widgets/goldens/create_page_settings_dropdown_v3_pool_type_disabled.png b/test/app/create/widgets/goldens/create_page_settings_dropdown_v3_pool_type_disabled.png
index 268ed13..0cc6b41 100644
Binary files a/test/app/create/widgets/goldens/create_page_settings_dropdown_v3_pool_type_disabled.png and b/test/app/create/widgets/goldens/create_page_settings_dropdown_v3_pool_type_disabled.png differ
diff --git a/test/app/create/widgets/goldens/create_page_settings_dropdown_v3_pool_type_enable.png b/test/app/create/widgets/goldens/create_page_settings_dropdown_v3_pool_type_enable.png
index c619409..30c2dd9 100644
Binary files a/test/app/create/widgets/goldens/create_page_settings_dropdown_v3_pool_type_enable.png and b/test/app/create/widgets/goldens/create_page_settings_dropdown_v3_pool_type_enable.png differ
diff --git a/test/app/create/widgets/goldens/create_page_settings_dropdown_v4_pool_type_disabled.png b/test/app/create/widgets/goldens/create_page_settings_dropdown_v4_pool_type_disabled.png
index 303eebf..edcc71b 100644
Binary files a/test/app/create/widgets/goldens/create_page_settings_dropdown_v4_pool_type_disabled.png and b/test/app/create/widgets/goldens/create_page_settings_dropdown_v4_pool_type_disabled.png differ
diff --git a/test/app/create/widgets/goldens/create_page_settings_dropdown_v4_pool_type_enable.png b/test/app/create/widgets/goldens/create_page_settings_dropdown_v4_pool_type_enable.png
index 650fd94..370abc4 100644
Binary files a/test/app/create/widgets/goldens/create_page_settings_dropdown_v4_pool_type_enable.png and b/test/app/create/widgets/goldens/create_page_settings_dropdown_v4_pool_type_enable.png differ
diff --git a/test/app/goldens/app_layout_cookie_consent_not_null.png b/test/app/goldens/app_layout_cookie_consent_not_null.png
index bfac424..0d58aa3 100644
Binary files a/test/app/goldens/app_layout_cookie_consent_not_null.png and b/test/app/goldens/app_layout_cookie_consent_not_null.png differ
diff --git a/test/app/goldens/app_layout_cookie_consent_null.png b/test/app/goldens/app_layout_cookie_consent_null.png
index 226a708..fdf81b4 100644
Binary files a/test/app/goldens/app_layout_cookie_consent_null.png and b/test/app/goldens/app_layout_cookie_consent_null.png differ
diff --git a/test/app/goldens/app_layout_footer_desktop.png b/test/app/goldens/app_layout_footer_desktop.png
index 8144947..b263421 100644
Binary files a/test/app/goldens/app_layout_footer_desktop.png and b/test/app/goldens/app_layout_footer_desktop.png differ
diff --git a/test/app/goldens/app_layout_footer_mobile.png b/test/app/goldens/app_layout_footer_mobile.png
index 1496e6d..b8c790d 100644
Binary files a/test/app/goldens/app_layout_footer_mobile.png and b/test/app/goldens/app_layout_footer_mobile.png differ
diff --git a/test/app/goldens/app_layout_navbar.png b/test/app/goldens/app_layout_navbar.png
index 8adaf2f..b3bd968 100644
Binary files a/test/app/goldens/app_layout_navbar.png and b/test/app/goldens/app_layout_navbar.png differ
diff --git a/test/app/goldens/app_layout_top_app_bar.png b/test/app/goldens/app_layout_top_app_bar.png
index bfac424..0d58aa3 100644
Binary files a/test/app/goldens/app_layout_top_app_bar.png and b/test/app/goldens/app_layout_top_app_bar.png differ
diff --git a/test/core/enums/app_theme_mode_test.dart b/test/core/enums/app_theme_mode_test.dart
new file mode 100644
index 0000000..8f3e9ae
--- /dev/null
+++ b/test/core/enums/app_theme_mode_test.dart
@@ -0,0 +1,41 @@
+import 'package:flutter/material.dart';
+import 'package:flutter_test/flutter_test.dart';
+import 'package:zup_app/core/enums/app_theme_mode.dart';
+
+void main() {
+ test("When calling 'isLight' and the theme mode is light, it should return true", () {
+ expect(AppThemeMode.light.isLight, true);
+ });
+
+ test("When calling 'isLight' and the theme mode is not light, it should return false", () {
+ expect(AppThemeMode.dark.isLight, false);
+ });
+
+ test("When calling 'isDark' and the theme mode is dark, it should return true", () {
+ expect(AppThemeMode.dark.isDark, true);
+ });
+
+ test("When calling 'isDark' and the theme mode is not dark, it should return false", () {
+ expect(AppThemeMode.light.isDark, false);
+ });
+
+ test("When calling 'isSystem' and the theme mode is system, it should return true", () {
+ expect(AppThemeMode.system.isSystem, true);
+ });
+
+ test("When calling 'isSystem' and the theme mode is not system, it should return false", () {
+ expect(AppThemeMode.light.isSystem, false);
+ });
+
+ test("When calling 'flutterThemeMode' and the theme mode is light, it should return ThemeMode.light", () {
+ expect(AppThemeMode.light.flutterThemeMode, ThemeMode.light);
+ });
+
+ test("When calling 'flutterThemeMode' and the theme mode is dark, it should return ThemeMode.dark", () {
+ expect(AppThemeMode.dark.flutterThemeMode, ThemeMode.dark);
+ });
+
+ test("When calling 'flutterThemeMode' and the theme mode is system, it should return ThemeMode.system", () {
+ expect(AppThemeMode.system.flutterThemeMode, ThemeMode.system);
+ });
+}
diff --git a/test/core/slippage_test.dart b/test/core/slippage_test.dart
index b373578..5d84c62 100644
--- a/test/core/slippage_test.dart
+++ b/test/core/slippage_test.dart
@@ -1,35 +1,25 @@
+import 'dart:ui';
+
import 'package:flutter_test/flutter_test.dart';
import 'package:zup_app/core/slippage.dart';
import 'package:zup_ui_kit/zup_ui_kit.dart';
void main() {
- test(
- "When using `zeroPointOnePercent` method it should create the slippage object with 0.1 value",
- () {
- expect(Slippage.zeroPointOnePercent.value, 0.1);
- },
- );
+ test("When using `zeroPointOnePercent` method it should create the slippage object with 0.1 value", () {
+ expect(Slippage.zeroPointOnePercent.value, 0.1);
+ });
- test(
- "When using `halfPercent` method it should create the slippage object with 0.5 value",
- () {
- expect(Slippage.halfPercent.value, 0.5);
- },
- );
+ test("When using `halfPercent` method it should create the slippage object with 0.5 value", () {
+ expect(Slippage.halfPercent.value, 0.5);
+ });
- test(
- "When using `onePercent` method it should create the slippage object with 1 value",
- () {
- expect(Slippage.onePercent.value, 1);
- },
- );
+ test("When using `onePercent` method it should create the slippage object with 1 value", () {
+ expect(Slippage.onePercent.value, 1);
+ });
- test(
- "When using `custom` method it should create the slippage object with the passed value",
- () {
- expect(Slippage.custom(32).value, 32);
- },
- );
+ test("When using `custom` method it should create the slippage object with the passed value", () {
+ expect(Slippage.custom(32).value, 32);
+ });
test("When passing '0.1' to `fromValue` factory, it should create a 'zeroPointOnePercent' slippage object", () {
expect(Slippage.fromValue(0.1), Slippage.zeroPointOnePercent);
@@ -47,109 +37,127 @@ void main() {
expect(Slippage.fromValue(542), Slippage.custom(542));
});
- test("When passing a value greater than 10 in `riskBackgroundColor` it should return the red6 color", () {
- expect(Slippage.custom(11).riskBackgroundColor, ZupColors.red6);
- });
+ test(
+ "When passing a value greater than 10 in `riskBackgroundColor` and a light brightness, it should return the red6 color",
+ () {
+ expect(Slippage.custom(11).riskBackgroundColor(Brightness.light), ZupColors.red6);
+ },
+ );
- test("When passing a value lower than 10 in `riskBackgroundColor` it should return the orange6 color", () {
- expect(Slippage.custom(5).riskBackgroundColor, ZupColors.orange6);
+ test("When calling `riskBackgroundColor` and the brightness is dark, it should return the black3 color", () {
+ expect(Slippage.custom(11).riskBackgroundColor(Brightness.dark), ZupColors.black3);
});
- test("When passing a value lower than 1 in `riskBackgroundColor` it should return the gray6 color", () {
- expect(Slippage.custom(0.5).riskBackgroundColor, ZupColors.gray6);
- });
+ test(
+ "When passing a value lower than 10 in `riskBackgroundColor` and a light brightness. it should return the orange6 color",
+ () {
+ expect(Slippage.custom(5).riskBackgroundColor(Brightness.light), ZupColors.orange6);
+ },
+ );
- test("When passing a value greater than 10 in `riskForegroundColor` it should return the red color", () {
- expect(Slippage.custom(11).riskForegroundColor, ZupColors.red);
+ test("When passing a value lower than 1 in `riskBackgroundColor` it should return null", () {
+ expect(Slippage.custom(0.5).riskBackgroundColor(Brightness.light), null);
});
- test("When passing a value lower than 10 in `riskForegroundColor` it should return the orange color", () {
- expect(Slippage.custom(5).riskForegroundColor, ZupColors.orange);
- });
+ test(
+ """When passing a value greater than 10 in `riskForegroundColor`
+ it should return the error color from zup theme colors (Light brightness test case)""",
+ () {
+ expect(Slippage.custom(11).riskForegroundColor(Brightness.light), ZupThemeColors.error.lightColor);
+ },
+ );
- test("When passing a value lower than 1 in `riskForegroundColor` it should return the brand color", () {
- expect(Slippage.custom(0.5).riskForegroundColor, ZupColors.brand);
- });
+ test(
+ """When passing a value greater than 10 in `riskForegroundColor`
+ it should return the error color from zup theme colors (Dark brightness test case)""",
+ () {
+ expect(Slippage.custom(11).riskForegroundColor(Brightness.dark), ZupThemeColors.error.darkColor);
+ },
+ );
test(
- "When using `isCustom` method it should return true if the slippage is not `zeroPointOnePercent`, `halfPercent` or `onePercent`",
- () {
- expect(Slippage.custom(43672).isCustom, true);
- });
+ """When passing a value lower than 10 in `riskForegroundColor`
+ it should return the alert color from zup theme colors (Light brightness test case)""",
+ () {
+ expect(Slippage.custom(5).riskForegroundColor(Brightness.light), ZupThemeColors.alert.lightColor);
+ },
+ );
test(
- "When using `isCustom` method it should return false if the slippage is one of `zeroPointOnePercent`, `halfPercent` or `onePercent`",
- () {
- expect(Slippage.zeroPointOnePercent.isCustom, false, reason: "zeroPointOnePercent is not custom");
- expect(Slippage.halfPercent.isCustom, false, reason: "halfPercent is not custom");
- expect(Slippage.onePercent.isCustom, false, reason: "onePercent is not custom");
+ """When passing a value lower than 10 in `riskForegroundColor`
+ it should return the alert color from zup theme colors (Dark brightness test case)""",
+ () {
+ expect(Slippage.custom(5).riskForegroundColor(Brightness.dark), ZupThemeColors.alert.darkColor);
+ },
+ );
+
+ test("When passing a value lower than 1 in `riskForegroundColor` it should return null", () {
+ expect(Slippage.custom(0.5).riskForegroundColor(Brightness.light), null);
});
+ test(
+ "When using `isCustom` method it should return true if the slippage is not `zeroPointOnePercent`, `halfPercent` or `onePercent`",
+ () {
+ expect(Slippage.custom(43672).isCustom, true);
+ },
+ );
+
+ test(
+ "When using `isCustom` method it should return false if the slippage is one of `zeroPointOnePercent`, `halfPercent` or `onePercent`",
+ () {
+ expect(Slippage.zeroPointOnePercent.isCustom, false, reason: "zeroPointOnePercent is not custom");
+ expect(Slippage.halfPercent.isCustom, false, reason: "halfPercent is not custom");
+ expect(Slippage.onePercent.isCustom, false, reason: "onePercent is not custom");
+ },
+ );
+
test("Equatable props should use the `value` field", () {
expect(Slippage.zeroPointOnePercent.props, [Slippage.zeroPointOnePercent.value]);
});
- group("""`calculateMinTokenAmountFromSlippage` should calculate the token amount with the slippage applied.
- basicaly it's the amount - (x)%""", () {
- test("(50% test case)", () {
- expect(
- Slippage.fromValue(50).calculateMinTokenAmountFromSlippage(BigInt.from(1000000)),
- BigInt.from(500000),
- );
- });
-
- test("(10% test case)", () {
- expect(
- Slippage.fromValue(10).calculateMinTokenAmountFromSlippage(BigInt.from(1000000)),
- BigInt.from(900000),
- );
- });
-
- test("(0% test case)", () {
- expect(
- Slippage.fromValue(0).calculateMinTokenAmountFromSlippage(BigInt.from(1000000)),
- BigInt.from(1000000),
- );
- });
-
- test("(100% test case)", () {
- expect(
- Slippage.fromValue(100).calculateMinTokenAmountFromSlippage(BigInt.from(1000000)),
- BigInt.from(0),
- );
- });
- });
+ group(
+ """`calculateMinTokenAmountFromSlippage` should calculate the token amount with the slippage applied.
+ basicaly it's the amount - (x)%""",
+ () {
+ test("(50% test case)", () {
+ expect(Slippage.fromValue(50).calculateMinTokenAmountFromSlippage(BigInt.from(1000000)), BigInt.from(500000));
+ });
- group("""`calculateMaxTokenAmountFromSlippage` should calculate the token amount with the slippage applied.
- basicaly it's the amount + (x)%""", () {
- test("(50% test case)", () {
- expect(
- Slippage.fromValue(50).calculateMaxTokenAmountFromSlippage(BigInt.from(1000000)),
- BigInt.from(1500000),
- );
- });
-
- test("(10% test case)", () {
- expect(
- Slippage.fromValue(10).calculateMaxTokenAmountFromSlippage(BigInt.from(1000000)),
- BigInt.from(1100000),
- );
- });
-
- test("(0% test case)", () {
- expect(
- Slippage.fromValue(0).calculateMaxTokenAmountFromSlippage(BigInt.from(1000000)),
- BigInt.from(1000000),
- );
- });
-
- test("(100% test case)", () {
- expect(
- Slippage.fromValue(100).calculateMaxTokenAmountFromSlippage(BigInt.from(1000000)),
- BigInt.from(2000000),
- );
- });
- });
+ test("(10% test case)", () {
+ expect(Slippage.fromValue(10).calculateMinTokenAmountFromSlippage(BigInt.from(1000000)), BigInt.from(900000));
+ });
+
+ test("(0% test case)", () {
+ expect(Slippage.fromValue(0).calculateMinTokenAmountFromSlippage(BigInt.from(1000000)), BigInt.from(1000000));
+ });
+
+ test("(100% test case)", () {
+ expect(Slippage.fromValue(100).calculateMinTokenAmountFromSlippage(BigInt.from(1000000)), BigInt.from(0));
+ });
+ },
+ );
+
+ group(
+ """`calculateMaxTokenAmountFromSlippage` should calculate the token amount with the slippage applied.
+ basicaly it's the amount + (x)%""",
+ () {
+ test("(50% test case)", () {
+ expect(Slippage.fromValue(50).calculateMaxTokenAmountFromSlippage(BigInt.from(1000000)), BigInt.from(1500000));
+ });
+
+ test("(10% test case)", () {
+ expect(Slippage.fromValue(10).calculateMaxTokenAmountFromSlippage(BigInt.from(1000000)), BigInt.from(1100000));
+ });
+
+ test("(0% test case)", () {
+ expect(Slippage.fromValue(0).calculateMaxTokenAmountFromSlippage(BigInt.from(1000000)), BigInt.from(1000000));
+ });
+
+ test("(100% test case)", () {
+ expect(Slippage.fromValue(100).calculateMaxTokenAmountFromSlippage(BigInt.from(1000000)), BigInt.from(2000000));
+ });
+ },
+ );
test("`valueBasisPoints` should return the slippage value in basis points", () {
expect(Slippage.zeroPointOnePercent.valueBasisPoints, 10, reason: "zeroPointOnePercent is 10 basis points");
diff --git a/test/golden_config.dart b/test/golden_config.dart
index ad86fe6..1b99865 100644
--- a/test/golden_config.dart
+++ b/test/golden_config.dart
@@ -52,36 +52,32 @@ class GoldenConfig {
],
home: Scaffold(
backgroundColor: Colors.white,
- body: CustomScrollView(controller: scrollController, slivers: [
- SliverFillRemaining(
- hasScrollBody: false,
- child: child,
- )
- ]),
+ body: CustomScrollView(
+ controller: scrollController,
+ slivers: [SliverFillRemaining(hasScrollBody: false, child: child)],
+ ),
),
- theme: ZupTheme.lightTheme,
+ theme: AppTheme.lightTheme,
);
}
static Widget Function(Widget) localizationsWrapper({GlobalKey? scaffoldMessengerKey}) {
return (child) => MaterialApp(
- scaffoldMessengerKey: scaffoldMessengerKey,
- localizationsDelegates: const [
- S.delegate,
- GlobalMaterialLocalizations.delegate,
- GlobalWidgetsLocalizations.delegate,
- Web3KitLocalizations.delegate,
- ],
- theme: ZupTheme.lightTheme,
- home: Scaffold(
- body: CustomScrollView(controller: scrollController, slivers: [
- SliverFillRemaining(
- hasScrollBody: false,
- child: child,
- )
- ]),
- ),
- );
+ scaffoldMessengerKey: scaffoldMessengerKey,
+ localizationsDelegates: const [
+ S.delegate,
+ GlobalMaterialLocalizations.delegate,
+ GlobalWidgetsLocalizations.delegate,
+ Web3KitLocalizations.delegate,
+ ],
+ theme: AppTheme.lightTheme,
+ home: Scaffold(
+ body: CustomScrollView(
+ controller: scrollController,
+ slivers: [SliverFillRemaining(hasScrollBody: false, child: child)],
+ ),
+ ),
+ );
}
}
diff --git a/test/mocks.dart b/test/mocks.dart
index 38d52f0..657af0d 100644
--- a/test/mocks.dart
+++ b/test/mocks.dart
@@ -34,8 +34,7 @@ import 'package:zup_app/core/zup_navigator.dart';
import 'package:zup_app/gen/assets.gen.dart';
import 'package:zup_app/widgets/token_selector_modal/token_selector_modal_cubit.dart';
import 'package:zup_app/widgets/zup_cached_image.dart';
-import 'package:zup_core/zup_holder.dart';
-import 'package:zup_core/zup_singleton_cache.dart';
+import 'package:zup_core/zup_core.dart';
class $AssetsLottiesGenMock extends Mock implements $AssetsLottiesGen {}
@@ -173,15 +172,21 @@ T mockHttpImage(T Function() on, {Uint8List? overrideImage}) {
ZupCachedImage mockZupCachedImage() {
final zupCachedImage = ZupCachedImageMock();
-
- when(() => zupCachedImage.build(
- any(),
- height: any(named: "height"),
- width: any(named: "width"),
- radius: any(named: "radius"),
- errorWidget: any(named: "errorWidget"),
- placeholder: any(named: "placeholder"),
- )).thenReturn(const SizedBox(child: Text("IMAGE")));
+ final context = BuildContextMock();
+ registerFallbackValue(context);
+
+ when(
+ () => zupCachedImage.build(
+ any(),
+ any(),
+ height: any(named: "height"),
+ width: any(named: "width"),
+ radius: any(named: "radius"),
+ errorWidget: any(named: "errorWidget"),
+ placeholder: any(named: "placeholder"),
+ backgroundColor: any(named: "backgroundColor"),
+ ),
+ ).thenReturn(const SizedBox(child: Text("IMAGE")));
return zupCachedImage;
}
diff --git a/test/widgets/app_settings_dropdown_test.dart b/test/widgets/app_settings_dropdown_test.dart
index 646052c..1073428 100644
--- a/test/widgets/app_settings_dropdown_test.dart
+++ b/test/widgets/app_settings_dropdown_test.dart
@@ -3,6 +3,7 @@ import 'package:flutter_test/flutter_test.dart';
import 'package:golden_toolkit/golden_toolkit.dart';
import 'package:mocktail/mocktail.dart';
import 'package:zup_app/app/app_cubit/app_cubit.dart';
+import 'package:zup_app/core/enums/app_theme_mode.dart';
import 'package:zup_app/core/injections.dart';
import 'package:zup_app/widgets/app_settings_dropdown.dart';
@@ -20,6 +21,7 @@ void main() {
when(() => appCubit.toggleTestnetMode()).thenAnswer((_) async {});
when(() => appCubit.state).thenReturn(const AppState.standard());
when(() => appCubit.stream).thenAnswer((_) => const Stream.empty());
+ when(() => appCubit.currentThemeMode).thenAnswer((_) => AppThemeMode.light);
});
tearDown(() {
@@ -32,8 +34,9 @@ void main() {
await tester.pumpDeviceBuilder(await goldenBuilder());
});
- zGoldenTest("When clicking the testnet mode switch, it should call the app cubit to toggle the testnet mode",
- (tester) async {
+ zGoldenTest("When clicking the testnet mode switch, it should call the app cubit to toggle the testnet mode", (
+ tester,
+ ) async {
await tester.pumpDeviceBuilder(await goldenBuilder());
await tester.tap(find.byKey(const Key("testnet-mode-switch")));
@@ -42,16 +45,20 @@ void main() {
verify(() => appCubit.toggleTestnetMode()).called(1);
});
- zGoldenTest("When the app is in testnet mode, the switch should be on",
- goldenFileName: "app_settings_dropdown_testnet_mode_on", (tester) async {
- when(() => appCubit.isTestnetMode).thenReturn(true);
+ zGoldenTest(
+ "When the app is in testnet mode, the switch should be on",
+ goldenFileName: "app_settings_dropdown_testnet_mode_on",
+ (tester) async {
+ when(() => appCubit.isTestnetMode).thenReturn(true);
- await tester.pumpDeviceBuilder(await goldenBuilder());
- await tester.pumpAndSettle();
- });
+ await tester.pumpDeviceBuilder(await goldenBuilder());
+ await tester.pumpAndSettle();
+ },
+ );
- zGoldenTest("When clicking the testnet mode text, it should call the app cubit to toggle the testnet mode",
- (tester) async {
+ zGoldenTest("When clicking the testnet mode text, it should call the app cubit to toggle the testnet mode", (
+ tester,
+ ) async {
await tester.pumpDeviceBuilder(await goldenBuilder());
await tester.tap(find.byKey(const Key("testnet-mode-text")));
diff --git a/test/widgets/goldens/app_bottom_navigation_bar_initial_new_position.png b/test/widgets/goldens/app_bottom_navigation_bar_initial_new_position.png
index f13f725..8a9c51a 100644
Binary files a/test/widgets/goldens/app_bottom_navigation_bar_initial_new_position.png and b/test/widgets/goldens/app_bottom_navigation_bar_initial_new_position.png differ
diff --git a/test/widgets/goldens/app_cookies_consent_widget.png b/test/widgets/goldens/app_cookies_consent_widget.png
index 6eb4f08..a4d024d 100644
Binary files a/test/widgets/goldens/app_cookies_consent_widget.png and b/test/widgets/goldens/app_cookies_consent_widget.png differ
diff --git a/test/widgets/goldens/app_footer.png b/test/widgets/goldens/app_footer.png
index 8f4c767..4e3d9a9 100644
Binary files a/test/widgets/goldens/app_footer.png and b/test/widgets/goldens/app_footer.png differ
diff --git a/test/widgets/goldens/app_footer_mobile.png b/test/widgets/goldens/app_footer_mobile.png
index e7a8554..9eed48c 100644
Binary files a/test/widgets/goldens/app_footer_mobile.png and b/test/widgets/goldens/app_footer_mobile.png differ
diff --git a/test/widgets/goldens/app_settings_dropdown.png b/test/widgets/goldens/app_settings_dropdown.png
index 919f671..58e57b0 100644
Binary files a/test/widgets/goldens/app_settings_dropdown.png and b/test/widgets/goldens/app_settings_dropdown.png differ
diff --git a/test/widgets/goldens/app_settings_dropdown_testnet_mode_on.png b/test/widgets/goldens/app_settings_dropdown_testnet_mode_on.png
index 6d74f18..95052cd 100644
Binary files a/test/widgets/goldens/app_settings_dropdown_testnet_mode_on.png and b/test/widgets/goldens/app_settings_dropdown_testnet_mode_on.png differ
diff --git a/test/widgets/goldens/token_avatar_not_empty_logo_url.png b/test/widgets/goldens/token_avatar_not_empty_logo_url.png
index 1fdac35..8d449f9 100644
Binary files a/test/widgets/goldens/token_avatar_not_empty_logo_url.png and b/test/widgets/goldens/token_avatar_not_empty_logo_url.png differ
diff --git a/test/widgets/goldens/token_card_default.png b/test/widgets/goldens/token_card_default.png
index b978aed..344f51c 100644
Binary files a/test/widgets/goldens/token_card_default.png and b/test/widgets/goldens/token_card_default.png differ
diff --git a/test/widgets/goldens/token_card_hover.png b/test/widgets/goldens/token_card_hover.png
index b0f0e9a..e45f15d 100644
Binary files a/test/widgets/goldens/token_card_hover.png and b/test/widgets/goldens/token_card_hover.png differ
diff --git a/test/widgets/goldens/token_group_card_hover.png b/test/widgets/goldens/token_group_card_hover.png
index 0d241ad..0372fa2 100644
Binary files a/test/widgets/goldens/token_group_card_hover.png and b/test/widgets/goldens/token_group_card_hover.png differ
diff --git a/test/widgets/goldens/token_group_card_hover_info.png b/test/widgets/goldens/token_group_card_hover_info.png
index 9d24364..12a9dee 100644
Binary files a/test/widgets/goldens/token_group_card_hover_info.png and b/test/widgets/goldens/token_group_card_hover_info.png differ
diff --git a/test/widgets/goldens/yield_card_24h.png b/test/widgets/goldens/yield_card_24h.png
index 0fc6d59..6906af6 100644
Binary files a/test/widgets/goldens/yield_card_24h.png and b/test/widgets/goldens/yield_card_24h.png differ
diff --git a/test/widgets/goldens/yield_card_30d.png b/test/widgets/goldens/yield_card_30d.png
index 066d0cf..ca9d642 100644
Binary files a/test/widgets/goldens/yield_card_30d.png and b/test/widgets/goldens/yield_card_30d.png differ
diff --git a/test/widgets/goldens/yield_card_7d.png b/test/widgets/goldens/yield_card_7d.png
index c7a6a58..b08c0fb 100644
Binary files a/test/widgets/goldens/yield_card_7d.png and b/test/widgets/goldens/yield_card_7d.png differ
diff --git a/test/widgets/goldens/yield_card_90d.png b/test/widgets/goldens/yield_card_90d.png
index b6f1127..dcbb607 100644
Binary files a/test/widgets/goldens/yield_card_90d.png and b/test/widgets/goldens/yield_card_90d.png differ
diff --git a/test/widgets/goldens/yield_card_network_icon.png b/test/widgets/goldens/yield_card_network_icon.png
index 3a8d396..4231682 100644
Binary files a/test/widgets/goldens/yield_card_network_icon.png and b/test/widgets/goldens/yield_card_network_icon.png differ
diff --git a/test/widgets/goldens/yield_card_selected.png b/test/widgets/goldens/yield_card_selected.png
index af02700..72e6319 100644
Binary files a/test/widgets/goldens/yield_card_selected.png and b/test/widgets/goldens/yield_card_selected.png differ
diff --git a/test/widgets/goldens/yield_card_tooltip_protocol.png b/test/widgets/goldens/yield_card_tooltip_protocol.png
index 1df6275..db140a3 100644
Binary files a/test/widgets/goldens/yield_card_tooltip_protocol.png and b/test/widgets/goldens/yield_card_tooltip_protocol.png differ
diff --git a/test/widgets/goldens/zup_header.png b/test/widgets/goldens/zup_header.png
index 5330038..6ff862b 100644
Binary files a/test/widgets/goldens/zup_header.png and b/test/widgets/goldens/zup_header.png differ
diff --git a/test/widgets/goldens/zup_header_generic_route_event.png b/test/widgets/goldens/zup_header_generic_route_event.png
index 5330038..6ff862b 100644
Binary files a/test/widgets/goldens/zup_header_generic_route_event.png and b/test/widgets/goldens/zup_header_generic_route_event.png differ
diff --git a/test/widgets/goldens/zup_header_mobile.png b/test/widgets/goldens/zup_header_mobile.png
index 05d8804..b2d927f 100644
Binary files a/test/widgets/goldens/zup_header_mobile.png and b/test/widgets/goldens/zup_header_mobile.png differ
diff --git a/test/widgets/goldens/zup_header_new_position.png b/test/widgets/goldens/zup_header_new_position.png
index 021e87c..f6ac284 100644
Binary files a/test/widgets/goldens/zup_header_new_position.png and b/test/widgets/goldens/zup_header_new_position.png differ
diff --git a/test/widgets/goldens/zup_header_new_position_event.png b/test/widgets/goldens/zup_header_new_position_event.png
index 021e87c..f6ac284 100644
Binary files a/test/widgets/goldens/zup_header_new_position_event.png and b/test/widgets/goldens/zup_header_new_position_event.png differ
diff --git a/test/widgets/token_selector_button/goldens/token_selector_button_click.png b/test/widgets/token_selector_button/goldens/token_selector_button_click.png
index b6b7ff7..f9295f2 100644
Binary files a/test/widgets/token_selector_button/goldens/token_selector_button_click.png and b/test/widgets/token_selector_button/goldens/token_selector_button_click.png differ
diff --git a/test/widgets/token_selector_button/goldens/token_selector_button_click_mobile.png b/test/widgets/token_selector_button/goldens/token_selector_button_click_mobile.png
index b94d983..c537d0c 100644
Binary files a/test/widgets/token_selector_button/goldens/token_selector_button_click_mobile.png and b/test/widgets/token_selector_button/goldens/token_selector_button_click_mobile.png differ
diff --git a/test/widgets/token_selector_button/goldens/token_selector_button_selection.png b/test/widgets/token_selector_button/goldens/token_selector_button_selection.png
index 3e79aaa..3f635af 100644
Binary files a/test/widgets/token_selector_button/goldens/token_selector_button_selection.png and b/test/widgets/token_selector_button/goldens/token_selector_button_selection.png differ
diff --git a/test/widgets/token_selector_button/goldens/token_selector_button_selection_token_group.png b/test/widgets/token_selector_button/goldens/token_selector_button_selection_token_group.png
index 46b5b61..09f9623 100644
Binary files a/test/widgets/token_selector_button/goldens/token_selector_button_selection_token_group.png and b/test/widgets/token_selector_button/goldens/token_selector_button_selection_token_group.png differ
diff --git a/test/widgets/token_selector_modal/goldens/token_selector_modal_all_networks.png b/test/widgets/token_selector_modal/goldens/token_selector_modal_all_networks.png
index 5b1a24f..2b3d1a0 100644
Binary files a/test/widgets/token_selector_modal/goldens/token_selector_modal_all_networks.png and b/test/widgets/token_selector_modal/goldens/token_selector_modal_all_networks.png differ
diff --git a/test/widgets/token_selector_modal/goldens/token_selector_modal_error_state.png b/test/widgets/token_selector_modal/goldens/token_selector_modal_error_state.png
index fa2e10a..f030ec1 100644
Binary files a/test/widgets/token_selector_modal/goldens/token_selector_modal_error_state.png and b/test/widgets/token_selector_modal/goldens/token_selector_modal_error_state.png differ
diff --git a/test/widgets/token_selector_modal/goldens/token_selector_modal_loading.png b/test/widgets/token_selector_modal/goldens/token_selector_modal_loading.png
index 2a4c07f..4113b67 100644
Binary files a/test/widgets/token_selector_modal/goldens/token_selector_modal_loading.png and b/test/widgets/token_selector_modal/goldens/token_selector_modal_loading.png differ
diff --git a/test/widgets/token_selector_modal/goldens/token_selector_modal_search_error_state.png b/test/widgets/token_selector_modal/goldens/token_selector_modal_search_error_state.png
index de2f287..898248b 100644
Binary files a/test/widgets/token_selector_modal/goldens/token_selector_modal_search_error_state.png and b/test/widgets/token_selector_modal/goldens/token_selector_modal_search_error_state.png differ
diff --git a/test/widgets/token_selector_modal/goldens/token_selector_modal_search_loading.png b/test/widgets/token_selector_modal/goldens/token_selector_modal_search_loading.png
index 5422b5e..3a6819a 100644
Binary files a/test/widgets/token_selector_modal/goldens/token_selector_modal_search_loading.png and b/test/widgets/token_selector_modal/goldens/token_selector_modal_search_loading.png differ
diff --git a/test/widgets/token_selector_modal/goldens/token_selector_modal_search_not_found.png b/test/widgets/token_selector_modal/goldens/token_selector_modal_search_not_found.png
index 3a1e080..d8f261d 100644
Binary files a/test/widgets/token_selector_modal/goldens/token_selector_modal_search_not_found.png and b/test/widgets/token_selector_modal/goldens/token_selector_modal_search_not_found.png differ
diff --git a/test/widgets/token_selector_modal/goldens/token_selector_modal_search_success.png b/test/widgets/token_selector_modal/goldens/token_selector_modal_search_success.png
index bdd1814..7c1daac 100644
Binary files a/test/widgets/token_selector_modal/goldens/token_selector_modal_search_success.png and b/test/widgets/token_selector_modal/goldens/token_selector_modal_search_success.png differ
diff --git a/test/widgets/token_selector_modal/goldens/token_selector_modal_success.png b/test/widgets/token_selector_modal/goldens/token_selector_modal_success.png
index 38f24ce..c4aa76a 100644
Binary files a/test/widgets/token_selector_modal/goldens/token_selector_modal_success.png and b/test/widgets/token_selector_modal/goldens/token_selector_modal_success.png differ
diff --git a/test/widgets/token_selector_modal/goldens/token_selector_modal_token_groups_tooltip.png b/test/widgets/token_selector_modal/goldens/token_selector_modal_token_groups_tooltip.png
index d8ccb7f..7c8f6f3 100644
Binary files a/test/widgets/token_selector_modal/goldens/token_selector_modal_token_groups_tooltip.png and b/test/widgets/token_selector_modal/goldens/token_selector_modal_token_groups_tooltip.png differ
diff --git a/web/index.html b/web/index.html
index e8684f0..fdd14a9 100644
--- a/web/index.html
+++ b/web/index.html
@@ -20,7 +20,7 @@
Zup Protocol
-
+
@@ -45,7 +45,7 @@
@@ -61,6 +61,6 @@
inject();
-
+
diff --git a/web/loading.json b/web/loading.json
index 31eb497..abfbc97 100644
--- a/web/loading.json
+++ b/web/loading.json
@@ -1 +1 @@
-{"nm":"NetSurf-Preloader @5x","ddd":0,"h":800,"w":800,"meta":{"g":"@lottiefiles/toolkit-js 0.25.8"},"layers":[{"ty":0,"nm":"NetSurf-Preloader @1x","sr":1,"st":0,"op":61,"ip":0,"hd":false,"ddd":0,"bm":0,"hasMask":false,"ao":0,"ks":{"a":{"a":0,"k":[50,50,0],"ix":1},"s":{"a":0,"k":[800,800,100],"ix":6},"sk":{"a":0,"k":0},"p":{"a":0,"k":[400,400,0],"ix":2},"r":{"a":0,"k":0,"ix":10},"sa":{"a":0,"k":0},"o":{"a":0,"k":100,"ix":11}},"ef":[],"w":100,"h":100,"refId":"comp_0","ind":1}],"v":"5.7.4","fr":15,"op":60,"ip":0,"assets":[{"nm":"","id":"comp_0","layers":[{"ty":4,"nm":"Oval 1","sr":1,"st":0,"op":62,"ip":0,"hd":false,"ddd":0,"bm":0,"hasMask":false,"ao":0,"ks":{"a":{"a":0,"k":[0,0,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6},"sk":{"a":0,"k":0},"p":{"a":0,"k":[50.071,50.159,0],"ix":2},"r":{"a":1,"k":[{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[-240],"t":0},{"s":[1180],"t":59}],"ix":10},"sa":{"a":0,"k":0},"o":{"a":0,"k":100,"ix":11}},"ef":[],"shapes":[{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"Oval","ix":1,"cix":2,"np":2,"it":[{"ty":"el","bm":0,"hd":false,"mn":"ADBE Vector Shape - Ellipse","nm":"Ellipse Path 1","d":1,"p":{"a":0,"k":[0,0],"ix":3},"s":{"a":0,"k":[49.698,49.698],"ix":2}},{"ty":"st","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Stroke","nm":"Stroke 1","lc":2,"lj":2,"ml":1,"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":3,"ix":5},"c":{"a":0,"k":[0.451,0.3412,1,1],"ix":3}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":55,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]},{"ty":"tm","bm":0,"hd":false,"mn":"ADBE Vector Filter - Trim","nm":"Trim Paths 1","ix":2,"e":{"a":1,"k":[{"o":{"x":0.4,"y":0},"i":{"x":0.6,"y":1},"s":[8],"t":0},{"o":{"x":0.4,"y":0},"i":{"x":0.6,"y":1},"s":[30],"t":25},{"s":[8],"t":59}],"ix":2},"o":{"a":0,"k":0,"ix":3},"s":{"a":0,"k":0,"ix":1},"m":1}],"ind":1},{"ty":4,"nm":"Oval 2","sr":1,"st":0,"op":62,"ip":0,"hd":false,"ddd":0,"bm":0,"hasMask":false,"ao":0,"ks":{"a":{"a":0,"k":[0,0,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6},"sk":{"a":0,"k":0},"p":{"a":0,"k":[50.071,50.159,0],"ix":2},"r":{"a":1,"k":[{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[0],"t":0},{"s":[720],"t":59}],"ix":10},"sa":{"a":0,"k":0},"o":{"a":0,"k":100,"ix":11}},"ef":[],"shapes":[{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"Oval","ix":1,"cix":2,"np":2,"it":[{"ty":"el","bm":0,"hd":false,"mn":"ADBE Vector Shape - Ellipse","nm":"Ellipse Path 1","d":1,"p":{"a":0,"k":[0,0],"ix":3},"s":{"a":0,"k":[49.698,49.698],"ix":2}},{"ty":"st","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Stroke","nm":"Stroke 1","lc":2,"lj":2,"ml":1,"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":3,"ix":5},"c":{"a":0,"k":[0.2366,0.1599,0.6201,1],"ix":3}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":55,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]},{"ty":"tm","bm":0,"hd":false,"mn":"ADBE Vector Filter - Trim","nm":"Trim Paths 1","ix":2,"e":{"a":1,"k":[{"o":{"x":0.4,"y":0},"i":{"x":0.6,"y":1},"s":[10],"t":0},{"o":{"x":0.4,"y":0},"i":{"x":0.6,"y":1},"s":[24],"t":25},{"s":[10],"t":59}],"ix":2},"o":{"a":0,"k":0,"ix":3},"s":{"a":0,"k":0,"ix":1},"m":1}],"ind":2},{"ty":4,"nm":"Oval 3","sr":1,"st":0,"op":62,"ip":0,"hd":false,"ddd":0,"bm":0,"hasMask":false,"ao":0,"ks":{"a":{"a":0,"k":[0,0,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6},"sk":{"a":0,"k":0},"p":{"a":0,"k":[50.071,50.159,0],"ix":2},"r":{"a":1,"k":[{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[90],"t":0},{"s":[1170],"t":59}],"ix":10},"sa":{"a":0,"k":0},"o":{"a":0,"k":100,"ix":11}},"ef":[],"shapes":[{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"Oval","ix":1,"cix":2,"np":2,"it":[{"ty":"el","bm":0,"hd":false,"mn":"ADBE Vector Shape - Ellipse","nm":"Ellipse Path 1","d":1,"p":{"a":0,"k":[0,0],"ix":3},"s":{"a":0,"k":[49.698,49.698],"ix":2}},{"ty":"st","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Stroke","nm":"Stroke 1","lc":2,"lj":2,"ml":1,"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":3,"ix":5},"c":{"a":0,"k":[0.2146,0.1769,0.4031,1],"ix":3}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":55,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]},{"ty":"tm","bm":0,"hd":false,"mn":"ADBE Vector Filter - Trim","nm":"Trim Paths 1","ix":2,"e":{"a":1,"k":[{"o":{"x":0.4,"y":0},"i":{"x":0.6,"y":1},"s":[4],"t":0},{"o":{"x":0.4,"y":0},"i":{"x":0.6,"y":1},"s":[20],"t":25},{"s":[4],"t":59}],"ix":2},"o":{"a":0,"k":0,"ix":3},"s":{"a":0,"k":0,"ix":1},"m":1}],"ind":3}]}]}
\ No newline at end of file
+{"nm":"main","ddd":0,"h":512,"w":512,"meta":{"g":"@lottiefiles/toolkit-js 0.33.2"},"layers":[{"ty":3,"nm":"ÐÑÑÑо 2","sr":1,"st":0,"op":144,"ip":0,"hd":false,"ddd":0,"bm":0,"hasMask":false,"ao":0,"ks":{"a":{"a":0,"k":[0,0,0],"ix":1},"s":{"a":1,"k":[{"o":{"x":0.333,"y":0},"i":{"x":0.667,"y":1},"s":[102,98,100],"t":0},{"o":{"x":0.333,"y":0},"i":{"x":0.667,"y":1},"s":[97,103,100],"t":13},{"o":{"x":0.333,"y":0},"i":{"x":0.667,"y":1},"s":[102,98,100],"t":30},{"o":{"x":0.333,"y":0},"i":{"x":0.667,"y":1},"s":[97,103,100],"t":47},{"o":{"x":0.333,"y":0},"i":{"x":0.667,"y":1},"s":[102,98,100],"t":65},{"o":{"x":0.333,"y":0},"i":{"x":0.667,"y":1},"s":[97,103,100],"t":88},{"o":{"x":0.333,"y":0},"i":{"x":0.667,"y":1},"s":[102,98,100],"t":109},{"o":{"x":0.333,"y":0},"i":{"x":0.667,"y":1},"s":[97,103,100],"t":126},{"s":[102,98,100],"t":144}],"ix":6},"sk":{"a":0,"k":0},"p":{"a":0,"k":[255,486,0],"ix":2},"r":{"a":0,"k":0,"ix":10},"sa":{"a":0,"k":0},"o":{"a":0,"k":0,"ix":11}},"ef":[],"ind":1},{"ty":3,"nm":"ÐÑÑÑо 1","sr":1,"st":0,"op":144,"ip":0,"hd":false,"ddd":0,"bm":0,"hasMask":false,"ao":0,"ks":{"a":{"a":0,"k":[0,0,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6},"sk":{"a":0,"k":0},"p":{"a":1,"k":[{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[-36.125,-213.375,0],"t":0,"ti":[18.167,15.583,0],"to":[-20.167,1.917,0]},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[-146.125,-244.375,0],"t":36,"ti":[0.042,-0.042,0],"to":[0.057,-0.032,0]},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[-146.125,-244.375,0],"t":65,"ti":[-0.625,-22.375,0],"to":[-14.318,-12.282,0]},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[165.375,-219.875,0],"t":66,"ti":[0,-0.031,0],"to":[0.125,0.125,0]},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[165.375,-219.875,0],"t":102,"ti":[14.819,-1.272,0],"to":[-6.673,1.647,0]},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[146.023,-215.46,0],"t":109,"ti":[29.341,4.05,0],"to":[-51.523,4.422,0]},{"s":[-36.125,-213.375,0],"t":144}],"ix":2},"r":{"a":1,"k":[{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[0],"t":0},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[-9],"t":24},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[6],"t":36},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[9],"t":65},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[-9],"t":66},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[-9],"t":102},{"s":[0],"t":144}],"ix":10},"sa":{"a":0,"k":0},"o":{"a":0,"k":0,"ix":11}},"ef":[],"ind":2,"parent":1},{"ty":4,"nm":"Слой-ÑигÑÑа 21","sr":1,"st":0,"op":144,"ip":0,"hd":false,"ddd":0,"bm":0,"hasMask":false,"ao":0,"ks":{"a":{"a":0,"k":[0,0,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6},"sk":{"a":0,"k":0},"p":{"a":0,"k":[37.125,-16.625,0],"ix":2},"r":{"a":0,"k":0,"ix":10},"sa":{"a":0,"k":0},"o":{"a":1,"k":[{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[100],"t":30},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[0],"t":31},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[0],"t":94},{"s":[100],"t":95}],"ix":11}},"ef":[],"shapes":[{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":1,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[0,0]],"o":[[-10.455,5.861],[0,0]],"v":[[-78.592,35.927],[-97.415,35.927]]}],"t":0},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[0,0]],"o":[[-11.489,-2.772],[0,0]],"v":[[-70.349,19.85],[-82.513,11.343]]}],"t":24},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[0,0]],"o":[[-0.526,-0.273],[0,0]],"v":[[-56.943,16.154],[-58.34,14.889]]}],"t":30},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[0,0]],"o":[[-0.218,4.918],[0,0]],"v":[[-36.491,13.819],[-37.765,15.261]]}],"t":94},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[0,0]],"o":[[-3.791,5.646],[0,0]],"v":[[-41.035,18.796],[-48.98,20.361]]}],"t":96},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[0,0]],"o":[[-7.38,6.108],[0,0]],"v":[[-60.522,24.602],[-74.782,25.777]]}],"t":102},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[0,0]],"o":[[-10.68,5.441],[0,0]],"v":[[-77,29.773],[-95.808,29.026]]}],"t":114},{"s":[{"c":false,"i":[[0,0],[0,0]],"o":[[-10.455,5.861],[0,0]],"v":[[-78.592,35.927],[-97.415,35.927]]}],"t":131}],"ix":2}},{"ty":"st","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Stroke","nm":"undefined","lc":2,"lj":2,"ml":1,"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":5,"ix":5},"c":{"a":0,"k":[0,0,0],"ix":3}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]},{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":2,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[0,-4.608],[4.608,0],[0,4.607],[-4.607,0]],"o":[[0,4.607],[-4.607,0],[0,-4.608],[4.608,0]],"v":[[-79.661,15.203],[-88.004,23.545],[-96.346,15.203],[-88.004,6.86]]}],"t":0},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[3.22,-3.678],[3.527,2.992],[-3.22,3.678],[-2.832,-1.742]],"o":[[-3.22,3.678],[-2.676,-2.27],[3.22,-3.678],[2.78,1.71]],"v":[[-57.771,1.156],[-68.644,4.043],[-66.553,-7.156],[-56.688,-10.063]]}],"t":24},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[1.241,-3.904],[0.506,0.544],[-1.862,3.649],[-1.149,-0.479]],"o":[[-1.337,4.205],[-1.062,0.12],[1.417,-2.778],[0.863,0.378]],"v":[[-52.045,-3.236],[-54.174,3.993],[-52.679,-4.097],[-49.989,-10.182]]}],"t":30},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[-0.385,-3.333],[0.313,-0.347],[0.385,3.326],[-0.317,0.349]],"o":[[0.386,3.341],[-0.315,0.365],[-0.382,-3.303],[0.315,-0.351]],"v":[[-38.363,-1.393],[-38.206,5.111],[-39.397,-0.143],[-39.595,-6.782]]}],"t":94},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[-0.489,-3.756],[1.945,-0.383],[0.489,3.756],[-1.945,0.383]],"o":[[0.489,3.756],[-1.945,0.383],[-0.489,-3.756],[1.945,-0.383]],"v":[[-43.874,1.694],[-46.314,8.971],[-50.38,3.051],[-48.119,-4.421]]}],"t":96},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[-0.425,-4.288],[3.49,-0.288],[0.425,4.288],[-3.491,0.288]],"o":[[0.425,4.288],[-3.49,0.288],[-0.425,-4.288],[3.491,-0.288]],"v":[[-63.545,5.028],[-68.723,13.083],[-75.232,6.076],[-70.349,-2.214]]}],"t":102},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[0.183,-4.604],[4.604,0.183],[-0.183,4.604],[-4.604,-0.183]],"o":[[-0.183,4.604],[-4.604,-0.183],[0.183,-4.604],[4.604,0.183]],"v":[[-77.576,8.608],[-85.718,16.421],[-93.006,8.086],[-85.208,-0.017]]}],"t":114},{"s":[{"c":true,"i":[[0,-4.608],[4.608,0],[0,4.607],[-4.607,0]],"o":[[0,4.607],[-4.607,0],[0,-4.608],[4.608,0]],"v":[[-79.661,15.203],[-88.004,23.545],[-96.346,15.203],[-88.004,6.86]]}],"t":131}],"ix":2}},{"ty":"fl","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Fill","nm":"undefined","c":{"a":0,"k":[0,0,0],"ix":4},"r":1,"o":{"a":0,"k":100,"ix":5}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]},{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":3,"cix":2,"np":3,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[1.024,9.359],[11.781,-2.561],[-4.162,-8.063],[-6.659,1.776]],"o":[[-0.658,-6.015],[-11.781,2.561],[2.945,5.704],[6.659,-1.776]],"v":[[-72.727,12.768],[-90.654,0.08],[-101.396,21.807],[-84.904,29.378]]}],"t":0},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[-4.4,8.783],[5.357,2.877],[2.511,-4.968],[-5.052,-3.032]],"o":[[2.894,-5.778],[-8.686,-4.665],[-3.122,6.176],[5.845,3.508]],"v":[[-51.317,1.53],[-55.25,-16.586],[-73.567,-7.49],[-70.234,10.123]]}],"t":24},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[-2.931,7.692],[0.997,0.412],[1.677,-4.352],[-1.349,-0.496]],"o":[[1.928,-5.06],[-1.6,-0.662],[-2.084,5.411],[1.371,0.504]],"v":[[-52.19,-4.499],[-47.925,-15.548],[-52.962,-4.397],[-55.723,8.41]]}],"t":30},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[0.832,6.83],[0.589,-2.706],[-0.812,-5.602],[-0.377,1.282]],"o":[[-0.529,-4.339],[-0.588,2.7],[0.626,4.374],[0.327,-1.114]],"v":[[-38.165,-3.195],[-40.373,-12.465],[-39.189,4.871],[-37.452,9.693]]}],"t":94},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[1.256,7.709],[4.7,-3.066],[-1.736,-6.399],[-2.757,1.452]],"o":[[-0.797,-4.892],[-4.7,3.067],[1.338,4.932],[2.399,-1.263]],"v":[[-41.801,-0.319],[-49.631,-10.877],[-51.811,8.854],[-44.375,14.187]]}],"t":96},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[1.32,8.822],[8.688,-3.119],[-2.325,-7.374],[-5.055,1.437]],"o":[[-0.838,-5.598],[-8.688,3.119],[1.792,5.684],[4.399,-1.25]],"v":[[-59.636,2.905],[-72.271,-9.636],[-78.448,12.538],[-65.899,19.133]]}],"t":102},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[0.205,9.533],[11.873,-2.091],[-1.765,-8.139],[-6.843,0.816]],"o":[[-0.13,-6.05],[-11.873,2.091],[1.36,6.274],[5.955,-0.71]],"v":[[-72.111,6.904],[-86.439,-8.151],[-98.313,14.484],[-83.074,23.227]]}],"t":114},{"s":[{"c":true,"i":[[1.024,9.359],[11.781,-2.561],[-4.162,-8.063],[-6.659,1.776]],"o":[[-0.658,-6.015],[-11.781,2.561],[2.945,5.704],[6.659,-1.776]],"v":[[-72.727,12.768],[-90.654,0.08],[-101.396,21.807],[-84.904,29.378]]}],"t":131}],"ix":2}},{"ty":"st","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Stroke","nm":"undefined","lc":2,"lj":2,"ml":1,"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":5,"ix":5},"c":{"a":0,"k":[0,0,0],"ix":3}},{"ty":"fl","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Fill","nm":"undefined","c":{"a":0,"k":[1,1,1],"ix":4},"r":1,"o":{"a":0,"k":100,"ix":5}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]}],"ind":3,"parent":2},{"ty":4,"nm":"Слой-ÑигÑÑа 20","sr":1,"st":0,"op":144,"ip":0,"hd":false,"ddd":0,"bm":0,"hasMask":false,"ao":0,"ks":{"a":{"a":0,"k":[0,0,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6},"sk":{"a":0,"k":0},"p":{"a":0,"k":[37.125,-16.625,0],"ix":2},"r":{"a":0,"k":0,"ix":10},"sa":{"a":0,"k":0},"o":{"a":1,"k":[{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[100],"t":48},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[0],"t":49},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[0],"t":106},{"s":[100],"t":107}],"ix":11}},"ef":[],"shapes":[{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":1,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[0,0]],"o":[[-10.455,5.861],[0,0]],"v":[[28.225,38.532],[9.402,38.532]]}],"t":0},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[0,0]],"o":[[-11.931,0.621],[0,0]],"v":[[16.822,50.967],[1.395,42.76]]}],"t":24},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[0,0]],"o":[[-9.218,1.145],[0,0]],"v":[[5.141,35.558],[-9.699,28.608]]}],"t":36},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[0,0]],"o":[[-8.168,1.014],[0,0]],"v":[[-13.975,25.6],[-27.124,19.441]]}],"t":42},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[0,0]],"o":[[-0.39,-0.32],[0,0]],"v":[[-35.846,12.327],[-36.694,11.888]]}],"t":48},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[0,0]],"o":[[0.533,3.663],[0,0]],"v":[[-23.77,13.798],[-23.669,16.427]]}],"t":106},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[0,0]],"o":[[-3.088,4.15],[0,0]],"v":[[-1.199,16.132],[-9.24,19.053]]}],"t":114},{"s":[{"c":false,"i":[[0,0],[0,0]],"o":[[-10.455,5.861],[0,0]],"v":[[28.225,38.532],[9.402,38.532]]}],"t":131}],"ix":2}},{"ty":"st","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Stroke","nm":"undefined","lc":2,"lj":2,"ml":1,"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":5,"ix":5},"c":{"a":0,"k":[0,0,0],"ix":3}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]},{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":2,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[0,-4.607],[4.607,0],[0,4.607],[-4.608,0]],"o":[[0,4.607],[-4.608,0],[0,-4.607],[4.607,0]],"v":[[27.156,17.808],[18.813,26.15],[10.47,17.808],[18.813,9.465]]}],"t":0},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[2.035,-4.117],[4.117,2.035],[-2.035,4.117],[-4.117,-2.035]],"o":[[-2.035,4.117],[-4.117,-2.035],[2.035,-4.117],[4.117,2.035]],"v":[[25.863,31.409],[14.724,35.18],[10.953,24.041],[22.092,20.27]]}],"t":24},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[1.901,-4.197],[4.541,0.783],[-1.934,5.522],[-4.54,-0.783]],"o":[[-1.928,4.257],[-4.541,-0.783],[1.523,-4.349],[4.54,0.783]],"v":[[15.024,15.424],[4.717,23.599],[-0.093,11.366],[10.897,2.703]]}],"t":36},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[1.684,-3.719],[4.023,0.694],[-1.713,4.892],[-4.023,-0.694]],"o":[[-1.708,3.772],[-4.023,-0.694],[1.349,-3.853],[4.023,0.694]],"v":[[-5.218,7.76],[-14.351,15.004],[-18.613,4.165],[-8.875,-3.511]]}],"t":42},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[1.307,-2.886],[0.623,0.068],[-1.33,3.797],[-0.55,-0.1]],"o":[[-1.326,2.927],[-0.31,-0.227],[1.047,-2.99],[0.497,0.114]],"v":[[-31.933,-0.933],[-34.032,5.417],[-32.214,-1.402],[-29.783,-8.951]]}],"t":48},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[-0.664,-3.528],[0.094,-0.099],[0.664,3.528],[-0.094,0.099]],"o":[[0.664,3.528],[-0.094,0.099],[-0.664,-3.528],[0.094,-0.099]],"v":[[-26.42,0.41],[-25.389,6.977],[-26.809,0.7],[-27.816,-5.833]]}],"t":106},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[-0.155,-4.028],[2.329,-0.089],[0.155,4.028],[-2.329,0.089]],"o":[[0.155,4.028],[-2.329,0.089],[-0.155,-4.028],[2.329,-0.089]],"v":[[-4.509,0.82],[-8.446,8.276],[-13.688,1.06],[-9.379,-6.353]]}],"t":114},{"s":[{"c":true,"i":[[0,-4.607],[4.607,0],[0,4.607],[-4.608,0]],"o":[[0,4.607],[-4.608,0],[0,-4.607],[4.607,0]],"v":[[27.156,17.808],[18.813,26.15],[10.47,17.808],[18.813,9.465]]}],"t":131}],"ix":2}},{"ty":"fl","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Fill","nm":"undefined","c":{"a":0,"k":[0,0,0],"ix":4},"r":1,"o":{"a":0,"k":100,"ix":5}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]},{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":3,"cix":2,"np":3,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[1.024,9.359],[11.781,-2.561],[-4.162,-8.063],[-6.659,1.776]],"o":[[-0.658,-6.015],[-11.781,2.561],[2.945,5.704],[6.659,-1.776]],"v":[[34.09,15.373],[16.163,2.685],[5.421,24.411],[21.913,31.983]]}],"t":0},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[-4.778,7.687],[7.836,3.335],[3.479,-8.211],[-7.069,-3.288]],"o":[[3.07,-4.939],[-7.836,-3.335],[-3.479,8.211],[8.637,4.017]],"v":[[32.712,33.161],[25.143,13.641],[5.512,21.799],[12.34,41.378]]}],"t":24},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[-2.422,8.965],[9.302,2.207],[-1.605,-10.984],[-6.878,0.438]],"o":[[1.578,-5.841],[-10.051,-2.385],[0.928,6.352],[5.846,-0.373]],"v":[[22.818,15.256],[13.779,-2.585],[-6.145,18.907],[8.918,29.788]]}],"t":36},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[-2.146,7.943],[8.242,1.956],[-1.422,-9.733],[-6.094,0.388]],"o":[[1.398,-5.176],[-8.906,-2.113],[0.822,5.628],[5.18,-0.33]],"v":[[1.688,7.611],[-6.321,-8.196],[-23.975,10.846],[-10.628,20.487]]}],"t":42},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[-1.665,6.164],[0.433,0.282],[1.744,-7.217],[-0.48,-0.104]],"o":[[1.085,-4.016],[-0.509,-0.075],[-1.037,4.291],[0.657,0.286]],"v":[[-31.16,-3.233],[-28.438,-12.612],[-35.027,3.506],[-34.961,9.138]]}],"t":48},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[1.369,7.144],[-0.112,-1.67],[-1.635,-8.023],[0.12,1.502]],"o":[[-0.88,-4.592],[0.158,2.352],[0.882,4.33],[-0.12,-1.502]],"v":[[-26.658,-1.561],[-28.823,-10.935],[-25.905,6.105],[-24.485,11.376]]}],"t":106},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[0.832,8.161],[4.117,-1.865],[-2.961,-9.186],[-3.306,1.682]],"o":[[-0.535,-5.245],[-5.799,2.627],[1.598,4.957],[3.306,-1.682]],"v":[[-1.845,-1.402],[-10.573,-12.186],[-15.798,7.208],[-6.683,13.314]]}],"t":114},{"s":[{"c":true,"i":[[1.024,9.359],[11.781,-2.561],[-4.162,-8.063],[-6.659,1.776]],"o":[[-0.658,-6.015],[-11.781,2.561],[2.945,5.704],[6.659,-1.776]],"v":[[34.09,15.373],[16.163,2.685],[5.421,24.411],[21.913,31.983]]}],"t":131}],"ix":2}},{"ty":"st","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Stroke","nm":"undefined","lc":2,"lj":2,"ml":1,"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":5,"ix":5},"c":{"a":0,"k":[0,0,0],"ix":3}},{"ty":"fl","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Fill","nm":"undefined","c":{"a":0,"k":[1,1,1],"ix":4},"r":1,"o":{"a":0,"k":100,"ix":5}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]}],"ind":4,"parent":2},{"ty":4,"nm":"Слой-ÑигÑÑа 19","sr":1,"st":0,"op":144,"ip":0,"hd":false,"ddd":0,"bm":0,"hasMask":false,"ao":0,"ks":{"a":{"a":0,"k":[0,0,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6},"sk":{"a":0,"k":0},"p":{"a":0,"k":[37.125,-16.625,0],"ix":2},"r":{"a":0,"k":0,"ix":10},"sa":{"a":0,"k":0},"o":{"a":1,"k":[{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[100],"t":41},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[0],"t":42},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[0],"t":101},{"s":[100],"t":102}],"ix":11}},"ef":[],"shapes":[{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":1,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[-11.56,9.866],[0,0],[-5.024,14.318]],"o":[[0,0],[0,0],[1.642,2.652],[0,0]],"v":[[-50.994,26.15],[-35.588,31.983],[-35.563,31.983],[-19.652,25.416]]}],"t":0},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[-6.613,6.065],[0,0],[-12.34,2.973]],"o":[[0,0],[0,0],[1.387,5.101],[0,0]],"v":[[-49.821,24.551],[-40.141,26.931],[-40.116,26.931],[-21.143,35.923]]}],"t":24},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[-4.14,4.165],[0,0],[-5.676,8.957]],"o":[[0,0],[0,0],[1.642,2.652],[0,0]],"v":[[-40.988,36.589],[-34.759,38.812],[-34.734,38.812],[-21.784,37.524]]}],"t":36},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[-0.402,-0.156],[0,0],[-0.23,-0.159]],"o":[[0,0],[0,0],[0.34,0.292],[0,0]],"v":[[-40.017,35.928],[-39.113,36.496],[-38.924,36.533],[-38.461,36.906]]}],"t":42},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[-1.254,2.895],[0,0],[-0.378,0.274]],"o":[[0,0],[0,0],[0.058,0.069],[0,0]],"v":[[-37.775,19.106],[-35.73,18.435],[-35.709,18.435],[-35.081,17.818]]}],"t":102},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[-6.017,10.838],[0,0],[-0.9,6.594]],"o":[[0,0],[0,0],[1.081,1.507],[0,0]],"v":[[-50.485,15.223],[-39.069,16.511],[-39.048,16.511],[-31.064,14.401]]}],"t":108},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[-7.605,13.486],[0,0],[-1.074,8.701]],"o":[[0,0],[0,0],[1.423,1.987],[0,0]],"v":[[-54.612,20.569],[-39.474,19.433],[-39.452,19.433],[-28.967,19.724]]}],"t":114},{"s":[{"c":false,"i":[[0,0],[-11.56,9.866],[0,0],[-5.024,14.318]],"o":[[0,0],[0,0],[1.642,2.652],[0,0]],"v":[[-50.994,26.15],[-35.588,31.983],[-35.563,31.983],[-19.652,25.416]]}],"t":131}],"ix":2}},{"ty":"st","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Stroke","nm":"undefined","lc":2,"lj":2,"ml":1,"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":5,"ix":5},"c":{"a":0,"k":[0,0,0],"ix":3}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]},{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":2,"cix":2,"np":3,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[0,0],[0,0],[0,0]],"o":[[-6.068,1.507],[0,0],[0,0]],"v":[[-31.692,12.939],[-42.57,13.03],[-37.09,17.808]]}],"t":0},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[0,0],[0,0],[0,0]],"o":[[-4.54,-0.951],[0,0],[0,0]],"v":[[-29.017,15.416],[-38.199,11.99],[-37.09,17.808]]}],"t":24},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[0,0],[0,0],[0,0]],"o":[[-3.915,-1.11],[0,0],[0,0]],"v":[[-27.895,16.134],[-36.857,13.138],[-33.567,19.275]]}],"t":36},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[0,0],[0,0],[0,0]],"o":[[-0.762,-0.34],[0,0],[0,0]],"v":[[-36.397,12.798],[-36.994,12.274],[-37.415,17.353]]}],"t":42},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[0,0],[0,0],[0,0]],"o":[[-0.798,0.837],[0,0],[0,0]],"v":[[-36.656,3.08],[-38.917,4.107],[-36.87,7.587]]}],"t":102},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[0,0],[0,0],[0,0]],"o":[[-4.143,1.056],[0,0],[0,0]],"v":[[-37.18,1.365],[-44.673,2.464],[-40.331,5.833]]}],"t":108},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[0,0],[0,0],[0,0]],"o":[[-5.259,1.129],[0,0],[0,0]],"v":[[-36.647,4.356],[-45.884,5.48],[-40.776,8.812]]}],"t":114},{"s":[{"c":true,"i":[[0,0],[0,0],[0,0]],"o":[[-6.068,1.507],[0,0],[0,0]],"v":[[-31.692,12.939],[-42.57,13.03],[-37.09,17.808]]}],"t":131}],"ix":2}},{"ty":"st","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Stroke","nm":"undefined","lc":2,"lj":2,"ml":1,"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":5,"ix":5},"c":{"a":0,"k":[0.5961,0.1922,0.3373],"ix":3}},{"ty":"fl","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Fill","nm":"undefined","c":{"a":0,"k":[0.5922,0.2039,0.3333],"ix":4},"r":1,"o":{"a":0,"k":100,"ix":5}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]},{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":3,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[-1.529,-3.728]],"o":[[0,0],[0,0]],"v":[[-37.09,17.808],[-35.563,31.983]]}],"t":0},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[0.512,-3.228]],"o":[[0,0],[0,0]],"v":[[-37.09,17.808],[-40.116,26.931]]}],"t":24},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[-1.499,-9.089]],"o":[[0,0],[0,0]],"v":[[-33.567,19.275],[-35.133,38.418]]}],"t":36},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[-1.499,-9.089]],"o":[[0,0],[0,0]],"v":[[-37.415,17.353],[-38.981,36.496]]}],"t":42},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[0.274,-3.694]],"o":[[0,0],[0,0]],"v":[[-36.87,7.587],[-35.709,18.435]]}],"t":102},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[-0.925,-3.018]],"o":[[0,0],[0,0]],"v":[[-40.331,5.833],[-39.048,16.511]]}],"t":108},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[-1.325,-2.793]],"o":[[0,0],[0,0]],"v":[[-40.776,8.812],[-39.452,19.433]]}],"t":114},{"s":[{"c":false,"i":[[0,0],[-1.529,-3.728]],"o":[[0,0],[0,0]],"v":[[-37.09,17.808],[-35.563,31.983]]}],"t":131}],"ix":2}},{"ty":"st","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Stroke","nm":"undefined","lc":2,"lj":2,"ml":1,"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":5,"ix":5},"c":{"a":0,"k":[0,0,0],"ix":3}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]}],"ind":5,"parent":2},{"ty":4,"nm":"Слой-ÑигÑÑа 18","sr":1,"st":0,"op":144,"ip":0,"hd":false,"ddd":0,"bm":0,"hasMask":false,"ao":0,"ks":{"a":{"a":0,"k":[0,0,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6},"sk":{"a":0,"k":0},"p":{"a":0,"k":[256,256,0],"ix":2},"r":{"a":0,"k":0,"ix":10},"sa":{"a":0,"k":0},"o":{"a":0,"k":100,"ix":11}},"ef":[],"shapes":[{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":1,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":0,"k":{"c":false,"i":[[0,0],[0,0]],"o":[[0,0],[0,0]],"v":[[12.826,-171.007],[36.882,-157.859]]},"ix":2}},{"ty":"st","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Stroke","nm":"undefined","lc":2,"lj":2,"ml":1,"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":13,"ix":5},"c":{"a":1,"k":[{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":0},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":6},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":12},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":18},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":24},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[0.3176,0.2392,0.7333],"t":30},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":36},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":42},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[1,1,1],"t":48},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":54},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":60},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[0.3176,0.2392,0.7333],"t":66},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":72},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":78},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[1,1,1],"t":84},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":90},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":96},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[0.3176,0.2392,0.7333],"t":102},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":108},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":114},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[1,1,1],"t":120},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":126},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":132},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[0.3176,0.2392,0.7333],"t":138},{"s":[0.3176,0.2392,0.7333],"t":144}],"ix":3}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]},{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":2,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":0,"k":{"c":false,"i":[[0,0],[0,0]],"o":[[0,0],[0,0]],"v":[[12.622,-190.48],[36.397,-204.128]]},"ix":2}},{"ty":"st","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Stroke","nm":"undefined","lc":2,"lj":2,"ml":1,"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":13,"ix":5},"c":{"a":1,"k":[{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":0},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[1,1,1],"t":6},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":12},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":18},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[0.3176,0.2392,0.7333],"t":24},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":30},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":36},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[1,1,1],"t":42},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":48},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":54},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[0.3176,0.2392,0.7333],"t":60},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":66},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":72},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[1,1,1],"t":78},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":84},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":90},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[0.3176,0.2392,0.7333],"t":96},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":102},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":108},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[1,1,1],"t":114},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":120},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":126},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[0.3176,0.2392,0.7333],"t":132},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":138},{"s":[0.3176,0.2392,0.7333],"t":144}],"ix":3}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]},{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":3,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":0,"k":{"c":false,"i":[[0,0],[0,0]],"o":[[0,0],[0,0]],"v":[[-4.655,-200.483],[-4.655,-227.898]]},"ix":2}},{"ty":"st","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Stroke","nm":"undefined","lc":2,"lj":2,"ml":1,"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":13,"ix":5},"c":{"a":1,"k":[{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[1,1,1],"t":0},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":6},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":12},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[0.3176,0.2392,0.7333],"t":18},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":24},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":30},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[1,1,1],"t":36},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":42},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":48},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[0.3176,0.2392,0.7333],"t":54},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":60},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":66},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[1,1,1],"t":72},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":78},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":84},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[0.3176,0.2392,0.7333],"t":90},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":96},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":102},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[1,1,1],"t":108},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":114},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":120},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[0.3176,0.2392,0.7333],"t":126},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":132},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":138},{"s":[1,1,1],"t":144}],"ix":3}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]},{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":4,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":0,"k":{"c":false,"i":[[0,0],[0,0]],"o":[[0,0],[0,0]],"v":[[-46.192,-203.264],[-22.136,-190.116]]},"ix":2}},{"ty":"st","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Stroke","nm":"undefined","lc":2,"lj":2,"ml":1,"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":13,"ix":5},"c":{"a":1,"k":[{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":0},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":6},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[0.3176,0.2392,0.7333],"t":12},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":18},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":24},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[1,1,1],"t":30},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":36},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":42},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[0.3176,0.2392,0.7333],"t":48},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":54},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":60},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[1,1,1],"t":66},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":72},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":78},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[0.3176,0.2392,0.7333],"t":84},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":90},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":96},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[1,1,1],"t":102},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":108},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":114},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[0.3176,0.2392,0.7333],"t":120},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":126},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":132},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[1,1,1],"t":138},{"s":[0.3176,0.2392,0.7333],"t":144}],"ix":3}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]},{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":5,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":0,"k":{"c":false,"i":[[0,0],[0,0]],"o":[[0,0],[0,0]],"v":[[-45.708,-156.994],[-21.933,-170.643]]},"ix":2}},{"ty":"st","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Stroke","nm":"undefined","lc":2,"lj":2,"ml":1,"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":13,"ix":5},"c":{"a":1,"k":[{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":0},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[0.3176,0.2392,0.7333],"t":6},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":12},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":18},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[1,1,1],"t":24},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":30},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":36},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[0.3176,0.2392,0.7333],"t":42},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":48},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":54},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[1,1,1],"t":60},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":66},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":72},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[0.3176,0.2392,0.7333],"t":78},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":84},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":90},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[1,1,1],"t":96},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":102},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":108},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[0.3176,0.2392,0.7333],"t":114},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":120},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":126},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[1,1,1],"t":132},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":138},{"s":[0.3176,0.2392,0.7333],"t":144}],"ix":3}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]},{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":6,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":0,"k":{"c":false,"i":[[0,0],[0,0]],"o":[[0,0],[0,0]],"v":[[-4.655,-133.225],[-4.655,-160.639]]},"ix":2}},{"ty":"st","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Stroke","nm":"undefined","lc":2,"lj":2,"ml":1,"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":13,"ix":5},"c":{"a":1,"k":[{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[0.3176,0.2392,0.7333],"t":0},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":6},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":12},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[1,1,1],"t":18},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":24},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":30},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[0.3176,0.2392,0.7333],"t":36},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":42},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":48},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[1,1,1],"t":54},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":60},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":66},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[0.3176,0.2392,0.7333],"t":72},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":78},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":84},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[1,1,1],"t":90},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":96},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":102},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[0.3176,0.2392,0.7333],"t":108},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":114},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":120},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[1,1,1],"t":126},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":132},{"o":{"x":0.167,"y":0.001},"i":{"x":0.833,"y":0.999},"s":[0.3176,0.2392,0.7333],"t":138},{"s":[0.3176,0.2392,0.7333],"t":144}],"ix":3}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]}],"ind":6},{"ty":4,"nm":"Слой-ÑигÑÑа 17","sr":1,"st":0,"op":144,"ip":0,"hd":false,"ddd":0,"bm":0,"hasMask":false,"ao":0,"ks":{"a":{"a":0,"k":[0,0,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6},"sk":{"a":0,"k":0},"p":{"a":0,"k":[37.125,-16.625,0],"ix":2},"r":{"a":0,"k":0,"ix":10},"sa":{"a":0,"k":0},"o":{"a":0,"k":100,"ix":11}},"ef":[],"shapes":[{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":1,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[-17.414,4.386]],"o":[[0,0],[0,0]],"v":[[-49.134,95.947],[-16.528,95.947]]}],"t":0},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[-11.783,-0.108]],"o":[[0,0],[0,0]],"v":[[-66.913,77.125],[-47.257,89.256]]}],"t":24},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[-0.372,-0.295]],"o":[[0,0],[0,0]],"v":[[-46.706,85.211],[-45.783,85.473]]}],"t":32},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[-0.372,-0.295]],"o":[[0,0],[0,0]],"v":[[-46.706,85.211],[-45.783,85.473]]}],"t":107},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[-0.308,0.009]],"o":[[0,0],[0,0]],"v":[[-40.918,79.526],[-40.278,78.981]]}],"t":108},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[-11.607,6.192]],"o":[[0,0],[0,0]],"v":[[-49.29,94.928],[-18.348,91.257]]}],"t":119},{"s":[{"c":false,"i":[[0,0],[-17.414,4.386]],"o":[[0,0],[0,0]],"v":[[-49.134,95.947],[-16.528,95.947]]}],"t":136}],"ix":2}},{"ty":"st","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Stroke","nm":"undefined","lc":2,"lj":2,"ml":1,"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":5,"ix":5},"c":{"a":0,"k":[0.8157,0.8431,0.9137],"ix":3}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":1,"k":[{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[100],"t":31},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[0],"t":32},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[0],"t":107},{"s":[100],"t":108}],"ix":7}}]},{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":2,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[-40.755,14.214]],"o":[[0,0],[0,0]],"v":[[-68.183,80.194],[4.91,80.194]]}],"t":0},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[-28.529,2.733]],"o":[[0,0],[0,0]],"v":[[-69.372,62.076],[-29.79,82.645]]}],"t":24},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[-14.306,0.721]],"o":[[0,0],[0,0]],"v":[[-49.566,75.857],[-29.333,78.162]]}],"t":32},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[-0.192,0.006]],"o":[[0,0],[0,0]],"v":[[-32.924,78.13],[-32.798,78.086]]}],"t":36},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[-0.192,0.006]],"o":[[0,0],[0,0]],"v":[[-32.924,78.13],[-32.798,78.086]]}],"t":102},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[-0.549,0.126]],"o":[[0,0],[0,0]],"v":[[-49.281,66.399],[-47.742,66.347]]}],"t":103},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[-6.764,7.133]],"o":[[0,0],[0,0]],"v":[[-57.963,75.524],[-33.128,63.941]]}],"t":108},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[-19.137,18.227]],"o":[[0,0],[0,0]],"v":[[-68.183,80.194],[-4.004,70.821]]}],"t":119},{"s":[{"c":false,"i":[[0,0],[-40.755,14.214]],"o":[[0,0],[0,0]],"v":[[-68.183,80.194],[4.91,80.194]]}],"t":136}],"ix":2}},{"ty":"st","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Stroke","nm":"undefined","lc":2,"lj":2,"ml":1,"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":5,"ix":5},"c":{"a":0,"k":[0.8157,0.8431,0.9137],"ix":3}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":1,"k":[{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[100],"t":35},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[0],"t":36},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[0],"t":102},{"s":[100],"t":103}],"ix":7}}]}],"ind":7,"parent":2},{"ty":4,"nm":"Слой-ÑигÑÑа 16","sr":1,"st":0,"op":144,"ip":140,"hd":false,"ddd":0,"bm":0,"hasMask":false,"ao":0,"ks":{"a":{"a":0,"k":[134.25,100,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6},"sk":{"a":0,"k":0},"p":{"a":0,"k":[135.25,-130,0],"ix":2},"r":{"a":0,"k":0,"ix":10},"sa":{"a":0,"k":0},"o":{"a":0,"k":100,"ix":11}},"ef":[],"shapes":[{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":1,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[0,0],[-13.602,1.753],[30.852,14.78],[7.161,-15.867],[-6.916,25.79],[3.401,-16.667]],"o":[[-2.543,-22.79],[0,0],[24.898,-3.208],[0,0],[-4.849,10.745],[0,0],[0,0]],"v":[[98.489,140.218],[100.246,98.181],[134.997,86.695],[100.246,98.181],[129.173,124.504],[100.246,98.181],[89.484,126.612]]}],"t":134},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[0,0],[-13.602,1.753],[30.852,14.78],[7.161,-15.867],[-6.916,25.79],[3.401,-16.667]],"o":[[-2.543,-22.79],[0,0],[24.898,-3.208],[0,0],[-4.849,10.745],[0,0],[0,0]],"v":[[137.489,137.718],[139.246,95.681],[173.997,84.195],[139.246,95.681],[168.173,122.004],[139.246,95.681],[128.484,124.112]]}],"t":140},{"s":[{"c":false,"i":[[0,0],[0,0],[-13.602,1.753],[30.852,14.78],[7.161,-15.867],[-6.916,25.79],[3.401,-16.667]],"o":[[-2.543,-22.79],[0,0],[24.898,-3.208],[0,0],[-4.849,10.745],[0,0],[0,0]],"v":[[131.489,141.718],[133.246,99.681],[167.997,88.195],[133.246,99.681],[162.173,126.004],[133.246,99.681],[122.484,128.112]]}],"t":144}],"ix":2}},{"ty":"st","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Stroke","nm":"undefined","lc":2,"lj":2,"ml":1,"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":5,"ix":5},"c":{"a":0,"k":[0.3176,0.2392,0.7333],"ix":3}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]}],"ind":8,"parent":1},{"ty":4,"nm":"Слой-ÑигÑÑа 15","sr":1,"st":0,"op":70,"ip":0,"hd":false,"ddd":0,"bm":0,"hasMask":false,"ao":0,"ks":{"a":{"a":0,"k":[134.25,100,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6},"sk":{"a":0,"k":0},"p":{"a":1,"k":[{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[135.25,-130,0],"t":0,"ti":[45.333,57.25,0],"to":[-14.333,20,0]},{"s":[-137.75,-144,0],"t":70}],"ix":2},"r":{"a":0,"k":0,"ix":10},"sa":{"a":0,"k":0},"o":{"a":0,"k":100,"ix":11}},"ef":[],"shapes":[{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":1,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.167,"y":0},"i":{"x":0.667,"y":1},"s":[{"c":false,"i":[[0,0],[0,0],[-13.602,1.753],[30.852,14.78],[7.161,-15.867],[-6.916,25.79],[3.401,-16.667]],"o":[[-2.543,-22.79],[0,0],[24.898,-3.208],[0,0],[-4.849,10.745],[0,0],[0,0]],"v":[[131.489,141.718],[133.246,99.681],[167.997,88.195],[133.246,99.681],[162.173,126.004],[133.246,99.681],[122.484,128.112]]}],"t":0},{"o":{"x":0.333,"y":0},"i":{"x":0.667,"y":1},"s":[{"c":false,"i":[[0,0],[0,0],[-14.891,-4.594],[19.155,14.78],[-0.108,-16.478],[-4.294,25.79],[-10.589,-13.807]],"o":[[-15.69,-8.026],[0,0],[15.086,4.654],[0,0],[0.147,22.421],[0,0],[0,0]],"v":[[162.561,130.748],[139.142,99.681],[162.785,68.053],[139.142,99.681],[172.316,98.876],[139.142,99.681],[145.941,129.642]]}],"t":22},{"o":{"x":0.333,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[0,0],[5.421,-17.549],[-6.032,35.973],[-1.805,-15.867],[1.744,25.79],[-6.256,-15.452]],"o":[[-12.313,-12.709],[0,0],[-2.736,8.858],[0,0],[1.223,10.745],[0,0],[0,0]],"v":[[143.8,137.301],[135.483,99.681],[118.708,105.165],[135.483,99.681],[129.139,131.076],[135.483,99.681],[143.926,128.762]]}],"t":53},{"s":[{"c":false,"i":[[0,0],[0,0],[12.207,1.753],[-27.687,14.78],[-1.655,-17.038],[6.207,25.79],[12.445,-18.738]],"o":[[11.404,-7.498],[0,0],[-22.344,-3.208],[0,0],[1.955,20.132],[0,0],[0,0]],"v":[[113.891,119.66],[132.779,99.681],[106.771,67.658],[132.779,99.681],[98.19,96.594],[132.779,99.681],[123.452,127.605]]}],"t":70}],"ix":2}},{"ty":"st","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Stroke","nm":"undefined","lc":2,"lj":2,"ml":1,"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":5,"ix":5},"c":{"a":0,"k":[0.451,0.3412,1],"ix":3}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]}],"ind":9,"parent":1},{"ty":4,"nm":"Слой-ÑигÑÑа 14","sr":1,"st":0,"op":144,"ip":0,"hd":false,"ddd":0,"bm":0,"hasMask":false,"ao":0,"ks":{"a":{"a":0,"k":[0,0,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6},"sk":{"a":0,"k":0},"p":{"a":0,"k":[1,-230,0],"ix":2},"r":{"a":0,"k":0,"ix":10},"sa":{"a":0,"k":0},"o":{"a":0,"k":100,"ix":11}},"ef":[],"shapes":[{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":1,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.203,"y":0},"i":{"x":0.548,"y":1},"s":[{"c":false,"i":[[0,0],[-54.603,35.893]],"o":[[57.784,38.036],[0,0]],"v":[[-141.403,100.968],[131.663,100.968]]}],"t":0},{"o":{"x":0.307,"y":0},"i":{"x":0.683,"y":1},"s":[{"c":false,"i":[[0,0],[-54.603,35.893]],"o":[[42.403,51.532],[0,0]],"v":[[-136.903,79.968],[133.663,94.968]]}],"t":36},{"o":{"x":0.136,"y":0},"i":{"x":0.656,"y":1},"s":[{"c":false,"i":[[0,0],[-44.913,39.782]],"o":[[42.403,51.532],[0,0]],"v":[[-140.153,86.968],[143.413,99.718]]}],"t":72},{"o":{"x":0.271,"y":0},"i":{"x":0.611,"y":1},"s":[{"c":false,"i":[[0,0],[-44.913,39.782]],"o":[[42.403,51.532],[0,0]],"v":[[-149.403,82.718],[140.663,98.968]]}],"t":102},{"s":[{"c":false,"i":[[0,0],[-54.603,35.893]],"o":[[57.784,38.036],[0,0]],"v":[[-141.403,100.968],[131.663,100.968]]}],"t":144}],"ix":2}},{"ty":"st","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Stroke","nm":"undefined","lc":2,"lj":2,"ml":1,"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":5,"ix":5},"c":{"a":0,"k":[0.451,0.3412,1],"ix":3}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]}],"ind":10,"parent":1},{"ty":4,"nm":"Слой-ÑигÑÑа 13","sr":1,"st":0,"op":144,"ip":0,"hd":false,"ddd":0,"bm":0,"hasMask":false,"ao":0,"ks":{"a":{"a":0,"k":[107.5,140.5,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6},"sk":{"a":0,"k":0},"p":{"a":0,"k":[108.5,-89.5,0],"ix":2},"r":{"a":1,"k":[{"o":{"x":0.333,"y":0},"i":{"x":0.667,"y":1.046},"s":[0],"t":0},{"o":{"x":0.333,"y":0.077},"i":{"x":0.667,"y":1},"s":[22.215],"t":15},{"o":{"x":0.333,"y":0},"i":{"x":0.667,"y":1},"s":[-7],"t":48},{"o":{"x":0.333,"y":0},"i":{"x":0.667,"y":1},"s":[4],"t":87},{"s":[0],"t":143}],"ix":10},"sa":{"a":0,"k":0},"o":{"a":0,"k":100,"ix":11}},"ef":[],"shapes":[{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":1,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":0,"k":{"c":false,"i":[[0,0],[-22.936,-8.896],[1.001,4.928],[0.586,3.968],[-7.124,18.215]],"o":[[0,0],[10.915,4.233],[-0.672,-3.308],[-0.971,-6.572],[0,0]],"v":[[84.235,132.152],[114.328,199.315],[128.95,191.988],[123.193,184.343],[130.663,132.152]]},"ix":2}},{"ty":"st","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Stroke","nm":"undefined","lc":2,"lj":2,"ml":1,"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":5,"ix":5},"c":{"a":0,"k":[0,0,0],"ix":3}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]},{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":2,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":0,"k":{"c":true,"i":[[10.91,4.24],[4.6,16.21],[0,0],[-8.68,-2.49],[-8.32,1.83],[0,0],[-0.55,-3.72],[-0.67,-3.31]],"o":[[-11.95,-4.63],[0,0],[0,0],[6.39,1.83],[4.07,-0.89],[-1.55,11.63],[0.59,3.97],[1,4.92]],"v":[[114.33,199.313],[90.11,160.443],[90.11,160.433],[104.55,152.343],[118.88,154.763],[124.38,158.593],[123.19,184.343],[128.95,191.993]]},"ix":2}},{"ty":"fl","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Fill","nm":"undefined","c":{"a":0,"k":[0.5647,0.451,0.3608],"ix":4},"r":1,"o":{"a":0,"k":100,"ix":5}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]}],"ind":11,"parent":1},{"ty":4,"nm":"Слой-ÑигÑÑа 12","sr":1,"st":0,"op":144,"ip":0,"hd":false,"ddd":0,"bm":0,"hasMask":false,"ao":0,"ks":{"a":{"a":0,"k":[0,0,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6},"sk":{"a":0,"k":0},"p":{"a":0,"k":[37.125,-16.625,0],"ix":2},"r":{"a":0,"k":0,"ix":10},"sa":{"a":0,"k":0},"o":{"a":1,"k":[{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[100],"t":60},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[0],"t":61},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[0],"t":127},{"s":[100],"t":128}],"ix":11}},"ef":[],"shapes":[{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":1,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[11.458,2.51],[-9.184,-3.861]],"o":[[-5.317,-1.165],[9.184,3.861]],"v":[[57.386,90.269],[54.961,101.341]]}],"t":0},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[9.115,7.383],[-6.476,-7.571]],"o":[[-4.229,-3.426],[6.476,7.571]],"v":[[33.432,101.827],[22.816,107.046]]}],"t":24},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[9.131,3.291],[-8.395,-5.365]],"o":[[-7.855,-2.831],[6.474,4.137]],"v":[[20.444,83.608],[12.855,90.274]]}],"t":32},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[4.982,3.349],[-4.581,-5.459]],"o":[[-4.286,-2.881],[3.533,4.21]],"v":[[-27.631,62.621],[-31.772,69.404]]}],"t":47},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[2.665,3.855],[-1.952,-4.179]],"o":[[-2.203,-2.193],[1.946,4.572]],"v":[[-35.957,49.913],[-37.475,56.854]]}],"t":56},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[1.893,4.023],[-1.075,-3.752]],"o":[[-1.509,-1.964],[1.417,4.692]],"v":[[-39.874,47.1],[-40.518,54.095]]}],"t":59},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[1.635,4.08],[-0.93,-3.589]],"o":[[-1.277,-1.887],[1.241,4.732]],"v":[[-40.699,45.482],[-41.168,52.448]]}],"t":60},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[0.348,4.36],[-0.202,-2.776]],"o":[[-0.12,-1.505],[0.36,4.933]],"v":[[-59.548,40.346],[-59.148,47.17]]}],"t":65},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[0.348,4.36],[-0.202,-2.776]],"o":[[-0.12,-1.505],[0.36,4.933]],"v":[[-59.548,40.346],[-59.148,47.17]]}],"t":125},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[0.746,0.576],[0.116,-0.05]],"o":[[-0.904,-0.859],[0.624,-0.141]],"v":[[56.613,91.137],[54.483,101.099]]}],"t":126},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[3.051,1.056],[-4.602,-0.857]],"o":[[-2.752,-1.042],[4.484,0.727]],"v":[[57.345,90.887],[54.966,97.414]]}],"t":128},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[4.204,1.296],[-6.961,-1.26]],"o":[[-3.676,-1.133],[6.414,1.161]],"v":[[57.711,90.762],[55.985,98.248]]}],"t":129},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[5.188,1.724],[-8.592,-1.677]],"o":[[-4.537,-1.508],[7.916,1.545]],"v":[[56.613,91.137],[54.483,101.099]]}],"t":133},{"s":[{"c":true,"i":[[11.458,2.51],[-9.184,-3.861]],"o":[[-5.317,-1.165],[9.184,3.861]],"v":[[57.386,90.269],[54.961,101.341]]}],"t":144}],"ix":2}},{"ty":"fl","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Fill","nm":"undefined","c":{"a":0,"k":[1,0.5843,0],"ix":4},"r":1,"o":{"a":0,"k":100,"ix":5}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]},{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":2,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[21.936,4.881],[-16.202,-5.151]],"o":[[-19.474,-4.333],[24.95,7.932]],"v":[[84.77,73.925],[72.639,93.435]]}],"t":0},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[17.415,14.203],[-12.17,-11.872]],"o":[[-15.461,-12.609],[18.74,18.282]],"v":[[65.239,99.505],[42.461,109.224]]}],"t":24},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[17.737,7.491],[-14.804,-8.36]],"o":[[-18.379,-7.762],[21.008,11.864]],"v":[[52.721,79.527],[32.24,91.957]]}],"t":32},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[9.678,7.623],[-8.078,-8.508]],"o":[[-10.029,-7.899],[11.463,12.073]],"v":[[-10.019,58.468],[-21.194,71.117]]}],"t":47},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[3.655,7.606],[-1.462,-3.944]],"o":[[-3.787,-7.881],[4.364,10.902]],"v":[[-37.894,43.129],[-39.833,55.885]]}],"t":59},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[1.6,8.075],[-1.333,-4.747]],"o":[[-1.319,-6.659],[1.22,7.876]],"v":[[-41.504,41.97],[-40.555,54.213]]}],"t":60},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[0.643,7.597],[-0.691,-8.763]],"o":[[-0.666,-7.872],[0.814,10.316]],"v":[[-59.553,36.175],[-58.889,48.807]]}],"t":65},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[0.643,7.597],[-0.691,-8.763]],"o":[[-0.666,-7.872],[0.814,10.316]],"v":[[-59.553,36.175],[-58.889,48.807]]}],"t":125},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[13.14,1.814],[-14.804,-1.953]],"o":[[-18.419,-2.543],[21.654,2.857]],"v":[[80.085,74.38],[70.008,93.986]]}],"t":126},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[0.38,-0.004],[-0.981,-2.062]],"o":[[-2.778,-0.801],[0.446,-0.081]],"v":[[69.855,73.729],[61.134,87.784]]}],"t":127},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[2.507,0.299],[-3.285,-2.044]],"o":[[-5.385,-1.092],[3.981,0.409]],"v":[[73.108,75.182],[64.205,89.414]]}],"t":128},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[13.14,1.814],[-14.804,-1.953]],"o":[[-18.419,-2.543],[21.654,2.857]],"v":[[80.085,74.38],[70.008,93.986]]}],"t":133},{"s":[{"c":true,"i":[[21.936,4.881],[-16.202,-5.151]],"o":[[-19.474,-4.333],[24.95,7.932]],"v":[[84.77,73.925],[72.639,93.435]]}],"t":144}],"ix":2}},{"ty":"fl","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Fill","nm":"undefined","c":{"a":0,"k":[1,0.5843,0],"ix":4},"r":1,"o":{"a":0,"k":100,"ix":5}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]}],"ind":12,"parent":2},{"ty":4,"nm":"Слой-ÑигÑÑа 22","sr":1,"st":0,"op":144,"ip":71,"hd":false,"ddd":0,"bm":0,"hasMask":false,"ao":0,"ks":{"a":{"a":0,"k":[127.125,-80.25,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6},"sk":{"a":0,"k":0},"p":{"a":1,"k":[{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[128.125,-310.25,0],"t":0,"ti":[91.384,14.858,0],"to":[-2.333,13.333,0]},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[22.625,-278.25,0],"t":36,"ti":[-24.875,7.5,0],"to":[-46.204,-7.512,0]},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[-92.375,-317.25,0],"t":72,"ti":[-37.145,-2.503,0],"to":[24.875,-7.5,0]},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[26.5,-330.5,0],"t":102,"ti":[0.779,-6.628,0],"to":[35.25,2.375,0]},{"s":[128.125,-310.25,0],"t":144}],"ix":2},"r":{"a":0,"k":0,"ix":10},"sa":{"a":0,"k":0},"o":{"a":0,"k":100,"ix":11}},"ef":[],"shapes":[{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":1,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":false,"i":[[0,0],[-8.772,-3.509],[0,0]],"o":[[0,0],[8.772,3.509],[0,0]],"v":[[114.208,-86.598],[151.547,-97.402],[137.511,-74.134]]}],"t":0},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":false,"i":[[0,0],[-11.359,-9.385],[0,0]],"o":[[0,0],[3.202,2.645],[0,0]],"v":[[114.208,-86.598],[154.297,-94.902],[138.799,-72.349]]}],"t":18},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":false,"i":[[0,0],[-8.772,-3.509],[0,0]],"o":[[0,0],[8.772,3.509],[0,0]],"v":[[114.208,-86.598],[151.547,-97.402],[137.761,-73.634]]}],"t":36},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":false,"i":[[0,0],[-8.772,-3.509],[0,0]],"o":[[0,0],[8.772,3.509],[0,0]],"v":[[114.865,-73.898],[128.797,-107.527],[139.183,-83.453]]}],"t":72},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":false,"i":[[0,0],[-8.772,-3.509],[0,0]],"o":[[0,0],[8.772,3.509],[0,0]],"v":[[112.615,-79.648],[116.297,-101.277],[143.183,-78.328]]}],"t":102},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":false,"i":[[0,0],[-8.772,-3.509],[0,0]],"o":[[0,0],[8.772,3.509],[0,0]],"v":[[112.999,-81.083],[133.083,-99.431],[140.482,-68.206]]}],"t":122},{"s":[{"c":false,"i":[[0,0],[-8.772,-3.509],[0,0]],"o":[[0,0],[8.772,3.509],[0,0]],"v":[[114.208,-86.598],[151.547,-97.402],[137.511,-74.134]]}],"t":144}],"ix":2}},{"ty":"st","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Stroke","nm":"undefined","lc":2,"lj":2,"ml":1,"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":5,"ix":5},"c":{"a":0,"k":[0,0,0],"ix":3}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]},{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":2,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":true,"i":[[-25.02,16.503],[-8.78,-3.51],[3.341,-3.125]],"o":[[2.061,-1.359],[8.77,3.5],[-15.51,14.507]],"v":[[114.27,-86.628],[151.55,-97.398],[137.51,-74.007]]}],"t":0},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":true,"i":[[-25.02,16.503],[-10.745,-10.019],[3.964,-2.284]],"o":[[2.061,-1.359],[2.698,2.516],[-18.401,10.604]],"v":[[114.27,-86.628],[154.3,-94.898],[138.769,-72.226]]}],"t":18},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":true,"i":[[-25.02,16.503],[-8.78,-3.51],[3.341,-3.125]],"o":[[2.061,-1.359],[8.77,3.5],[-15.51,14.507]],"v":[[114.27,-86.628],[151.55,-97.398],[137.76,-73.507]]}],"t":36},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":true,"i":[[-3.47,29.771],[-8.78,-3.51],[-0.83,-4.499]],"o":[[0.286,-2.452],[8.77,3.5],[3.854,20.885]],"v":[[114.883,-73.965],[128.8,-107.523],[139.289,-83.384]]}],"t":72},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":true,"i":[[0.851,4.589],[-8.78,-3.51],[-1.855,-4.344]],"o":[[-0.45,-2.427],[8.77,3.5],[0.365,3.96]],"v":[[113.533,-77.415],[121.3,-103.773],[141.689,-80.309]]}],"t":90},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":true,"i":[[-1.581,6.061],[-8.78,-3.51],[-3.22,-3.75]],"o":[[-0.238,-2.457],[8.77,3.5],[4.256,6.367]],"v":[[112.633,-79.715],[116.3,-101.273],[143.289,-78.259]]}],"t":102},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":true,"i":[[-13.732,23.453],[-8.78,-3.51],[0.261,-3.709]],"o":[[1.131,-1.932],[8.77,3.5],[-1.672,16.453]],"v":[[113.038,-81.132],[133.086,-99.427],[140.537,-68.11]]}],"t":122},{"s":[{"c":true,"i":[[-25.02,16.503],[-8.78,-3.51],[3.341,-3.125]],"o":[[2.061,-1.359],[8.77,3.5],[-15.51,14.507]],"v":[[114.27,-86.628],[151.55,-97.398],[137.51,-74.007]]}],"t":144}],"ix":2}},{"ty":"fl","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Fill","nm":"undefined","c":{"a":0,"k":[1,0.5843,0],"ix":4},"r":1,"o":{"a":0,"k":100,"ix":5}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]}],"ind":13,"parent":1},{"ty":4,"nm":"Слой-ÑигÑÑа 11","sr":1,"st":0,"op":71,"ip":0,"hd":false,"ddd":0,"bm":0,"hasMask":false,"ao":0,"ks":{"a":{"a":0,"k":[127.125,-80.25,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6},"sk":{"a":0,"k":0},"p":{"a":1,"k":[{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[128.125,-310.25,0],"t":0,"ti":[91.384,14.858,0],"to":[-2.333,13.333,0]},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[22.625,-278.25,0],"t":36,"ti":[-24.875,7.5,0],"to":[-46.204,-7.512,0]},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[-92.375,-317.25,0],"t":72,"ti":[-37.145,-2.503,0],"to":[24.875,-7.5,0]},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[26.5,-330.5,0],"t":102,"ti":[0.779,-6.628,0],"to":[35.25,2.375,0]},{"s":[128.125,-310.25,0],"t":144}],"ix":2},"r":{"a":0,"k":0,"ix":10},"sa":{"a":0,"k":0},"o":{"a":0,"k":100,"ix":11}},"ef":[],"shapes":[{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":1,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":false,"i":[[0,0],[-8.772,-3.509],[0,0]],"o":[[0,0],[8.772,3.509],[0,0]],"v":[[114.208,-86.598],[151.547,-97.402],[137.511,-74.134]]}],"t":0},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":false,"i":[[0,0],[-11.359,-9.385],[0,0]],"o":[[0,0],[3.202,2.645],[0,0]],"v":[[114.208,-86.598],[154.297,-94.902],[138.799,-72.349]]}],"t":18},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":false,"i":[[0,0],[-8.772,-3.509],[0,0]],"o":[[0,0],[8.772,3.509],[0,0]],"v":[[114.208,-86.598],[151.547,-97.402],[137.761,-73.634]]}],"t":36},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":false,"i":[[0,0],[-8.772,-3.509],[0,0]],"o":[[0,0],[8.772,3.509],[0,0]],"v":[[114.865,-73.898],[128.797,-107.527],[139.183,-83.453]]}],"t":72},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":false,"i":[[0,0],[-8.772,-3.509],[0,0]],"o":[[0,0],[8.772,3.509],[0,0]],"v":[[112.615,-79.648],[116.297,-101.277],[143.183,-78.328]]}],"t":102},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":false,"i":[[0,0],[-8.772,-3.509],[0,0]],"o":[[0,0],[8.772,3.509],[0,0]],"v":[[112.999,-81.083],[133.083,-99.431],[140.482,-68.206]]}],"t":122},{"s":[{"c":false,"i":[[0,0],[-8.772,-3.509],[0,0]],"o":[[0,0],[8.772,3.509],[0,0]],"v":[[114.208,-86.598],[151.547,-97.402],[137.511,-74.134]]}],"t":144}],"ix":2}},{"ty":"st","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Stroke","nm":"undefined","lc":2,"lj":2,"ml":1,"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":5,"ix":5},"c":{"a":0,"k":[0,0,0],"ix":3}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]},{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":2,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":true,"i":[[-25.02,16.503],[-8.78,-3.51],[3.341,-3.125]],"o":[[2.061,-1.359],[8.77,3.5],[-15.51,14.507]],"v":[[114.27,-86.628],[151.55,-97.398],[137.51,-74.007]]}],"t":0},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":true,"i":[[-25.02,16.503],[-10.745,-10.019],[3.964,-2.284]],"o":[[2.061,-1.359],[2.698,2.516],[-18.401,10.604]],"v":[[114.27,-86.628],[154.3,-94.898],[138.769,-72.226]]}],"t":18},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":true,"i":[[-25.02,16.503],[-8.78,-3.51],[3.341,-3.125]],"o":[[2.061,-1.359],[8.77,3.5],[-15.51,14.507]],"v":[[114.27,-86.628],[151.55,-97.398],[137.76,-73.507]]}],"t":36},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":true,"i":[[-3.47,29.771],[-8.78,-3.51],[-0.83,-4.499]],"o":[[0.286,-2.452],[8.77,3.5],[3.854,20.885]],"v":[[114.883,-73.965],[128.8,-107.523],[139.289,-83.384]]}],"t":72},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":true,"i":[[0.851,4.589],[-8.78,-3.51],[-1.855,-4.344]],"o":[[-0.45,-2.427],[8.77,3.5],[0.365,3.96]],"v":[[113.533,-77.415],[121.3,-103.773],[141.689,-80.309]]}],"t":90},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":true,"i":[[-1.581,6.061],[-8.78,-3.51],[-3.22,-3.75]],"o":[[-0.238,-2.457],[8.77,3.5],[4.256,6.367]],"v":[[112.633,-79.715],[116.3,-101.273],[143.289,-78.259]]}],"t":102},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":true,"i":[[-13.732,23.453],[-8.78,-3.51],[0.261,-3.709]],"o":[[1.131,-1.932],[8.77,3.5],[-1.672,16.453]],"v":[[113.038,-81.132],[133.086,-99.427],[140.537,-68.11]]}],"t":122},{"s":[{"c":true,"i":[[-25.02,16.503],[-8.78,-3.51],[3.341,-3.125]],"o":[[2.061,-1.359],[8.77,3.5],[-15.51,14.507]],"v":[[114.27,-86.628],[151.55,-97.398],[137.51,-74.007]]}],"t":144}],"ix":2}},{"ty":"fl","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Fill","nm":"undefined","c":{"a":0,"k":[1,0.5843,0],"ix":4},"r":1,"o":{"a":0,"k":100,"ix":5}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]}],"ind":14,"parent":1},{"ty":4,"nm":"Слой-ÑигÑÑа 10","sr":1,"st":0,"op":144,"ip":0,"hd":false,"ddd":0,"bm":0,"hasMask":false,"ao":0,"ks":{"a":{"a":0,"k":[-107.75,-89.75,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6},"sk":{"a":0,"k":0},"p":{"a":1,"k":[{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[-106.75,-319.75,0],"t":0,"ti":[-37.146,-0.045,0],"to":[8.696,-6.57,0]},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[3.5,-330.609,0],"t":36,"ti":[-4.75,-11,0],"to":[37.146,0.045,0]},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[117,-308,0],"t":72,"ti":[50.75,-0.5,0],"to":[4.75,11,0]},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[13.25,-282.25,0],"t":102,"ti":[-28.109,42.035,0],"to":[-44.775,0,0]},{"s":[-106.75,-319.75,0],"t":144}],"ix":2},"r":{"a":0,"k":0,"ix":10},"sa":{"a":0,"k":0},"o":{"a":0,"k":100,"ix":11}},"ef":[],"shapes":[{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":1,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":false,"i":[[-1.363,7.563],[-7.261,-2.188],[0,0]],"o":[[2.605,-14.457],[6.833,2.059],[0,0]],"v":[[-120.98,-83.918],[-90.975,-116.741],[-95.373,-93.768]]}],"t":0},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":false,"i":[[-3.541,6.821],[-7.261,-2.188],[0,0]],"o":[[5.105,-9.832],[6.833,2.059],[0,0]],"v":[[-122.23,-88.668],[-93.975,-103.991],[-97.498,-89.143]]}],"t":36},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":false,"i":[[-3.541,6.821],[-7.261,-2.188],[0,0]],"o":[[5.105,-9.832],[6.833,2.059],[0,0]],"v":[[-122.254,-89.529],[-98.225,-107.828],[-99.699,-81.545]]}],"t":53},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":false,"i":[[-3.541,6.821],[-7.261,-2.188],[0,0]],"o":[[5.105,-9.832],[6.833,2.059],[0,0]],"v":[[-119.105,-93.668],[-102.975,-112.116],[-99.248,-83.643]]}],"t":72},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":false,"i":[[-0.633,7.659],[-7.261,-2.188],[0,0]],"o":[[0.913,-11.041],[6.833,2.059],[0,0]],"v":[[-122.39,-91.695],[-115.85,-127.866],[-88.623,-88.018]]}],"t":102},{"s":[{"c":false,"i":[[-1.363,7.563],[-7.261,-2.188],[0,0]],"o":[[2.605,-14.457],[6.833,2.059],[0,0]],"v":[[-120.98,-83.918],[-90.975,-116.741],[-95.373,-93.768]]}],"t":144}],"ix":2}},{"ty":"st","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Stroke","nm":"undefined","lc":2,"lj":2,"ml":1,"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":5,"ix":5},"c":{"a":0,"k":[0,0,0],"ix":3}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]},{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":2,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":true,"i":[[0.278,12.919],[-7.26,-2.19],[1.229,-2.662]],"o":[[-0.27,-12.583],[6.84,2.06],[-4.625,10.023]],"v":[[-120.23,-83.792],[-90.98,-116.742],[-95.25,-93.898]]}],"t":0},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":true,"i":[[-4.532,12.101],[-7.26,-2.19],[1.229,-2.662]],"o":[[3.73,-9.958],[6.84,2.06],[-4.625,10.023]],"v":[[-121.48,-88.542],[-93.98,-103.992],[-97.375,-89.273]]}],"t":36},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":true,"i":[[-4.532,12.101],[-7.26,-2.19],[1.229,-2.662]],"o":[[3.73,-9.958],[6.84,2.06],[-4.625,10.023]],"v":[[-121.504,-89.403],[-98.23,-107.829],[-99.576,-81.675]]}],"t":53},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":true,"i":[[-4.532,12.101],[-7.26,-2.19],[1.229,-2.662]],"o":[[3.73,-9.958],[6.84,2.06],[-4.625,10.023]],"v":[[-118.355,-93.542],[-102.98,-112.117],[-99.125,-83.773]]}],"t":72},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":true,"i":[[0.49,12.912],[-7.26,-2.19],[-1.5,-8.352]],"o":[[-0.403,-10.626],[6.84,2.06],[1.952,10.864]],"v":[[-121.65,-91.869],[-115.855,-127.867],[-88.5,-88.148]]}],"t":102},{"s":[{"c":true,"i":[[0.278,12.919],[-7.26,-2.19],[1.229,-2.662]],"o":[[-0.27,-12.583],[6.84,2.06],[-4.625,10.023]],"v":[[-120.23,-83.792],[-90.98,-116.742],[-95.25,-93.898]]}],"t":144}],"ix":2}},{"ty":"fl","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Fill","nm":"undefined","c":{"a":0,"k":[0.5647,0.451,0.3608],"ix":4},"r":1,"o":{"a":0,"k":100,"ix":5}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]}],"ind":15,"parent":1},{"ty":4,"nm":"Слой-ÑигÑÑа 9","sr":1,"st":0,"op":144,"ip":0,"hd":false,"ddd":0,"bm":0,"hasMask":false,"ao":0,"ks":{"a":{"a":0,"k":[0,0,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6},"sk":{"a":0,"k":0},"p":{"a":0,"k":[1,-230,0],"ix":2},"r":{"a":0,"k":0,"ix":10},"sa":{"a":0,"k":0},"o":{"a":0,"k":100,"ix":11}},"ef":[],"shapes":[{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":1,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":false,"i":[[0,0],[0,58.674],[-8.774,4.402],[-63.836,-2.974],[-4.185,-2.102],[-7.595,-5.424],[5.021,-60.266],[0,0]],"o":[[0,0],[0,-70.11],[19.558,-9.814],[64.131,2.988],[6.23,3.129],[6.489,4.634],[-4.796,57.569],[0,0]],"v":[[-141.403,100.968],[-178.216,13.96],[-114.129,-87.868],[9.435,-108.513],[114.27,-86.629],[137.511,-74.009],[171.431,21.902],[131.663,100.968]]}],"t":0},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":false,"i":[[0,0],[-2.011,43.034],[-8.252,5.316],[-63.836,-2.974],[-3.501,-3.11],[-5.939,-7.2],[-0.248,-40.261],[0,0]],"o":[[0,0],[2.402,-51.41],[18.395,-11.851],[64.131,2.988],[5.212,4.63],[5.074,6.15],[0.237,38.459],[0,0]],"v":[[-137.903,77.968],[-155.552,18.437],[-104.7,-75.717],[6.186,-103.513],[104.156,-70.667],[123.356,-52.479],[154.049,32.455],[135.663,92.968]]}],"t":36},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":false,"i":[[0,0],[-0.248,44.496],[-8.479,4.946],[-63.836,-2.974],[-4.185,-2.102],[-7.595,-5.424],[2.784,-60.411],[0,0]],"o":[[0,0],[0.296,-53.139],[18.901,-11.025],[64.131,2.988],[6.23,3.129],[6.489,4.634],[-2.659,57.707],[0,0]],"v":[[-141.403,85.468],[-160.211,20.328],[-110.948,-77.034],[8.935,-100.513],[101.27,-84.129],[124.511,-71.509],[163.481,28.405],[144.163,98.968]]}],"t":72},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":false,"i":[[0,0],[-0.248,44.496],[-8.479,4.946],[-63.836,-2.974],[-3.813,-2.718],[-6.675,-6.524],[3.519,-50.405],[0,0]],"o":[[0,0],[0.296,-53.139],[18.901,-11.025],[64.131,2.988],[5.677,4.047],[5.702,5.573],[-4.023,57.628],[0,0]],"v":[[-150.903,81.468],[-160.211,20.328],[-107.948,-74.534],[8.935,-100.513],[101.082,-76.497],[122.115,-60.464],[168.981,31.405],[143.163,97.468]]}],"t":102},{"s":[{"c":false,"i":[[0,0],[0,58.674],[-8.774,4.402],[-63.836,-2.974],[-4.185,-2.102],[-7.595,-5.424],[5.021,-60.266],[0,0]],"o":[[0,0],[0,-70.11],[19.558,-9.814],[64.131,2.988],[6.23,3.129],[6.489,4.634],[-4.796,57.569],[0,0]],"v":[[-141.403,100.968],[-178.216,13.96],[-114.129,-87.868],[9.435,-108.513],[114.27,-86.629],[137.511,-74.009],[171.431,21.902],[131.663,100.968]]}],"t":144}],"ix":2}},{"ty":"st","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Stroke","nm":"undefined","lc":2,"lj":2,"ml":1,"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":5,"ix":5},"c":{"a":0,"k":[0,0,0],"ix":3}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]}],"ind":16,"parent":1},{"ty":4,"nm":"Слой-ÑигÑÑа 8","sr":1,"st":0,"op":144,"ip":106,"hd":false,"ddd":0,"bm":0,"hasMask":false,"ao":0,"ks":{"a":{"a":0,"k":[80.392,-25.51,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6},"sk":{"a":0,"k":0},"p":{"a":0,"k":[81.392,-255.51,0],"ix":2},"r":{"a":0,"k":0,"ix":10},"sa":{"a":0,"k":0},"o":{"a":0,"k":100,"ix":11}},"ef":[],"shapes":[{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":1,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":true,"i":[[2.571,-51.263],[8.93,12],[28.005,2.142],[-24.049,-17.676]],"o":[[1.834,-51.518],[-22.312,-29.98],[28.988,3.16],[17.93,13.178]],"v":[[169.202,36.038],[144.656,-36.891],[53.572,-96.226],[118.705,-65.918]]}],"t":106},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":true,"i":[[6.111,-61.987],[19.389,38.817],[0,0],[-24.049,-17.676]],"o":[[-0.372,50.954],[-16.699,-33.433],[27.641,2.125],[17.93,13.178]],"v":[[169.202,36.038],[128.19,-18.321],[53.572,-96.226],[120.671,-67.445]]}],"t":114},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":true,"i":[[3.827,-55.521],[26.345,95.775],[0,0],[-24.049,-17.676]],"o":[[-0.447,86.84],[-16.067,-53.343],[46.126,-0.484],[17.93,13.178]],"v":[[170.465,28.028],[42.873,-8.023],[19.333,-103.378],[130.213,-71.164]]}],"t":131},{"s":[{"c":true,"i":[[2.079,-50.576],[31.664,139.331],[0,0],[-24.049,-17.676]],"o":[[-0.372,50.954],[-15.583,-68.569],[60.261,-2.479],[17.93,13.178]],"v":[[171.43,21.903],[-22.37,-0.148],[-6.85,-108.847],[137.51,-74.007]]}],"t":144}],"ix":2}},{"ty":"fl","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Fill","nm":"undefined","c":{"a":0,"k":[1,0.5843,0],"ix":4},"r":1,"o":{"a":0,"k":100,"ix":5}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]}],"ind":17,"parent":1},{"ty":4,"nm":"Слой-ÑигÑÑа 7","sr":1,"st":0,"op":102,"ip":0,"hd":false,"ddd":0,"bm":0,"hasMask":false,"ao":0,"ks":{"a":{"a":0,"k":[80.392,-25.51,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6},"sk":{"a":0,"k":0},"p":{"a":0,"k":[81.392,-255.51,0],"ix":2},"r":{"a":0,"k":0,"ix":10},"sa":{"a":0,"k":0},"o":{"a":0,"k":100,"ix":11}},"ef":[],"shapes":[{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":1,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":true,"i":[[2.079,-50.576],[31.664,139.331],[0,0],[-24.049,-17.676]],"o":[[-0.372,50.954],[-15.583,-68.569],[60.261,-2.479],[17.93,13.178]],"v":[[171.43,21.903],[-22.37,-0.148],[-6.85,-108.847],[137.51,-74.007]]}],"t":0},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":true,"i":[[6.512,-49.352],[22.896,127.143],[-8.471,2.175],[-27.279,-17.152]],"o":[[-5.905,51.121],[-11.127,-64.096],[49.836,-12.795],[21.663,13.314]],"v":[[165.502,22.053],[-46.454,-0.148],[-19.665,-103.036],[123.466,-75.218]]}],"t":8},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":true,"i":[[25.748,-43.051],[-7.789,84.485],[-25.981,11.51],[-38.674,-15.079]],"o":[[-32.728,54.721],[4.466,-48.444],[29.713,-13.163],[48.422,18.879]],"v":[[113.263,32.966],[-130.751,-0.148],[-64.52,-86.218],[56.97,-84.568]]}],"t":36},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":true,"i":[[27.427,-39.15],[-11.456,83.879],[-31.444,8.868],[-28.36,-16.425]],"o":[[-35.355,50.239],[7.151,-39.358],[29.28,-9.942],[36.421,24.181]],"v":[[67.288,35.213],[-150.935,-10.981],[-73.679,-91.732],[36.823,-82.542]]}],"t":47},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":true,"i":[[31.243,-30.283],[-19.791,82.502],[-47.984,4.447],[-4.919,-19.485]],"o":[[-41.324,40.053],[13.29,-55.401],[28.296,-2.622],[9.147,36.231]],"v":[[-37.199,40.32],[-158.007,-0.652],[-59.069,-96.319],[-8.966,-77.937]]}],"t":72},{"s":[{"c":true,"i":[[18.823,-23.436],[-1.997,7.551],[-47.664,7.098],[19.587,-4.497]],"o":[[-13.575,16.902],[13.145,-49.696],[21.824,-3.25],[-59.311,13.616]],"v":[[-139.231,-42.324],[-155.277,-9.59],[-44.67,-98.585],[-47.941,-98.331]]}],"t":102}],"ix":2}},{"ty":"fl","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Fill","nm":"undefined","c":{"a":0,"k":[1,0.5843,0],"ix":4},"r":1,"o":{"a":0,"k":100,"ix":5}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]}],"ind":18,"parent":1},{"ty":4,"nm":"Слой-ÑигÑÑа 6","sr":1,"st":0,"op":144,"ip":42,"hd":false,"ddd":0,"bm":0,"hasMask":false,"ao":0,"ks":{"a":{"a":0,"k":[0,0,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6},"sk":{"a":0,"k":0},"p":{"a":0,"k":[1,-230,0],"ix":2},"r":{"a":0,"k":0,"ix":10},"sa":{"a":0,"k":0},"o":{"a":0,"k":100,"ix":11}},"ef":[],"shapes":[{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":1,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":true,"i":[[1.452,6.577],[7.066,19.605],[21.292,8.788],[-30.718,-21.933]],"o":[[-0.391,-1.773],[-23.678,-65.691],[-17.474,-7.212],[37.291,26.626]],"v":[[153.15,13.543],[149.663,-8.85],[52.93,-96.57],[113.355,-64.868]]}],"t":42},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":true,"i":[[4.702,-9.185],[27.73,25.608],[-26.04,30.317],[-34.828,-20.455]],"o":[[-21.566,42.128],[-31.832,-29.395],[17.387,-20.243],[39.51,23.206]],"v":[[161.31,39.044],[48.177,49.018],[30.491,-82.838],[122.534,-73.205]]}],"t":72},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":true,"i":[[55.623,-35.695],[39.543,41.785],[-62.512,42.488],[-37.608,-26.027]],"o":[[-40.031,29.721],[-27.055,-28.266],[46.427,-31.386],[32.286,22.145]],"v":[[141.96,59.294],[-74.065,51.12],[-51.279,-76.532],[113.268,-68.904]]}],"t":97},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":true,"i":[[65.807,-40.997],[41.905,45.021],[-69.807,44.922],[-38.164,-27.141]],"o":[[-43.725,27.24],[-26.1,-28.04],[52.234,-33.614],[30.841,21.933]],"v":[[118.69,72.846],[-98.514,51.54],[-67.633,-75.271],[107.172,-62.105]]}],"t":102},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":true,"i":[[61.143,-49.289],[6.635,24.314],[-72.234,40.635],[-27.722,-13.939]],"o":[[-57.822,49.582],[-2.615,-9.584],[29.346,-16.415],[32.121,16.152]],"v":[[20.296,65.156],[-166.086,40.816],[-104.941,-82.837],[-3.888,-98.201]]}],"t":124},{"s":[{"c":true,"i":[[56.904,-56.828],[12.399,25.373],[-74.44,36.737],[-32.73,4.23]],"o":[[-36.051,36.003],[-11.815,-24.178],[15.015,-7.41],[0,0]],"v":[[-83.884,57.236],[-174.479,44.994],[-114.305,-87.859],[-43.27,-106.417]]}],"t":144}],"ix":2}},{"ty":"fl","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Fill","nm":"undefined","c":{"a":0,"k":[0.5647,0.451,0.3608],"ix":4},"r":1,"o":{"a":0,"k":100,"ix":5}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]}],"ind":19,"parent":1},{"ty":4,"nm":"Слой-ÑигÑÑа 5","sr":1,"st":0,"op":34,"ip":0,"hd":false,"ddd":0,"bm":0,"hasMask":false,"ao":0,"ks":{"a":{"a":0,"k":[0,0,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6},"sk":{"a":0,"k":0},"p":{"a":0,"k":[1,-230,0],"ix":2},"r":{"a":0,"k":0,"ix":10},"sa":{"a":0,"k":0},"o":{"a":0,"k":100,"ix":11}},"ef":[],"shapes":[{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":1,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":true,"i":[[56.904,-56.828],[12.399,25.373],[-74.44,36.737],[-32.73,4.23]],"o":[[-36.051,36.003],[-11.815,-24.178],[15.015,-7.41],[0,0]],"v":[[-83.884,57.236],[-174.479,44.994],[-114.305,-87.859],[-43.27,-106.417]]}],"t":0},{"o":{"x":0.167,"y":0.167},"i":{"x":0.833,"y":0.833},"s":[{"c":true,"i":[[22.197,-47.918],[1.082,28.219],[-31.02,24.108],[-29.637,2.453]],"o":[[-13.381,28.886],[-1.444,-37.637],[13.221,-10.275],[-46.467,28.444]],"v":[[-118.053,24.379],[-164.79,12.628],[-110.735,-80.013],[-41.23,-103.475]]}],"t":18},{"s":[{"c":true,"i":[[21.323,-81.691],[-1.584,5.254],[-31.02,24.108],[-29.637,2.453]],"o":[[-6.593,25.257],[10.874,-36.061],[13.221,-10.275],[-43.934,9.328]],"v":[[-153.736,-0.516],[-153.962,-6.171],[-105.075,-77.472],[-31.878,-103.729]]}],"t":33}],"ix":2}},{"ty":"fl","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Fill","nm":"undefined","c":{"a":0,"k":[0.5647,0.451,0.3608],"ix":4},"r":1,"o":{"a":0,"k":100,"ix":5}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]}],"ind":20,"parent":1},{"ty":4,"nm":"Слой-ÑигÑÑа 4","sr":1,"st":0,"op":144,"ip":0,"hd":false,"ddd":0,"bm":0,"hasMask":false,"ao":0,"ks":{"a":{"a":0,"k":[0,0,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6},"sk":{"a":0,"k":0},"p":{"a":0,"k":[1,-230,0],"ix":2},"r":{"a":0,"k":0,"ix":10},"sa":{"a":0,"k":0},"o":{"a":0,"k":100,"ix":11}},"ef":[],"shapes":[{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":1,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.203,"y":0},"i":{"x":0.548,"y":1},"s":[{"c":true,"i":[[0,0],[-145.368,-6.691],[-12.578,49.125],[37.219,-26.7],[25.312,2.159],[32.494,28.921]],"o":[[0,0],[125.01,5.754],[0,0],[-31.422,22.542],[-29.417,-2.509],[-23.335,-20.769]],"v":[[-175.46,40.913],[-24.419,109.079],[169.99,33.509],[130.13,103.053],[-24.419,129.045],[-148.501,94.2]]}],"t":0},{"o":{"x":0.307,"y":0},"i":{"x":0.683,"y":1},"s":[{"c":true,"i":[[0,0],[-145.47,-3.919],[-6.74,41.491],[24.12,-15.553],[25.312,2.159],[30.751,37.05]],"o":[[0,0],[108.419,2.921],[0,0],[-32.501,20.957],[-29.417,-2.509],[-16.576,-19.972]],"v":[[-155.96,19.413],[-20.919,94.579],[153.24,41.509],[130.63,96.803],[-18.669,120.295],[-140.501,75.95]]}],"t":36},{"o":{"x":0.136,"y":0},"i":{"x":0.656,"y":1},"s":[{"c":true,"i":[[0,0],[-145.47,-3.919],[-6.74,41.491],[17.87,-12.053],[25.312,2.159],[30.751,37.05]],"o":[[0,0],[108.419,2.921],[0,0],[-32.061,21.624],[-29.417,-2.509],[-16.576,-19.972]],"v":[[-159.71,21.163],[-13.419,107.079],[161.74,46.009],[142.88,99.553],[-18.419,126.795],[-145.251,81.7]]}],"t":72},{"o":{"x":0.271,"y":0},"i":{"x":0.611,"y":1},"s":[{"c":true,"i":[[0,0],[-144.081,-4.579],[-6.74,41.491],[20.134,-12.381],[50.169,2.955],[27.501,29.8]],"o":[[0,0],[108.404,3.445],[0,0],[-41.38,25.447],[-29.473,-1.736],[-12.608,-13.662]],"v":[[-159.71,21.163],[-13.419,107.079],[165.74,49.009],[142.63,99.553],[-16.419,124.545],[-150.001,83.45]]}],"t":102},{"s":[{"c":true,"i":[[0,0],[-145.368,-6.691],[-12.578,49.125],[37.219,-26.7],[25.312,2.159],[32.494,28.921]],"o":[[0,0],[125.01,5.754],[0,0],[-31.422,22.542],[-29.417,-2.509],[-23.335,-20.769]],"v":[[-175.46,40.913],[-24.419,109.079],[169.99,33.509],[130.13,103.053],[-24.419,129.045],[-148.501,94.2]]}],"t":144}],"ix":2}},{"ty":"fl","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Fill","nm":"undefined","c":{"a":0,"k":[0.0588,0.2471,0.7176],"ix":4},"r":1,"o":{"a":0,"k":15,"ix":5}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]},{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":2,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.203,"y":0},"i":{"x":0.548,"y":1},"s":[{"c":true,"i":[[0,0],[-4.796,57.569],[0,0],[0,0],[64.131,2.988],[19.061,-9.341],[0,-70.11],[0,0],[-87.822,1.688]],"o":[[0,0],[5.021,-60.266],[0,0],[0,0],[-63.836,-2.974],[-6.134,3.006],[0,58.674],[0,0],[87.823,-1.688]],"v":[[131.663,100.968],[171.431,21.902],[137.511,-74.009],[114.27,-86.629],[9.435,-108.513],[-114.107,-87.402],[-178.216,13.96],[-141.403,100.968],[-9.604,128.976]]}],"t":0},{"o":{"x":0.307,"y":0},"i":{"x":0.683,"y":1},"s":[{"c":true,"i":[[0,0],[0.237,38.459],[0,0],[0,0],[64.131,2.988],[17.952,-11.327],[2.068,-51.424],[0,0],[-87.77,-3.476]],"o":[[0,0],[-0.248,-40.261],[0,0],[0,0],[-63.836,-2.974],[-5.777,3.645],[-1.731,43.046],[0,0],[101.604,4.024]],"v":[[135.663,92.968],[154.049,32.454],[123.356,-52.479],[104.156,-70.667],[6.185,-103.513],[-104.629,-75.257],[-155.552,18.437],[-137.903,77.968],[-8.104,118.976]]}],"t":36},{"o":{"x":0.136,"y":0},"i":{"x":0.656,"y":1},"s":[{"c":true,"i":[[0,0],[-2.659,57.707],[0,0],[0,0],[64.131,2.988],[18.435,-10.521],[-0.233,-53.139],[0,0],[-87.834,-0.86]],"o":[[0,0],[2.784,-60.411],[0,0],[0,0],[-63.836,-2.974],[-5.933,3.386],[0.195,44.496],[0,0],[104.604,1.024]],"v":[[144.163,98.968],[163.481,28.405],[124.511,-71.509],[101.27,-84.129],[8.935,-100.513],[-110.897,-76.57],[-160.211,20.328],[-141.403,85.468],[1.896,127.476]]}],"t":72},{"o":{"x":0.271,"y":0},"i":{"x":0.611,"y":1},"s":[{"c":true,"i":[[0,0],[-4.063,57.625],[0,0],[0,0],[64.131,2.988],[18.435,-10.521],[-0.233,-53.139],[0,0],[-87.834,-0.86]],"o":[[0,0],[3.519,-49.905],[0,0],[0,0],[-63.836,-2.974],[-5.933,3.386],[0.195,44.496],[0,0],[104.604,1.024]],"v":[[143.163,97.468],[168.981,31.405],[122.115,-60.464],[101.082,-76.497],[8.935,-100.513],[-107.897,-74.07],[-160.211,20.328],[-150.903,81.468],[2.396,120.476]]}],"t":102},{"s":[{"c":true,"i":[[0,0],[-4.796,57.569],[0,0],[0,0],[64.131,2.988],[19.061,-9.341],[0,-70.11],[0,0],[-87.822,1.688]],"o":[[0,0],[5.021,-60.266],[0,0],[0,0],[-63.836,-2.974],[-6.134,3.006],[0,58.674],[0,0],[87.823,-1.688]],"v":[[131.663,100.968],[171.431,21.902],[137.511,-74.009],[114.27,-86.629],[9.435,-108.513],[-114.107,-87.402],[-178.216,13.96],[-141.403,100.968],[-9.604,128.976]]}],"t":144}],"ix":2}},{"ty":"fl","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Fill","nm":"undefined","c":{"a":0,"k":[0.949,0.949,0.949],"ix":4},"r":1,"o":{"a":0,"k":100,"ix":5}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]}],"ind":21,"parent":1},{"ty":4,"nm":"Слой-ÑигÑÑа 3","sr":1,"st":0,"op":144,"ip":0,"hd":false,"ddd":0,"bm":0,"hasMask":false,"ao":0,"ks":{"a":{"a":0,"k":[0,0,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6},"sk":{"a":0,"k":0},"p":{"a":0,"k":[1,-230,0],"ix":2},"r":{"a":0,"k":0,"ix":10},"sa":{"a":0,"k":0},"o":{"a":0,"k":100,"ix":11}},"ef":[],"shapes":[{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":1,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[-3.101,-17.769],[-5.343,2.746]],"o":[[0,0],[2.203,12.625],[0,0]],"v":[[-152.031,90.159],[-162.649,157.766],[-146.112,175.404]]}],"t":0},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[0.546,-18.029],[-5.343,2.746]],"o":[[0,0],[-0.388,12.81],[0,0]],"v":[[-149.503,81.506],[-167.6,153.641],[-144.362,172.681]]}],"t":14},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[-4.943,-17.347],[-5.343,2.746]],"o":[[0,0],[3.512,12.325],[0,0]],"v":[[-145.531,67.909],[-152.357,151.093],[-141.612,168.404]]}],"t":36},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[-3.101,-17.769],[-5.343,2.746]],"o":[[0,0],[2.203,12.625],[0,0]],"v":[[-145.531,67.909],[-158.149,150.766],[-141.612,168.404]]}],"t":81},{"s":[{"c":false,"i":[[0,0],[-3.101,-17.769],[-5.343,2.746]],"o":[[0,0],[2.203,12.625],[0,0]],"v":[[-152.031,90.159],[-162.649,157.766],[-146.112,175.404]]}],"t":144}],"ix":2}},{"ty":"st","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Stroke","nm":"undefined","lc":2,"lj":2,"ml":1,"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":5,"ix":5},"c":{"a":0,"k":[0,0,0],"ix":3}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]},{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":2,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[5.667,-75.019]],"o":[[0,0],[0,0]],"v":[[138.982,95.11],[150.561,214.423]]}],"t":0},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[5.667,-75.019]],"o":[[0,0],[0,0]],"v":[[138.398,94.137],[149.977,211.895]]}],"t":14},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[5.667,-75.019]],"o":[[0,0],[0,0]],"v":[[137.482,92.61],[149.061,207.923]]}],"t":36},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[5.667,-75.019]],"o":[[0,0],[0,0]],"v":[[141.482,99.11],[153.061,214.423]]}],"t":81},{"s":[{"c":false,"i":[[0,0],[5.667,-75.019]],"o":[[0,0],[0,0]],"v":[[138.982,95.11],[150.561,214.423]]}],"t":144}],"ix":2}},{"ty":"st","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Stroke","nm":"undefined","lc":2,"lj":2,"ml":1,"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":5,"ix":5},"c":{"a":0,"k":[0,0,0],"ix":3}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]},{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":3,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[-5.934,-58.264]],"o":[[0,0],[0,0]],"v":[[-138.031,118.394],[-144.505,214.423]]}],"t":0},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[-5.934,-58.264]],"o":[[0,0],[0,0]],"v":[[-136.281,115.672],[-142.755,208.978]]}],"t":14},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[-5.934,-58.264]],"o":[[0,0],[0,0]],"v":[[-133.531,111.394],[-140.005,200.423]]}],"t":36},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[-5.934,-58.264]],"o":[[0,0],[0,0]],"v":[[-133.531,111.394],[-140.005,213.923]]}],"t":81},{"s":[{"c":false,"i":[[0,0],[-5.934,-58.264]],"o":[[0,0],[0,0]],"v":[[-138.031,118.394],[-144.505,214.423]]}],"t":144}],"ix":2}},{"ty":"st","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Stroke","nm":"undefined","lc":2,"lj":2,"ml":1,"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":5,"ix":5},"c":{"a":0,"k":[0,0,0],"ix":3}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]},{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":4,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[0.4,-8.88],[1.35,-10.25],[3.63,14.68],[-2.31,12.23],[0,0],[-2.68,-5.74],[-1.582,-0.076]],"o":[[-0.29,6.49],[-2.85,-0.54],[-1.81,-7.32],[0,0],[0,0],[2.68,5.74],[2.58,0.124]],"v":[[-142.67,139.142],[-146.86,175.833],[-162.65,157.763],[-160.68,125.553],[-159.89,124.343],[-153.048,126.302],[-148.13,132.933]]}],"t":0},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[0.4,-8.88],[1.35,-10.25],[0.595,15.11],[-4.728,11.513],[0,0],[-1.468,-6.162],[-1.534,-0.394]],"o":[[-0.29,6.49],[-2.85,-0.54],[-0.297,-7.535],[0,0],[0,0],[1.468,6.162],[2.502,0.642]],"v":[[-140.92,136.42],[-145.11,173.11],[-167.599,153.638],[-159.175,122.486],[-158.158,121.46],[-151.852,124.759],[-148.371,132.245]]}],"t":14},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[0.4,-8.88],[1.35,-10.25],[5.146,14.219],[-1.017,12.405],[0,0],[-3.266,-5.428],[-1.581,0.09]],"o":[[-0.29,6.49],[-2.85,-0.54],[-2.566,-7.09],[0,0],[0,0],[3.266,5.428],[2.579,-0.146]],"v":[[-138.17,132.142],[-142.36,168.833],[-152.358,151.09],[-153.769,118.85],[-153.11,117.564],[-146.101,118.797],[-140.516,124.876]]}],"t":36},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[0.4,-8.88],[1.35,-10.25],[3.63,14.68],[-2.31,12.23],[0,0],[-2.68,-5.74],[-1.582,-0.076]],"o":[[-0.29,6.49],[-2.85,-0.54],[-1.81,-7.32],[0,0],[0,0],[2.68,5.74],[2.58,0.124]],"v":[[-138.17,132.142],[-142.36,168.833],[-158.15,150.763],[-156.18,118.553],[-155.39,117.343],[-148.548,119.302],[-143.63,125.933]]}],"t":81},{"s":[{"c":true,"i":[[0.4,-8.88],[1.35,-10.25],[3.63,14.68],[-2.31,12.23],[0,0],[-2.68,-5.74],[-1.582,-0.076]],"o":[[-0.29,6.49],[-2.85,-0.54],[-1.81,-7.32],[0,0],[0,0],[2.68,5.74],[2.58,0.124]],"v":[[-142.67,139.142],[-146.86,175.833],[-162.65,157.763],[-160.68,125.553],[-159.89,124.343],[-153.048,126.302],[-148.13,132.933]]}],"t":144}],"ix":2}},{"ty":"fl","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Fill","nm":"undefined","c":{"a":0,"k":[1,0.5843,0],"ix":4},"r":1,"o":{"a":0,"k":100,"ix":5}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]},{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":5,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[13.284,45.727],[0.569,-35.014],[0,0]],"o":[[0,0],[-0.467,28.732],[0,0]],"v":[[144.733,115.671],[134.127,165.126],[149.984,207.369]]}],"t":0},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[13.284,45.726],[-1.135,-34.935],[0,0]],"o":[[0,0],[1.221,31.315],[0,0]],"v":[[143.372,111.004],[133.932,160.653],[149.401,204.841]]}],"t":14},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[13.284,45.727],[-3.811,-34.81],[0,0]],"o":[[0,0],[3.873,35.374],[0,0]],"v":[[141.233,103.671],[133.627,153.626],[148.484,200.869]]}],"t":36},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[13.284,45.727],[-3.811,-34.81],[0,0]],"o":[[0,0],[3.873,35.374],[0,0]],"v":[[145.233,110.171],[137.627,160.126],[152.484,207.369]]}],"t":81},{"s":[{"c":true,"i":[[13.284,45.727],[0.569,-35.014],[0,0]],"o":[[0,0],[-0.467,28.732],[0,0]],"v":[[144.733,115.671],[134.127,165.126],[149.984,207.369]]}],"t":144}],"ix":2}},{"ty":"fl","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Fill","nm":"undefined","c":{"a":0,"k":[0.5647,0.451,0.3608],"ix":4},"r":1,"o":{"a":0,"k":100,"ix":5}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]},{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":6,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[-3.874,-12.411],[-89.524,0],[0,0],[19.497,53.441],[30.751,-60.651],[-4.314,-17.428],[0,0]],"o":[[0,0],[84.84,0],[0,0],[-16.009,-43.882],[0,0],[4.314,17.428],[0,0]],"v":[[-144.505,214.423],[4.088,233.245],[150.561,214.423],[138.982,95.11],[-152.693,92.634],[-162.649,157.766],[-146.024,175.955]]}],"t":0},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[-3.874,-12.411],[-89.524,0],[0,0],[19.497,53.441],[30.751,-60.651],[-0.711,-17.94],[0,0]],"o":[[0,0],[84.84,0],[0,0],[-16.009,-43.882],[0,0],[0.711,17.94],[0,0]],"v":[[-142.755,208.978],[4.088,233.245],[149.977,211.895],[138.398,94.137],[-150.165,83.981],[-167.6,153.641],[-144.274,173.233]]}],"t":14},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[-3.874,-12.411],[-89.524,0],[0,0],[19.497,53.441],[30.751,-60.651],[-6.114,-16.881],[0,0]],"o":[[0,0],[84.84,0],[0,0],[-16.009,-43.882],[0,0],[6.114,16.881],[0,0]],"v":[[-140.005,200.423],[4.088,233.245],[149.061,207.923],[137.482,92.61],[-146.193,70.384],[-152.357,151.093],[-141.524,168.955]]}],"t":36},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":true,"i":[[-3.874,-12.411],[-89.524,0],[0,0],[19.497,53.441],[30.751,-60.651],[-4.314,-17.428],[0,0]],"o":[[0,0],[84.84,0],[0,0],[-16.009,-43.882],[0,0],[4.314,17.428],[0,0]],"v":[[-140.005,213.923],[1.088,234.245],[153.061,214.423],[141.482,99.11],[-146.193,70.384],[-158.149,150.766],[-141.524,168.955]]}],"t":81},{"s":[{"c":true,"i":[[-3.874,-12.411],[-89.524,0],[0,0],[19.497,53.441],[30.751,-60.651],[-4.314,-17.428],[0,0]],"o":[[0,0],[84.84,0],[0,0],[-16.009,-43.882],[0,0],[4.314,17.428],[0,0]],"v":[[-144.505,214.423],[4.088,233.245],[150.561,214.423],[138.982,95.11],[-152.693,92.634],[-162.649,157.766],[-146.024,175.955]]}],"t":144}],"ix":2}},{"ty":"fl","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Fill","nm":"undefined","c":{"a":0,"k":[0.949,0.949,0.949],"ix":4},"r":1,"o":{"a":0,"k":100,"ix":5}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]}],"ind":22,"parent":1},{"ty":4,"nm":"Слой-ÑигÑÑа 2","sr":1,"st":0,"op":81,"ip":70,"hd":false,"ddd":0,"bm":0,"hasMask":false,"ao":0,"ks":{"a":{"a":0,"k":[134.25,100,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6},"sk":{"a":0,"k":0},"p":{"a":0,"k":[-137.75,-144,0],"ix":2},"r":{"a":0,"k":0,"ix":10},"sa":{"a":0,"k":0},"o":{"a":0,"k":100,"ix":11}},"ef":[],"shapes":[{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":1,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[0,0],[12.207,1.753],[-27.687,14.78],[-1.655,-17.038],[6.207,25.79],[12.445,-18.738]],"o":[[11.404,-7.498],[0,0],[-22.344,-3.208],[0,0],[1.955,20.132],[0,0],[0,0]],"v":[[113.891,119.66],[132.779,99.681],[106.771,67.658],[132.779,99.681],[98.19,96.594],[132.779,99.681],[123.452,127.605]]}],"t":70},{"s":[{"c":false,"i":[[0,0],[0,0],[12.207,1.753],[-27.687,14.78],[-6.426,-15.867],[6.207,25.79],[-3.052,-16.667]],"o":[[2.282,-22.79],[0,0],[-22.344,-3.208],[0,0],[4.352,10.745],[0,0],[0,0]],"v":[[184.856,148.218],[183.279,106.181],[152.094,94.695],[183.279,106.181],[157.32,132.504],[183.279,106.181],[192.937,134.612]]}],"t":80}],"ix":2}},{"ty":"st","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Stroke","nm":"undefined","lc":2,"lj":2,"ml":1,"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":5,"ix":5},"c":{"a":0,"k":[0.3176,0.2392,0.7333],"ix":3}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]}],"ind":23,"parent":1},{"ty":4,"nm":"Слой-ÑигÑÑа 1","sr":1,"st":0,"op":140,"ip":134,"hd":false,"ddd":0,"bm":0,"hasMask":false,"ao":0,"ks":{"a":{"a":0,"k":[134.25,100,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6},"sk":{"a":0,"k":0},"p":{"a":0,"k":[135.25,-130,0],"ix":2},"r":{"a":0,"k":0,"ix":10},"sa":{"a":0,"k":0},"o":{"a":0,"k":100,"ix":11}},"ef":[],"shapes":[{"ty":"gr","bm":0,"hd":false,"mn":"ADBE Vector Group","nm":"undefined","ix":1,"cix":2,"np":2,"it":[{"ty":"sh","bm":0,"hd":false,"mn":"ADBE Vector Shape - Group","nm":"ÐонÑÑÑ 1","ix":1,"d":1,"ks":{"a":1,"k":[{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[0,0],[-13.602,1.753],[30.852,14.78],[7.161,-15.867],[-6.916,25.79],[3.401,-16.667]],"o":[[-2.543,-22.79],[0,0],[24.898,-3.208],[0,0],[-4.849,10.745],[0,0],[0,0]],"v":[[98.489,140.218],[100.246,98.181],[134.997,86.695],[100.246,98.181],[129.173,124.504],[100.246,98.181],[89.484,126.612]]}],"t":134},{"o":{"x":0.167,"y":0},"i":{"x":0.833,"y":1},"s":[{"c":false,"i":[[0,0],[0,0],[-13.602,1.753],[30.852,14.78],[7.161,-15.867],[-6.916,25.79],[3.401,-16.667]],"o":[[-2.543,-22.79],[0,0],[24.898,-3.208],[0,0],[-4.849,10.745],[0,0],[0,0]],"v":[[137.489,137.718],[139.246,95.681],[173.997,84.195],[139.246,95.681],[168.173,122.004],[139.246,95.681],[128.484,124.112]]}],"t":140},{"s":[{"c":false,"i":[[0,0],[0,0],[-13.602,1.753],[30.852,14.78],[7.161,-15.867],[-6.916,25.79],[3.401,-16.667]],"o":[[-2.543,-22.79],[0,0],[24.898,-3.208],[0,0],[-4.849,10.745],[0,0],[0,0]],"v":[[131.489,141.718],[133.246,99.681],[167.997,88.195],[133.246,99.681],[162.173,126.004],[133.246,99.681],[122.484,128.112]]}],"t":144}],"ix":2}},{"ty":"st","bm":0,"hd":false,"mn":"ADBE Vector Graphic - Stroke","nm":"undefined","lc":2,"lj":2,"ml":1,"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":5,"ix":5},"c":{"a":0,"k":[0.3176,0.2392,0.7333],"ix":3}},{"ty":"tr","a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"sk":{"a":0,"k":0,"ix":4},"p":{"a":0,"k":[0,0],"ix":2},"r":{"a":0,"k":0,"ix":6},"sa":{"a":0,"k":0,"ix":5},"o":{"a":0,"k":100,"ix":7}}]}],"ind":24,"parent":1}],"v":"5.9.0","fr":60,"op":144,"ip":0,"assets":[]}
\ No newline at end of file