From 52464d4486a70f1664689c3187fd6e757f152c5e Mon Sep 17 00:00:00 2001 From: Jean-Patrick Guerrero Date: Mon, 15 Aug 2022 20:15:43 +0200 Subject: [PATCH] Add checkbox to change the panel style (preview: https://i.imgur.com/gNPLf0B.png) --- init.lua | 1 + src/fields.lua | 10 +++- src/gui.lua | 121 ++++++++++++++++++++++++++-------------- src/styles.lua | 21 ++++--- textures/i3_all.png | Bin 0 -> 2346 bytes textures/i3_all_on.png | Bin 0 -> 1615 bytes textures/i3_item.png | Bin 0 -> 1809 bytes textures/i3_item_on.png | Bin 0 -> 1458 bytes textures/i3_node.png | Bin 0 -> 1487 bytes textures/i3_node_on.png | Bin 0 -> 1411 bytes 10 files changed, 100 insertions(+), 53 deletions(-) create mode 100644 textures/i3_all.png create mode 100644 textures/i3_all_on.png create mode 100644 textures/i3_item.png create mode 100644 textures/i3_item_on.png create mode 100644 textures/i3_node.png create mode 100644 textures/i3_node_on.png diff --git a/init.lua b/init.lua index bf344fb..960377c 100644 --- a/init.lua +++ b/init.lua @@ -53,6 +53,7 @@ i3 = { bag = true, home = true, font_size = true, + hide_tabs = true, waypoints = true, inv_items = true, known_recipes = true, diff --git a/src/fields.lua b/src/fields.lua index af2fa0c..5db3cbb 100644 --- a/src/fields.lua +++ b/src/fields.lua @@ -178,7 +178,7 @@ local function inv_fields(player, data, fields) for _, v in ipairs(data.waypoints) do if vec_eq(vec_round(pos), vec_round(str_to_pos(v.pos))) then play_sound(name, "i3_cannot", 0.8) - return msg(name, S"You already set a waypoint at this position") + return msg(name, S"You already have set a waypoint at this position") end end @@ -301,7 +301,7 @@ end local function rcp_fields(player, data, fields) local sb_rcp, sb_usg = fields.scrbar_rcp, fields.scrbar_usg - if fields.filter and fields.filter == "" then + if not data.hide_tabs and fields.filter and fields.filter == "" then data.enable_search = nil end @@ -312,7 +312,11 @@ local function rcp_fields(player, data, fields) data.query_item = nil elseif fields.enable_search then - data.enable_search = true + if data.hide_tabs then + data.enable_search = not data.enable_search + else + data.enable_search = true + end elseif fields.filter and (fields.key_enter_field == "filter" or fields.search) then if fields.filter == "" then diff --git a/src/gui.lua b/src/gui.lua index 0e2a2b2..e816767 100644 --- a/src/gui.lua +++ b/src/gui.lua @@ -299,7 +299,7 @@ end local function get_waypoint_fs(fs, data, player, yextra, ctn_len) fs(fmt("box[0,%f;4.9,0.6;#bababa25]", yextra + 1.1)) - label(0, yextra + 0.85, ES"Waypoint name:") + label(0, yextra + 0.85, ES"New waypoint" .. ":") fs(fmt("field[0.1,%f;4.8,0.6;waypoint_name;;]", yextra + 1.1)) image_button(5.1, yextra + 1.15, 0.5, 0.5, "", "waypoint_add", "") fs(fmt("tooltip[waypoint_add;%s]", ES"Add waypoint")) @@ -574,10 +574,10 @@ end local function show_settings(fs, data) if data.confirm_trash then - image(2.9, 10.65, 4.6, 0.7, PNG.bg_goto) - label(3.12, 11, "Confirm trash?") - image_button(5.17, 10.75, 1, 0.5, "", "confirm_trash_yes", "Yes") - image_button(6.27, 10.75, 1, 0.5, "", "confirm_trash_no", "No") + image(2.8, 10.65, 4.6, 0.7, PNG.bg_goto) + label(3.02, 11, "Confirm trash?") + image_button(5.07, 10.75, 1, 0.5, "", "confirm_trash_yes", "Yes") + image_button(6.17, 10.75, 1, 0.5, "", "confirm_trash_no", "No") elseif data.show_settings then image(2.2, 9, 6, 2.35, PNG.bg_content) @@ -623,18 +623,20 @@ local function show_settings(fs, data) image_button(4.2, 10.4, 1.8, 0.7, "", "set_home", "Set home") elseif show_style then + checkbox(2.6, 9.95, "cb_hide_tabs", "Hide tabs", tostring(data.hide_tabs)) + local sign = (data.font_size > 0 and "+") or (data.font_size > 0 and "-") or "" - label(2.6, 10.05, ES"Font size" .. fmt(": %s", sign .. data.font_size)) + label(2.6, 10.45, ES"Font size" .. fmt(": %s", sign .. data.font_size)) local range = 5 fs(fmt("scrollbaroptions[min=-%u;max=%u;smallstep=1;largestep=1;thumbsize=2]", range, range)) - fs(fmt("scrollbar[2.6,10.3;2.5,0.3;horizontal;sb_font_size;%d]", data.font_size)) + fs(fmt("scrollbar[2.6,10.65;2.5,0.3;horizontal;sb_font_size;%d]", data.font_size)) elseif show_sorting then - checkbox(2.6, 10.05, "cb_inv_compress", "Compression", tostring(data.inv_compress)) - checkbox(2.6, 10.5, "cb_reverse_sorting", "Reverse mode", tostring(data.reverse_sorting)) - checkbox(2.6, 10.95, "cb_ignore_hotbar", "Ignore hotbar", tostring(data.ignore_hotbar)) - checkbox(5.5, 10.05, "cb_auto_sorting", "Automation", tostring(data.auto_sorting)) + checkbox(2.6, 9.95, "cb_inv_compress", "Compression", tostring(data.inv_compress)) + checkbox(2.6, 10.4, "cb_reverse_sorting", "Reverse mode", tostring(data.reverse_sorting)) + checkbox(2.6, 10.85, "cb_ignore_hotbar", "Ignore hotbar", tostring(data.ignore_hotbar)) + checkbox(5.5, 9.95, "cb_auto_sorting", "Automation", tostring(data.auto_sorting)) local methods = {} @@ -643,11 +645,9 @@ local function show_settings(fs, data) insert(methods, name) end - fs"style_type[label;font_size=14]" - label(5.5, 10.45, ES"Sorting method:") + label(5.5, 10.4, ES"Sorting method:") fs(fmt("dropdown[%f,%f;2.3,0.5;dd_sorting_method;%s;%u;true]", 5.5, 10.6, concat(methods, ","), data.sort)) - fs"style_type[label;font_size=16]" local desc = i3.sorting_methods[data.sort].description if desc then @@ -1359,52 +1359,85 @@ local function hide_items(player, data) end end -local function get_header_items_fs(fs, data, full_height) - if data.enable_search then - fs("set_focus[filter]", - "style[filter;font_size=18;textcolor=#ccc]", - fmt("field[%f,0.2;3.35,0.6;filter;;%s]", data.inv_width + 0.85, ESC(data.filter)), - "field_close_on_enter[filter;false]") +local function get_header_items_fs(fs, data) + local X = data.inv_width + fs"set_focus[filter;true]" - image(data.inv_width + 0.85, 0.75, 4, 0.01, PNG.search_outline_trim .. "^[opacity:100") + if data.hide_tabs then + fs(fmt("style[enable_search;bgimg=%s;bgimg_hovered=%s;bgimg_pressed=%s]", + data.enable_search and PNG.search_hover or PNG.search, PNG.search_hover, PNG.search_hover)) + image_button(X + 0.3, 0.2, 0.5, 0.5, "", "enable_search", "") + fs(fmt("tooltip[enable_search;%s]", ES"Search")) + + if data.enable_search then + image(X + 0.4, 0.75, 3.4, 0.8, PNG.bg_goto) + + fs("style[filter;font_size=16]", + fmt("field[%f,%f;3,0.45;filter;;%s]", X + 0.6, 0.95, data.filter), + "field_close_on_enter[filter;false]") + end + + box(X + 1, 0.2, 0.01, 0.5, "#bababa50") + local cat = {{"all", "all items"}, {"node", "nodes only"}, {"item", "items only"}} + + for i, name in ipairs(cat) do + local name, desc = unpack(cat[i]) + local active = PNG[name .. "_hover"] + + fs(fmt("style[itab_%u;bgimg=%s;bgimg_hovered=%s;bgimg_pressed=%s;sound=i3_tab]", + i, data.itab == i and active or PNG[name], active, active)) + image_button(X + 1.25 + ((i - 1) * 0.7), 0.2, 0.5, 0.5, "", fmt("itab_%s", i), "") + fs(fmt("tooltip[itab_%u;Show %s]", i, desc)) + end else - fs"style_type[label;font=italic;font_size=18]" - label(data.inv_width + 0.9, 0.49, clr("#aaa", ES"Search...")) - button(data.inv_width + 0.8, 0.12, 4, 0.8, "enable_search", "") - fs"style_type[label;font=normal;font_size=16]" + fs(fmt("style[search;bgimg=%s]", PNG.search_hover)) + image_button(X + 0.35, 0.32, 0.35, 0.35, "", "search", "") + fs(fmt("tooltip[search;%s]", ES"Search")) + + if data.enable_search then + fs("style[filter;font_size=18]", + fmt("field[%f,0.2;3.35,0.6;filter;;%s]", X + 0.85, ESC(data.filter)), + "field_close_on_enter[filter;false]") + + image(X + 0.85, 0.75, 4, 0.01, PNG.search_outline_trim .. "^[opacity:100") + else + fs"style_type[label;font=italic;font_size=18]" + label(X + 0.9, 0.49, clr("#aaa", ES"Search...")) + button(X + 0.8, 0.12, 4, 0.8, "enable_search", "") + fs"style_type[label;font=normal;font_size=16]" + end + + if true_str(data.filter) then + image_button(X + 4.3, 0.4, 0.2, 0.2, "", "cancel", "") + fs(fmt("tooltip[cancel;%s]", ES"Clear")) + box(X + 0.85, 0.75, 3.74, 0.01, "#f9826c") + end end - image_button(data.inv_width + 0.35, 0.32, 0.35, 0.35, "", "search", "") - image_button(data.inv_width + 5.27, 0.3, 0.35, 0.35, "", "prev_page", "") - image_button(data.inv_width + 7.45, 0.3, 0.35, 0.35, "", "next_page", "") - - fs(fmt("tooltip[search;%s]", ES"Search")) - - if true_str(data.filter) then - image_button(data.inv_width + 4.3, 0.4, 0.2, 0.2, "", "cancel", "") - fs(fmt("tooltip[cancel;%s]", ES"Clear")) - box(data.inv_width + 0.85, 0.75, 3.74, 0.01, "#f9826c") - end + image_button(X + 5.27, 0.3, 0.35, 0.35, "", "prev_page", "") + image_button(X + 7.45, 0.3, 0.35, 0.35, "", "next_page", "") fs(fmt("style[pagenum;bgimg=%s;bgimg_hovered=%s;bgimg_middle=9;padding=-9;sound=i3_click]", data.goto_page and PNG.pagenum_hover or "", PNG.pagenum_hover)) - button(data.inv_width + 5.8, 0.14, 1.48, 0.7, "pagenum", + button(X + 5.8, 0.14, 1.48, 0.7, "pagenum", fmt("%s / %u", clr(colors.yellow, data.pagenum), data.pagemax)) if data.goto_page then - image(data.inv_width + 4.8, 0.85, 2.9, 0.8, PNG.bg_goto) + image(X + 4.8, 0.85, 2.9, 0.8, PNG.bg_goto) fs"style_type[label;font_size=16;textcolor=#ddd]" - label(data.inv_width + 5, 1.25, ES"Go to page" .. ":") - box(data.inv_width + 6.5, 1, 1, 0.45, "#bababa10") + label(X + 5, 1.25, ES"Go to page" .. ":") + box(X + 6.5, 1, 1, 0.45, "#bababa10") fs(fmt("style[goto_page;font=mono,bold;font_size=16;textcolor=%s]", colors.yellow), - fmt("field[%f,%f;1,0.45;goto_page;;%s]", data.inv_width + 6.55, 1.05, data.pagenum), + fmt("field[%f,%f;1,0.45;goto_page;;%s]", X + 6.55, 1.05, data.pagenum), "field_close_on_enter[goto_page;false]") fs"style_type[label;font_size=16;textcolor=#fff]" end +end +local function get_minitabs(fs, data, full_height) local _tabs = {"All", "Nodes", "Items"} local tab_len, tab_hgh = 1.8, 0.5 @@ -1474,7 +1507,7 @@ local function get_items_fs(fs, data, player, full_height) end end - get_header_items_fs(fs, data, full_height) + get_header_items_fs(fs, data) end local function get_favs(fs, data) @@ -1633,6 +1666,10 @@ local function make_fs(player, data) get_items_fs(fs, data, player, full_height) end + if not data.hide_tabs then + get_minitabs(fs, data, full_height) + end + local visible_tabs = #i3.tabs for _, def in ipairs(i3.tabs) do diff --git a/src/styles.lua b/src/styles.lua index 8215ed3..366d18f 100644 --- a/src/styles.lua +++ b/src/styles.lua @@ -51,6 +51,9 @@ local PNG = { find_more = "i3_find_more.png", search_outline = "i3_search_outline.png", search_outline_trim = "i3_search_outline_trim.png", + all = "i3_all.png", + node = "i3_node.png", + item = "i3_item.png", cancel_hover = "i3_cancel.png^\\[brighten", search_hover = "i3_search.png^\\[brighten", @@ -74,6 +77,9 @@ local PNG = { exit_hover = "i3_exit.png^\\[brighten", home_hover = "i3_home.png^\\[brighten", edit_hover = "i3_edit.png^\\[brighten", + all_hover = "i3_all_on.png^\\[brighten", + node_hover = "i3_node_on.png^\\[brighten", + item_hover = "i3_item_on.png^\\[brighten", } local styles = string.format([[ @@ -86,8 +92,8 @@ local styles = string.format([[ style[;sound=] style[nofav;sound=i3_cannot] + style[search;content_offset=0] style[pagenum,no_item,no_rcp;font=bold;font_size=18] - style[search;fgimg=%s;content_offset=0] style[enable_search:hovered;bgimg=%s] style[enable_search:pressed;bgimg=%s^[opacity:178] style[exit;fgimg=%s;fgimg_hovered=%s;content_offset=0] @@ -106,14 +112,13 @@ local styles = string.format([[ style[confirm_trash_yes;sound=i3_trash] ]], PNG.slot, -PNG.search_hover, PNG.search_outline, PNG.search_outline, -PNG.exit, PNG.exit_hover, -PNG.cancel, PNG.cancel_hover, -PNG.prev, PNG.prev_hover, -PNG.next, PNG.next_hover, -PNG.add, PNG.add_hover, -PNG.edit, PNG.edit_hover) +PNG.exit, PNG.exit_hover, +PNG.cancel, PNG.cancel_hover, +PNG.prev, PNG.prev_hover, +PNG.next, PNG.next_hover, +PNG.add, PNG.add_hover, +PNG.edit, PNG.edit_hover) local fs_elements = { label = "label[%f,%f;%s]", diff --git a/textures/i3_all.png b/textures/i3_all.png new file mode 100644 index 0000000000000000000000000000000000000000..c404271e091af3182a2af9f16ed5666fff8358d4 GIT binary patch literal 2346 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 N002ovPDHLkV1h-N>P-Lu literal 0 HcmV?d00001 diff --git a/textures/i3_item.png b/textures/i3_item.png new file mode 100644 index 0000000000000000000000000000000000000000..d5b50da17e1fc443772a2c93a6387ecb6242bf53 GIT binary patch literal 1809 zcmV+s2k!WZP);rl0FPNoB;44pG|l4fq_^qlwoZtwT~ z|72wJ;{jv>V}QGW7l19mkH8V29_RvMdJX}{fW5$G;6>nGpaLiah5?xwet7@^U_9^% za299+T7eD$?h*LQdXDPzb|9kT>wv$2Pl2a^JAfh}7YL*}0ok(PSp)Q1{-Po!44eYC z0S^J?Kt2#mRRXer>A)dbv_oL71h!3JoAkQJd><1TA>b!qIZy@U^~ED@nD@v+i-2{& zHzK1BxM2UWghCUjqIC-T`I_@;vIT60Zt|EsB4*sY7T5sXsgTM8#sZ6F^?DN; zQJ@j{3YZH_QusA^fOnerog!g+Qp4dY5@rD~3)rN}(P^w3kvBX76w9(Xiu=caeX?fE zB+BE!E+tg=c?)n5*a@6A3AP1z8yJxam7^GVKsVWF!lGNmtN|thL*zxnfT_T{z&VdM zSQ5h$SX1OdOGH9UMEnkvq>6ybQF&XTgxG14WLU{;rb}M(h+=ujL3x0!FzvwSz|A@~ zpd7Tz{O{As9f4HQ5kZB;{VI*k#+sLa{j%as0u)e=m;-#LQtL?Q0CvdwSt4PIDuGj^ z$AQvRl+!uDWMHilV$_ts6Tma-H-bii-YR!*G^AYwJ`?as`aa_EkWs0sDqU0cq$)+1 ziSt_E4JE{&Ile-qg*+te0KV`f$1}i#KyIoxS0h!k_enK603nsTO4l(egi3+er6jFh zXgBX0fYlOeDc@iPl=x;!3|%tGv625ClUzL)31flRq!(hIz9I~)mskpB_~jwZKU;GJ zE2Eo%t%~y@9#2?na)J{;yF{3;<_tkuY`tRovd5||Qi8X8NT^WayJ+SQ$E6sv{RDoz z#888Y<2GgVs8NnJuI!n_I9W-s-DLmm(i}m*Siaf=J}kFiEhQK=p0L%4A5$XdsQ!1G z+_6HMBj88ynTHRu1)es& zLq71h(Fa``$q#%&ybj=<>^&l}LY&czCcr8?J%qisNuUoBte8H)#i5x^71)nn2D%ajZ&f!_>4 zr?d>0nTnR5(2M1(d+X{%!WcC~&1S}UK-1v843%D@Y3KaU%?Gs!x2UsBK8#Vf1nO30Oj4-NI=?dSveS(2XftsI2Q~LI+WNtAf zvkth&*KVKS`cw>539-$y?r=2OZoerR*}f0= zR-i@ENSxg&JwPa#mfx7HY~M#On4#flG|qsvEp5S@`z+KZjn+5>bo#Q?UBeo~0&Ulc z_1gndIpz~ogmK!l)aA(m=hM>dal-98SMkupN7*)%b4P=GfL(h}gX#$_J^W70C_6Xbz> zjm#G+tTX!?^GR!IlSo8XZ=0^K)Y2vb-xvpcIX>H#@;~^&48HU#!6$W+Gf)JK)~18d zRhGKVshsVvg@A|6uIj-BUf_0`L19E72M2foY*2&HqaQs@9W>wtvNhi3fk6RY1ROFy zajOR&6$#UT57QdF2v{YMZqrdc@UxnRNLqsz0k;9WO(JyR5cOQr#6aoEHt{(!v)rO*?bOrw}E);A500000NkvXXu0mjfrbRv- literal 0 HcmV?d00001 diff --git a/textures/i3_item_on.png b/textures/i3_item_on.png new file mode 100644 index 0000000000000000000000000000000000000000..41dec85def795a3c5a1d3bb11259f4b47f65baa9 GIT binary patch literal 1458 zcmV;j1x@;iP)1q_NJ5;Q3@?pTeS3|=E4I# z*n(C;enIHz#;YEZi&m{YU{SD*Q7f&2n$xbXmZWAAcSmpj124nOW)9u#?6(~lhF#{H z_xb<7=lMT}_x)C^=;MW9Y{E7879PQqcmaoT0`+`O;-7d7598a|j&raMYcRZGsk~6b z7W^Eq<1HM;OaRXY{CoMF%m0tzNWOmv&*PW485dza#!wq{0!DHNUoU|6@}3JR(|85H z!VNeZ;~47U#;n5X*jQUA0#@RqcrJHzCScy{<6RFKllU{ff%6g`wGM!fV=F#}9k@Cn zHnAW?WWi74$M|)~IE4Qc@!u;M@8V7T2{**&l)cX+3Y3xayPh_1& z{C_+lbF9U+vv@k8R6ErfV`W_TGCYL+aqWJ*;UD-?LT_l-u3fdH&nxhI{I>y(5?aBe)TRupS@q*xlv z9wWwn0H44UZB)F|aCo30j770F@jtHw7l?$_xEPP-j`l*rWU|Bhf$u8Y5U~muq-L1v zfrPoF$SQLhWogf`=*xzQ_t2@L={L+X>+x zDhIx48}9OX1n~r3tR(otwsk3PF5Ct;RTnq@q#+usVw*=FSx&j7SwUP(%_5Y z=(?N@sQ2vwO9_0D5jMA|3ubY!(%=ibC-B{zUMsV}zRH7-?IYPHKh!iSexmZ=i!eAl zLz6}}I0}^qU*K4e-xZ^?X?$~8fDe|_V@Knd-fOseS%5EQhu3Egupd9erey)X(1CGW zicbaK@Uj5kqC9SS=(_UYmyO{4AAAqs&*~HW)RF`r0yg08KEdCYZLg&TJ_LL*$4HkS z_z_?oMmC{J@8RkFVYq&rdNi9>Eemc*^u%o?rJ`nQAH9y9H4u%lhSxv^M=NwX;sAjJ}~6zYevtDKmY&$ M07*qoM6N<$g6{0qSO5S3 literal 0 HcmV?d00001 diff --git a/textures/i3_node.png b/textures/i3_node.png new file mode 100644 index 0000000000000000000000000000000000000000..b4b483a93d379e7688fd376bc7b1bac8090c96ef GIT binary patch literal 1487 zcmV;=1u*)FP)Y8xfqM!6-Py5fKM8Mp1D_O^n8kD_rOb7rHVU-RMR)xKKaD;DpgQ z5{%I}#(9i!7Elo<1f?6ap}XCjPF`N#D_&Q6E;f@;Bz@X@C|yf1>fUt9E(X9y|Zn60uID=cn_PQ3z$LVj0-v_WAf8ZrtiD?)+5;r~?lW__jz)$!$HrkJW zuog>Wti{&EzyFJM@!eB{GscV*bKe~^aSOf-KOa2dZD9q^;-avQsW>kP@fY+aETkv6 z;!YeH9MaLM8y}DTaV_4&#)O~uh2Ou8MK~Zn-w|UR_Qf@L9e;*941V`7yo>9DOUAbh z5ZEQIumyN3=M=xf?KmRu6a$Fea2RgJ=jcvZ&+l<;(nYQTr;}a=Dr(d;6{9g%^6I-5)12P^02JEaRHvrxIwz{ zMR3hw!95*SZ+;x6hp)bd4H>@rQQYMR#r@w=0=FCx8sgmyZrO;pf?M{BHFlJ}@iFMa znRpoMQ+~b$-vwJAg+0nN%Y=%Y6(|06#_jSeR^XhloL$QD^F44h?utz&g-dUM@mOg4 zt}5^ASkGRV7aCz*N?&XZO|b+g1ec7i7x4*U#y8-@Fz>#EpKrh`xH{Zo+|s2>JDS8p zg9`HsycoB`_Jl=l#;3RmhYU$pS2}q$F~*P%smSK%#1&JGc~#>UMcnk!kk#XAP1cF~ zLW%V!qP2g*8WxmBFxBK4x^On0k2Mb@EO%2JY-g=Wy6||M_CR9v;K8ttJzFtePguh2 z2(Wrmd)OL#>#7HU{)pE<8E)S%zy%+~TKmfYpg$pRlf?2et{U!mJveJxim$I37pM$?j7-q^1u{X07tQA-EbY(&nW0PaEUj_?8qEdf%r(^9;DjBlty%zf zkPYsxkqw@jl+z(&r_{&}Z%N!Xg|fp<1t6myFc2$f*gwpQ;INk4^ub^7CYk zux?E;>;M#~3iqdit*zk#rBsPq27naNb>a*x4>uS{#2hOkmM^7GpydEaMQ}62%(ut* zIP`sKdBv6mApW0e(I+qnzuCa)OXqxHV3`JAr*l257+bg{{SypP>m<~tOo!9002ovPDHLkV1hdFzhnRa literal 0 HcmV?d00001 diff --git a/textures/i3_node_on.png b/textures/i3_node_on.png new file mode 100644 index 0000000000000000000000000000000000000000..b49c9dc8a16b9d6bf6cc0f4c6124a6338c173eb0 GIT binary patch literal 1411 zcmV-}1$_F6P)0R!s%LIKC( zD!hoLxE>==7;w10(1M|ugeUML_Fym8VLm2f7+McE!;iqpcmSVb2fA=DRu^{SE6l~I z7>t(wZhRY#$E{d~tvHY}Ji9uv4e#J?j7EEZG`tl@<03qRU+^!wdoVs(-SOVv@GLG1 z%_#Jj<30pu;chww$X zqOJxsJP(LnScOM$M%iI?eBegB8Lp?Z9~hn&R&U395sD8kXZJ^8UPNL08uZAQ>N3|w z_BpELQxKvz5;x%G5SRn~$oM2^dL6e!&{QZ@^x8T)I$CnV+vQaZZ)@om(_!-|p=B*$ zQ(I9{4CBW{WH%ylBUMgtYI)p?CQd0gJ}qo)%>$qvGooOz08`U$B$eV`94YRvWu&;Z zT>Fcq&N*)U6I_~`Lj(XbBbh1cMp8wN+rvw2?IV3iiYM>lp4i#;B5wTipvLB~u}1*5 z&9@!)6*57_@BdZVf=k#yuVbcRTY5rkKTjtBY!xj zNDy)@Ug)7_cp!H2HOvZE+m@+9O~9jAU12a*69CeD-4VgYoZ#l56ki7hhiBu%;C5#( zK3BWvdZLSLd<#2gYtUT?QT!wZu900}C ze0)aD3z?v*x89@S0O-k|7c%vS(YUKh@k7G_kd5dTh1exRH?~F*WWxcF&|*Vyybx=0 zJgaqT-4FmAjO1!+3V^Bc>|hgsCIC$UngBEbXadj#pb0<|fF=M<0Ga^Q8-O-k5GAT| zDy{tifTTjTCTwggc11oUYH+pe_^dYo=?>Fb7}8fgzx4*7@*d+lG)2@Bfa-Ob>s{Y} zy#c7*oI$E7;x@cdg{FvV15o=(lPWhwR11Lm&l)K{{ncGZ01}=j%@XyWHcK@{%nZ(L zDnlQ713*$*Uz}=|=(~BMOjE?$C0=S&0zhZ#a^=3HS)!w(qwhy&a;~*j9^zW78~~E$ z=hb=55{)=6S4vYvDFF0%!P@BKbLpmtCH_BPaVP+iEB04$lWGk>^Z_l>%?;@hn_>VY zBQPIln~MO>>YE5tr=$Rw63^;81l0%nFg%*6=0{&&0>H$0HlyA={}2BxYA;H- ROeO#T002ovPDHLkV1h^lhc*BJ literal 0 HcmV?d00001