@next-bricks/form 1.16.1 → 1.16.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chunks/8653.d5c60d3b.js","mappings":";kLAGIA,QAA0B,GAA4B,KAE1DA,EAAwBC,KAAK,CAACC,EAAOC,GAAI,2rEAEilE,KAE1nE,QAAeH,EAAwBI,uCCAvCF,EAAOG,QANP,SAAwCC,GACtC,IAAIC,EAAmD,KACnDA,GACFD,EAAaE,aAAa,QAASD,EAEvC,+ECLIP,QAA0B,GAA4B,KAE1DA,EAAwBC,KAAK,CAACC,EAAOC,GAAI,2oIAIy6C,KAEl9C,QAAeH,EAAwBI,yFCRnCJ,QAA0B,GAA4B,KAE1DA,EAAwBC,KAAK,CAACC,EAAOC,GAAI,+BAAgC,KAEzE,QAAeH,EAAwBI,kCCqDvCF,EAAOG,QAjBP,SAAgBI,GACd,GAAwB,oBAAbC,SACT,MAAO,CACLC,OAAQ,WAAmB,EAC3BC,OAAQ,WAAmB,GAG/B,IAAIN,EAAeG,EAAQI,mBAAmBJ,GAC9C,MAAO,CACLE,OAAQ,SAAgBG,IAjD5B,SAAeR,EAAcG,EAASK,GACpC,IAAIC,EAAM,GACND,EAAIE,WACND,GAAO,cAAcE,OAAOH,EAAIE,SAAU,QAExCF,EAAII,QACNH,GAAO,UAAUE,OAAOH,EAAII,MAAO,OAErC,IAAIC,OAAiC,IAAdL,EAAIM,MACvBD,IACFJ,GAAO,SAASE,OAAOH,EAAIM,MAAMC,OAAS,EAAI,IAAIJ,OAAOH,EAAIM,OAAS,GAAI,OAE5EL,GAAOD,EAAIC,IACPI,IACFJ,GAAO,KAELD,EAAII,QACNH,GAAO,KAELD,EAAIE,WACND,GAAO,KAET,IAAIO,EAAYR,EAAIQ,UAChBA,GAA6B,oBAATC,OACtBR,GAAO,uDAAuDE,OAAOM,KAAKC,SAASC,mBAAmBC,KAAKC,UAAUL,MAAe,QAKtIb,EAAQmB,kBAAkBb,EAAKT,EAAcG,EAAQA,QACvD,CAoBMoB,CAAMvB,EAAcG,EAASK,EAC/B,EACAF,OAAQ,YArBZ,SAA4BN,GAE1B,GAAgC,OAA5BA,EAAawB,WACf,OAAO,EAETxB,EAAawB,WAAWC,YAAYzB,EACtC,CAgBM0B,CAAmB1B,EACrB,EAEJ,gFCxDIN,QAA0B,GAA4B,KAE1DA,EAAwBC,KAAK,CAACC,EAAOC,GAAI,+rBAKmO,KAE5Q,QAAeH,EAAwBI,yFCTnCJ,QAA0B,GAA4B,KAE1DA,EAAwBC,KAAK,CAACC,EAAOC,GAAI,sNACiE,KAE1G,gCCRoED,EAAOG,QAAgL,SAAU4B,GAAG,aAAqF,IAAIC,EAA5E,SAAWD,GAAG,OAAOA,GAAG,iBAAiBA,GAAG,YAAYA,EAAEA,EAAE,CAACE,QAAQF,EAAE,CAAOG,CAAEH,GAAGI,EAAE,CAACC,KAAK,QAAQC,SAAS,8BAA8BC,MAAM,KAAKC,cAAc,uBAAuBD,MAAM,KAAKE,YAAY,gBAAgBF,MAAM,KAAKG,OAAO,wCAAwCH,MAAM,KAAKI,YAAY,yCAAyCJ,MAAM,KAAKK,QAAQ,SAASZ,EAAEG,GAAG,MAAM,MAAMA,EAAEH,EAAE,IAAIA,EAAE,GAAG,EAAEa,UAAU,EAAEC,UAAU,EAAEC,QAAQ,CAACC,GAAG,QAAQC,IAAI,WAAWC,EAAE,aAAaC,GAAG,YAAYC,IAAI,kBAAkBC,KAAK,sBAAsBC,EAAE,WAAWC,GAAG,YAAYC,IAAI,kBAAkBC,KAAK,uBAAuBC,aAAa,CAACC,OAAO,MAAMC,KAAK,MAAMC,EAAE,KAAKC,EAAE,OAAOC,GAAG,QAAQC,EAAE,OAAOC,GAAG,QAAQ7B,EAAE,MAAM8B,GAAG,OAAOC,EAAE,OAAOC,GAAG,QAAQC,EAAE,MAAMC,GAAG,QAAQC,SAAS,SAASvC,EAAEG,GAAG,IAAIF,EAAE,IAAID,EAAEG,EAAE,OAAOF,EAAE,IAAI,KAAKA,EAAE,IAAI,KAAKA,EAAE,KAAK,KAAKA,EAAE,KAAK,KAAKA,EAAE,KAAK,KAAK,IAAI,GAAG,OAAOA,EAAEC,QAAQsC,OAAOpC,EAAE,MAAK,GAAIA,CAAE,CAAjlCD,CAAE,EAAQ,8BCE7F,IAAIsC,EAAc,GAClB,SAASC,EAAqBC,GAE5B,IADA,IAAIC,GAAU,EACLC,EAAI,EAAGA,EAAIJ,EAAYrD,OAAQyD,IACtC,GAAIJ,EAAYI,GAAGF,aAAeA,EAAY,CAC5CC,EAASC,EACT,KACF,CAEF,OAAOD,CACT,CACA,SAASE,EAAaC,EAAMvE,GAG1B,IAFA,IAAIwE,EAAa,CAAC,EACdC,EAAc,GACTJ,EAAI,EAAGA,EAAIE,EAAK3D,OAAQyD,IAAK,CACpC,IAAIK,EAAOH,EAAKF,GACZ3E,EAAKM,EAAQ2E,KAAOD,EAAK,GAAK1E,EAAQ2E,KAAOD,EAAK,GAClDE,EAAQJ,EAAW9E,IAAO,EAC1ByE,EAAa,GAAG3D,OAAOd,EAAI,KAAKc,OAAOoE,GAC3CJ,EAAW9E,GAAMkF,EAAQ,EACzB,IAAIC,EAAoBX,EAAqBC,GACzC9D,EAAM,CACRC,IAAKoE,EAAK,GACVjE,MAAOiE,EAAK,GACZ7D,UAAW6D,EAAK,GAChBnE,SAAUmE,EAAK,GACf/D,MAAO+D,EAAK,IAEd,IAA2B,IAAvBG,EACFZ,EAAYY,GAAmBC,aAC/Bb,EAAYY,GAAmBE,QAAQ1E,OAClC,CACL,IAAI0E,EAAUC,EAAgB3E,EAAKL,GACnCA,EAAQiF,QAAUZ,EAClBJ,EAAYiB,OAAOb,EAAG,EAAG,CACvBF,WAAYA,EACZY,QAASA,EACTD,WAAY,GAEhB,CACAL,EAAYjF,KAAK2E,EACnB,CACA,OAAOM,CACT,CACA,SAASO,EAAgB3E,EAAKL,GAC5B,IAAImF,EAAMnF,EAAQoF,OAAOpF,GAYzB,OAXAmF,EAAIjF,OAAOG,GACG,SAAiBgF,GAC7B,GAAIA,EAAQ,CACV,GAAIA,EAAO/E,MAAQD,EAAIC,KAAO+E,EAAO5E,QAAUJ,EAAII,OAAS4E,EAAOxE,YAAcR,EAAIQ,WAAawE,EAAO9E,WAAaF,EAAIE,UAAY8E,EAAO1E,QAAUN,EAAIM,MACzJ,OAEFwE,EAAIjF,OAAOG,EAAMgF,EACnB,MACEF,EAAIhF,QAER,CAEF,CACAV,EAAOG,QAAU,SAAU2E,EAAMvE,GAG/B,IAAIsF,EAAkBhB,EADtBC,EAAOA,GAAQ,GADfvE,EAAUA,GAAW,CAAC,GAGtB,OAAO,SAAgBuF,GACrBA,EAAUA,GAAW,GACrB,IAAK,IAAIlB,EAAI,EAAGA,EAAIiB,EAAgB1E,OAAQyD,IAAK,CAC/C,IACImB,EAAQtB,EADKoB,EAAgBjB,IAEjCJ,EAAYuB,GAAOV,YACrB,CAEA,IADA,IAAIW,EAAqBnB,EAAaiB,EAASvF,GACtC0F,EAAK,EAAGA,EAAKJ,EAAgB1E,OAAQ8E,IAAM,CAClD,IACIC,EAASzB,EADKoB,EAAgBI,IAEK,IAAnCzB,EAAY0B,GAAQb,aACtBb,EAAY0B,GAAQZ,UACpBd,EAAYiB,OAAOS,EAAQ,GAE/B,CACAL,EAAkBG,CACpB,CACF,yBC1EAhG,EAAOG,QANP,SAA4BI,GAC1B,IAAI4F,EAAU3F,SAAS4F,cAAc,SAGrC,OAFA7F,EAAQ8F,cAAcF,EAAS5F,EAAQ+F,YACvC/F,EAAQgG,OAAOJ,EAAS5F,EAAQA,SACzB4F,CACT,yBCKAnG,EAAOG,QAVP,SAA2BU,EAAKT,GAC9B,GAAIA,EAAaoG,WACfpG,EAAaoG,WAAWC,QAAU5F,MAC7B,CACL,KAAOT,EAAasG,YAClBtG,EAAayB,YAAYzB,EAAasG,YAExCtG,EAAauG,YAAYnG,SAASoG,eAAe/F,GACnD,CACF,gFCTIf,QAA0B,GAA4B,KAE1DA,EAAwBC,KAAK,CAACC,EAAOC,GAAI,+QAE8J,KAEvM,QAAeH,EAAwBI,6BCT6BF,EAAOG,QAAuJ,WAAY,aAAa,IAAI6B,EAAE,QAAQ6E,EAAE,UAAU,OAAO,SAAS9E,EAAE6C,GAAG,IAAIkC,EAAElC,EAAEmC,UAAUD,EAAEE,QAAQ,SAAShF,GAAG,OAAOiF,KAAKC,SAASC,EAAEnF,GAAGoF,KAAKC,MAAMJ,KAAKK,QAAQ,GAAG,GAAGL,KAAKK,MAAML,KAAKK,QAAQ,EAAE,GAAGtF,EAAE,GAAG,EAAE,IAAI4B,EAAEkD,EAAES,IAAIT,EAAES,IAAI,SAASxF,EAAE6C,GAAG,OAAO7C,EAAEyF,OAAOzF,GAAGkF,KAAKC,SAASO,EAAE7C,KAAKiC,EAAEI,KAAKM,IAAI,EAAExF,EAAEC,GAAG4B,EAAE8D,KAAKT,KAAPrD,CAAa7B,EAAE6C,EAAE,EAAE,IAAIuC,EAAEL,EAAEa,QAAQb,EAAEa,QAAQ,SAAS5F,EAAE6C,GAAG,IAAIkC,EAAEG,KAAKC,SAAStD,IAAIkD,EAAEK,EAAEvC,IAAIA,EAAE,GAAGkC,EAAEW,EAAE1F,KAAK8E,EAAE,CAAC,IAAIe,EAAEX,KAAKD,UAAU,EAAE,OAAOpD,EAAEqD,KAAKK,MAAM,EAAEM,GAAGD,QAAQ3F,GAAG2F,QAAQ,OAAOV,KAAKK,MAAM,EAAEM,EAAE,GAAGC,MAAM7F,GAAG6F,MAAM,MAAM,CAAC,OAAOV,EAAEO,KAAKT,KAAPE,CAAapF,EAAE6C,EAAE,CAAC,CAAE,CAA9qBiC,iFCG/E/G,QAA0B,GAA4B,KAE1DA,EAAwBC,KAAK,CAACC,EAAOC,GAAI,qnLAAsnL,KAE/pL,QAAeH,EAAwBI,yFCJnCJ,QAA0B,GAA4B,KAE1DA,EAAwBC,KAAK,CAACC,EAAOC,GAAI,2DAA4D,KAErG,QAAeH,EAAwBI,yFCJnCJ,QAA0B,GAA4B,KAE1DA,EAAwBC,KAAK,CAACC,EAAOC,GAAI,46TACA,KAEzC,QAAeH,EAAwBI,yFCLnCJ,QAA0B,GAA4B,KAE1DA,EAAwBC,KAAK,CAACC,EAAOC,GAAI,wzFAMuL,KAEhO,QAAeH,EAAwBI,yFCVnCJ,QAA0B,GAA4B,KAE1DA,EAAwBC,KAAK,CAACC,EAAOC,GAAI,sLAAuL,KAEhO,QAAeH,EAAwBI,yFCJnCJ,QAA0B,GAA4B,KAE1DA,EAAwBC,KAAK,CAACC,EAAOC,GAAI,+7EAE80E,KAEv3E,QAAeH,EAAwBI,yFCNnCJ,QAA0B,GAA4B,KAE1DA,EAAwBC,KAAK,CAACC,EAAOC,GAAI,k3BAIF,KAEvC,QAAeH,EAAwBI,yFCRnCJ,QAA0B,GAA4B,KAE1DA,EAAwBC,KAAK,CAACC,EAAOC,GAAI,k2CAAm2C,KAE54C,QAAeH,EAAwBI,yFCJnCJ,QAA0B,GAA4B,KAE1DA,EAAwBC,KAAK,CAACC,EAAOC,GAAI,i4BAAk4B,KAE36B,QAAeH,EAAwBI,kCCLvC,IAAI4H,EAAO,CAAC,EA+BZ9H,EAAOG,QAPP,SAA0BoG,EAAQwB,GAChC,IAAIC,EAtBN,SAAmBA,GACjB,QAA4B,IAAjBF,EAAKE,GAAyB,CACvC,IAAIC,EAAczH,SAAS0H,cAAcF,GAGzC,GAAIG,OAAOC,mBAAqBH,aAAuBE,OAAOC,kBAC5D,IAGEH,EAAcA,EAAYI,gBAAgBC,IAC5C,CAAE,MAAOvG,GAEPkG,EAAc,IAChB,CAEFH,EAAKE,GAAUC,CACjB,CACA,OAAOH,EAAKE,EACd,CAIeO,CAAUhC,GACvB,IAAKyB,EACH,MAAM,IAAIQ,MAAM,2GAElBR,EAAOrB,YAAYoB,EACrB,gFC7BIjI,QAA0B,GAA4B,KAE1DA,EAAwBC,KAAK,CAACC,EAAOC,GAAI,g5FAW2a,KAEpd,QAAeH,EAAwBI,6BClB6BF,EAAOG,QAAiJ,WAAY,aAAa,IAAI4B,EAAE,MAAM,OAAO,SAASC,EAAE4C,EAAEhB,GAAG,IAAI6E,EAAE,SAASzG,GAAG,OAAOA,EAAEuF,IAAI,EAAEvF,EAAE0G,aAAa3G,EAAE,EAAEI,EAAEyC,EAAEmC,UAAU5E,EAAEwG,YAAY,WAAW,OAAOF,EAAExB,MAAM2B,MAAM,EAAEzG,EAAE0G,QAAQ,SAAS7G,GAAG,IAAIiF,KAAKC,SAASC,EAAEnF,GAAG,OAAOiF,KAAKM,IAAI,GAAGvF,EAAEiF,KAAK4B,WAAW9G,GAAG,IAAI6C,EAAIiC,EAAEe,EAAEd,EAAE2B,EAAExB,MAAME,GAAGvC,EAAEqC,KAAK0B,cAAgEf,EAAE,GAA1Cf,GAARI,KAAK6B,GAAQlF,EAAEmF,IAAInF,KAAKgF,KAAKhE,GAAG+C,QAAQ,SAAce,aAAa7B,EAAE6B,aAAa,IAAId,GAAG,GAAGf,EAAEU,IAAIK,EAAE7F,IAAI,OAAO+E,EAAEkC,KAAK7B,EAAE,QAAQ,CAAC,EAAEhF,EAAEuG,WAAW,SAAS3G,GAAG,OAAOkF,KAAKC,SAASC,EAAEpF,GAAGkF,KAAKgC,OAAO,EAAEhC,KAAKgC,IAAIhC,KAAKgC,MAAM,EAAElH,EAAEA,EAAE,EAAE,EAAE,IAAI8E,EAAE1E,EAAEwF,QAAQxF,EAAEwF,QAAQ,SAAS5F,EAAEC,GAAG,IAAI4C,EAAEqC,KAAKC,SAAStD,IAAIgB,EAAEuC,EAAEnF,IAAIA,EAAE,MAAM,YAAY4C,EAAE6C,EAAE1F,GAAG6B,EAAEqD,KAAKiC,KAAKjC,KAAKiC,QAAQjC,KAAKyB,aAAa,IAAIf,QAAQ,OAAOV,KAAKiC,KAAKjC,KAAKiC,OAAO,GAAGjC,KAAKyB,aAAa,GAAG,GAAGb,MAAM,OAAOhB,EAAEa,KAAKT,KAAPJ,CAAa9E,EAAEC,EAAE,CAAC,CAAE,CAAj5BA,+MCGnF,MAaMmH,EAAe,CACnB,iBACA,cACA,cACA,iBACA,cACA,cACA,YACA,eACA,iBACA,iBACA,QACA,cACA,eACA,gBACA,eACA,aACA,aACA,eAGF,IAAIC,ECzBJ,MAAMC,EAAS,uBAAuBC,KAAKC,UAAUC,UACjD,UACA,UAuBSC,EAAqBC,EAAAA,WAGhCC,GAEF,SAASA,EAAwBC,EAkB/BC,GACmB,IAjBjBC,WAAYC,EAAW,QACvBC,EAAO,QACPC,EAAO,WACPC,EAAU,YACVC,EAAW,aACXC,EACAC,MAAOC,EAAS,MAChBvC,EAAK,WACLwC,EAAU,SACVC,EAAQ,SACRC,EAAQ,UACRC,EAAS,mBACTC,EAAkB,iBAClBC,KACGC,GACqBjB,EAG1B,MAAME,EAAaC,SAAAA,GACZM,EAAOS,IAAYC,EAAAA,EAAAA,UAAST,QAAAA,EAAa,IAC1CU,GAAcC,EAAAA,EAAAA,QAA4B,OACzCC,EAAWC,IAAgBJ,EAAAA,EAAAA,UAAqC,OAEvEK,EAAAA,EAAAA,qBACEvB,GACA,KAAM,CACJwB,MAAOA,KACL,MAAMC,EAAWN,EAAYO,QAE7B,GAAID,EAAU,KAAAE,EACZ,MAAMC,EAA4B,QAAjBD,EAAGF,EAASjB,aAAK,IAAAmB,OAAA,EAAdA,EAAgBrK,OACpCmK,EAASD,QACTI,GAAeH,EAASI,kBAAkBD,EAAaA,EACzD,MAGJ,IAGF,MAAME,GAAeC,EAAAA,EAAAA,cAAY,KAC/B,MAAMN,EAAWN,EAAYO,QAC7B,GAAID,GAAYxB,EAAY,CAC1B,MAAM/B,EDpCG,SACb8D,EACAtL,GAEA,MAAM,QACJyJ,EAAU,KAAI,QACdC,EAAU,KAAI,WACdC,EAAa,EAAC,YACdC,EAAc,GACZ5J,QAAAA,EAAW,CAAC,EAEX6I,IACHA,EAAiB5I,SAAS4F,cAAc,YACxCgD,EAAe9I,aAAa,YAAa,MACzC8I,EAAe9I,aAAa,cAAe,QAC3CE,SAASsL,KAAKnF,YAAYyC,IAG5B,MAAM2C,EAAkB5D,OAAO6D,iBAAiBH,GAC1CI,EAAc9C,EAAa+C,KAC9B9J,GAAS,GAAGA,KAAQ2J,EAAgBI,iBAAiB/J,OACtDgK,KAAK,KASP,IAAIC,EACAC,EACAC,EARJnD,EAAe9I,aACb,QACA,GAAG2L,wSAEL7C,EAAeiB,MAAQwB,EAAWxB,OAASwB,EAAWW,aAAe,GAMrE,IAAIC,EAASrD,EAAesD,aAAexC,EAE3C,GAAgB,OAAZF,GAAgC,OAAZC,EAAkB,CACxC,MAAM0C,EAGAC,WACEzE,OACG6D,iBAAiB5C,GACjB+C,iBAAiB,gBAEZ,OAAZnC,IACFqC,EAAYM,EAAkB3C,EAAUG,EAAcD,EACtDuC,EAASrF,KAAKyF,IAAIR,EAAWI,IAEf,OAAZxC,IACFqC,EAAYK,EAAkB1C,EAAUE,EAAcD,EAClDuC,GAAUH,IACZC,EAAY,UAEdE,EAASrF,KAAK0F,IAAIR,EAAWG,GAEjC,CAEA,MAAM1E,EAA6B,CACjC0E,SACAF,YACAQ,OAAQ,QAUV,OAPIV,IACFtE,EAAMsE,UAAYA,GAEhBC,IACFvE,EAAMuE,UAAYA,GAGbvE,CACT,CCpCoBiF,CAAuB1B,EAAU,CAC7CtB,UACAC,UACAC,aACAC,iBAMA8C,EAAAA,EAAAA,YAAU,KACR9B,EAAapD,EAAM,GAGzB,IACC,CAAC+B,EAAYG,EAASD,EAASE,EAAYC,KAS9C+C,EAAAA,EAAAA,YAAU,KACRpC,EAASR,QAAAA,EAAa,GAAG,GACxB,CAACA,KAEJ4C,EAAAA,EAAAA,YAAU,KACRvB,GAAc,GACb,CAACA,EAActB,IAElB,MAAM8C,GAAiBlC,EAAAA,EAAAA,SAAO,GAExBmC,GAAyBxB,EAAAA,EAAAA,cAC5B7J,IACCoL,EAAe5B,SAAU,EACzBZ,SAAAA,EAAqB5I,EAAE,GAEzB,CAAC4I,IAGG0C,GAAuBzB,EAAAA,EAAAA,cAC1B7J,IACCoL,EAAe5B,SAAU,EACzBX,SAAAA,EAAmB7I,EAAE,GAEvB,CAAC6I,IAGG0C,GAAgB1B,EAAAA,EAAAA,cACnB7J,IACKoL,EAAe5B,UAMP,UAAVxJ,EAAEwL,MACc,wBAAfhD,GACIxI,EAAEyL,SACY,mBAAfjD,GAAmCxI,EAAEsH,MAEzCtH,EAAE0L,iBACF1L,EAAE2L,kBACFjD,SAAAA,EAAW1I,IAGb2I,SAAAA,EAAY3I,GAAE,GAEhB,CAAC2I,EAAWD,EAAUF,IAuCxB,OAnCA2C,EAAAA,EAAAA,YAAU,KACR,MAAMS,EAAYvD,aAAY,EAAZA,EAAcmB,QAChC,IAAKoC,IAAc7D,EACjB,OAEF,IAAI8D,EACJ,MAAMC,EAAW,IAAIC,EAAAA,GAAgBC,IACnC,IAAK,MAAMC,KAASD,EAClB,GAAIC,EAAMhG,SAAW2F,EAAW,CAE9B,MAAMM,EAAoBD,EAAME,eAC5BF,EAAME,eAAe,GACnBF,EAAME,eAAe,GAAGC,WACvBH,EAAME,eACJC,WACLH,EAAMI,YAAYC,MACtB,QACwBC,IAAtBL,GACAA,IAAsBL,EACtB,CACA,MAAMW,GAAaX,EACnBA,EAAqBK,EAChBM,GACHC,sBAAsB7C,EAE1B,CACF,CACF,IAGF,OADAkC,EAASY,QAAQd,GACV,KACLE,EAASa,YAAY,CACtB,GACA,CAAC5E,EAAYM,EAAcuB,IAG5BjC,EAAAA,cAAA,YAAAiF,EAAAA,EAAAA,GAAA,GACM9D,EAAK,CACThB,IAAKmB,EACLX,MAAOA,EACPtC,MAAO,IACFA,KACAmD,GAELV,SApGFzI,IAEA+I,EAAS/I,EAAEiG,OAAOqC,OAClBG,SAAAA,EAAWzI,EAAE,EAkGX4I,mBAAoByC,EACpBxC,iBAAkByC,EAClB3C,UAAW4C,IAGjB,mICrMA,MAAMsB,IAAkBC,EAAAA,EAAAA,WAAmC,iBA4BrD,cAAEC,GAAa,SAAEC,GAAUC,MAAK,UAAEC,KAAWC,EAAAA,EAAAA,oBAEnD,IAAAC,GAAA,IAAAC,GAAA,IAAAC,QAAAC,GAAA,IAAAD,QAAAE,GAAA,IAAAF,QAAAG,GAAA,IAAAH,QAAAI,GAAA,IAAAJ,QAAAK,GAAA,IAAAL,QAAAM,GAAA,IAAAN,QAAAO,GAAA,IAAAP,QAAAQ,GAAA,IAAAR,QAAAS,GAAA,IAAAT,QAAAU,GAAA,IAAAV,QAAAW,GAAA,IAAAX,QAAAY,GAAA,IAAAZ,QAAAa,GAAA,IAAAb,QAAAc,GAAA,IAAAd,QAAAe,GAAA,IAAAC,QAKA,MAAAC,WAIuBC,EAAAA,EAA6CC,WAAAA,GAAA,SAAAC,YAAAC,EAAAA,EAAAA,GAAA,KAAAN,KAClEO,EAAAA,EAAAA,GAAA,KAAAvB,IAAawB,EAAA,OAAGC,EAAAA,EAAAA,gBAEhBF,EAAAA,EAAAA,GAAA,KAAArB,GAAAwB,EAAA,QAKAH,EAAAA,EAAAA,GAAA,KAAApB,IAAAwB,EAAA,MAAAC,EAAA,SAKAL,EAAAA,EAAAA,GAAA,KAAAnB,IAAAyB,EAAA,MAAAC,EAAA,SAKAP,EAAAA,EAAAA,GAAA,KAAAlB,IAAA0B,EAAA,MAAAC,EAAA,SAKAT,EAAAA,EAAAA,GAAA,KAAAjB,IAAA2B,EAAA,MAAAC,EAAA,SAQAX,EAAAA,EAAAA,GAAA,KAAAhB,IAAA4B,EAAA,MAAAC,EAAA,SAQAb,EAAAA,EAAAA,GAAA,KAAAf,IAAA6B,EAAA,MAAAC,EAAA,SAQAf,EAAAA,EAAAA,GAAA,KAAAd,IAAA8B,EAAA,MAAAC,EAAA,SAQAjB,EAAAA,EAAAA,GAAA,KAAAb,IAAA+B,EAAA,MAAAC,EAAA,SAQAnB,EAAAA,EAAAA,GAAA,KAAAZ,IAAAgC,EAAA,MAAAC,EAAA,SAQArB,EAAAA,EAAAA,GAAA,KAAAX,IAAAiC,EAAA,MAAAC,EAAA,SAQAvB,EAAAA,EAAAA,GAAA,KAAAV,IAAAkC,EAAA,MAAAC,EAAA,SAQAzB,EAAAA,EAAAA,GAAA,KAAAT,IAAAmC,GAAA,MAAAC,GAAA,SAOA3B,EAAAA,EAAAA,GAAA,KAAAR,IAAAoC,GAAA,MAAAC,GAAA,SAAAC,EAAAA,EAAAA,GAAA,0BAAAC,GAAA,MAeqBrI,IACnBpD,KAAKoD,MAAQA,GACbsI,EAAAA,EAAAA,GAAAvC,GAAAnJ,KAAK2L,IAAkBC,KAAKxI,EAAM,GACnC,SA1GoBjI,GAAI,OAAA0Q,EAAAA,EAAAA,GAAAxD,GAAA,cAAJlN,CAAI2Q,IAAAC,EAAAA,EAAAA,GAAA1D,GAAA,KAAAyD,EAAA,UAKJE,GAAK,OAAAH,EAAAA,EAAAA,GAAAvD,GAAA,eAAL0D,CAAKF,IAAAC,EAAAA,EAAAA,GAAAzD,GAAA,KAAAwD,EAAA,UAKL1I,GAAK,OAAAyI,EAAAA,EAAAA,GAAAtD,GAAA,eAALnF,CAAK0I,IAAAC,EAAAA,EAAAA,GAAAxD,GAAA,KAAAuD,EAAA,gBAKLvG,GAAW,OAAAsG,EAAAA,EAAAA,GAAArD,GAAA,qBAAXjD,CAAWuG,IAAAC,EAAAA,EAAAA,GAAAvD,GAAA,KAAAsD,EAAA,aAQvBG,GAAQ,OAAAJ,EAAAA,EAAAA,GAAApD,GAAA,kBAARwD,CAAQH,IAAAC,EAAAA,EAAAA,GAAAtD,GAAA,KAAAqD,EAAA,cAQRI,GAAS,OAAAL,EAAAA,EAAAA,GAAAnD,GAAA,mBAATwD,CAASJ,IAAAC,EAAAA,EAAAA,GAAArD,GAAA,KAAAoD,EAAA,cAQTK,GAAS,OAAAN,EAAAA,EAAAA,GAAAlD,GAAA,mBAATwD,CAASL,IAAAC,EAAAA,EAAAA,GAAApD,GAAA,KAAAmD,EAAA,aAQTM,GAAQ,OAAAP,EAAAA,EAAAA,GAAAjD,GAAA,kBAARwD,CAAQN,IAAAC,EAAAA,EAAAA,GAAAnD,GAAA,KAAAkD,EAAA,aAQRO,GAAQ,OAAAR,EAAAA,EAAAA,GAAAhD,GAAA,kBAARwD,CAAQP,IAAAC,EAAAA,EAAAA,GAAAlD,GAAA,KAAAiD,EAAA,QAQRlG,GAAG,OAAAiG,EAAAA,EAAAA,GAAA/C,GAAA,aAAHlD,CAAGkG,IAAAC,EAAAA,EAAAA,GAAAjD,GAAA,KAAAgD,EAAA,QAQHjG,GAAG,OAAAgG,EAAAA,EAAAA,GAAA9C,GAAA,aAAHlD,CAAGiG,IAAAC,EAAAA,EAAAA,GAAAhD,GAAA,KAAA+C,EAAA,YAQHQ,GAAO,OAAAT,EAAAA,EAAAA,GAAA7C,GAAA,iBAAPsD,CAAOR,IAAAC,EAAAA,EAAAA,GAAA/C,GAAA,KAAA8C,EAAA,kBAKyBS,GAAa,OAAAV,EAAAA,EAAAA,GAAA5C,GAAA,uBAAbsD,CAAaT,IAAAC,EAAAA,EAAAA,GAAA9C,GAAA,KAAA6C,EAAA,CAetDU,aAAAA,GAAgB,IAAAC,EACd,OAAiC,QAAjCA,GAAOZ,EAAAA,EAAAA,GAAK1D,GAALnI,MAAmBsE,eAAO,IAAAmI,OAAA,EAA1BA,EAA4BrI,OACrC,CAOAsI,MAAAA,GACE,OAEEjK,IAAAA,cAACkK,GAAiB,CAChBC,WAAY5M,KACZ6M,YAAa7M,KAAK8M,iBAClB3R,KAAM6E,KAAK7E,KACX6Q,MAAOhM,KAAKgM,MACZ5I,MAAOpD,KAAKoD,MACZiJ,SAAUrM,KAAKqM,SACf9G,YAAavF,KAAKuF,YAClB0G,SAAUjM,KAAKiM,SACfC,UAAWlM,KAAKkM,UAChBC,UAAWnM,KAAKmM,UAChBC,SAAUpM,KAAKoM,SACfW,UAAW/M,KAAK+M,UAChBC,WAAYhN,KAAKgN,WACjBC,UAAWjN,KAAKiN,UAChBV,cAAevM,KAAKuM,cACpBW,cAAelN,KAAKkN,cACpBtH,IAAK5F,KAAK4F,IACVC,IAAK7F,KAAK6F,IACVyG,QAAStM,KAAKsM,QACda,QAAQ,oBACRvK,KAAKiJ,EAAAA,EAAAA,GAAK1D,GAALnI,MACLoN,cAAepN,KAAKqN,mBAG1B,EACDC,EAAAjE,KAAAvO,GAAA+O,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,GAAAC,GAAAC,GAAAC,GAAAI,GAAA4B,GAAA9B,GAAA9B,GAAA6D,GAAAtF,GAAAuF,KAAAC,EAAAA,EAAAA,GAAAJ,EAAA,CAnJAzF,GAAc,cAAe,CAC5B8F,WAAY,CAACC,EAAAA,GACbC,MAAO,CAAC,4BACR,EAOC/F,KAAU,WAKVA,KAAU,YAKVA,KAAU,YAKVA,KAAU,kBAKVA,GAAS,CACRgG,KAAMC,UACN,eAMDjG,GAAS,CACRgG,KAAMvN,SACN,gBAMDuH,GAAS,CACRgG,KAAMvN,SACN,gBAMDuH,GAAS,CACRkG,WAAW,IACX,eAMDlG,GAAS,CACRgG,KAAMC,UACN,eAMDjG,GAAS,CACRgG,KAAMvN,SACN,UAMDuH,GAAS,CACRgG,KAAMvN,SACN,UAMDuH,GAAS,CACRkG,WAAW,IACX,cAMDlG,GAAS,CAAEkG,WAAW,IAAQ,oBAQ9BjG,GAAM,CAAE+F,KAAM,WAAW,qBAAAnN,IAAAkL,EAAAA,EAAAA,GAAA3C,GAAAvI,GAAA,CAAAA,EAAAmL,KAAAC,EAAAA,EAAAA,GAAA7C,GAAAvI,EAAAmL,IAAA,CAMzB9D,GAAO,CAAEiG,OAAO,IAAO,uBAAAhT,GAAAkN,GAAA+F,KAAAC,EAAAA,EAAAA,GAAAlT,KAxGHqO,EAAAA,IAAmBmE,IAiJnC,MAAMd,IAAoByB,EAAAA,EAAAA,aAG/B,SAA2BxK,EAAOhB,GAAK,IAAAyL,EACvC,MAAM,KACJlT,EAAI,MACJiI,EAAK,YACLmC,EAAW,SACX0G,EAAQ,cACRM,EAAa,UACbL,EAAS,UACTC,EAAS,SACTC,EAAQ,cACRc,EAAa,cACbE,GACExJ,GACGb,EAASC,GAAWP,IAAAA,SAAc,IACnC2J,GAAgC,iBAAbA,EACd,CAACA,EAASrJ,QAASqJ,EAASpJ,SAG9B,IACN,CAACoJ,IAEEkC,GAActK,EAAAA,EAAAA,QAAiB,MAE/BuK,GAAe5J,EAAAA,EAAAA,cAClB7J,IACCsS,EAActS,EAAEiG,OAAOqC,MAAM,GAE/B,CAACgK,IAGH,OACE3K,IAAAA,cAACkF,IAAeD,EAAAA,EAAAA,GAAA,CACd8G,YAAY,YACRC,EAAAA,EAAAA,GAAkB7K,GAAM,CAC5BhB,IAAK0L,IAEL7L,IAAAA,cAACD,EAAkB,CACjBI,IAAKA,EACLO,aAAcmL,EACdzL,aAAcuJ,EACdrJ,QAASA,EACTC,QAASA,EACT0L,UAAWC,IAAW,CACpBC,MAAyB,UAAlB1B,IAET/R,KAAMA,EACNiI,MAAOA,EACP6I,SAAUA,EACVnL,MAAO,IAGDsL,EACA,CACE5G,OAEI,IADmB,iBAAb4G,GAAyC,QAApBiC,EAAIjC,EAASrJ,eAAO,IAAAsL,EAAAA,EAAS,GAE1D,IAEJ,QACD9B,GAELhH,YAAaA,EACb2G,UAAWA,EACXC,UAAWA,EACX5I,SAAUgL,IAIlB,8BC5QgCM,GAAA,IAAAzG,QAAA0G,GAAA,IAAA1G,QAEzB,MAAM2G,GAAOxF,WAAAA,IAClBG,EAAAA,EAAAA,GAAA,KAAAmF,GAA+D,CAAC,IAChEnF,EAAAA,EAAAA,GAAA,KAAAoF,GAAU,EAAE,CAEZE,OAAAA,CAAQC,EAAepK,GACrB,KAAKgH,EAAAA,EAAAA,GAAKgD,GAAL7O,MAAaiP,GAChB,OAEF,MAAMC,GAAcrD,EAAAA,EAAAA,GAAKgD,GAAL7O,MAAaiP,GACjC,IAAIE,EAAMD,EAAcA,EAAYhV,OAAS,EAC7C,KAAOiV,KACLD,EAAYC,GAAKC,KAAKH,EAAOpK,EAEjC,CAEAwK,SAAAA,CAAUJ,EAAeK,GAAkD,IAAAC,GACpE1D,EAAAA,EAAAA,GAAKgD,GAAL7O,MAAaiP,MAChBpD,EAAAA,EAAAA,GAAKgD,GAAL7O,MAAaiP,GAAS,IAExB,MAAMO,GAAWzD,EAAAA,EAAAA,GAAK+C,GAAL9O,MAAIuP,GAAJ1D,EAAAA,EAAAA,GAAKiD,GAAL9O,QAAYuP,IAAEtW,WAK/B,OAJA4S,EAAAA,EAAAA,GAAKgD,GAAL7O,MAAaiP,GAAOnW,KAAK,CACvB0W,MAAOA,EACPJ,KAAME,IAEDE,CACT,CAEAC,WAAAA,CAAYD,GACV,IAAK,MAAM5S,KAAKiP,EAAAA,EAAAA,GAAKgD,GAAL7O,OACV6L,EAAAA,EAAAA,GAAKgD,GAAL7O,MAAapD,KACfnD,EAAAA,GAAAA,SAAOoS,EAAAA,EAAAA,GAAKgD,GAAL7O,MAAapD,IAAKoB,GAASA,EAAKwR,QAAUA,GAGvD,ECKF,IAAIE,GAAM,EAEV,MAAMC,GAGJpG,WAAAA,CAAYpO,EAAcyU,IAAqBpE,EAAAA,EAAAA,GAAA,sBAAAA,EAAAA,EAAAA,GAAA,sBAC7CxL,KAAK6P,MAAQ1U,EACb6E,KAAK4P,OAASA,CAChB,EACD,OAAAE,GAAA,IAAA1H,QAAA2H,GAAA,IAAA3H,QAAA4H,GAAA,IAAA5H,QAAA6H,GAAA,IAAA7H,QAAA8H,GAAA,IAAA9G,QAEM,MAAM+G,WAAkBpB,GAG7B,kBAAOqB,CAAY9W,GAMjB,OALK0G,KAAKqQ,SAASC,IAAIZ,MACrB1P,KAAK0P,IAAMA,GACX1P,KAAKqQ,SAASE,IAAIvQ,KAAK0P,IAAK,IAAIS,GAAU7W,IAC1CoW,IAAO,GAEF1P,KAAKqQ,SAASC,IAAItQ,KAAK0P,IAChC,CAOAnG,WAAAA,CAAYjQ,GACVkX,SAAQ/G,EAAAA,EAAAA,GAAA,KAAAyG,KANVxG,EAAAA,EAAAA,GAAA,KAAAoG,GAA8B,IAAIW,MAClC/G,EAAAA,EAAAA,GAAA,KAAAqG,QAAQ,IACRrG,EAAAA,EAAAA,GAAA,KAAAsG,QAAS,IACTtG,EAAAA,EAAAA,GAAA,KAAAuG,QAAS,IAIPlE,EAAAA,EAAAA,GAAKiE,GAALhQ,KAAiB,CAAC,IAClB+L,EAAAA,EAAAA,GAAKgE,GAAL/P,KAAgB1G,EAClB,CAEAoX,QAAAA,CAASvV,EAAcyU,IACrB/D,EAAAA,EAAAA,GAAKiE,GAAL9P,MAAauQ,IAAIpV,EAAM,IAAIwU,GAAMxU,EAAMyU,GACzC,CAOAe,YAAAA,GACE,MAAMC,GAAYC,EAAAA,GAAAA,GAAAX,GAAAlQ,KAAK8Q,IAAaC,KAAlB/Q,MAWlB,OAViBgR,OAAOC,YACtBD,OAAOlK,SAAQ+E,EAAAA,EAAAA,GAAKmE,GAALhQ,OACZiF,KAAItC,IAAY,IAAVuO,EAAGpF,GAAEnJ,EACV,OAAIiO,EAAUO,SAASD,GACd,CAACA,EAAGpF,GAEN,EAAE,IAEVsF,QAAQpT,GAASA,EAAK9D,SAG7B,CAEAmX,YAAAA,CAAaC,GAA4D,IAA3BC,IAAkB/H,UAAAtP,OAAA,QAAAmN,IAAAmC,UAAA,KAAAA,UAAA,IAC9DuC,EAAAA,EAAAA,GAAKkE,GAALjQ,KAAiBsR,GACjBtR,KAAKwR,eAAeF,EAAQC,EAC9B,CAEAE,wBAAAA,CAAyBtW,GAAc,IAAAsR,EACrC,MAAMrJ,EAAsB,QAAjBqJ,GAAGZ,EAAAA,EAAAA,GAAKoE,GAALjQ,aAAc,IAAAyM,OAAA,EAAdA,EAAiBtR,IAC1BuW,EAAAA,GAAAA,OAAMtO,MACTyI,EAAAA,EAAAA,GAAKmE,GAALhQ,MAAe7E,GAAQiI,EACvBpD,KAAKgP,QAAQ,GAAG7T,eAAmBiI,GAEvC,CAEAoO,cAAAA,CAAeF,GAA4D,IAA3BC,IAAkB/H,UAAAtP,OAAA,QAAAmN,IAAAmC,UAAA,KAAAA,UAAA,GAChE,MAAMmI,EAAuC,KACxC9F,EAAAA,EAAAA,GAAKmE,GAALhQ,OASmB,IAAA4R,EAAAC,EAPxBb,OAAOlK,QAAQwK,GAAQQ,SAAQC,IAAY,IAAVb,EAAGpF,GAAEiG,EACpCJ,EAAYT,GAAKpF,GACjBD,EAAAA,EAAAA,GAAKoE,GAALjQ,SAAmB6L,EAAAA,EAAAA,GAAKoE,GAALjQ,MAAekR,GAAKpF,GACvC9L,KAAKgP,QAAQ,GAAGkC,eAAgBpF,EAAE,KAEpCC,EAAAA,EAAAA,GAAKiE,GAALhQ,KAAiB2R,GAEbJ,IACW,QAAbK,GAAA/F,EAAAA,EAAAA,GAAKkE,GAAL/P,aAAa,IAAA4R,GAAiB,QAAjBC,EAAbD,EAAeI,uBAAe,IAAAH,GAA9BA,EAAAd,KAAAa,EAAiC,CAC/BK,cAAeX,EACfY,UAAWlS,KAAK2Q,iBAGtB,CAEAwB,WAAAA,CAAYhX,GACNA,UACK0Q,EAAAA,EAAAA,GAAKmE,GAALhQ,MAAe7E,GACtB6E,KAAKgP,QAAQ,GAAG7T,iBAAqB,SAErC4Q,EAAAA,EAAAA,GAAKiE,GAALhQ,KAAiB,CAAC,GAClBA,KAAKgP,QAAQ,eAAgB,OAE/BhP,KAAKoS,oBACP,CAEAC,cAAAA,CAAelX,GACb,OAAIA,GACK0Q,EAAAA,EAAAA,GAAKmE,GAALhQ,MAAe7E,GAEjB6E,KAAK2Q,cACd,CAEA2B,WAAAA,CAAYnX,IACV0Q,EAAAA,EAAAA,GAAKiE,GAAL9P,MAAauS,OAAOpX,EACtB,CAEAqX,cAAAA,CACEC,GAEA,MAAM7B,GAAYC,EAAAA,GAAAA,GAAAX,GAAAlQ,KAAK8Q,IAAaC,KAAlB/Q,MACZ0S,EAA0C,GAQhD,GAPA9B,EAAUkB,SAAS3W,IACjB,MAAM0U,GAAQhE,EAAAA,EAAAA,GAAKiE,GAAL9P,MAAasQ,IAAInV,GAC3B0U,GACF6C,EAAQ5Z,KAAKkH,KAAK2S,cAAc9C,EAAMD,QACxC,IAGE8C,EAAQE,MAAMlV,GAA4B,YAAjBA,aAAM,EAANA,EAAQoQ,QAKnC,OAJA2E,GACE,EACAC,EAAQtB,QAAQ1T,GAA4B,YAAjBA,aAAM,EAANA,EAAQoQ,UAE9B,EACF,CACL,MAAM+E,EAAW7S,KAAK2Q,eAEtB,OADA8B,GAAS,EAAOI,GACTA,CACT,CACF,CAEAF,aAAAA,CAAc9C,GAA6B,IAAAiD,EACzC,MAAMC,EACa,iBAAVlD,EAA4C,QAA1BiD,GAAGjH,EAAAA,EAAAA,GAAKiE,GAAL9P,MAAasQ,IAAIT,UAAM,IAAAiD,OAAA,EAAvBA,EAAyBlD,OAASC,EAChE,IAAKkD,EAAa,OAClB,MAAM,KAAE5X,EAAI,MAAE6Q,EAAK,SAAEgH,GAAaD,EAC5BE,GAAgBpH,EAAAA,EAAAA,GAAKmE,GAALhQ,MAAe7E,GAE/B+X,EAAc,SAAC5G,GACnB,MAAO,CACLwB,KAFsCtE,UAAAtP,OAAA,QAAAmN,IAAAmC,UAAA,GAAAA,UAAA,GAAG,QAGzC8C,UAEJ,EAEM6G,EAAUA,IAAMnH,QAAAA,EAAS7Q,EAkFzBuC,EAAS,CAAEvC,UAhFHiY,EACZJ,EACA5P,KAEA,MAAM,SAAEiJ,EAAQ,QAAEgH,EAAO,QAAE/G,EAAO,KAAEwB,EAAI,IAAEjI,EAAG,IAAED,EAAG,UAAE0N,GAClDN,EACIhH,EAAQmH,IAEd,GACmB,iBAAV/P,GACHmQ,EAAAA,GAAAA,SAAQnQ,QACEiE,IAAVjE,GAAiC,KAAVA,EAE3B,OAAIiJ,EACK6G,GAAY5G,aAAO,EAAPA,EAASD,WAAY,GAAGL,SAEtCkH,EAAY,GAAI,UAGzB,MAAMM,EAAcC,OAAOrQ,GAE3B,GAAIiQ,IACU,IAAIK,OAAOL,GACdhR,KAAKmR,GACZ,OAAON,GACL5G,aAAO,EAAPA,EAAS+G,UAAW,GAAGrH,WAAeqH,KAK5C,MAAMM,EAA0B,iBAAR9N,EAClB+N,EAA0B,iBAARhO,EACxB,GAAI+N,GAAYC,EACd,GAAa,WAAT9F,EAAmB,CACrB,MAAM+F,EACa,iBAAVzQ,EAAqBA,EAAQuC,WAAWvC,GACjD,GAAIuQ,GAAYE,EAAchO,EAC5B,OAAOqN,GAAY5G,aAAO,EAAPA,EAASzG,MAAO,GAAGmG,SAAanG,KAErD,GAAI+N,GAAYC,EAAcjO,EAC5B,OAAOsN,GAAY5G,aAAO,EAAPA,EAAS1G,MAAO,GAAGoG,SAAapG,IAEvD,KAAO,CACL,GAAI+N,GAAYH,EAAYtZ,OAAS2L,EACnC,OAAOqN,GACL5G,aAAO,EAAPA,EAASzG,MAAO,GAAGmG,SAAanG,SAGpC,GAAI+N,GAAYJ,EAAYtZ,OAAS0L,EACnC,OAAOsN,GACL5G,aAAO,EAAPA,EAAS1G,MAAO,GAAGoG,SAAapG,QAGtC,CAGF,GAAI0N,EAAW,CACb,IAAI5V,EAAS,GACToW,EAAkB,GAClBC,MAAMC,QAAQV,GAChBQ,EAAkBR,EAElBQ,EAAgBhb,KAAKwa,GAGvB,IAAK,MAAMxH,KAAKgI,EAGd,GAFApW,EAASoO,EAAE1I,GAEP1F,EACF,MAGJ,MAAyB,iBAAXA,EACVwV,EAAYxV,EAAQA,EAAS,QAAU,UACtCA,CACP,CAEA,OAAOwV,EAAY,GAAI,SAAS,EAGRE,CAAMJ,EAAUC,IAE1C,OADAjT,KAAKgP,QAAQ,GAAG7T,aAAiBuC,GAC1BA,CACT,CAEAuW,iBAAAA,CAAkBnZ,GAChB,IAAKA,IAAMA,EAAEiG,OACX,OAAOjG,EAET,MAAMiG,EAASjG,EAAEiG,OACjB,MAAuB,aAAhBA,EAAO+M,KAAsB/M,EAAOmT,QAAUnT,EAAOqC,KAC9D,CAEAgP,kBAAAA,GACEpS,KAAKgP,QAAQ,iBAAkB,KACjC,CAEAmF,OAAAA,CACEhZ,EACA4M,EACA0K,EACAnZ,GAEA,MAAMuW,GAAQhE,EAAAA,EAAAA,GAAKiE,GAAL9P,MAAasQ,IAAInV,GAE/B,GAAI0U,EAAO,KAAAuE,EACT,MAAMhR,EAAQpD,KAAKiU,kBAAkBlM,GAE/BsM,EAAYN,MAAMC,QAAQ5Q,GAASA,EAAM,GAAKA,EAEpDpD,KAAKwR,eAAe,CAClB,CAACrW,GAAOkZ,KAGe,QAAzBD,EAAI9a,aAAO,EAAPA,EAASgb,oBAAY,IAAAF,GAAAA,IACvBpU,KAAK2S,cAAc9C,EAAMD,QAE3B6C,SAAAA,EAAU/X,MAAMsF,KAAMoD,EACxB,CACF,CAEAG,QAAAA,CACEpI,EACAiI,EACAqP,EACAnZ,GAEA,MAAMuW,GAAQhE,EAAAA,EAAAA,GAAKiE,GAAL9P,MAAasQ,IAAInV,GAEpB,IAAAoZ,EAAP1E,IACF7P,KAAKwR,eAAe,CAClB,CAACrW,GAAOiI,KAGe,QAAzBmR,EAAIjb,aAAO,EAAPA,EAASgb,oBAAY,IAAAC,GAAAA,IACvBvU,KAAK2S,cAAc9C,EAAMD,QAE3B6C,SAAAA,EAAWrP,GAEf,EACD,SAAA0N,KA/PG,MAAO,KAAIjF,EAAAA,EAAAA,GAAKiE,GAAL9P,MAAawU,QAAQpD,QAAQ9K,IAAQ,IAAAmO,EAC9C,QAAqC,QAA9BA,GAAC5I,EAAAA,EAAAA,GAAKiE,GAAL9P,MAAasQ,IAAIhK,GAAMsJ,cAAM,IAAA6E,GAA7BA,EAA+B1H,UAAS,GAEpD,oFAACvB,EAAAA,EAAAA,GA9BU2E,GAAS,eAAA3E,EAAAA,EAAAA,GAAT2E,GAAS,WAEsB,IAAIM,KC1ChD,MAAQ5I,cAAa,GAAEC,SAAQ,GAAEC,MAAK,GAAEC,OAAMA,KAAKC,EAAAA,EAAAA,oBAAmB,IAAAyM,GAAA,IAAAC,GAAA,IAAAvM,QAAAwM,GAAA,IAAAxL,QAAAf,GAAA,IAAAD,QAAAE,GAAA,IAAAF,QAAAG,GAAA,IAAAH,QAAAI,GAAA,IAAAJ,QAAAK,GAAA,IAAAL,QAAAM,GAAA,IAAAN,QAAAO,GAAA,IAAAP,QAAAQ,GAAA,IAAAR,QAAAS,GAAA,IAAAT,QA0BtE,MAAAyM,WAGmBC,EAAAA,iBAKjBvL,WAAAA,GACEiH,SAAO/G,EAAAA,EAAAA,GAAA,KAAAmL,KAAApJ,EAAAA,EAAAA,GAAA,sBAAA7B,GAAA,QAAAD,EAAAA,EAAAA,GAAA,KAJTiL,QAAO,IAAAnJ,EAAAA,EAAAA,GAAA,gCACmB,IAAI9B,EAAAA,EAAAA,GAAA,KAAArB,GAAA0M,GAAA,QAAArL,EAAAA,EAAAA,GAAA,KAAApB,IAAA0M,GAAA,MAAAC,GAAA,KAmCQ,eAAUvL,EAAAA,EAAAA,GAAA,KAAAnB,IAAA2M,GAAA,MAAAC,GAAA,SAAAzL,EAAAA,EAAAA,GAAA,KAAAlB,IAAA4M,GAAA,MAAAC,GAAA,KAalB,CAC5BC,GAAI,CACFC,KAAM,IAERC,GAAI,CACFD,KAAM,IAERE,GAAI,CACFF,KAAM,GAERG,GAAI,CACFH,KAAM,GAERI,IAAK,CACHJ,KAAM,QAET7L,EAAAA,EAAAA,GAAA,KAAAjB,IAAAmN,GAAA,MAAAC,GAAA,KAQ+B,CAC9BP,GAAI,CACFC,KAAM,IAERC,GAAI,CACFD,KAAM,IAERE,GAAI,CACFF,KAAM,IAERG,GAAI,CACFH,KAAM,IAERI,IAAK,CACHJ,KAAM,SAET7L,EAAAA,EAAAA,GAAA,KAAAhB,IAAAoN,GAAA,MAAAC,GAAA,SAAAvK,EAAAA,EAAAA,GAAA,2BAAAwK,GAAA,MASqB1E,KACpB5F,EAAAA,EAAAA,GAAAkJ,GAAA5U,KAAKiW,IAAmBrK,KAAK0F,EAAO,KACrC5H,EAAAA,EAAAA,GAAA,KAAAf,GAAAuN,GAAA,QAAAxM,EAAAA,EAAAA,GAAA,KAAAd,IAAAuN,GAAA,MAAAC,GAAA,SAAA1M,EAAAA,EAAAA,GAAA,KAAAb,IAAAwN,GAAA,MAAAC,GAAA,QAAAC,GAAA,MA/FCvW,KAAKwW,UAAYrG,GAAUC,YAAY,CACrC4B,gBAAiBhS,KAAKyW,oBAE1B,CAEA,iBAAIC,GACF,OAAO,CACT,CAEA,UAAIpF,CAAOlO,IACT2I,EAAAA,EAAAA,GAAK4I,GAAL3U,KAAeoD,IAEfyN,EAAAA,GAAAA,GAAA+D,GAAA5U,KAAK2W,IAAa5F,KAAlB/Q,KAAmBoD,EACrB,CACA,UAAIkO,GACF,OAAOzF,EAAAA,EAAAA,GAAK8I,GAAL3U,KACT,CAWA,gBAFS4W,GAAY,OAAA/K,EAAAA,EAAAA,GAAAxD,GAAA,sBAAZuO,CAAY9K,IAAAC,EAAAA,EAAAA,GAAA1D,GAAA,KAAAyD,EAAA,CAQrB,UAFqB+K,GAAM,OAAAhL,EAAAA,EAAAA,GAAAvD,GAAA,gBAANuO,CAAM/K,IAAAC,EAAAA,EAAAA,GAAAzD,GAAA,KAAAwD,EAAA,CAO3B,QAFqBgL,GAAI,OAAAjL,EAAAA,EAAAA,GAAAtD,GAAA,cAAJuO,CAAIhL,IAAAC,EAAAA,EAAAA,GAAAxD,GAAA,KAAAuD,EAAA,CA0BzB,YAlBSiL,GAAQ,OAAAlL,EAAAA,EAAAA,GAAArD,GAAA,kBAARuO,CAAQjL,IAAAC,EAAAA,EAAAA,GAAAvD,GAAA,KAAAsD,EAAA,CA0CjB,cAlBSkL,GAAU,OAAAnL,EAAAA,EAAAA,GAAApD,GAAA,oBAAVuO,CAAUlL,IAAAC,EAAAA,EAAAA,GAAAtD,GAAA,KAAAqD,EAAA,CA8CnBkH,QAAAA,GACE,OAAOhT,KAAKwW,UAAUhE,gBAAe,CAACyE,EAAK3F,KAGlC,IAAA4F,EAFHD,GACFvL,EAAAA,EAAAA,GAAAkJ,GAAA5U,KAAKmX,IAAYvL,KAAK0F,IAEtB5F,EAAAA,EAAAA,GAAAkJ,GAAA5U,KAAKoX,IAAcxL,KAAK,IACD,QAArBsL,EAAIlX,KAAK4W,oBAAY,IAAAM,EAAAA,EAAI,CAAC,KACvB5F,GAEP,GAEJ,CAMAD,YAAAA,CACEC,EACAhY,GAEIA,GACFA,EAAQ+d,gBACNC,gBAAe,KACbtX,KAAKsR,OAASA,CAAM,IAExBhY,EAAQie,gBACNC,YAAW,KACTxX,KAAKsR,OAASA,CAAM,KAGxBtR,KAAKsR,OAASA,CAElB,CAMAa,WAAAA,CAAYhX,GACV6E,KAAKwW,UAAUrE,YAA4B,iBAAThX,EAAoBA,OAAOkM,EAC/D,CAMAgL,cAAAA,CAAelX,GACb,OAAO6E,KAAKwW,UAAUnE,eACJ,iBAATlX,EAAoBA,OAAOkM,EAEtC,CAOA,aAFSoQ,GAAS,OAAA5L,EAAAA,EAAAA,GAAAhD,GAAA,mBAAT4O,CAAS3L,IAAAC,EAAAA,EAAAA,GAAAlD,GAAA,KAAAiD,EAAA,CAMlB6G,aAAAA,CAAcxX,GACZ6E,KAAKwW,UAAU7D,cAAcxX,EAC/B,CAMAiX,kBAAAA,GACEpS,KAAKwW,UAAUpE,oBACjB,CAEA1F,MAAAA,GACE,OACEjK,IAAAA,cAACiV,GAAa,CACZb,OAAQ7W,KAAK6W,OACbC,KAAM9W,KAAK8W,KACXC,SAAU/W,KAAK+W,SACfC,WAAYhX,KAAKgX,WACjBS,UAAWzX,KAAKyX,WAGtB,EACD,SAAAd,GArLerF,GACZtR,KAAKwW,UAAUnF,aAAaC,EAAQtR,KAAK2X,wBAC3C,CA8LK,SAASD,GAAa/U,GAGN,IAHO,OAC5BkU,EAAS,WAAU,UACnBY,GACmB9U,EACnB,MAAMiV,GAAgBC,EAAAA,EAAAA,UAAQ,KAC5B,OAAQhB,GACN,IAAK,WACL,IAAK,aACH,MAAO,CACLiB,QAAS,OACTC,cAAe,UAGnB,IAAK,SACH,MAAO,CACLD,QAAS,OACTE,IAAK,IAGT,QACE,MAAO,CAAC,EACZ,GACC,CAACnB,IAEJ,OACEpU,IAAAA,cAAA,YACEA,IAAAA,cAAA,QACE3B,MAAO,IACF8W,KACCH,GAAwB,CAAC,KAKvC,CA7CCQ,GAAApD,KAnLE/Z,GAAAia,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAO,GAAAC,GAAAC,GAAAC,GAAAE,GAAAiC,GAAAlC,GAAAE,GAAAkB,GAAAe,GAAAhC,GAAAC,GAAAe,GAAAiB,GAAA/B,GAAAC,GAAAC,GAAA5M,IAAA6D,GAAAkH,GAAAjH,MAAAC,EAAAA,EAAAA,GAAAuK,GAAA,CA9BFpQ,GAAc,UAAW,CACxBgG,MAAO,CAAC,wBACR,EA8BC/F,GAAS,CACRkG,WAAW,IACX,mBAODlG,KAAU,aAKVA,KAAU,WAKVA,GAAS,CACRkG,WAAW,IACX,eAsBDlG,GAAS,CACRkG,WAAW,IACX,iBAuBDjG,GAAM,CAAE+F,KAAM,kBAAkB,sBAAAnN,IAAAkL,EAAAA,EAAAA,GAAAnD,GAAA/H,GAAA,CAAAA,EAAAmL,KAAAC,EAAAA,EAAAA,GAAArD,GAAA/H,EAAAmL,IAAA,CAUhC/D,GAAM,CAAE+F,KAAM,qBAAqB,iBAAAnN,IAAAkL,EAAAA,EAAAA,GAAAlD,GAAAhI,GAAA,CAAAA,EAAAmL,KAAAC,EAAAA,EAAAA,GAAApD,GAAAhI,EAAAmL,IAAA,CAMnC/D,GAAM,CAAE+F,KAAM,mBAAmB,eAAAnN,IAAAkL,EAAAA,EAAAA,GAAAjD,GAAAjI,GAAA,CAAAA,EAAAmL,KAAAC,EAAAA,EAAAA,GAAAnD,GAAAjI,EAAAmL,IAAA,CAOjC9D,KAAQ,eAiBRA,KAAQ,mBAsBRA,KAAQ,kBAQRA,KAAQ,qBAORF,GAAS,CACRkG,WAAW,IACX,gBAMDhG,KAAQ,oBAQRA,KAAQ,4BAAA/M,GAAA0Z,GAAAzG,KAAAC,EAAAA,EAAAA,GAAAlT,KA9LQ6Z,EAAAA,mBAAgBrH,+BCrC5B,SAAS4K,KAGd,IAFA/e,EAAwBkQ,UAAAtP,OAAA,QAAAmN,IAAAmC,UAAA,GAAAA,UAAA,GAAG,GAC3B8O,EAA2C9O,UAAAtP,OAAA,EAAAsP,UAAA,QAAAnC,EAE3C,OAAOkR,EAAAA,GAAAA,QACLjf,EAAQ2L,KAAKuT,GACO,iBAAPA,GAAiC,iBAAPA,EAC5B,CAAExM,MAAOwM,EAAIpV,MAAOoV,GAEX,kBAAPA,EACF,CAAExM,MAAOyH,OAAO+E,GAAKpV,MAAOoV,GAEjCF,EACK,IACFE,EACHxM,OAAOsE,EAAAA,GAAAA,KAAIkI,EAAIF,EAAOtM,OAAS,SAC/B5I,OAAOkN,EAAAA,GAAAA,KAAIkI,EAAIF,EAAOlV,OAAS,UAG5B,IAAKoV,EAAIxM,MAAOwM,EAAGxM,MAAO5I,MAAOoV,EAAGpV,SAE7C,QAEJ,sJCfI9J,GAAU,CAAC,yGAEfA,GAAQmB,kBAAoB,KAC5BnB,GAAQ8F,cAAgB,KACxB9F,GAAQgG,OAAS,UAAc,KAAM,QACrChG,GAAQoF,OAAS,KACjBpF,GAAQI,mBAAqB,KAEhB,KAAI,KAASJ,IAKJ,MAAW,KAAQmf,QAAS,KAAQA,OCE1D,MAAMC,IAAqB9Q,EAAAA,EAAAA,WAAyC,WAE9DD,IAAkBC,EAAAA,EAAAA,WAAmC,iBAkCnDC,cAAa,GAAEC,SAAQ,GAAEC,MAAKA,KAAKE,EAAAA,EAAAA,oBAE3C,IAAA0Q,GAAA,IAAAC,GAAA,IAAAxQ,QAAAC,GAAA,IAAAD,QAAAE,GAAA,IAAAF,QAAAG,GAAA,IAAAH,QAAAI,GAAA,IAAAJ,QAAAK,GAAA,IAAAL,QAAAM,GAAA,IAAAN,QAAAO,GAAA,IAAAP,QAAAQ,GAAA,IAAAR,QAAAS,GAAA,IAAAT,QAAAU,GAAA,IAAAV,QAAAW,GAAA,IAAAX,QAAAY,GAAA,IAAAZ,QAAAa,GAAA,IAAAb,QAAAyQ,GAAA,IAAAzP,QAAAF,GAAA,IAAAd,QAAA0Q,GAAA,IAAA1Q,QAKA,MAAA2Q,WAIoBzP,EAAAA,EAAoBC,WAAAA,GAAA,SAAAC,YAAAC,EAAAA,EAAAA,GAAA,KAAAoP,KACtCnP,EAAAA,EAAAA,GAAA,KAAAkP,QAAc,IACdlP,EAAAA,EAAAA,GAAA,KAAArB,GAAAwB,GAAA,QAKAH,EAAAA,EAAAA,GAAA,KAAApB,IAAAwB,GAAA,MAAAC,GAAA,SAKAL,EAAAA,EAAAA,GAAA,KAAAnB,IAAAyB,GAAA,MAAAgP,GAAA,SAOAtP,EAAAA,EAAAA,GAAA,KAAAlB,IAAAyQ,GAAA,MAAAhP,GAAA,SAQAP,EAAAA,EAAAA,GAAA,KAAAjB,IAAAyB,GAAA,MAAAW,GAAA,SAKAnB,EAAAA,EAAAA,GAAA,KAAAhB,IAAAoC,GAAA,MAAAK,GAAA,SAOAzB,EAAAA,EAAAA,GAAA,KAAAf,IAAAyC,GAAA,MAAAf,GAAA,SAMAX,EAAAA,EAAAA,GAAA,KAAAd,IAAA0B,GAAA,MAAA4O,GAAA,KAK2B,cAE3BxP,EAAAA,EAAAA,GAAA,KAAAb,IAAAsQ,GAAA,MAAAC,GAAA,SAOA1P,EAAAA,EAAAA,GAAA,KAAAZ,IAAAuQ,GAAA,MAAAlE,GAAA,SAOAzL,EAAAA,EAAAA,GAAA,KAAAX,IAAAqM,GAAA,MAAAkE,GAAA,SAQA5P,EAAAA,EAAAA,GAAA,KAAAV,IAAAuQ,GAAA,MAAAC,GAAA,SAQA9P,EAAAA,EAAAA,GAAA,KAAAT,IAAAwQ,GAAA,MAAAC,GAAA,SAOAhQ,EAAAA,EAAAA,GAAA,KAAAR,IAAAyQ,GAAA,MAAAC,GAAA,SAAApO,EAAAA,EAAAA,GAAA,qBAAAqO,GAAA,MAYgBzW,IAAqB,IAAAqJ,EACnCzM,KAAKoD,MAAQA,GACbsI,EAAAA,EAAAA,GAAAmN,GAAA7Y,KAAK8Z,IAAalO,KACG,QADCa,GACpBZ,EAAAA,EAAAA,GAAK+M,GAAL5Y,aAAmB,IAAAyM,OAAA,EAAnBA,EAAqBsN,MAAM/b,IAASA,aAAI,EAAJA,EAAMoF,SAAUA,IACrD,KAGHsG,EAAAA,EAAAA,GAAA,KAAAoP,IAAuB,CACrBxf,EAKA6B,MAEAuQ,EAAAA,EAAAA,GAAAmN,GAAA7Y,KAAKga,IAAepO,KAAK,CAAEtS,UAAS6B,QAAO,GAC3C,SAhHmBA,GAAI,OAAA0Q,EAAAA,EAAAA,GAAAxD,GAAA,cAAJlN,CAAI2Q,IAAAC,EAAAA,EAAAA,GAAA1D,GAAA,KAAAyD,EAAA,UAKJE,GAAK,OAAAH,EAAAA,EAAAA,GAAAvD,GAAA,eAAL0D,CAAKF,IAAAC,EAAAA,EAAAA,GAAAzD,GAAA,KAAAwD,EAAA,YAOjBxS,GAAO,OAAAuS,EAAAA,EAAAA,GAAAtD,GAAA,iBAAPjP,CAAOwS,IAAAC,EAAAA,EAAAA,GAAAxD,GAAA,KAAAuD,EAAA,UAQP1I,GAAK,OAAAyI,EAAAA,EAAAA,GAAArD,GAAA,eAALpF,CAAK0I,IAAAC,EAAAA,EAAAA,GAAAvD,GAAA,KAAAsD,EAAA,aAKwBO,GAAQ,OAAAR,EAAAA,EAAAA,GAAApD,GAAA,kBAAR4D,CAAQP,IAAAC,EAAAA,EAAAA,GAAAtD,GAAA,KAAAqD,EAAA,YAKLQ,GAAO,OAAAT,EAAAA,EAAAA,GAAAnD,GAAA,iBAAP4D,CAAOR,IAAAC,EAAAA,EAAAA,GAAArD,GAAA,KAAAoD,EAAA,aAQvCG,GAAQ,OAAAJ,EAAAA,EAAAA,GAAAlD,GAAA,kBAARsD,CAAQH,IAAAC,EAAAA,EAAAA,GAAApD,GAAA,KAAAmD,EAAA,SAORgC,GAAI,OAAAjC,EAAAA,EAAAA,GAAAjD,GAAA,cAAJkF,CAAIhC,IAAAC,EAAAA,EAAAA,GAAAnD,GAAA,KAAAkD,EAAA,OAOJmO,GAAE,OAAApO,EAAAA,EAAAA,GAAAhD,GAAA,YAAFoR,CAAEnO,IAAAC,EAAAA,EAAAA,GAAAlD,GAAA,KAAAiD,EAAA,SAOFgL,GAAI,OAAAjL,EAAAA,EAAAA,GAAA/C,GAAA,cAAJgO,CAAIhL,IAAAC,EAAAA,EAAAA,GAAAjD,GAAA,KAAAgD,EAAA,gBAQJoO,GAAW,OAAArO,EAAAA,EAAAA,GAAA9C,GAAA,qBAAXmR,CAAWpO,IAAAC,EAAAA,EAAAA,GAAAhD,GAAA,KAAA+C,EAAA,aAQXqO,GAAQ,OAAAtO,EAAAA,EAAAA,GAAA7C,GAAA,kBAARmR,CAAQrO,IAAAC,EAAAA,EAAAA,GAAA/C,GAAA,KAAA8C,EAAA,CAuCjBY,MAAAA,GAEE,OADAX,EAAAA,EAAAA,GAAK6M,GAAL5Y,KAAsBqY,GAAcrY,KAAK1G,UAEvCmJ,IAAAA,cAAC2X,GAAc,CACbxN,WAAY5M,KACZ6M,YAAa7M,KAAK8M,iBAClB3R,KAAM6E,KAAK7E,KACX6Q,MAAOhM,KAAKgM,MACZmO,SAAUna,KAAKma,SACflO,SAAUjM,KAAKiM,SACf6K,KAAM9W,KAAK8W,KACXxd,SAASuS,EAAAA,EAAAA,GAAK+M,GAAL5Y,MACT8N,KAAM9N,KAAK8N,KACX1K,MAAOpD,KAAKoD,MACZiJ,SAAUrM,KAAKqM,SACfC,QAAStM,KAAKsM,QACd/I,SAAUvD,KAAKuO,aACfxB,UAAW/M,KAAK+M,UAChBE,UAAWjN,KAAKiN,UAChBD,WAAYhN,KAAKgN,WACjBG,QAAQ,eACRkN,eAAexO,EAAAA,EAAAA,GAAKiN,GAAL9Y,MACfka,YAAala,KAAKka,aAGxB,EAUK,SAASE,GAAexW,GAC7B,MAAM,KAAEzI,EAAI,SAAE8Q,EAAQ,KAAE6B,EAAI,YAAEoM,EAAW,cAAEG,EAAa,KAAEvD,GAASlT,GAC5DR,EAAOS,GAAYpB,IAAAA,SAAemB,EAAMR,QACxC9J,EAASghB,GAAc7X,IAAAA,SAAemB,EAAMtK,SAEnDmJ,IAAAA,WAAgB,KACdoB,EAASD,EAAMR,MAAM,GACpB,CAACQ,EAAMR,QAEVX,IAAAA,WAAgB,MACT8X,EAAAA,GAAAA,SAAQjhB,EAASsK,EAAMtK,WAC1BghB,EAAW1W,EAAMtK,SACjB+gB,SAAAA,EAAgBzW,EAAMtK,QAAS6B,GACjC,GACC,CAACA,EAAM7B,EAAS+gB,EAAezW,EAAMtK,UAExC,MAAMiV,EAAeA,CACnBzT,EACA0f,KACS,IAAAC,EACT3f,EAAE2L,kBACF5C,EAAU2W,aAAM,EAANA,EAAiCpX,OAC7B,QAAdqX,EAAA7W,EAAML,gBAAQ,IAAAkX,GAAdA,EAAA1J,KAAAnN,EAAiB4W,EAAOpX,MAAM,EAGhC,OACEX,IAAAA,cAACkF,IAAeD,EAAAA,EAAAA,GAAA,CAAC8G,YAAY,YAAcC,EAAAA,EAAAA,GAAkB7K,IAC3DnB,IAAAA,cAAA,OAAKiM,UAAU,eACZpV,aAAO,EAAPA,EAAS2L,KAAKjH,IACb,MAAM0c,EAAO1c,EAAK0c,KACZC,EAA2BD,aAAI,EAAJA,EAAMC,UACjCrU,GAAMsU,EAAAA,GAAAA,WAAU5c,EAAKoF,OACvBpF,EAAKoF,MAAMnK,WACX+E,EAAKoF,MACHyX,EAAa7c,EAAKiO,UAAYA,EACpC,OACExJ,IAAAA,cAAA,SACEqY,QAASxU,EACTxF,MAAOoZ,EACPxL,UAAWC,IAAW,aAAc,CAClC1C,SAAU4O,EACV3G,QAAS9Q,IAAUpF,EAAKoF,MACxB,CAAC0T,GAAQ,UAAoB,WAAThJ,IAEtBxH,IAAKA,EACLyU,QAAUjgB,IAAO+f,GAActM,EAAazT,EAAGkD,IAE/CyE,IAAAA,cAAA,QAAMiM,UAAU,SACdjM,IAAAA,cAAA,SACEqL,KAAK,QACL3S,KAAMA,EACN8Q,SAAU4O,EACV3G,QAAS9Q,IAAUpF,EAAKoF,MACxBG,SAAWzI,IAAO+f,GAActM,EAAazT,EAAGkD,KAElDyE,IAAAA,cAAA,QACEiM,UAAWC,IAAW,cAAe,CACnCuF,QAAS9Q,IAAUpF,EAAKoF,WAIpB,SAAT0K,EACCrL,IAAAA,cAAA,OAAKiM,UAAU,WACZgM,GACCjY,IAAAA,cAACiW,IAAkBhR,EAAAA,EAAAA,GAAA,GACbgT,EAAI,CACR5Z,MAAO,CACLka,SAAU,UACPL,MAITlY,IAAAA,cAAA,WAAMzE,EAAKgO,QAEF,WAAT8B,EACFrL,IAAAA,cAAA,OAAKiM,UAAU,WACZ9K,EAAMuW,UACL1X,IAAAA,cAACwY,GAAAA,cAAa,CACZd,SAAUvW,EAAMuW,SAChBe,KAAMld,KAID,gBAAT8P,GAAmC,gBAATA,EAC5BrL,IAAAA,cAAA,OAAKiM,UAAU,WACZ1Q,EAAK0c,MACJjY,IAAAA,cAAA,OACEiM,UAAWC,IAAW,OAAQ,CAC5B,cAAwB,gBAATb,EACf,cAAwB,gBAATA,KAGjBrL,IAAAA,cAACiW,IAAkBhR,EAAAA,EAAAA,GAAA,GACbgT,EAAI,CACR5Z,MAAO,CACLka,SAAU,UACPL,OAKXlY,IAAAA,cAAA,QAAM0Y,MAAOnd,EAAKgO,OAAQhO,EAAKgO,QAEtB,WAAT8B,EACFrL,IAAAA,cAAA,OAAKiM,UAAU,WACbjM,IAAAA,cAAA,YACGiY,GACCjY,IAAAA,cAACiW,IAAkBhR,EAAAA,EAAAA,GAAA,GACbgT,EAAI,CACR5Z,MAAO,CACLka,SAAU,OACVI,YAAa,MACbC,cAAe,aACZV,MAIR3c,EAAKgO,QAIVvJ,IAAAA,cAAA,QAAMiM,UAAU,WACbgM,GACCjY,IAAAA,cAACiW,IAAkBhR,EAAAA,EAAAA,GAAA,GACbgT,EAAI,CACR5Z,MAAO,CACLka,SAAU,OACVI,YAAa,MACbC,cAAe,aACZV,MAIR3c,EAAKgO,OAGJ,KAMpB,CAvJCsP,GAAAvC,KAAAje,GAAA+O,GAAAC,GAAAC,GAAAC,GAAAgP,GAAAC,GAAAhP,GAAAC,GAAAW,GAAAC,GAAAK,GAAAC,GAAAf,GAAAC,GAAA4O,GAAAC,GAAAC,GAAAC,GAAAlE,GAAAC,GAAAkE,GAAAC,GAAAC,GAAAC,GAAAC,GAAAI,GAAAyB,GAAA5B,GAAAC,GAAAI,GAAAwB,GAAA3B,IAAArM,GAAAmL,GAAAlL,MAAAC,EAAAA,EAAAA,GAAA4N,GAAA,CArJAzT,GAAc,WAAY,CACzB8F,WAAY,CAACC,GAAAA,GACbC,MAAO,CAAC,yBACR,EAMC/F,KAAU,WAKVA,KAAU,YAMVA,GAAS,CAAEkG,WAAW,IAAQ,cAM9BlG,GAAS,CACRkG,WAAW,IACX,YAMDlG,GAAS,CAAEgG,KAAMC,UAAU,eAK3BjG,GAAS,CAAEkG,WAAW,IAAQ,cAO9BlG,GAAS,CAAEgG,KAAMC,UAAU,eAO3BjG,KAAU,WAOVA,KAAU,SAOVA,KAAU,WAMVA,GAAS,CACRkG,WAAW,IACX,kBAMDlG,GAAS,CACRkG,WAAW,IACX,eAMDjG,GAAM,CAAE+F,KAAM,WAAW,gBAAAnN,IAAAkL,EAAAA,EAAAA,GAAA5C,GAAAtI,GAAA,CAAAA,EAAAmL,KAAAC,EAAAA,EAAAA,GAAA9C,GAAAtI,EAAAmL,IAAA,CAOzB/D,GAAM,CAAE+F,KAAM,mBAAmB,kBAAAnN,IAAAkL,EAAAA,EAAAA,GAAA3C,GAAAvI,GAAA,CAAAA,EAAAmL,KAAAC,EAAAA,EAAAA,GAAA7C,GAAAvI,EAAAmL,KAAA,GAAA7Q,GAAA6d,GAAA5K,KAAAC,EAAAA,EAAAA,GAAAlT,KA5FhBqO,EAAAA,IAAmBmE,+BCxEvC,MACA,GADiB7J,GAASnB,EAAAA,cAAA,OAAAiF,EAAAA,EAAAA,GAAA,CAAK+T,MAAM,6BAA6BC,WAAW,+BAA+BtU,MAAO,GAAI5B,OAAQ,IAAQ5B,GAAOnB,EAAAA,cAAA,YAAMA,EAAAA,cAAA,kBAAgBzJ,GAAG,IAAI2iB,GAAG,SAASC,GAAG,SAASC,GAAG,SAASC,GAAG,WAAUrZ,EAAAA,cAAA,QAAMsZ,OAAO,KAAKC,UAAU,YAAYvZ,EAAAA,cAAA,QAAMsZ,OAAO,OAAOC,UAAU,aAA6BvZ,EAAAA,cAAA,kBAAgBzJ,GAAG,IAAI2iB,GAAG,UAAUC,GAAG,SAASC,GAAG,UAAUC,GAAG,WAAUrZ,EAAAA,cAAA,QAAMsZ,OAAO,KAAKC,UAAU,YAAYvZ,EAAAA,cAAA,QAAMsZ,OAAO,OAAOC,UAAU,aAA6BvZ,EAAAA,cAAA,UAAQzJ,GAAG,IAAIoO,MAAM,SAAS5B,OAAO,SAASyW,EAAE,SAAS9e,EAAE,SAAS+e,YAAY,qBAAoBzZ,EAAAA,cAAA,YAAU0Z,GAAI,EAAGC,GAAI,EAAGC,GAAG,cAAc3e,OAAO,uBAAuB+E,EAAAA,cAAA,kBAAgB4Z,GAAG,qBAAqB3e,OAAO,mBAAmB4e,aAAc,IAAK7Z,EAAAA,cAAA,eAAa4Z,GAAG,mBAAmBE,IAAI,cAAcC,SAAS,MAAM9e,OAAO,qBAAqB+E,EAAAA,cAAA,iBAAe4Z,GAAG,mBAAmB/K,OAAO,gDAAwD7O,EAAAA,cAAA,UAAQzJ,GAAG,IAAIoO,MAAM,SAAS5B,OAAO,SAASyW,EAAE,SAAS9e,EAAE,UAAU+e,YAAY,qBAAoBzZ,EAAAA,cAAA,YAAU2Z,IAAK,EAAGC,GAAG,cAAc3e,OAAO,uBAAuB+E,EAAAA,cAAA,kBAAgB4Z,GAAG,qBAAqB3e,OAAO,mBAAmB4e,aAAc,IAAK7Z,EAAAA,cAAA,iBAAe4Z,GAAG,mBAAmB/K,OAAO,gDAAwD7O,EAAAA,cAAA,QAAMzJ,GAAG,IAAIkC,EAAE,qGAAqGuH,EAAAA,cAAA,QAAMzJ,GAAG,IAAIkC,EAAE,sDAA4DuH,EAAAA,cAAA,KAAGga,KAAK,OAAOC,SAAS,WAAUja,EAAAA,cAAA,QAAMga,KAAK,UAAUvhB,EAAE,gKAAgKuH,EAAAA,cAAA,QAAMga,KAAK,UAAUvhB,EAAE,+GAA+GuH,EAAAA,cAAA,OAAKka,UAAU,KAAKF,KAAK,OAAOrL,OAAO,YAAY3O,EAAAA,cAAA,QAAMga,KAAK,UAAUG,OAAO,OAAOC,eAAe,QAAQ3hB,EAAE,2PAA2PuH,EAAAA,cAAA,KAAGqa,UAAU,6BAA4Bra,EAAAA,cAAA,OAAKka,UAAU,KAAKF,KAAK,OAAOrL,OAAO,YAAY3O,EAAAA,cAAA,OAAKka,UAAU,KAAKF,KAAK,aAAgBha,EAAAA,cAAA,QAAMga,KAAK,UAAUvhB,EAAE,2VAA2V6hB,QAAS,KAAOta,EAAAA,cAAA,QAAMga,KAAK,UAAUvhB,EAAE,oNAAoNuH,EAAAA,cAAA,QAAMga,KAAK,UAAUvhB,EAAE,sIAAsI6hB,QAAS,KAAOta,EAAAA,cAAA,QAAMga,KAAK,UAAUvhB,EAAE,+IAA+I6hB,QAAS,6LCiE9tG,MAAMC,IAAiBpV,EAAAA,EAAAA,WAC5B,YAGID,IAAkBC,EAAAA,EAAAA,WAAmC,gBAErDqV,IAAarV,EAAAA,EAAAA,WAAkD,SAAU,CAC7EsV,QAAS,QACTC,QAAS,UAGLC,IAAcxV,EAAAA,EAAAA,WAAyC,WAMvDyV,GAAYA,CAChBC,EACAC,IAEIxJ,MAAMC,QAAQsJ,GACTA,EAAKrY,KAAKuY,GAAQH,GAAUG,EAAKD,KAEtB,mBAATD,EACDA,EAAkCvM,KAAK,KAAMwM,GAGhDD,GAiCDzV,cAAa,GAAEC,SAAQ,GAAEC,MAAKA,KAAKE,EAAAA,EAAAA,oBAE3C,IAAAwV,GAAA,IAAApV,GAAA,IAAAD,QAAAE,GAAA,IAAAF,QAAAG,GAAA,IAAAH,QAAAI,GAAA,IAAAJ,QAAAK,GAAA,IAAAL,QAAAM,GAAA,IAAAN,QAAAO,GAAA,IAAAP,QAAAQ,GAAA,IAAAR,QAAAS,GAAA,IAAAT,QAAAU,GAAA,IAAAV,QAAAW,GAAA,IAAAX,QAAAY,GAAA,IAAAZ,QAAAa,GAAA,IAAAb,QAAAc,GAAA,IAAAd,QAAAsV,GAAA,IAAAtV,QAAAuV,GAAA,IAAAvV,QAAAwV,GAAA,IAAAxV,QAAAyV,GAAA,IAAAzV,QAAA0V,GAAA,IAAA1V,QAAA2V,GAAA,IAAA3V,QAAA4V,GAAA,IAAA5V,QAAA6V,GAAA,IAAA7U,QAAA8U,GAAA,IAAA9V,QAAA+V,GAAA,IAAA/V,QAAAgW,GAAA,IAAAhW,QAAA0Q,GAAA,IAAA1Q,QAAAiW,GAAA,IAAAjW,QAKA,MAAAkW,WAIqBhV,EAAAA,EAAoBC,WAAAA,GAAA,SAAAC,YAAAC,EAAAA,EAAAA,GAAA,KAAAwU,KACvCvU,EAAAA,EAAAA,GAAA,KAAArB,GAAAwB,GAAA,QAKAH,EAAAA,EAAAA,GAAA,KAAApB,IAAAwB,GAAA,MAAAK,GAAA,SAKAT,EAAAA,EAAAA,GAAA,KAAAnB,IAAA6B,GAAA,MAAAL,GAAA,SAKAL,EAAAA,EAAAA,GAAA,KAAAlB,IAAAwB,GAAA,MAAAgP,GAAA,SAOAtP,EAAAA,EAAAA,GAAA,KAAAjB,IAAAwQ,GAAA,MAAAhP,GAAA,SAQAP,EAAAA,EAAAA,GAAA,KAAAhB,IAAAwB,GAAA,MAAAW,GAAA,SAKAnB,EAAAA,EAAAA,GAAA,KAAAf,IAAAmC,GAAA,MAAAK,GAAA,SAOAzB,EAAAA,EAAAA,GAAA,KAAAd,IAAAwC,GAAA,MAAAf,GAAA,SAMAX,EAAAA,EAAAA,GAAA,KAAAb,IAAAyB,GAAA,MAAAiU,GAAA,SAMA7U,EAAAA,EAAAA,GAAA,KAAAZ,IAAA0V,GAAA,MAAAC,GAAA,SAQA/U,EAAAA,EAAAA,GAAA,KAAAX,IAAA2V,GAAA,MAAAC,GAAA,SAMAjV,EAAAA,EAAAA,GAAA,KAAAV,IAAA4V,GAAA,MAAAC,GAAA,SAMAnV,EAAAA,EAAAA,GAAA,KAAAT,IAAA6V,GAAA,MAAAC,GAAA,SAOArV,EAAAA,EAAAA,GAAA,KAAAR,IAAA8V,GAAA,MAAAC,GAAA,SAOAvV,EAAAA,EAAAA,GAAA,KAAAgU,IAAAwB,GAAA,MAAAC,GAAA,SAQAzV,EAAAA,EAAAA,GAAA,KAAAiU,IAAAyB,GAAA,MAAAC,GAAA,SAQA3V,EAAAA,EAAAA,GAAA,KAAAkU,IAAA0B,GAAA,MAAAC,GAAA,SASA7V,EAAAA,EAAAA,GAAA,KAAAmU,IAAA2B,GAAA,MAAAC,GAAA,SAQA/V,EAAAA,EAAAA,GAAA,KAAAoU,IAAA4B,GAAA,MAAAC,GAAA,SAQAjW,EAAAA,EAAAA,GAAA,KAAAqU,IAAA6B,GAAA,MAAAC,GAAA,SAMAnW,EAAAA,EAAAA,GAAA,KAAAsU,IAAA8B,GAAA,MAAApG,GAAA,SAQAhQ,EAAAA,EAAAA,GAAA,KAAAwU,IAAAvE,GAAA,MAAAoG,GAAA,SAOArW,EAAAA,EAAAA,GAAA,KAAAyU,IAAA6B,GAAA,MAAAC,GAAA,SAOAvW,EAAAA,EAAAA,GAAA,KAAA0U,IAAA8B,GAAA,MAAAtG,GAAA,SAAApO,EAAAA,EAAAA,GAAA,qBAAAqO,GAAA,MAYe,CACbzW,EACA9J,KAEA0G,KAAKoD,MAAQA,GAEbsI,EAAAA,EAAAA,GAAAuS,GAAAje,KAAK8Z,IAAalO,KAAK,CACrBxI,QACA9J,WACA,KAGJoQ,EAAAA,EAAAA,GAAA,KAAAoP,IAAuB,CACrBxf,EAKA6B,KAEAglB,QAAQC,UAAUC,MAAK,MACrB3U,EAAAA,EAAAA,GAAAuS,GAAAje,KAAKga,IAAepO,KAAK,CAAEtS,UAAS6B,QAAO,GAC3C,KACFqQ,EAAAA,EAAAA,GAAA,qBAEcpI,KACdsI,EAAAA,EAAAA,GAAAuS,GAAAje,KAAKsgB,IAAa1U,KAAK,CACrBxI,SACA,KAGJsG,EAAAA,EAAAA,GAAA,KAAA2U,IAAqB,MACnB3S,EAAAA,EAAAA,GAAAuS,GAAAje,KAAKugB,IAAY3U,MAAM,GACvB,SAvMmBzQ,GAAI,OAAA0Q,EAAAA,EAAAA,GAAAxD,GAAA,cAAJlN,CAAI2Q,IAAAC,EAAAA,EAAAA,GAAA1D,GAAA,KAAAyD,EAAA,gBAKJvG,GAAW,OAAAsG,EAAAA,EAAAA,GAAAvD,GAAA,qBAAX/C,CAAWuG,IAAAC,EAAAA,EAAAA,GAAAzD,GAAA,KAAAwD,EAAA,UAKXE,GAAK,OAAAH,EAAAA,EAAAA,GAAAtD,GAAA,eAALyD,CAAKF,IAAAC,EAAAA,EAAAA,GAAAxD,GAAA,KAAAuD,EAAA,YAOjBxS,GAAO,OAAAuS,EAAAA,EAAAA,GAAArD,GAAA,iBAAPlP,CAAOwS,IAAAC,EAAAA,EAAAA,GAAAvD,GAAA,KAAAsD,EAAA,UAQP1I,GAAK,OAAAyI,EAAAA,EAAAA,GAAApD,GAAA,eAALrF,CAAK0I,IAAAC,EAAAA,EAAAA,GAAAtD,GAAA,KAAAqD,EAAA,aAKwBO,GAAQ,OAAAR,EAAAA,EAAAA,GAAAnD,GAAA,kBAAR2D,CAAQP,IAAAC,EAAAA,EAAAA,GAAArD,GAAA,KAAAoD,EAAA,YAKLQ,GAAO,OAAAT,EAAAA,EAAAA,GAAAlD,GAAA,iBAAP2D,CAAOR,IAAAC,EAAAA,EAAAA,GAAApD,GAAA,KAAAmD,EAAA,aAQvCG,GAAQ,OAAAJ,EAAAA,EAAAA,GAAAjD,GAAA,kBAARqD,CAAQH,IAAAC,EAAAA,EAAAA,GAAAnD,GAAA,KAAAkD,EAAA,SAMR0U,GAAI,OAAA3U,EAAAA,EAAAA,GAAAhD,GAAA,cAAJ2X,CAAI1U,IAAAC,EAAAA,EAAAA,GAAAlD,GAAA,KAAAiD,EAAA,oBAQJ2U,GAAe,OAAA5U,EAAAA,EAAAA,GAAA/C,GAAA,yBAAf2X,CAAe3U,IAAAC,EAAAA,EAAAA,GAAAjD,GAAA,KAAAgD,EAAA,gBAMf4U,GAAW,OAAA7U,EAAAA,EAAAA,GAAA9C,GAAA,qBAAX2X,CAAW5U,IAAAC,EAAAA,EAAAA,GAAAhD,GAAA,KAAA+C,EAAA,YAMX6U,GAAO,OAAA9U,EAAAA,EAAAA,GAAA7C,GAAA,iBAAP2X,CAAO7U,IAAAC,EAAAA,EAAAA,GAAA/C,GAAA,KAAA8C,EAAA,WAOP8U,GAAM,OAAA/U,EAAAA,EAAAA,GAAA5C,GAAA,gBAAN2X,CAAM9U,IAAAC,EAAAA,EAAAA,GAAA9C,GAAA,KAAA6C,EAAA,cAON+U,GAAS,OAAAhV,EAAAA,EAAAA,GAAA3C,GAAA,mBAAT2X,CAAS/U,IAAAC,EAAAA,EAAAA,GAAA7C,GAAA,KAAA4C,EAAA,WAQTwM,GAAM,OAAAzM,EAAAA,EAAAA,GAAA6R,GAAA,gBAANpF,CAAMxM,IAAAC,EAAAA,EAAAA,GAAA2R,GAAA,KAAA5R,EAAA,eAQNgV,GAAU,OAAAjV,EAAAA,EAAAA,GAAA8R,GAAA,oBAAVmD,CAAUhV,IAAAC,EAAAA,EAAAA,GAAA4R,GAAA,KAAA7R,EAAA,wBASViV,GAAmB,OAAAlV,EAAAA,EAAAA,GAAA+R,GAAA,6BAAnBmD,CAAmBjV,IAAAC,EAAAA,EAAAA,GAAA6R,GAAA,KAAA9R,EAAA,eAQnBkV,GAAU,OAAAnV,EAAAA,EAAAA,GAAAgS,GAAA,oBAAVmD,CAAUlV,IAAAC,EAAAA,EAAAA,GAAA8R,GAAA,KAAA/R,EAAA,kBAQVmV,GAAa,OAAApV,EAAAA,EAAAA,GAAAiS,GAAA,uBAAbmD,CAAanV,IAAAC,EAAAA,EAAAA,GAAA+R,GAAA,KAAAhS,EAAA,kBAMboV,GAAa,OAAArV,EAAAA,EAAAA,GAAAkS,GAAA,uBAAbmD,CAAapV,IAAAC,EAAAA,EAAAA,GAAAgS,GAAA,KAAAjS,EAAA,CAuEtBY,MAAAA,GACE,OACEjK,IAAAA,cAAC0e,GAAe,CACdvU,WAAY5M,KACZ6M,YAAa7M,KAAK8M,iBAClB3R,KAAM6E,KAAK7E,KACX6Q,MAAOhM,KAAKgM,MACZ5I,MAAOpD,KAAKoD,MACZ6I,SAAUjM,KAAKiM,SACf1G,YAAavF,KAAKuF,YAClB8G,SAAUrM,KAAKqM,SACfmU,KAAMxgB,KAAKwgB,KACXC,gBAAiBzgB,KAAKygB,gBACtBC,YAAa1gB,KAAK0gB,YAClBC,QAAS3gB,KAAK2gB,QACdC,OAAQ5gB,KAAK4gB,OACbtI,OAAQtY,KAAKsY,OACbwI,WAAY9gB,KAAK8gB,WACjBC,oBAAqB/gB,KAAK+gB,oBAC1BF,UAAW7gB,KAAK6gB,UAChB1T,QAAQ,eACR6T,WAAYhhB,KAAKghB,WACjBC,cAAejhB,KAAKihB,cACpBC,cAAelhB,KAAKkhB,cACpBhU,cAAelN,KAAKkN,cACpBH,UAAW/M,KAAK+M,UAChBE,UAAWjN,KAAKiN,UAChBD,WAAYhN,KAAKgN,WACjB1T,QAAS0G,KAAK1G,QACdiK,SAAUvD,KAAKuO,aACf8L,eAAexO,EAAAA,EAAAA,GAAKiN,GAAL9Y,MACfohB,SAAUphB,KAAKqhB,aACfC,eAAezV,EAAAA,EAAAA,GAAKwS,GAALre,OAGrB,EAGK,SAASmhB,GAAgBvd,GAAoB,IAAAgV,EAAA2I,EAClD,MAAM,WACJ3U,EAAU,KACVzR,EAAI,SACJ8Q,EAAQ,KACRuU,EAAI,gBACJC,EAAe,YACfC,EAAW,OACXE,EAAM,OACNtI,EAAM,WACNwI,EAAU,oBACVC,EAAmB,UACnBF,GAAY,EAAI,WAChBG,EAAU,cACVC,EAAa,cACbC,EAAa,YACb3b,EAAW,cACX2H,EAAa,cACbmN,EAAa,SACb9W,EAAQ,cACR+d,EAAa,cACbE,EAAa,SACbJ,GACExd,EAEE6d,GAAoB5J,EAAAA,EAAAA,UAAQ,IACzBkJ,GACHW,EAAAA,GAAAA,UAASN,EAAWL,GACpBK,GACH,CAACL,EAAqBK,IAEnBO,GAAW9J,EAAAA,EAAAA,UACf,IAAM2I,GAAQ,CAAC,WAAY,QAAQrP,SAASqP,IAC5C,CAACA,IAEGoB,GAAY5d,EAAAA,EAAAA,QAAuB,MACnC6d,GAAe7d,EAAAA,EAAAA,QAAwB,MACvC8d,GAAiC9d,EAAAA,EAAAA,SAAO,IACvC+d,EAAYC,IAAiBle,EAAAA,EAAAA,UAAiB,KAC9Cme,EAAYC,IAAiBpe,EAAAA,EAAAA,aAC7BV,EAAOS,IAAYC,EAAAA,EAAAA,UAAc0c,EAAO,QAAKnZ,IAC7C8a,EAAeC,IAAoBte,EAAAA,EAAAA,aACnCxK,EAASghB,IAAcxW,EAAAA,EAAAA,UACQ,QADA8U,EACpCP,GAAczU,EAAMtK,QAASgf,UAAO,IAAAM,EAAAA,EAAI,KAEnCyJ,EAAcC,IAAmBxe,EAAAA,EAAAA,WAAkB,IACnDye,EAAWC,IAAgB1e,EAAAA,EAAAA,WAAkB,IAC7C2e,EAAiBC,IAAsB5e,EAAAA,EAAAA,UAE5C,KACK6e,EAAeC,IAAoB9e,EAAAA,EAAAA,UAAgB,KACnD+e,EAAiBC,IAAsBhf,EAAAA,EAAAA,UAC5C,CAAC,GAEGif,IAAW/e,EAAAA,EAAAA,QAAyB,OAE1CiC,EAAAA,EAAAA,YAAU,KAAM,IAAA+c,EACd1I,EACEjC,IACgB,QAAd2K,EAACpf,EAAMtK,eAAO,IAAA0pB,EAAAA,EAAI,IAAIlpB,OACX,SAAT0mB,GAAmB5c,EAAMR,MAAQQ,EAAMR,MAAQ,IAEjDkV,GAEH,GACA,CAAC1U,EAAMtK,QAASgf,EAAQ1U,EAAMR,MAAOod,IAExC,MAAMyC,IAAsBte,EAAAA,EAAAA,cAAY,KACjCvB,EAKO6I,IACVqW,GAAiBD,GACjBG,GAAa,GACbO,GAASze,SAAWye,GAASze,QAAQF,QACrCkd,SAAAA,MARAgB,GAAgB,GAChBE,GAAa,GACbO,GAASze,SAAWye,GAASze,QAAQF,QACrCkd,SAAAA,IAMF,GACC,CAACrV,EAAUoW,EAAcjf,EAAOke,IAE7B/S,IAAe5J,EAAAA,EAAAA,cAClB6V,IAEC,IAAI0I,EACU,IAAAvgB,EAFdmf,EAA+Bxd,SAAU,EAGvC4e,EADEvB,GACUve,QAAAA,EAAS,IAAI+N,SAASqJ,EAAOpX,OACpCA,EAAmBgO,QAAQpT,GAASA,IAASwc,EAAOpX,SAC7C,QAAPT,EAAES,SAAK,IAAAT,EAAAA,EAAc,IAAI7I,OAAO0gB,EAAOpX,OAEjCoX,EAAOpX,MAEpB,MAQM+f,EAAaxB,EAPGc,EAAgB1I,MACjC/b,GAASA,EAAKoF,QAAUoX,EAAOpX,QAG9Bqf,EAAgBrR,QAAQpT,GAASA,EAAKoF,QAAUoX,EAAOpX,QACvDqf,EAAgB3oB,OAAO0gB,GAEsB,CAACA,GACpDkI,EAAmBS,GACnBtf,EAASqf,GACT3f,SAAAA,EAAW2f,EAAUC,GACrB3B,SAAAA,EAAgB0B,GAChBZ,GAAiBX,GACjBmB,EAAmBtI,IAClBmH,GAAYa,GAAa,GAC1Bb,GAAYoB,GAASze,SAAWye,GAASze,QAAQF,QACjD4d,EAAc,GAAG,GAEnB,CAACL,EAAUpe,EAAUie,EAAeiB,EAAiBrf,IAGjDggB,IAA0Bze,EAAAA,EAAAA,cAC7B0e,IACC,MAAMF,EAAaV,EAAgBrR,QAChCpT,GAASA,EAAKoF,QAAUigB,IAE3BX,EAAmBS,GACnB5f,SAAAA,EACE4f,EAAWle,KAAKjH,GAASA,EAAKoF,QAC9B+f,EACD,GAEH,CAAC5f,EAAUkf,IASPa,IAAoB3e,EAAAA,EAAAA,cACxB4e,iBAAsD,IAA/CngB,EAAKoG,UAAAtP,OAAA,QAAAmN,IAAAmC,UAAA,GAAAA,UAAA,GAAG,GAAIsE,EAA8BtE,UAAAtP,OAAA,EAAAsP,UAAA,QAAAnC,EAC/C,GAAIyZ,GAtbY1d,IACc,iBAApBA,aAAK,EAALA,EAAOogB,UAqbCC,CAAa3C,GAAa,CAC1C,MAAM,SACJ0C,EAAQ,KACRlG,EAAI,kBACJoG,EAAiB,UACjB5G,EAAa5B,GAASA,GACpB4F,EACJ,IACEsB,EAAiB,WACjB,MAAMuB,EAAatG,GACR,WAATvP,EAAoBwP,EAAOoG,EAC3BtgB,GAEI1F,QAAekmB,EAAAA,GAAAA,iBAAgBJ,EAAUG,GAC/C,IAAIjS,EAAAA,GAAAA,OAAMhU,GAAS,OACnB,MACMmmB,EAAaxL,GADKyE,EAAUpf,GAGhC4a,GAEF8J,EAAiB,WACjB9H,EAAWuJ,GAEE,gBAAT/V,GACF4U,EACEmB,EAAWzS,QAAQpT,GACjB+V,MAAMC,QAAQpQ,EAAMR,OAChBQ,EAAMR,MAAM+N,SAASnT,EAAKoF,OAC1BpF,EAAKoF,QAAUQ,EAAMR,QAIjC,CAAE,MAAOtI,GACPsnB,EAAiB,UACjB0B,EAAAA,GAAAA,iBAAgBhpB,EAClB,CACF,CACF,GACA,CAACgmB,EAAYxI,EAAQ1U,EAAMR,QAGvB2gB,IAA8BlM,EAAAA,EAAAA,UAAQ,KACnC6J,EAAAA,GAAAA,UAAS4B,GAAmBvC,GAAuB,MACzD,CAACA,EAAqBuC,KAEnBU,GAAkBvhB,IAAAA,SAAc,KACnB,SAAT+d,GAAmBuB,EAAa,CAACA,GAAc,IACpD9c,KAAKjH,IAAI,CACRsI,IAAKtI,EACLgO,MAAOhO,EACPoF,MAAOpF,MAERlE,OACC2oB,EAAgBrR,QACb6S,IACE3qB,EAAQygB,MAAMS,GAAWA,EAAOpX,QAAU6gB,EAAS7gB,WAGzDtJ,OAAOR,IACT,CAACyoB,EAAYvB,EAAMlnB,EAASmpB,KAE/Bxc,EAAAA,EAAAA,YAAU,KACR,MAAMie,EACJvC,GAAY/d,EAAMR,QAAU2Q,MAAMC,QAAQpQ,EAAMR,OAC5C,CAACQ,EAAMR,OACPQ,EAAMR,MACZS,EAASqgB,GAETxB,EACEwB,EACIF,GAAgB5S,QAAQpT,GACtB2jB,EACIuC,EAAc/S,SAASnT,EAAKoF,OAC5BpF,EAAKoF,QAAUQ,EAAMR,QAE3B,GACL,GAEA,CAACQ,EAAMR,MAAO9J,KAEjB2M,EAAAA,EAAAA,YAAU,KACRoU,SAAAA,EAAgB2J,GAAiB7oB,EAAe,GAE/C,CAAC6oB,MAEJ/d,EAAAA,EAAAA,YAAU,KAAM,IAAAke,GACdvgB,SAAiB,QAAZugB,EAALvgB,EAAOkd,kBAAU,IAAAqD,OAAA,EAAjBA,EAAmBT,oBACjB5B,EAA+Bxd,WAC7ByP,MAAMC,QAAQpQ,EAAMR,OACK,IAAvBQ,EAAMR,MAAMlJ,QACZwX,EAAAA,GAAAA,OAAM9N,EAAMR,SAChBkgB,GAAkB1f,EAAMR,MAAO,eACjC0e,EAA+Bxd,SAAU,CAAI,GAC5C,CAACgf,GAAmB1f,SAAiB,QAAZ2d,EAAL3d,EAAOkd,kBAAU,IAAAS,OAAA,EAAjBA,EAAmBmC,kBAAmB9f,EAAMR,QAEnE,MAAMiK,IAAoB1I,EAAAA,EAAAA,cACvB7J,IACCA,EAAE2L,kBACF,MAAMrD,EAAQtI,EAAEiG,OAAOqC,MACvB,GAAa,SAATod,GAAmBpd,EAAO,CAC5B,MAAMghB,EAAa3D,aAAe,EAAfA,EAAiBtP,SAAS/N,EAAMA,EAAMlJ,OAAS,IAC5DmqB,EACJjhB,GAASghB,EAAahhB,EAAMkhB,UAAU,EAAGlhB,EAAMlJ,OAAS,GAAKkJ,EAC3DghB,EACF7V,GAAa,CACXjI,IAAK+d,EACLrY,MAAOqY,EACPjhB,MAAOihB,IAGTrC,EAAc5e,EAElB,MACE4e,EAAc5e,GACdkf,GAAgB,GAChBb,EAAmBre,GAErB2gB,GAA4B3gB,EAAO,SAAS,GAE9C,CACEmL,GACAwV,GACAvD,EACAiB,EACAhB,IAIE8D,IAAgB5f,EAAAA,EAAAA,cACnB7J,IAiBC,GAhBIynB,IACa,UAAXznB,EAAE0pB,MACJ3B,GAAmBtU,GAAasU,GAGrB,cAAX/nB,EAAE0pB,MACF7C,GACe,KAAfI,GAFAjnB,MAGA2nB,GAAAA,EAAiBvoB,SAEjBuoB,EAAgBgC,MAChB/B,EAAmB,IAAID,IACvBrf,EAAMqhB,MACN5gB,EAAS,IAAIT,OAGZif,GAAgBQ,EAAiB,CACpC,GAAe,cAAX/nB,EAAE0pB,KAAsB,CAC1B,MAAM1lB,EAAQ6jB,EAAc+B,WACzB1mB,GAASA,EAAKoF,QAAUyf,EAAgBzf,QAE3C0f,EACEH,EACE7jB,EAAQ,EAAI6jB,EAAczoB,OAAS,EAC/ByoB,EAAczoB,OAAS,EACvB4E,EAAQ,GAGlB,CACA,GAAe,YAAXhE,EAAE0pB,KAAoB,CACxB,MAAM1lB,EAAQ6jB,EAAc+B,WACzB1mB,GAASA,EAAKoF,QAAUyf,EAAgBzf,QAE3C0f,EAAmBH,EAAc7jB,EAAQ,EAAI,EAAI,EAAIA,EAAQ,GAC/D,CACF,IAEF,CACEyjB,EACAZ,EACAI,EACAU,EACAJ,EACAQ,EACAtU,GACAnL,EACAuf,IAIEgC,IAAe9M,EAAAA,EAAAA,UAAQ,IACO,iBAApB4K,GACVlP,EAAAA,GAAAA,SAAQkP,QACYpb,IAApBob,GACH,CAACA,KAEJmC,EAAAA,EAAAA,kBAAgB,KACd,MAAMjC,EAAgBqB,GAAgB5S,QAAQpT,IAC5C+jB,GACK/jB,EAAKgO,MACH6Y,oBACA1T,SAAS4Q,EAAW8C,uBAMH,IAAAC,EAAAC,EAH1BnC,EAAiBD,GACjBG,EAAmBH,aAAa,EAAbA,EAAgB,IAE/Bd,EAAavd,SACf4d,EACwC,KAAlB,QAApB4C,EAAAjD,EAAavd,eAAO,IAAAwgB,OAAA,EAApBA,EAAsBE,aAClB,EACoB,QADnBD,EACDlD,EAAavd,eAAO,IAAAygB,OAAA,EAApBA,EAAsBC,YAE9B,GACC,CAAChB,GAAiBzV,GAAcwT,EAAYvB,EAAMC,KAErDxa,EAAAA,EAAAA,YAAU,KACR,MAAMgf,EAAuBnqB,IAC3BA,EAAE2L,kBACF,MAAMye,EAAOpqB,EAAEqqB,eACXvY,GAAcsY,EAAK/T,SAASvE,KAChC4V,GAAa,GACbF,GAAgB,GAChBN,EAAc,IAAG,EAKnB,OAHAzoB,SAAS6rB,iBAAiB,UAAWb,IACrChrB,SAAS6rB,iBAAiB,QAASH,GAE5B,KACL1rB,SAAS8rB,oBAAoB,UAAWd,IACxChrB,SAAS8rB,oBAAoB,QAASJ,EAAoB,CAC3D,GACA,CAACrY,EAAY2X,KAEhB,MAAMe,IAAiBzN,EAAAA,EAAAA,UAAQ,KAC7B,IAAI0N,EAAkC9C,EACtC,GAAI/B,EAAa,CACf,MAAM8E,EACJ/C,EAAgBvoB,OAASwmB,EAAc,EACnC,CACE1U,MAAO,KAAIyW,EAAgBvoB,OAASwmB,GACpCpa,IAAK,QACLlD,MAAO,GACPqiB,UAAU,GAEZ,KACNF,EAAU9C,EAAgBiD,MAAM,EAAGhF,GACnC8E,GAAgBD,EAAQzsB,KAAK0sB,EAC/B,CACA,MAAMG,EAAa3B,GAAgB4B,QACjC,CAACC,EAAUC,IACTA,EAAIxsB,QAAU,IAAIusB,KAAQC,EAAIxsB,SAAW,IAAIusB,EAAKC,IACpD,IAGIC,EAAevL,IAAkD,IAAAwL,EACrE,OACEvjB,IAAAA,cAAA,OAAKiM,UAAU,SACbjM,IAAAA,cAAA,QAAMiM,UAAU,QACbiT,EACClf,IAAAA,cAACwa,GAAU,CACT3W,IAAKkU,EAAOpX,MACZ6iB,MAAOha,EAAW,YAAS5E,EAC3Boe,SAAyB,QAAjBO,EAAExL,EAAOiL,gBAAQ,IAAAO,GAAAA,EACzBE,WAAW,EACX/I,QAASA,IAAMiG,GAAwB5I,EAAOpX,QAE7CoX,EAAOxO,MACP2V,IAAYf,aAAM,EAANA,EAAQzG,WACnB1X,IAAAA,cAACwY,GAAAA,cAAa,CAACd,SAAUyG,EAAOzG,SAAUe,KAAMV,KAIpDA,EAAOxO,QAGT2V,IAAYf,aAAM,EAANA,EAAQzG,WACpB1X,IAAAA,cAACwY,GAAAA,cAAa,CAACd,SAAUyG,EAAOzG,SAAUe,KAAMV,IAE9C,EAqBV,OACE/X,IAAAA,cAAA,OACEiM,UAAWC,IAAW,CACpB,gBAAiBgT,EACjB,sBAAuBA,IAEzB7gB,MACE6jB,GAAe,CAAEsB,MAAO,uCAA0C,CAAC,GAGpExD,SAAAA,EAAiBvoB,OACdynB,EACsB4D,EA1BhBtgB,KAAKjH,IACf,IAAIwc,EAGG,IAAA2L,EAMP,MARoB,iBAATnoB,EACTwc,EAASxc,GAETwc,EACyD,QADnD2L,EACJR,EAAW5L,MAAMS,GAAgBA,EAAOpX,QAAUpF,WAAK,IAAAmoB,EAAAA,EACtD,CAAC,EACJ3L,EAAO4L,WAAana,GAAYuO,EAAO4L,WAElCL,EAAYvL,EAAO,IAiBpBuL,EAAYtD,EAAgB,IAC9BF,GAAaR,EACX,GACAxc,EACF,GAEP,CACDye,GACA/X,EACAmX,GACArB,EACA4C,GACApC,EACA7B,EACAiB,EACApc,EACAkd,EACA7B,IAGIyF,IAAUxO,EAAAA,EAAAA,UAAQ,KACtB,MAAMyO,EAAmBtoB,IAAS,IAAAuoB,EAAA,OAChC9jB,IAAAA,cAAA,OACE6D,IAAe,QAAZigB,EAAEvoB,EAAKoF,aAAK,IAAAmjB,OAAA,EAAVA,EAAYttB,WACjByV,UAAWC,IAAW,cAAe,qBAAsB,CACzD1C,SAAUjO,EAAKiO,SACf,sBAAuBjO,EAAKoF,QAAUyf,EAAgBzf,MACtD,yBACmB,iBAAVA,EACHA,KAAUpF,aAAI,EAAJA,EAAMoF,OACfA,aAAK,EAALA,EAAiB+N,SAASnT,EAAKoF,SAExC2X,QAASA,KAAO/c,EAAKiO,UAAYsC,GAAavQ,GAC9CwoB,YAAaA,IAAM1D,EAAmB9kB,GACtCyoB,aAAcA,IAAM3D,EAAmB,CAAC,IAExCrgB,IAAAA,cAAA,OAAKiM,UAAU,8BACbjM,IAAAA,cAAA,OAAKiM,UAAU,UACbjM,IAAAA,cAAA,OAAKiM,UAAU,kBACbjM,IAAAA,cAAA,QAAMiM,UAAU,SAAS1Q,EAAKgO,OAC7BhO,EAAK0oB,SAAWjkB,IAAAA,cAAA,QAAMiM,UAAU,WAAW1Q,EAAK0oB,WAElD9F,aAAM,EAANA,EAAQzG,WACP1X,IAAAA,cAACwY,GAAAA,cAAa,CAACd,SAAUyG,EAAOzG,SAAUe,KAAMld,KAGnD2jB,GACClf,IAAAA,cAAA,OAAKiM,UAAU,cACbjM,IAAAA,cAAC2a,GAAW,CAERuJ,IAAK,OACLjM,KAAM,QACNkM,MAAO,eAMb,EAuBR,OAAOjE,EAAczoB,OAAS,EAC5B0J,EAAM+c,QApBY3P,OAAOlK,SAAQ6Z,EAAAA,GAAAA,SAAQgC,EAAe/e,EAAM+c,UAE7C1b,KAAI,CAAA8M,EAAmBjT,KAAK,IAAtB+nB,EAAOvtB,GAAQyY,EAAA,MAC1B,cAAV8U,EACEpkB,IAAAA,cAAA,OAAK6D,IAAKxH,EAAO4P,UAAU,wBACzBjM,IAAAA,cAAA,OAAKiM,UAAU,sBAAsBmY,GACpCvtB,EAAQ2L,KAAKjH,GAASsoB,EAAgBtoB,MAGzC1E,EAAQ2L,KAAKjH,GAASsoB,EAAgBtoB,IACvC,IAKH2kB,EAAc1d,KAAKjH,GACVsoB,EAAgBtoB,KAUzByE,IAAAA,cAAA,OAAKiM,UAAU,cACbjM,IAAAA,cAACqkB,GAAK,MACNrkB,IAAAA,cAAA,YAAM,QAET,GACA,CACDkgB,EACA/e,EAAM+c,QACNkC,EACAzf,EACAwd,EACAe,EACApT,KAGF,OACE9L,IAAAA,cAACkF,IAAeD,EAAAA,EAAAA,GAAA,CAAC8G,YAAY,YAAcC,EAAAA,EAAAA,GAAkB7K,IAC3DnB,IAAAA,cAAA,OACEiM,UAAWC,IAAW,SAAU,CAC9B,kBAAmB1C,EACnB,qBAAsB4U,EACtB,iBAAkBc,EAClB,kBAAmBA,IAErB7gB,MAAOkgB,EACPpe,IAAKgf,GAELnf,IAAAA,cAACua,GAAc,CACb+J,QAAS1E,EACT2E,UAAU,SACVC,SAAU/F,EAAgB,QAAU,WACpCgG,SAAU,EACVC,KAAK,QACLC,MAAI,EACJ1Y,UAAU,wBACV,cAAY,yBAEZjM,IAAAA,cAAA,OACEiM,UAAWC,IAAW,kBAAmB,CACvC,mBAAoB4T,EACpB,WAA8B,UAAlBrV,IAEdma,KAAK,SACLtM,QAASkI,IAETxgB,IAAAA,cAAA,OAAKiM,UAAU,6BACZiT,GAAY2D,GACb7iB,IAAAA,cAAA,OAAKiM,UAAU,cACbjM,IAAAA,cAAA,OAAKiM,UAAU,2BACbjM,IAAAA,cAAA,QACE3B,MAAO,CAAEwmB,SAAU,WAAYvK,QAAS,KACxCna,IAAKif,GAEJE,GAEHtf,IAAAA,cAAA,SACE3B,MAAO,CAAEsG,MAAO6a,GAChBnU,KAAK,OACL1K,MAAO2e,EACPnf,IAAKmgB,GACLrU,UAAU,gCACVnL,SAAU8J,MAGZsU,EAA2C,MAA/BI,GAAcuD,KAGhC7iB,IAAAA,cAAA,QAAMiM,UAAU,iBACZiW,IAAgB9D,EAChBpe,IAAAA,cAAC2a,GAAW,CACV1O,UAAU,YACViY,IAAI,OACJjM,KAAK,eACLkM,MAAM,SACN7L,QAAUjgB,GAzdLA,KACnBA,EAAE2L,kBACFic,EAAmB,IACnBnf,SAAAA,OAAW8D,EAAW,GAAG,EAsdKkgB,CAAYzsB,KAG9B2H,IAAAA,cAAA,QACEiM,UAAWC,IACT,UACA,gBACA,oBACA,CACEvK,MAAOme,KAIX9f,IAAAA,cAAC2a,GAAW,CAAC1C,KAAK,OAAOiM,IAAI,OAAOC,MAAM,gBAKlDnkB,IAAAA,cAAA,OAAKiM,UAAU,gCAAgC5N,MAAOmgB,GACjC,YAAlBkB,EACC1f,IAAAA,cAAA,OAAKiM,UAAU,mCACbjM,IAAAA,cAAC2a,GAAW,CAER1C,KAAM,UACNiM,IAAK,OACLC,MAAO,WACPY,UAAU,KAKhB/kB,IAAAA,cAAA,OAAKiM,UAAU,kBAAkB2X,OAO/C,CAjoBCoB,GAAAnJ,KAAAxjB,GAAA+O,GAAAC,GAAAK,GAAAC,GAAAL,GAAAC,GAAAgP,GAAAC,GAAAhP,GAAAC,GAAAW,GAAAC,GAAAK,GAAAC,GAAAf,GAAAC,GAAAiU,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAApG,GAAAI,GAAAyB,GAAA5B,GAAAoG,GAAAO,GAAAoH,GAAA1H,GAAAC,GAAAM,GAAAoH,GAAAzH,GAAAtG,GAAAI,GAAAwB,GAAA3B,IAAArM,GAAAiQ,GAAAhQ,MAAAC,EAAAA,EAAAA,GAAA+Z,GAAA,CArPA5f,GAAc,YAAa,CAC1B8F,WAAY,CAACC,GAAAA,GACbC,MAAO,CAAC,0BACR,EAKC/F,KAAU,WAKVA,KAAU,kBAKVA,KAAU,YAMVA,GAAS,CAAEkG,WAAW,IAAQ,cAM9BlG,GAAS,CACRkG,WAAW,IACX,YAMDlG,GAAS,CAAEgG,KAAMC,UAAU,eAK3BjG,GAAS,CAAEkG,WAAW,IAAQ,cAO9BlG,GAAS,CAAEgG,KAAMC,UAAU,eAM3BjG,KAAU,WAMVA,GAAS,CACRkG,WAAW,IACX,sBAMDlG,KAAU,kBAMVA,KAAU,cAKVA,GAAS,CACRkG,WAAW,IACX,aAODlG,GAAS,CAAEgG,KAAMC,UAAU,gBAM3BjG,GAAS,CACRkG,WAAW,IACX,aAMDlG,GAAS,CACRkG,WAAW,IACX,iBAODlG,GAAS,CACRgG,KAAMvN,SACN,0BAMDuH,GAAS,CACRkG,WAAW,IACX,iBAMDlG,GAAS,CACRkG,WAAW,IACX,oBAMDlG,GAAS,CAAEgG,KAAMC,UAAU,oBAM3BhG,GAAM,CAAE+F,KAAM,WAAW,gBAAAnN,IAAAkL,EAAAA,EAAAA,GAAAmS,GAAArd,GAAA,CAAAA,EAAAmL,KAAAC,EAAAA,EAAAA,GAAAiS,GAAArd,EAAAmL,IAAA,CAQzB/D,GAAM,CAAE+F,KAAM,WAAW,gBAAAnN,IAAAkL,EAAAA,EAAAA,GAAAqS,GAAAvd,GAAA,CAAAA,EAAAmL,KAAAC,EAAAA,EAAAA,GAAAmS,GAAAvd,EAAAmL,IAAA,CASzB/D,GAAM,CAAE+F,KAAM,iBAAiB,eAAAnN,IAAAkL,EAAAA,EAAAA,GAAAsS,GAAAxd,GAAA,CAAAA,EAAAmL,KAAAC,EAAAA,EAAAA,GAAAoS,GAAAxd,EAAAmL,IAAA,CAK/B/D,GAAM,CAAE+F,KAAM,mBAAmB,kBAAAnN,IAAAkL,EAAAA,EAAAA,GAAAuS,GAAAzd,GAAA,CAAAA,EAAAmL,KAAAC,EAAAA,EAAAA,GAAAqS,GAAAzd,EAAAmL,KAAA,GAAA7Q,GAAAojB,GAAAnQ,KAAAC,EAAAA,EAAAA,GAAAlT,KAjKfqO,EAAAA,IAAmBmE,0FCjIxC,MAAM9F,IAAkBC,EAAAA,EAAAA,WAAmC,gBACrDggB,IAAgBhgB,EAAAA,EAAAA,WAA+B,cAa7CC,cAAa,GAAEC,SAAQ,GAAEC,MAAKA,KAAKE,EAAAA,EAAAA,oBAE3C,IAAA4f,GAAA,IAAAxf,GAAA,IAAAD,QAAAE,GAAA,IAAAF,QAAAG,GAAA,IAAAH,QAAAI,GAAA,IAAAJ,QAAAK,GAAA,IAAAL,QAAAM,GAAA,IAAAN,QAAAO,GAAA,IAAAP,QAAA0f,GAAA,IAAA1e,QAAAR,GAAA,IAAAR,QAKA,MAAA2f,WAI4Bze,EAAAA,EAAoBC,WAAAA,GAAA,SAAAC,YAAAC,EAAAA,EAAAA,GAAA,KAAAqe,KAC9Cpe,EAAAA,EAAAA,GAAA,KAAArB,GAAA2f,GAAA,KAI0C,QAE1Cte,EAAAA,EAAAA,GAAA,KAAApB,IAAA2f,GAAA,MAAAC,GAAA,SAMAxe,EAAAA,EAAAA,GAAA,KAAAnB,IAAA4f,GAAA,MAAAC,GAAA,SAMA1e,EAAAA,EAAAA,GAAA,KAAAlB,IAAA6f,GAAA,MAAAC,GAAA,SAKA5e,EAAAA,EAAAA,GAAA,KAAAjB,IAAA8f,GAAA,MAAAC,GAAA,SAKA9e,EAAAA,EAAAA,GAAA,KAAAhB,IAAA+f,GAAA,MAAAC,GAAA,SAKAhf,EAAAA,EAAAA,GAAA,KAAAf,IAAAggB,GAAA,MAAAC,GAAA,SAKAlf,EAAAA,EAAAA,GAAA,KAAAd,IAAAigB,GAAA,MAAAC,GAAA,SAAAtd,EAAAA,EAAAA,GAAA,2BAAAud,GAAA,MAK6B,KAC3B5I,QAAQC,UAAUC,MAAK,MACrB3U,EAAAA,EAAAA,GAAAoc,GAAA9nB,KAAKgpB,IAAapd,OACd5L,KAAK8M,kBACN9M,KAAK8M,iBAAyBkG,WAE7BhT,KAAKipB,oBACPjpB,KAAKkpB,gBAAiB,EACxB,GACA,KACH1d,EAAAA,EAAAA,GAAA,2BAE4B,KAC3B2U,QAAQC,UAAUC,MAAK,MACrB3U,EAAAA,EAAAA,GAAAoc,GAAA9nB,KAAKmpB,IAAavd,MAAM,GACxB,GACH,eAvDoBwd,GAAU,OAAAvd,EAAAA,EAAAA,GAAAxD,GAAA,oBAAV+gB,CAAUtd,IAAAC,EAAAA,EAAAA,GAAA1D,GAAA,KAAAyD,EAAA,eAMtBud,GAAU,OAAAxd,EAAAA,EAAAA,GAAAvD,GAAA,oBAAV+gB,CAAUvd,IAAAC,EAAAA,EAAAA,GAAAzD,GAAA,KAAAwD,EAAA,sBAMVmd,GAAiB,OAAApd,EAAAA,EAAAA,GAAAtD,GAAA,2BAAjB0gB,CAAiBnd,IAAAC,EAAAA,EAAAA,GAAAxD,GAAA,KAAAuD,EAAA,mBAKYod,GAAc,OAAArd,EAAAA,EAAAA,GAAArD,GAAA,wBAAd0gB,CAAcpd,IAAAC,EAAAA,EAAAA,GAAAvD,GAAA,KAAAsD,EAAA,eAK/Bwd,GAAU,OAAAzd,EAAAA,EAAAA,GAAApD,GAAA,oBAAV6gB,CAAUxd,IAAAC,EAAAA,EAAAA,GAAAtD,GAAA,KAAAqD,EAAA,eAKVyd,GAAU,OAAA1d,EAAAA,EAAAA,GAAAnD,GAAA,oBAAV6gB,CAAUzd,IAAAC,EAAAA,EAAAA,GAAArD,GAAA,KAAAoD,EAAA,CA8B/BY,MAAAA,GACE,OACEjK,IAAAA,cAAC+mB,GAAgB,CACf3c,YAAa7M,KAAK8M,iBAClBF,WAAY5M,KACZkpB,eAAgBlpB,KAAKkpB,eACrBE,WAAYppB,KAAKopB,WACjBE,WAAYtpB,KAAKspB,WACjBD,WAAYrpB,KAAKqpB,WACjBE,WAAYvpB,KAAKupB,WACjBE,cAAezpB,KAAK0pB,mBACpBC,cAAe3pB,KAAK4pB,oBAG1B,EAGK,SAASJ,GAAiB5lB,GAC/B,OACEnB,IAAAA,cAACkF,IAAeD,EAAAA,EAAAA,GAAA,CAAC8G,YAAY,YAAcC,EAAAA,EAAAA,GAAkB7K,IAC1DA,EAAMwlB,YACL3mB,IAAAA,cAACmlB,GAAa,CACZlZ,UAAW,YACXZ,KAAMlK,EAAM0lB,YAAc,UAC1BvO,QAASnX,EAAM+lB,cACf1d,SAAUrI,EAAMslB,gBAEftlB,EAAMwlB,YAGVxlB,EAAMylB,YACL5mB,IAAAA,cAACmlB,GAAa,CACZ,eAAa,YACb9Z,KAAMlK,EAAM2lB,YAAc,OAC1BxO,QAASnX,EAAM6lB,eAEd7lB,EAAMylB,YAKjB,CA1BCQ,GAAA9B,KAAAjtB,GAAAktB,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAI,GAAAc,GAAAjB,GAAAC,GAAAK,GAAAY,GAAAhB,IAAAvb,GAAAqa,GAAApa,MAAAC,EAAAA,EAAAA,GAAAmc,GAAA,CAjFAhiB,GAAc,oBAAqB,CAClC8F,WAAY,CAACC,GAAAA,GACbC,MAAO,CAAC,0BACR,EAMC/F,KAAU,iBAKVA,KAAU,iBAMVA,GAAS,CAAEgG,KAAMC,UAAU,wBAM3BjG,GAAS,CAAEgG,KAAMC,UAAU,qBAK3BjG,KAAU,iBAKVA,KAAU,iBAKVC,GAAM,CAAE+F,KAAM,WAAW,gBAAAnN,IAAAkL,EAAAA,EAAAA,GAAAlD,GAAAhI,GAAA,CAAAA,EAAAmL,KAAAC,EAAAA,EAAAA,GAAApD,GAAAhI,EAAAmL,IAAA,CAKzB/D,GAAM,CAAE+F,KAAM,WAAW,gBAAAnN,IAAAkL,EAAAA,EAAAA,GAAAjD,GAAAjI,GAAA,CAAAA,EAAAmL,KAAAC,EAAAA,EAAAA,GAAAnD,GAAAjI,EAAAmL,KAAA,GAAA7Q,GAAA6sB,GAAA5Z,KAAAC,EAAAA,EAAAA,GAAAlT,KA1CAqO,EAAAA,IAAmBmE,mBChC/C,SADyB,CAAE,KAAQ,CAAE,IAAO,MAAO,MAAS,CAAE,QAAW,gBAAiB,UAAa,SAAW,SAAY,CAAC,CAAE,IAAO,OAAQ,MAAS,CAAE,EAAK,2HAA+H,KAAQ,cAAe,MAAS,2BCM3T,GAAqB,SAA4B7J,EAAOhB,GAC1D,OAAoB,gBAAoBonB,GAAAC,GAAU,OAAS,CAAC,EAAGrmB,EAAO,CACpEhB,IAAKA,EACL8X,KAAM,KAEV,EAOA,SAJ2B,aAAiB,4GCC5C,MAAQ7S,cAAa,GAAEC,SAAQ,GAAEC,MAAKA,KAAKE,EAAAA,EAAAA,oBAErCN,IAAkBC,EAAAA,EAAAA,WAAmC,gBACrDwV,IAAcxV,EAAAA,EAAAA,WAAyC,WAAW,IAAAsiB,GAAA,IAAA7hB,GAAA,IAAAD,QAAAE,GAAA,IAAAF,QAAAG,GAAA,IAAAH,QAAAI,GAAA,IAAAJ,QAAAK,GAAA,IAAAL,QAAAM,GAAA,IAAAN,QAAAO,GAAA,IAAAP,QAAAQ,GAAA,IAAAR,QAAAS,GAAA,IAAAT,QAAAU,GAAA,IAAAV,QAAAW,GAAA,IAAAX,QAAAY,GAAA,IAAAZ,QAAA+hB,GAAA,IAAA/gB,QAAAH,GAAA,IAAAb,QAAA0Q,GAAA,IAAA1Q,QA2CxE,MAAAgiB,WAIuB9gB,EAAAA,EAAoBC,WAAAA,GAAA,SAAAC,YAAAC,EAAAA,EAAAA,GAAA,KAAA0gB,KACzCzgB,EAAAA,EAAAA,GAAA,KAAArB,GAAAwB,GAAA,QAMAH,EAAAA,EAAAA,GAAA,KAAApB,IAAAwB,GAAA,MAAAC,GAAA,SAKAL,EAAAA,EAAAA,GAAA,KAAAnB,IAAAyB,GAAA,MAAAC,GAAA,SAMAP,EAAAA,EAAAA,GAAA,KAAAlB,IAAA0B,GAAA,MAAA8O,GAAA,KAKyC,OAEzCtP,EAAAA,EAAAA,GAAA,KAAAjB,IAAAwQ,GAAA,MAAAC,GAAA,KAK8B,cAE9BxP,EAAAA,EAAAA,GAAA,KAAAhB,IAAAyQ,GAAA,MAAA9O,GAAA,SAMAX,EAAAA,EAAAA,GAAA,KAAAf,IAAA2B,GAAA,MAAA+f,GAAA,MAK6B,MAE7B3gB,EAAAA,EAAAA,GAAA,KAAAd,IAAA0hB,GAAA,MAAAzf,GAAA,SAMAnB,EAAAA,EAAAA,GAAA,KAAAb,IAAAiC,GAAA,MAAAK,GAAA,SAMAzB,EAAAA,EAAAA,GAAA,KAAAZ,IAAAsC,GAAA,MAAAmf,GAAA,SAQA7gB,EAAAA,EAAAA,GAAA,KAAAX,IAAAyhB,GAAA,MAAAC,GAAA,SAQA/gB,EAAAA,EAAAA,GAAA,KAAAV,IAAA0hB,GAAA,MAAAC,GAAA,SAAAnf,EAAAA,EAAAA,GAAA,6BAAAof,GAAA,MAMwBhb,IACtB5P,KAAKoD,MAAQwM,EACb,MASMib,EAAsBxS,GATLrY,KAAK8qB,aACxB9qB,KAAK8qB,aAAalF,QAChB,CAACmF,EAA8BC,IAAU,IACpCD,KACAC,EAAM1xB,UAEX,IAEF0G,KAAK1G,SACiD8X,QAAQpT,GAC1C,iBAAfA,EAAKoF,OAA4BwM,EAAOuB,SAASnT,EAAKoF,UAE/DsI,EAAAA,EAAAA,GAAAye,GAAAnqB,KAAKirB,IAAqBrf,KAAKif,EAAoB,KAGrDnhB,EAAAA,EAAAA,GAAA,KAAAT,GAAAiiB,GAAA,QASAxhB,EAAAA,EAAAA,GAAA,KAAAoP,IAAoBqS,GAAA,MAAG,CAAC7xB,EAA+B6B,MACrDuQ,EAAAA,EAAAA,GAAAye,GAAAnqB,KAAKorB,IAAoBxf,KAAK,CAC5BtS,UACA6B,QACA,GACF,SAzGOA,GAAI,OAAA0Q,EAAAA,EAAAA,GAAAxD,GAAA,cAAJlN,CAAI2Q,IAAAC,EAAAA,EAAAA,GAAA1D,GAAA,KAAAyD,EAAA,UAMJE,GAAK,OAAAH,EAAAA,EAAAA,GAAAvD,GAAA,eAAL0D,CAAKF,IAAAC,EAAAA,EAAAA,GAAAzD,GAAA,KAAAwD,EAAA,UAKL1I,GAAK,OAAAyI,EAAAA,EAAAA,GAAAtD,GAAA,eAALnF,CAAK0I,IAAAC,EAAAA,EAAAA,GAAAxD,GAAA,KAAAuD,EAAA,YAOLxS,GAAO,OAAAuS,EAAAA,EAAAA,GAAArD,GAAA,iBAAPlP,CAAOwS,IAAAC,EAAAA,EAAAA,GAAAvD,GAAA,KAAAsD,EAAA,SAOPgC,GAAI,OAAAjC,EAAAA,EAAAA,GAAApD,GAAA,cAAJqF,CAAIhC,IAAAC,EAAAA,EAAAA,GAAAtD,GAAA,KAAAqD,EAAA,aAMJG,GAAQ,OAAAJ,EAAAA,EAAAA,GAAAnD,GAAA,kBAARuD,CAAQH,IAAAC,EAAAA,EAAAA,GAAArD,GAAA,KAAAoD,EAAA,aAORuf,GAAQ,OAAAxf,EAAAA,EAAAA,GAAAlD,GAAA,kBAAR0iB,CAAQvf,IAAAC,EAAAA,EAAAA,GAAApD,GAAA,KAAAmD,EAAA,aAMRO,GAAQ,OAAAR,EAAAA,EAAAA,GAAAjD,GAAA,kBAARyD,CAAQP,IAAAC,EAAAA,EAAAA,GAAAnD,GAAA,KAAAkD,EAAA,YAMRQ,GAAO,OAAAT,EAAAA,EAAAA,GAAAhD,GAAA,iBAAPyD,CAAOR,IAAAC,EAAAA,EAAAA,GAAAlD,GAAA,KAAAiD,EAAA,YAQPwf,GAAO,OAAAzf,EAAAA,EAAAA,GAAA/C,GAAA,iBAAPwiB,CAAOxf,IAAAC,EAAAA,EAAAA,GAAAjD,GAAA,KAAAgD,EAAA,iBAQPgf,GAAY,OAAAjf,EAAAA,EAAAA,GAAA9C,GAAA,sBAAZ+hB,CAAYhf,IAAAC,EAAAA,EAAAA,GAAAhD,GAAA,KAAA+C,EAAA,CAyCrBY,MAAAA,GACE,OACEjK,IAAAA,cAAC8oB,GAAiB,CAChB3e,WAAY5M,KACZ6M,YAAa7M,KAAK8M,iBAClBxT,QAAS+e,GAAcrY,KAAK1G,SAC5B0S,MAAOhM,KAAKgM,MACZ7Q,KAAM6E,KAAK7E,KACXiI,MAAOpD,KAAKoD,MACZ0K,KAAM9N,KAAK8N,KACX7B,SAAUjM,KAAKiM,SACfof,SAAUrrB,KAAKqrB,SACfhf,SAAUrM,KAAKqM,SACfC,QAAStM,KAAKsM,QACdS,UAAW/M,KAAK+M,UAChBE,UAAWjN,KAAKiN,UAChBD,WAAYhN,KAAKgN,WACjBG,QAAQ,uBACR5J,SAAUvD,KAAKwrB,qBACfnR,eAAexO,EAAAA,EAAAA,GAAKiN,GAAL9Y,MACfsrB,QAAStrB,KAAKsrB,QACdR,aAAc9qB,KAAK8qB,cAGzB,EAGF,SAASS,GAAkB3nB,GAAsB,IAAA6nB,EAC/C,MAAM,QAAEH,GAAY1nB,GACb0N,EAAQoa,IAAa5nB,EAAAA,EAAAA,UAA0C,QAAlC2nB,EAAsB7nB,aAAK,EAALA,EAAOR,aAAK,IAAAqoB,EAAAA,EAAI,KACnEnyB,EAASghB,IAAcxW,EAAAA,EAAAA,UAC5BF,EAAMtK,SAAW,KAEZqyB,EAAcC,IAAmB9nB,EAAAA,EAAAA,WACrCF,EAAMknB,cAAgB,IAAI7lB,KAAKtE,GAAMA,EAAE2F,QAEnCwkB,EAAce,IAAmB/nB,EAAAA,EAAAA,UAASF,EAAMknB,eACvD7kB,EAAAA,EAAAA,YAAU,MACHsU,EAAAA,GAAAA,SAAQuQ,EAAclnB,EAAMknB,gBAC/Bc,GAAiBd,GAAgB,IAAI7lB,KAAKtE,GAAMA,EAAE2F,OAClDulB,EAAgBjoB,EAAMknB,cACxB,GACC,CAAClnB,EAAMknB,gBAEV7kB,EAAAA,EAAAA,YAAU,KAC8B,IAAA6lB,EAAA9I,GAAjCzI,EAAAA,GAAAA,SAAQjhB,EAASsK,EAAMtK,WAC1BghB,EAAW1W,EAAMtK,SAAW,IACT,QAAnBwyB,EAAAloB,EAAMyW,qBAAa,IAAAyR,GAAnBA,EAAA/a,KAAAnN,EAAmC,QAA9Bof,EAAiBpf,EAAMtK,eAAO,IAAA0pB,EAAAA,EAAI,GAAIpf,EAAMzI,MACnD,GACC,CAAC7B,EAASsK,EAAOA,EAAMtK,WAE1B2M,EAAAA,EAAAA,YAAU,KACRylB,GAAU9nB,aAAK,EAALA,EAAOR,QAAS,GAAG,GAC5B,CAACQ,EAAMR,QAEV,MAAM2oB,EAAmBA,CACvBjxB,EACAkD,KACG,IAAAyc,EACH3f,EAAE2L,kBACF,IAAIyc,EAAgC,GAIpC,GAHIpoB,EAAEiG,OAAOmT,UACXgP,EAAW,IAAI5R,EAAQtT,EAAKoF,SAEzBtI,EAAEiG,OAAOmT,SAAV,MAAqB5C,GAAAA,EAAQH,SAASnT,EAAKoF,OAAQ,CACrD8f,EAAW,IAAI5R,GACf,MAAMxS,EAAQokB,EAASwB,WAAW/mB,GAAMA,GAAKK,EAAKoF,QAClD8f,EAAS1kB,OAAOM,EAAO,EACzB,CACA4sB,EAAUxI,GACI,QAAdzI,EAAA7W,EAAML,gBAAQ,IAAAkX,GAAdA,EAAA1J,KAAAnN,EAAiBsf,EAAS,EAoCtB8I,EAAgBpoB,IACpB,MAAM,KAAEzI,EAAI,SAAE8Q,GAAW,EAAK,SAAEof,GAAW,GAAUznB,EACrD,OACEnB,IAAAA,cAAAA,IAAAA,SAAA,KACGnJ,EAAQ2L,KAAKjH,GACZyE,IAAAA,cAAA,SACE6D,IAAKtI,EAAKoF,MACVsL,UACEzC,GAAYjO,SAAAA,EAAMiO,SACd0C,IAAW,CACTsd,sBAAsB,EACtBC,2BAA4Bb,IAE9B1c,IAAW,CACTwd,cAAc,EACdC,mBAAoBf,KAI5B5oB,IAAAA,cAAA,OAAKiM,UAAWC,IAAW,CAAE0d,UAAU,KACrC5pB,IAAAA,cAAA,SACEqL,KAAK,WACL1K,MAAOpF,EAAKoF,MACZjI,KAAMA,EACNmxB,eAAgBhb,aAAM,EAANA,EAAQH,SAASnT,EAAKoF,OACtC6I,SAAUA,IAAYjO,aAAI,EAAJA,EAAMiO,UAC5B1I,SAAWzI,GAAMixB,EAAiBjxB,EAAGkD,MAGzCyE,IAAAA,cAAA,OAAKiM,UAAWC,IAAW,CAAE4d,SAAS,KACnCvuB,EAAK0c,MACJjY,IAAAA,cAAC2a,IAAW1V,EAAAA,EAAAA,GAAA,GACL1J,EAAK0c,KAAI,CACd5Z,MAAO,CACLka,SAAUqQ,EAAW,OAAS,WAIpC5oB,IAAAA,cAAA,OAAKiM,UAAWC,IAAW,CAAE6d,MAAM,KAChCxuB,EAAKgO,OAAShO,EAAKoF,WAK3B,EAIDqpB,EAAgB7oB,IAAyB,IAAA8oB,EAC7C,OACEjqB,IAAAA,cAAA,OACE3B,MAAO,CACLwmB,SAAU,WACVxP,QAAS,OACT6U,WAAY,SACZvnB,UAAW,SAGb3C,IAAAA,cAAA,OAAKiM,UAAU,kBAAkBke,KAAK,oBACtB,QADwCF,EACrD9oB,EAAMtK,eAAO,IAAAozB,OAAA,EAAbA,EAAeznB,KAAKjH,IACnB,MAAMiO,EAAWjO,EAAKiO,UAAYrI,EAAMqI,SACxC,OACExJ,IAAAA,cAAA,SACE6D,IAAKtI,EAAKoF,MACVsL,UAAWC,IAAW,CACpBke,eAAe,EACfC,sBAAuB7gB,EACvB8gB,mBAAoBzb,EAAOH,SAASnT,EAAKoF,SAE3CwpB,KAAK,mBAELnqB,IAAAA,cAAA,QACE3B,MAAO,CAAEmlB,MAAOjoB,EAAKgvB,eACrBte,UAAWC,IAAW,CACpBse,sBAAsB,EACtBC,6BAA8BjhB,EAC9BkhB,mBAAoB7b,EAAOH,SAASnT,EAAKoF,UAG3CX,IAAAA,cAAA,SACEc,SAAWzI,IAAOmR,GAAY8f,EAAiBjxB,EAAGkD,GAClDiO,SAAUA,EACVqgB,eAAgBhb,aAAM,EAANA,EAAQH,SAASnT,EAAKoF,OACtCsL,UAAWC,IAAW,CACpBye,eAAe,EACfC,sBAAuBphB,IAEzB6B,KAAK,WACL9U,GAAIgF,EAAKoF,QAEXX,IAAAA,cAAA,QACEiM,UAAWC,IAAW,CAAE2e,eAAe,IACvCxsB,MACEwQ,EAAOH,SAASnT,EAAKoF,QAAUpF,EAAKgvB,cAChC,CACEO,WAAYvvB,EAAKgvB,cACjBQ,YAAaxvB,EAAKgvB,eAEpB,CAAC,KAKXvqB,IAAAA,cAAA,QAAMiM,UAAWC,IAAW,CAAE8e,cAAc,KAxIzCzvB,KACf,IAAI0vB,EAAW,KACf,MAAM,KAAEhT,GAAS1c,EACjB,GAAI0c,EACF,GAAI,WAAYA,EAAM,CACpB,MAAMiT,EAAkB,IACnBjT,EACHkT,OAAQlT,EAAKkT,OACbC,SAAU,CACRzS,YAAa,MACbC,cAAe,aACZX,EAAKmT,WAGZH,EAAWhT,GACTjY,IAAAA,cAAC2a,GAAiBuQ,EAEtB,MACED,EAAWhT,GACTjY,IAAAA,cAAC2a,IAAW1V,EAAAA,EAAAA,GAAA,GACLgT,EAAI,CACT5Z,MAAO,CACLka,SAAU,OACVI,YAAa,MACbC,cAAe,cAMzB,OAAOqS,CAAQ,EA2GAI,CAAQ9vB,GACRA,EAAKgO,OAEF,KAIV,EAGJ+hB,EAAkBnqB,IACtB,MAAMoqB,GAAgBnW,EAAAA,EAAAA,UAAQ,IACrBiT,aAAY,EAAZA,EAAc7lB,KAAKuV,IACxB,MAAM2I,EAAa9K,GAAcmC,EAAOlhB,SAClC20B,EAAiB9K,EAAWle,KAAKrF,GAAMA,EAAEwD,QACzC8qB,GAAeC,EAAAA,GAAAA,cAAa7c,EAAQ2c,GACpCG,EACJF,EAAah0B,SAAW+zB,EAAe/zB,OACnC,MACAg0B,EAAah0B,OAAS,GACpBg0B,EAAah0B,SAAW+zB,EAAe/zB,OACvC,OACA,OACR,MAAO,IACFsgB,EACHlhB,QAAS6pB,EACTiL,YACA5Z,KAAMyZ,EACP,KAEF,CAACnD,EAAclnB,EAAMR,QACxB,OACEX,IAAAA,cAAA,OAAKiM,UAAU,oBACZ,IACAsf,aAAa,EAAbA,EAAe/oB,KAAKtH,GACnB8E,IAAAA,cAAA,OAAK6D,IAAK3I,EAAE2I,KACV7D,IAAAA,cAAA,OACEsY,QAASA,KACP,GAAI4Q,EAAaxa,SAASxT,EAAE2I,KAAM,CAChC,MAAM+nB,EAAU1C,EAAava,QAAQ9K,GAAQA,IAAQ3I,EAAE2I,MACvDslB,EAAgByC,EAClB,MACEzC,EAAgB,IAAID,EAAchuB,EAAE2I,KACtC,EAEFoI,UAAWC,IAAW,oBAEtBlM,IAAAA,cAAA,QAAMiM,UAAU,iBACdjM,IAAAA,cAAC6rB,GAAkB,CACjBC,OAAQ5C,EAAaxa,SAASxT,EAAE2I,KAAO,GAAK,EAC5CkoB,IAAI,MAGR/rB,IAAAA,cAAA,SACEsY,QAAUjgB,IACRA,EAAE2L,iBAAiB,EAErBiI,UAAWC,IAAW,CACpBke,eAAe,EACfE,mBAAoC,QAAhBpvB,EAAEywB,aAGxB3rB,IAAAA,cAAA,QACEiM,UAAWC,IAAW,CACpBse,sBAAsB,EACtBE,mBAAoC,QAAhBxvB,EAAEywB,UACtBK,uBAAwC,SAAhB9wB,EAAEywB,aAG5B3rB,IAAAA,cAAA,SACEiM,UAAWC,IAAW,CACpBye,eAAe,IAEjB7pB,SAAWzI,IAET,GADAA,EAAE2L,kBACkB,QAAhB9I,EAAEywB,UAAqB,KAAAM,EACzB,MAAMxL,EAAW5R,EAAOF,QACrBtF,IAAOnO,EAAE6W,KAAKrD,SAASrF,KAEZ,QAAd4iB,EAAA9qB,EAAML,gBAAQ,IAAAmrB,GAAdA,EAAA3d,KAAAnN,EAAiBsf,EACnB,KAAO,KAAAyL,EACS,QAAdA,EAAA/qB,EAAML,gBAAQ,IAAAorB,GAAdA,EAAA5d,KAAAnN,GAAiBgrB,EAAAA,GAAAA,MAAK,IAAItd,KAAW3T,EAAE6W,OACzC,GAEF1G,KAAK,aAEPrL,IAAAA,cAAA,QAAMiM,UAAWC,IAAW,CAAE2e,eAAe,OAG/C7qB,IAAAA,cAAA,QAAMiM,UAAWC,IAAW,CAAE8e,cAAc,KACzC9vB,EAAExC,QAITsH,IAAAA,cAAA,OACEiM,UAAWC,IAAW,mBAAoB,CACxC,2BAA4Bgd,EAAaxa,SAASxT,EAAE2I,QAGtD7D,IAAAA,cAACgqB,GAAY/kB,EAAAA,EAAAA,GAAA,GACF9D,EAAO,CAAAtK,QAASqE,EAAErE,eAK/B,EAGV,OACEmJ,IAAAA,cAACkF,IAAeD,EAAAA,EAAAA,GAAA,CAAC8G,YAAY,YAAcC,EAAAA,EAAAA,GAAkB7K,IAC5C,QAAdA,EAAMkK,KACLrL,IAAAA,cAACupB,EAAiBpoB,GAChB0nB,GAAW1nB,EAAMknB,aACnBroB,IAAAA,cAACsrB,EAAmBnqB,GAEpBnB,IAAAA,cAACgqB,GAAY/kB,EAAAA,EAAAA,GAAA,GAAU9D,EAAO,CAAAtK,QAASA,KAI/C,CAhTCu1B,GAAAzE,KAAAtvB,GAAA+O,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAA8O,GAAAC,GAAAC,GAAAC,GAAA9O,GAAAC,GAAA+f,GAAAC,GAAAzf,GAAAC,GAAAK,GAAAC,GAAAmf,GAAAC,GAAAC,GAAAC,GAAAC,GAAAM,GAAA6D,GAAAlE,GAAAM,GAAAE,GAAA2D,GAAA5D,IAAA3d,GAAA0c,GAAAzc,MAAAC,EAAAA,EAAAA,GAAAmhB,GAAA,CA7IAhnB,GAAc,cAAe,CAC5B8F,WAAY,CAACC,GAAAA,GACbC,MAAO,CAAC,4BACR,EAKC/F,KAAU,WAMVA,KAAU,YAKVA,GAAS,CAAEkG,WAAW,IAAQ,YAO9BlG,GAAS,CAAEkG,WAAW,IAAQ,cAO9BlG,KAAU,WAMVA,GAAS,CAAEgG,KAAMC,UAAU,eAO3BjG,GAAS,CAAEgG,KAAMC,UAAU,eAM3BjG,GAAS,CAAEgG,KAAMC,UAAU,eAM3BjG,GAAS,CAAEkG,WAAW,IAAQ,cAM9BlG,GAAS,CACRgG,KAAMC,UACN,cAMDjG,GAAS,CACRkG,WAAW,IACX,mBAMDjG,GAAM,CAAE+F,KAAM,WAAW,wBAAAnN,IAAAkL,EAAAA,EAAAA,GAAA7C,GAAArI,GAAA,CAAAA,EAAAmL,KAAAC,EAAAA,EAAAA,GAAA/C,GAAArI,EAAAmL,IAAA,CAuBzB/D,GAAM,CAAE+F,KAAM,mBAAmB,uBAAAnN,IAAAkL,EAAAA,EAAAA,GAAA5C,GAAAtI,GAAA,CAAAA,EAAAmL,KAAAC,EAAAA,EAAAA,GAAA9C,GAAAtI,EAAAmL,KAAA,GAAA7Q,GAAA6d,GAAA5K,KAAAC,EAAAA,EAAAA,GAAAlT,KAnGbqO,EAAAA,IAAmBmE,oBClEnC,IAAKuhB,GAAC,SAADA,GAAC,OAADA,EAAC,gBAADA,CAAC,MAIb,MAQaC,GAAK,0JCmBlBC,EAAAA,GAAAA,qBAAoBD,GDjBG,CAAEE,GAVN,CACjBC,OAAQ,8BASmBC,GANV,CACjBD,OAAQ,sBCwBV,MAAQvnB,cAAa,GAAEC,SAAQ,GAAEC,MAAKA,KAAKE,EAAAA,EAAAA,oBAErCmV,IAAcxV,EAAAA,EAAAA,WAAyC,WAEvDggB,IAAgBhgB,EAAAA,EAAAA,WAA+B,aAE/C0nB,IAAc1nB,EAAAA,EAAAA,WAClB,UACA,CACE2nB,eAAgB,gBAChBC,kBAAmB,mBACnBC,gBAAiB,mBAIf9nB,IAAkBC,EAAAA,EAAAA,WAAmC,gBAEpD,SAAS8nB,GACd9rB,EACA+rB,EACA50B,GAEA,MAAO,KAAM,IAAA60B,EACX,MAAMC,EAAajsB,SAAiB,QAAZgsB,EAALhsB,EAAOgJ,kBAAU,IAAAgjB,GAAO,QAAPA,EAAjBA,EAAmBxsB,aAAK,IAAAwsB,OAAA,EAAxBA,EAA0B3qB,KAC1C6G,GAAWA,EAAE6jB,EAAWx0B,QAEyB,IAAA20B,EAAAC,EAAAC,EAApD,OAAI,IAAIC,IAAIJ,GAAY/Y,OAAS+Y,EAAW31B,OAEL,QADrC41B,EACqB,QADrBC,EACGJ,EAAWrjB,eAAO,IAAAyjB,OAAA,EAAnBA,EAA6BG,cAAM,IAAAJ,EAAAA,EACnC/0B,EAAEi0B,GAAEI,OAAQ,CAAEj0B,KAAsB,QAAlB60B,EAAEL,EAAW3jB,aAAK,IAAAgkB,EAAAA,EAAIL,EAAWx0B,OAGhD,EAAE,CAEb,CA4BO,MAAMg1B,GAAeA,CAC1BroB,EACAwV,IAEwB,mBAAbxV,EACFA,KAAYwV,GAEdxV,EAET,IAAAsoB,GAAA,IAAA/nB,GAAA,IAAAD,QAAAE,GAAA,IAAAF,QAAAG,GAAA,IAAAH,QAAAI,GAAA,IAAAJ,QAAAK,GAAA,IAAAL,QAAAM,GAAA,IAAAN,QAAAO,GAAA,IAAAP,QAAAQ,GAAA,IAAAR,QAAAS,GAAA,IAAAT,QAAAU,GAAA,IAAAV,QAAAW,GAAA,IAAAX,QAAAioB,GAAA,IAAAjnB,QAAAJ,GAAA,IAAAZ,QAAAa,GAAA,IAAAb,QAAAkoB,GAAA,IAAAloB,QAAAmoB,GAAA,IAAAnoB,QAKA,MAAAooB,WAI8BlnB,EAAAA,EAAoBC,WAAAA,GAAA,SAAAC,YAAAC,EAAAA,EAAAA,GAAA,KAAA4mB,KAChD3mB,EAAAA,EAAAA,GAAA,KAAArB,GAAAwB,GAAA,QAIAH,EAAAA,EAAAA,GAAA,KAAApB,IAAAwB,GAAA,MAAAC,GAAA,SAIAL,EAAAA,EAAAA,GAAA,KAAAnB,IAAAyB,GAAA,MAAAa,GAAA,SAQAnB,EAAAA,EAAAA,GAAA,KAAAlB,IAAAsC,GAAA,MAAAb,GAAA,SAQAP,EAAAA,EAAAA,GAAA,KAAAjB,IAAAyB,GAAA,MAAAiB,GAAA,SAMAzB,EAAAA,EAAAA,GAAA,KAAAhB,IAAA0C,GAAA,MAAAqlB,GAAA,SAWA/mB,EAAAA,EAAAA,GAAA,KAAAf,IAAA+nB,GAAA,MAAAC,GAAA,SAWAjnB,EAAAA,EAAAA,GAAA,KAAAd,IAAAgoB,GAAA,MAAAC,GAAA,SAWAnnB,EAAAA,EAAAA,GAAA,KAAAb,IAAAioB,GAAA,MAAAC,GAAA,SAWArnB,EAAAA,EAAAA,GAAA,KAAAZ,IAAAkoB,GAAA,MAAAxX,GAAA,SAAA9P,EAAAA,EAAAA,GAAA,KAAAX,IAAA0Q,GAAA,MAAAC,GAAA,SAWAhQ,EAAAA,EAAAA,GAAA,KAAAV,IAAA2Q,GAAA,MAAAsX,GAAA,SAMAvnB,EAAAA,EAAAA,GAAA,KAAAT,IAAAioB,GAAA,MAAAC,GAAA,SAMAznB,EAAAA,EAAAA,GAAA,KAAA4mB,IAAUc,GAAA,MAAIhuB,KACZsI,EAAAA,EAAAA,GAAA2kB,GAAArwB,KAAKqxB,IAAUzlB,KAAKxI,EAAM,KAG5BsG,EAAAA,EAAAA,GAAA,KAAA6mB,IAAiBntB,KACfsI,EAAAA,EAAAA,GAAA2kB,GAAArwB,KAAKsxB,IAAa1lB,KAAKxI,EAAM,KAC7BoI,EAAAA,EAAAA,GAAA,gCAEyB8F,IAAoC,IAAAigB,EAC7DvxB,KAAKoD,MAAQkO,GACb5F,EAAAA,EAAAA,GAAA2kB,GAAArwB,KAAK8Z,IAAalO,KAAK0F,GACF,QAArBigB,EAAAvxB,KAAK8M,wBAAgB,IAAAykB,GAArBA,EAAuBnf,oBAAoB,GAC5C,SA1GoBjX,GAAI,OAAA0Q,EAAAA,EAAAA,GAAAxD,GAAA,cAAJlN,CAAI2Q,IAAAC,EAAAA,EAAAA,GAAA1D,GAAA,KAAAyD,EAAA,UAIJE,GAAK,OAAAH,EAAAA,EAAAA,GAAAvD,GAAA,eAAL0D,CAAKF,IAAAC,EAAAA,EAAAA,GAAAzD,GAAA,KAAAwD,EAAA,aAOjBO,GAAQ,OAAAR,EAAAA,EAAAA,GAAAtD,GAAA,kBAAR8D,CAAQP,IAAAC,EAAAA,EAAAA,GAAAxD,GAAA,KAAAuD,EAAA,UAQR1I,GAAK,OAAAyI,EAAAA,EAAAA,GAAArD,GAAA,eAALpF,CAAK0I,IAAAC,EAAAA,EAAAA,GAAAvD,GAAA,KAAAsD,EAAA,YAMLQ,GAAO,OAAAT,EAAAA,EAAAA,GAAApD,GAAA,iBAAP6D,CAAOR,IAAAC,EAAAA,EAAAA,GAAAtD,GAAA,KAAAqD,EAAA,qBAQP0lB,GAAgB,OAAA3lB,EAAAA,EAAAA,GAAAnD,GAAA,0BAAhB8oB,CAAgB1lB,IAAAC,EAAAA,EAAAA,GAAArD,GAAA,KAAAoD,EAAA,yBAWhB2lB,GAAoB,OAAA5lB,EAAAA,EAAAA,GAAAlD,GAAA,8BAApB8oB,CAAoB3lB,IAAAC,EAAAA,EAAAA,GAAApD,GAAA,KAAAmD,EAAA,kBAWpB4lB,GAAa,OAAA7lB,EAAAA,EAAAA,GAAAjD,GAAA,uBAAb8oB,CAAa5lB,IAAAC,EAAAA,EAAAA,GAAAnD,GAAA,KAAAkD,EAAA,sBAWb6lB,GAAiB,OAAA9lB,EAAAA,EAAAA,GAAAhD,GAAA,2BAAjB8oB,CAAiB7lB,IAAAC,EAAAA,EAAAA,GAAAlD,GAAA,KAAAiD,EAAA,aAWjBqO,GAAQ,OAAAtO,EAAAA,EAAAA,GAAA/C,GAAA,kBAARqR,CAAQrO,IAAAC,EAAAA,EAAAA,GAAAjD,GAAA,KAAAgD,EAAA,CA+BjBY,MAAAA,GACE,OACEjK,IAAAA,cAACmvB,GAAwB,CACvB/kB,YAAa7M,KAAK8M,iBAClBF,WAAY5M,KACZ7E,KAAM6E,KAAK7E,KACX6Q,MAAOhM,KAAKgM,MACZK,SAAUrM,KAAKqM,SACf8N,SAAUna,KAAKma,SACf/W,MAAOpD,KAAKoD,MACZ8J,cAAelN,KAAKkN,cACpBoH,cAAc,EACdvH,UAAW/M,KAAK+M,UAChBE,UAAWjN,KAAKiN,UAChBD,WAAYhN,KAAKgN,WACjBG,QAAQ,0BACR5J,SAAUvD,KAAK6xB,wBACftC,eAAgBvvB,KAAK6xB,wBACrBvlB,QAAStM,KAAKsM,QACdwlB,OAAOjmB,EAAAA,EAAAA,GAAKykB,GAALtwB,MACP+xB,UAAUlmB,EAAAA,EAAAA,GAAK0kB,GAALvwB,MACV0xB,cAAe1xB,KAAK0xB,cACpBF,iBAAkBxxB,KAAKwxB,iBACvBG,kBAAmB3xB,KAAK2xB,kBACxBF,qBAAsBzxB,KAAKyxB,sBAGjC,EAGK,SAASG,GAAyBhuB,GACvC,MAAM,IAAQouB,EAAAA,GAAAA,gBAAe/C,KACvB,MACJ7rB,EAAK,cACLsuB,GAAgB,EAAK,iBACrBF,GAAmB,EAAK,qBACxBC,GAAuB,EAAK,kBAC5BE,GAAoB,GAClB/tB,EACEquB,GAAiBjuB,EAAAA,EAAAA,QAAuB,OACvCsN,EAAQoa,IAAa5nB,EAAAA,EAAAA,UAAkCV,QAAAA,EAAS,KAEhE8uB,EAAQC,IAAaruB,EAAAA,EAAAA,UAA+B,IAErDsuB,GAAkBva,EAAAA,EAAAA,UACtB,IAAMqa,EAAOjtB,KAAKotB,IAAeC,EAAAA,GAAAA,MAAKD,EAAO,uBAC7C,CAACH,KAQHjsB,EAAAA,EAAAA,YAAU,MACHsU,EAAAA,GAAAA,SAAQnX,EAAOkO,IAClBoa,EAAUtoB,QAAAA,EAAS,GACrB,GACC,CAACA,KAEJ6C,EAAAA,EAAAA,YAAU,KACR,GAAIrC,EAAMuW,SAAU,CAClB,MAAMoY,GAAuCC,EAAAA,GAAAA,SAC3C,IAAIze,MAAMnQ,EAAMuW,WAGlBgY,EACEI,EAAettB,KAAKotB,IAClB,MAAM,WAAE1C,EAAa,CAAC,GAAM0C,EAC5B,GAAI1C,EAAWO,OAAQ,CACrB,IAAIpc,EAAuB,CACzB4b,GAAkB9rB,EAAO+rB,EAAY50B,IAQvC,OANI40B,EAAWrc,YACbQ,EAAkB,KACb0e,EAAAA,GAAAA,SAAQ,IAAIze,MAAM4b,EAAWrc,eAC7BQ,IAGA,IACFue,EACH1C,WAAY,IACP0C,EAAM1C,WACTrc,UAAWQ,GAGjB,CACE,OAAOue,CACT,IAGN,IACC,CAACzuB,EAAMuW,SAAUvW,EAAMgJ,aAE1B,MAeM6J,GAAqB9R,EAAAA,EAAAA,cACzB,CAACvB,EAA2CtE,KAAkB,IAAA2b,EAC9C,QAAdA,EAAA7W,EAAML,gBAAQ,IAAAkX,GAAdA,EAAA1J,KAAAnN,EACE0N,EAAOrM,KAAI,CAACjH,EAAML,IACZA,IAAMmB,EACDsE,EAAMwM,OAAOsC,UAEflU,IAEV,GAEH,CAAC4F,EAAO0N,IAGJmhB,GAAmB9tB,EAAAA,EAAAA,cACtB7F,IAAkB,IAAA4vB,EAAAgE,EACjB,MAAMC,EAAYrhB,EAAOF,QAAO,CAACnW,EAAG0C,IAAMA,IAAMmB,IAChD4sB,EAAUiH,GACI,QAAdjE,EAAA9qB,EAAML,gBAAQ,IAAAmrB,GAAdA,EAAA3d,KAAAnN,EAAiB+uB,GACH,QAAdD,EAAA9uB,EAAMmuB,gBAAQ,IAAAW,GAAdA,EAAA3hB,KAAAnN,EAAiB,CACfgM,OAAQ0B,EAAOyI,MAAK,CAAC9e,EAAG0C,IAAMA,IAAMmB,IACpCA,SACA,GAEJ,CAAC8E,EAAO0N,IAEJshB,GAAoB/a,EAAAA,EAAAA,UACxB,IAAMsY,GAAawB,EAAmB,CAACrgB,KACvC,CAACqgB,EAAmBrgB,IAEhBuhB,GAAgBhb,EAAAA,EAAAA,UACpB,IAAMsY,GAAauB,EAAe,CAACpgB,KACnC,CAACogB,EAAepgB,IAGlB,OACE7O,IAAAA,cAACkF,IAAeD,EAAAA,EAAAA,GAAA,CACd8G,YAAY,YACRC,EAAAA,EAAAA,GAAkB7K,GAAM,CAC5B0P,UAtDaN,KACf,MAAM8f,EAAcb,EAAe3tB,QAC7ByuB,EAAQD,aAAW,EAAXA,EAAaE,iBACzB,iBAEIt1B,EAAmD,GAMzD,OALIq1B,EAAM74B,QACR64B,EAAMjhB,SAAS9T,IACbN,EAAO5E,KAAKkF,EAAKgV,WAAW,IAGzBtV,EAAOu1B,MAAMllB,SAAW,GAAK,UAAU,IA6C5CtL,IAAAA,cAAA,OAAKiM,UAAU,uBAAuB9L,IAAKqvB,GACxC3gB,EAAOrM,KAAI,CAAC7B,EAAOtE,KAClB,MAAMo0B,EAAgB/C,GAAaqB,EAAkB,CAACpuB,EAAOtE,IACvDq0B,EAAoBhD,GAAasB,EAAsB,CAC3DruB,EACAtE,IAEF,OACE2D,IAAAA,cAAA,OAAKiM,UAAU,oBAAoBpI,IAAKxH,KACpCyU,EAAAA,GAAAA,SAAQ2e,IACRzvB,IAAAA,cAAC6sB,GAAW,CACVzY,OAAO,WACPY,UAAW,CACTM,cAAe,MACf4U,WAAY,cAEdje,UAAU,eACV4C,OAAQlO,EACRuU,yBAAyB,EAGzB4X,eAAiBnsB,GAAUqT,EAAmBrT,EAAOtE,IAErD2D,IAAAA,cAAC2wB,GAAAA,uBAAsB,CACrBjZ,SACa,IAAVrb,EACGozB,EACAE,EAGNlX,KAAM9X,KAEN8vB,GACAzwB,IAAAA,cAAA,OACEiM,UAAWC,IAAW,qBAAsB,CAC1C,8BAA+BwkB,KAGjC1wB,IAAAA,cAAC2a,GAAW,CACVuJ,IAAI,UACJ0M,SAAS,mBACT3Y,KAAK,MACLhM,UAAWC,IAAW,aAAc,CAClC,sBAAuBwkB,IAEzBpY,QAASA,IAAM0X,EAAiB3zB,OAMtC,IAGV2D,IAAAA,cAAA,OACEiM,UAAWC,IAAW,CACpB,2BAA4BikB,KAG9BnwB,IAAAA,cAACmlB,GAAa,CACZlZ,UAAWC,IAAW,UAAW,CAC/B,eAAgBkkB,EAChB,mBAAoBD,IAEtBlY,KAAM,CACJ2Y,SAAU,mBACV3Y,KAAM,MACNiM,IAAK,WAEP7Y,KAAK,SACLwlB,YAAa,CACXlsB,MAAO,OACP6e,MAAO2M,EAAoB,6BAA+B,IAE5D7X,QA/KYwY,KAAM,IAAAC,EACf,QAAXA,EAAA5vB,EAAMkuB,aAAK,IAAA0B,GAAXA,EAAAziB,KAAAnN,EAAc,CAAEgM,OAAQ,CAAC,EAAG9Q,MAAOwS,EAAOpX,SAC1CwxB,EAAUpa,EAAOxX,OAAO,CAAC,GAAG,GA8KrB,QAKL2I,IAAAA,cAAA,QAAMtH,KAAK,aAGjB,CA7MCs4B,GAAAjD,KAAA11B,GAAA+O,GAAAC,GAAAC,GAAAC,GAAAa,GAAAC,GAAAb,GAAAC,GAAAiB,GAAAC,GAAAqlB,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAxX,GAAAC,GAAAC,GAAAI,GAAAyB,GAAA5B,GAAAsX,GAAAI,GAAAqC,GAAAxC,GAAAC,GAAAG,GAAAqC,GAAAvC,IAAA5jB,GAAA4iB,GAAA3iB,MAAAC,EAAAA,EAAAA,GAAA+lB,GAAA,CAhJA5rB,GAAc,uBAAwB,CACrC8F,WAAY,CAACC,GAAAA,GACbC,MAAO,CAAC,6BACR,EAKC/F,KAAU,WAIVA,KAAU,YAIVA,GAAS,CACRgG,KAAMC,UACN,eAMDjG,GAAS,CACRkG,WAAW,IACX,YAMDlG,GAAS,CAAEkG,WAAW,IAAQ,cAM9BlG,GAAS,CACRkG,WAAW,IACX,uBASDlG,GAAS,CACRkG,WAAW,IACX,2BASDlG,GAAS,CACRkG,WAAW,IACX,oBASDlG,GAAS,CACRkG,WAAW,IACX,wBASDlG,GAAS,CACRkG,WAAW,IACX,eAGDjG,GAAM,CAAE+F,KAAM,WAAW,gBAAAnN,IAAAkL,EAAAA,EAAAA,GAAA9C,GAAApI,GAAA,CAAAA,EAAAmL,KAAAC,EAAAA,EAAAA,GAAAhD,GAAApI,EAAAmL,IAAA,CAMzB/D,GAAM,CAAE+F,KAAM,YAAY,aAAAnN,IAAAkL,EAAAA,EAAAA,GAAA7C,GAAArI,GAAA,CAAAA,EAAAmL,KAAAC,EAAAA,EAAAA,GAAA/C,GAAArI,EAAAmL,IAAA,CAM1B/D,GAAM,CAAE+F,KAAM,eAAe,gBAAAnN,IAAAkL,EAAAA,EAAAA,GAAA5C,GAAAtI,GAAA,CAAAA,EAAAmL,KAAAC,EAAAA,EAAAA,GAAA9C,GAAAtI,EAAAmL,KAAA,GAAA7Q,GAAAs1B,GAAAriB,KAAAC,EAAAA,EAAAA,GAAAlT,KA/FFqO,EAAAA,IAAmBmE,gGChGjD,MAAQ5F,cAAa,GAAEC,SAAQ,GAAEC,MAAKA,KAAKE,EAAAA,EAAAA,oBAErCmV,IAAcxV,EAAAA,EAAAA,WAAyC,WACvDgsB,IAAehsB,EAAAA,EAAAA,WACnB,WACA,CACErE,SAAU,WAEZ,IAAAswB,GAAA,IAAAxrB,GAAA,IAAAD,QAAAE,GAAA,IAAAF,QAAAG,GAAA,IAAAH,QAAAI,GAAA,IAAAJ,QAAAK,GAAA,IAAAL,QAAAM,GAAA,IAAAN,QAAAO,GAAA,IAAAP,QAAAQ,GAAA,IAAAR,QAAA0rB,GAAA,IAAA1qB,QAAA2qB,GAAA,IAAA3rB,QAAA4rB,GAAA,IAAA5rB,QAAAS,GAAA,IAAAT,QAAA6rB,GAAA,IAAA7rB,QA4BF,MAAA8rB,WAI4Bpf,EAAAA,iBAAwCvL,WAAAA,GAAA,SAAAC,YAAAC,EAAAA,EAAAA,GAAA,KAAAqqB,KAClEpqB,EAAAA,EAAAA,GAAA,KAAArB,GAAA4B,GAAA,KAIyB,MAEzBP,EAAAA,EAAAA,GAAA,KAAApB,IAAA4B,GAAA,MAAAC,GAAA,SAMAT,EAAAA,EAAAA,GAAA,KAAAnB,IAAA6B,GAAA,MAAA+pB,GAAA,SAQAzqB,EAAAA,EAAAA,GAAA,KAAAlB,IAAA4rB,GAAA,MAAAnV,GAAA,SAQAvV,EAAAA,EAAAA,GAAA,KAAAjB,IAAAyW,GAAA,MAAAmV,GAAA,SAQA3qB,EAAAA,EAAAA,GAAA,KAAAhB,IAAA4rB,GAAA,MAAAC,GAAA,KAMgC,MAEhC7qB,EAAAA,EAAAA,GAAA,KAAAf,IAAA6rB,GAAA,MAAA/U,GAAA,SAMA/V,EAAAA,EAAAA,GAAA,KAAAd,IAAA8W,GAAA,MAAA+U,GAAA,SAKA/qB,EAAAA,EAAAA,GAAA,KAAAqqB,IAAaW,GAAA,MAAItxB,IACfpD,KAAKoD,MAAQA,CAAK,KAEpBsG,EAAAA,EAAAA,GAAA,KAAAsqB,IAA0B5wB,KACxBsI,EAAAA,EAAAA,GAAAooB,GAAA9zB,KAAK20B,IAAQ/oB,KAAK5L,KAAK40B,KAAOxxB,aAAK,EAALA,EAAOwxB,OAASxxB,EAAM,KAGtDsG,EAAAA,EAAAA,GAAA,KAAAb,GAAAgsB,GAAA,QAKAnrB,EAAAA,EAAAA,GAAA,KAAAuqB,IAAaa,GAAA,MAAI1xB,KACfsI,EAAAA,EAAAA,GAAAooB,GAAA9zB,KAAK+0B,IAAQnpB,KAAK5L,KAAK40B,KAAOxxB,aAAK,EAALA,EAAOwxB,OAASxxB,EAAM,GACpD,UAjEOA,GAAK,OAAAyI,EAAAA,EAAAA,GAAAxD,GAAA,eAALjF,CAAK0I,IAAAC,EAAAA,EAAAA,GAAA1D,GAAA,KAAAyD,EAAA,gBAMLvG,GAAW,OAAAsG,EAAAA,EAAAA,GAAAvD,GAAA,qBAAX/C,CAAWuG,IAAAC,EAAAA,EAAAA,GAAAzD,GAAA,KAAAwD,EAAA,cAQXkpB,GAAS,OAAAnpB,EAAAA,EAAAA,GAAAtD,GAAA,mBAATysB,CAASlpB,IAAAC,EAAAA,EAAAA,GAAAxD,GAAA,KAAAuD,EAAA,cAQT+U,GAAS,OAAAhV,EAAAA,EAAAA,GAAArD,GAAA,mBAATqY,CAAS/U,IAAAC,EAAAA,EAAAA,GAAAvD,GAAA,KAAAsD,EAAA,SAQT8oB,GAAI,OAAA/oB,EAAAA,EAAAA,GAAApD,GAAA,cAAJmsB,CAAI9oB,IAAAC,EAAAA,EAAAA,GAAAtD,GAAA,KAAAqD,EAAA,iBAQJmpB,GAAY,OAAAppB,EAAAA,EAAAA,GAAAnD,GAAA,sBAAZusB,CAAYnpB,IAAAC,EAAAA,EAAAA,GAAArD,GAAA,KAAAoD,EAAA,eAMZkV,GAAU,OAAAnV,EAAAA,EAAAA,GAAAlD,GAAA,oBAAVqY,CAAUlV,IAAAC,EAAAA,EAAAA,GAAApD,GAAA,KAAAmD,EAAA,CAuBnBY,MAAAA,GACE,OACEjK,IAAAA,cAACyyB,GAAsB,CACrB9xB,MAAOpD,KAAKoD,MACZmC,YAAavF,KAAKuF,YAClByvB,UAAWh1B,KAAKg1B,UAChBnU,UAAW7gB,KAAK6gB,UAChBoU,aAAcj1B,KAAKi1B,aACnB1xB,UAAUsI,EAAAA,EAAAA,GAAKkoB,GAAL/zB,MACVohB,UAAUvV,EAAAA,EAAAA,GAAKooB,GAALj0B,MACVghB,WAAYhhB,KAAKghB,WACjBmU,mBAAmBtpB,EAAAA,EAAAA,GAAKmoB,GAALh0B,OAGzB,EASK,SAASk1B,GAAuBtxB,GACrC,MAAM,YACJ2B,EAAW,UACXyvB,EAAS,UACTnU,EAAS,aACToU,EAAY,WACZjU,EAAU,kBACVmU,EAAiB,SACjB5xB,EAAQ,SACR6d,GACExd,GAEGR,EAAOS,IAAYC,EAAAA,EAAAA,aAE1BmC,EAAAA,EAAAA,YAAU,KACRpC,EAASD,EAAMR,MAAM,GACpB,CAACQ,EAAMR,QAEV,MAAMgyB,GAAqBvd,EAAAA,EAAAA,UAAQ,IAC1Bod,GACHvT,EAAAA,GAAAA,UAASyT,EAAoBF,GAC7BE,GACH,CAACF,IAEE5T,EAAeA,KACnBD,SAAAA,EAAWhe,EAAO,EASpB,OACEX,IAAAA,cAACmxB,GAAY,CACX9lB,KAAK,OAEL,aAAYknB,EACZnU,UAAWA,EACXtb,YAAaA,EACbnC,MAAOA,EACPG,SAdkBzI,IACpB+I,EAAS/I,EAAE8U,QACXrM,SAAAA,EAAWzI,EAAE8U,QACbwlB,SAAAA,EAAqBt6B,EAAE8U,OAAO,EAY5BnM,UAAY3I,GAAgB,UAAVA,EAAEwL,KAAmB+a,IACvCL,WAAYA,GAEZve,IAAAA,cAAC2a,GAAW,CACViK,KAAK,SACL3Y,UAAU,gBACViY,IAAI,OACJjM,KAAK,SACLkM,MAAM,WACN7L,QAASA,IAAMsG,IACfgU,YAAcv6B,GAAMA,EAAE0L,mBAI9B,CAjEC8uB,GAAApB,KAAAp5B,GAAAmP,GAAAC,GAAAC,GAAAC,GAAA+pB,GAAAC,GAAAnV,GAAAC,GAAAmV,GAAAC,GAAAC,GAAAC,GAAA/U,GAAAC,GAAA+U,GAAAE,GAAAY,GAAAb,GAAAG,GAAAE,GAAAS,GAAAV,IAAAtnB,GAAAqmB,GAAApmB,MAAAC,EAAAA,EAAAA,GAAA4nB,GAAA,CA3FAztB,GAAc,YAAa,CAC1B8F,WAAY,CAACC,GAAAA,GACbC,MAAO,CAAC,0BACR,EAKC/F,KAAU,YAMVA,KAAU,kBAMVA,GAAS,CACRgG,KAAMC,UACN,gBAMDjG,GAAS,CACRgG,KAAMC,UACN,gBAMDjG,GAAS,CACRgG,KAAMC,UACN,WAMDjG,GAAS,CACRgG,KAAMvN,SACN,mBAMDuH,GAAS,CAAEkG,WAAW,IAAQ,iBAM9BjG,GAAM,CAAE+F,KAAM,WAAW,WAAAnN,IAAAkL,EAAAA,EAAAA,GAAAjD,GAAAjI,GAAA,CAAAA,EAAAmL,KAAAC,EAAAA,EAAAA,GAAAnD,GAAAjI,EAAAmL,IAAA,CAYzB/D,GAAM,CAAE+F,KAAM,WAAW,WAAAnN,IAAAkL,EAAAA,EAAAA,GAAAhD,GAAAlI,GAAA,CAAAA,EAAAmL,KAAAC,EAAAA,EAAAA,GAAAlD,GAAAlI,EAAAmL,KAAA,GAAA7Q,GAAAg5B,GAAA/lB,KAAAC,EAAAA,EAAAA,GAAAlT,KAlEA6Z,EAAAA,mBAAgBrH,oBCzDrC,IAAKuhB,GAAC,SAADA,GAAC,OAADA,EAAC,YAADA,EAAC,cAADA,EAAC,0BAADA,EAAC,wCAADA,CAAC,MAOb,MAcaC,GAAK,yCCrBX,IAAKwG,GAAM,SAANA,GAAM,OAANA,EAAM,cAANA,EAAM,UAANA,EAAM,YAANA,EAAM,gBAANA,EAAM,YAANA,EAAM,gBAANA,EAAM,oBAANA,EAAM,YAANA,CAAM,MAWX,MAAMC,GAGT,CACF,CAACD,GAAOE,OAAQ,CACd1P,MAAO,2BACPsH,WAAY,gCACZC,YAAa,mCAEf,CAACiI,GAAOG,KAAM,CACZ3P,MAAO,yBACPsH,WAAY,8BACZC,YAAa,iCAEf,CAACiI,GAAOI,MAAO,CACb5P,MAAO,0BACPsH,WAAY,+BACZC,YAAa,kCAEf,CAACiI,GAAOK,QAAS,CACf7P,MAAO,4BACPsH,WAAY,iCACZC,YAAa,oCAEf,CAACiI,GAAOM,MAAO,CACb9P,MAAO,0BACPsH,WAAY,+BACZC,YAAa,kCAEf,CAACiI,GAAOO,QAAS,CACf/P,MAAO,4BACPsH,WAAY,iCACZC,YAAa,oCAEf,CAACiI,GAAOQ,UAAW,CACjBhQ,MAAO,8BACPsH,WAAY,mCACZC,YAAa,sCAEf,CAACiI,GAAOS,MAAO,CACbjQ,MAAO,0BACPsH,WAAY,+BACZC,YAAa,mCASV,SAAS2I,GAASlQ,GAIvB,IAAAmQ,EACA,OAAKnQ,EAQwB,QAD7BmQ,EACEV,GAAWzP,UAAgB,IAAAmQ,EAAAA,EAAI,CAC7BnQ,QACAsH,WAAYtH,EACZuH,YAAavH,GAVR,CACLA,MAAO,2BACPsH,WAAY,wBACZC,YAAa,2BAUnB,gECvCA0B,EAAAA,GAAAA,qBAAoBD,GFnBG,CAAEE,GAhBN,CACjBkH,KAAM,OACNC,MAAO,QACPC,YAAa,cACbC,mBAAoB,2BAYOnH,GATV,CACjBgH,KAAM,KACNC,MAAO,KACPC,YAAa,OACbC,mBAAoB,aE0BtB,MAAQ3uB,cAAa,GAAEC,SAAQ,GAAEC,MAAKA,KAAKE,EAAAA,EAAAA,oBAErCwuB,IAAUC,EAAAA,GAAAA,gBAAgC,kBAC1CC,IAAcD,EAAAA,GAAAA,gBAAoC,sBAClDE,IAAsBhvB,EAAAA,EAAAA,WAK1B,WAAY,CACZ4Z,cAAe,SACfqV,gBAAiB,kBAEbne,IAAqB9Q,EAAAA,EAAAA,WAAyC,WAC9DkvB,IAAelvB,EAAAA,EAAAA,WACnB,WACA,CACEuV,QAAS,QACT4Z,UAAW,UACXC,SAAU,SACVC,OAAQ,SAGNC,IAAgBtvB,EAAAA,EAAAA,WAKpB,YAAa,CACbrE,SAAU,SACV6d,SAAU,WAENzZ,IAAkBC,EAAAA,EAAAA,WAAmC,gBAAgB,IAAAuvB,GAAA,IAAA9uB,GAAA,IAAAD,QAAAE,GAAA,IAAAF,QAAAG,GAAA,IAAAH,QAAAI,GAAA,IAAAJ,QAAAK,GAAA,IAAAL,QAAAM,GAAA,IAAAN,QAAAO,GAAA,IAAAP,QAAAgvB,GAAA,IAAAhuB,QAmB3E,MAAAiuB,WAIyB/tB,EAAAA,EAA+CC,WAAAA,GAAA,SAAAC,YAAAC,EAAAA,EAAAA,GAAA,KAAA2tB,KACtE1tB,EAAAA,EAAAA,GAAA,KAAArB,GAAAwB,GAAA,QAMAH,EAAAA,EAAAA,GAAA,KAAApB,IAAAwB,GAAA,MAAAC,GAAA,SAMAL,EAAAA,EAAAA,GAAA,KAAAnB,IAAAyB,GAAA,MAAAC,GAAA,SAQAP,EAAAA,EAAAA,GAAA,KAAAlB,IAAA0B,GAAA,MAAAG,GAAA,SAQAX,EAAAA,EAAAA,GAAA,KAAAjB,IAAA6B,GAAA,MAAAO,GAAA,SAQAnB,EAAAA,EAAAA,GAAA,KAAAhB,IAAAoC,GAAA,MAAAK,GAAA,SAQAzB,EAAAA,EAAAA,GAAA,KAAAf,IAAAyC,GAAA,MAAAqpB,GAAA,SAAAjpB,EAAAA,EAAAA,GAAA,qBAAAkpB,GAAA,MAKgBtxB,IACdpD,KAAKoD,MAAQA,GACbsI,EAAAA,EAAAA,GAAA0rB,GAAAp3B,KAAK20B,IAAQ/oB,KAAKxI,EAAM,GACzB,SAhDQjI,GAAI,OAAA0Q,EAAAA,EAAAA,GAAAxD,GAAA,cAAJlN,CAAI2Q,IAAAC,EAAAA,EAAAA,GAAA1D,GAAA,KAAAyD,EAAA,UAMJE,GAAK,OAAAH,EAAAA,EAAAA,GAAAvD,GAAA,eAAL0D,CAAKF,IAAAC,EAAAA,EAAAA,GAAAzD,GAAA,KAAAwD,EAAA,UAQL1I,GAAK,OAAAyI,EAAAA,EAAAA,GAAAtD,GAAA,eAALnF,CAAK0I,IAAAC,EAAAA,EAAAA,GAAAxD,GAAA,KAAAuD,EAAA,aAQLG,GAAQ,OAAAJ,EAAAA,EAAAA,GAAArD,GAAA,kBAARyD,CAAQH,IAAAC,EAAAA,EAAAA,GAAAvD,GAAA,KAAAsD,EAAA,aAQRO,GAAQ,OAAAR,EAAAA,EAAAA,GAAApD,GAAA,kBAAR4D,CAAQP,IAAAC,EAAAA,EAAAA,GAAAtD,GAAA,KAAAqD,EAAA,YAQRQ,GAAO,OAAAT,EAAAA,EAAAA,GAAAnD,GAAA,iBAAP4D,CAAOR,IAAAC,EAAAA,EAAAA,GAAArD,GAAA,KAAAoD,EAAA,CAYhBY,MAAAA,GACE,OACEjK,IAAAA,cAAC60B,GAAmB,CAClBzqB,YAAa7M,KAAK8M,iBAClBF,WAAY5M,KACZ7E,KAAM6E,KAAK7E,KACX6Q,MAAOhM,KAAKgM,MACZ5I,MAAOpD,KAAKoD,MACZiJ,SAAUrM,KAAKqM,SACfJ,SAAUjM,KAAKiM,SACfK,QAAStM,KAAKsM,QACdS,UAAW/M,KAAK+M,UAChBE,UAAWjN,KAAKiN,UAChBD,WAAYhN,KAAKgN,WACjBzJ,SAAUvD,KAAKuO,aACfpB,QAAQ,gBAGd,EACDoqB,GAAAF,KAAAv8B,GAAA+O,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAG,GAAAC,GAAAO,GAAAC,GAAAK,GAAAC,GAAAqpB,GAAAE,GAAAY,GAAAb,IAAAlnB,GAAA2pB,GAAA1pB,MAAAC,EAAAA,EAAAA,GAAA6pB,GAAA,CA9EA1vB,GAAc,iBAAkB,CAC/B8F,WAAY,CAACC,GAAAA,GACbC,MAAO,CAAC,uBACR,EAKC/F,KAAU,WAMVA,KAAU,YAMVA,GAAS,CACRkG,WAAW,IACX,YAMDlG,GAAS,CACRgG,KAAMC,UACN,eAMDjG,GAAS,CACRgG,KAAMC,UACN,eAMDjG,GAAS,CACRkG,WAAW,IACX,cAMDjG,GAAM,CAAE+F,KAAM,WAAW,WAAAnN,IAAAkL,EAAAA,EAAAA,GAAAlD,GAAAhI,GAAA,CAAAA,EAAAmL,KAAAC,EAAAA,EAAAA,GAAApD,GAAAhI,EAAAmL,KAAA,GAAA7Q,GAAAm8B,GAAAlpB,KAAAC,EAAAA,EAAAA,GAAAlT,KAhDHqO,EAAAA,IAAmBmE,KA4E5C,MAAM+pB,GAAY,CAChB7Q,IAAK,UACLjM,KAAM,aACN2Y,SAAU,UAOL,SAASiE,GAAoB1zB,GAClC,MAAM,IAAQouB,EAAAA,GAAAA,gBAAe/C,KACvB,SAAEhjB,EAAQ,SAAE1I,GAAaK,EAEzB6zB,GAAWzzB,EAAAA,EAAAA,QAAc,OAExB0zB,EAAUC,IAAe7zB,EAAAA,EAAAA,UAAoB,KAC7C8zB,EAAcC,IAAmB/zB,EAAAA,EAAAA,UAGrC,CAAC,IACGg0B,EAAUC,IAAej0B,EAAAA,EAAAA,UAAqB,KAErDmC,EAAAA,EAAAA,YAAU,KACRwwB,KAAUpW,MAAM2X,IACdL,EAAYK,GACZH,EAAgB,IAAKD,EAAcjR,IAAKqR,EAAK,GAAGrR,KAAM,GACtD,GACD,IAEH,MAAMsR,EAAqBC,IACzBvB,GAAY,CAAEhQ,IAAKuR,EAAOvR,IAAKwR,EAAGD,EAAOC,EAAGC,KAAM,EAAGC,SAAU,MAAOhY,MACnE3iB,GAAWq6B,EAAYr6B,EAAOG,OAChC,GAGIy6B,EAAaC,IAAkBz0B,EAAAA,EAAAA,aAC/B00B,EAAcC,IAAmB30B,EAAAA,EAAAA,aAExCmC,EAAAA,EAAAA,YAAU,KAAM,IAAAwlB,EAAAiN,EACdH,EAA0B,QAAX9M,EAAA7nB,EAAMR,aAAK,IAAAqoB,GAAXA,EAAa9E,IAAM/iB,EAAMR,WAAQiE,GAChDoxB,EAA2B,QAAZC,EAAC90B,EAAMR,aAAK,IAAAs1B,OAAA,EAAXA,EAAazS,MAAM,GAClC,CAACriB,EAAMR,QAEV,MAAOu1B,EAAcC,IAAmB90B,EAAAA,EAAAA,aACjC+0B,EAAeC,IAAoBh1B,EAAAA,EAAAA,YAEpCi1B,EAAcA,KAClBH,OAAgBvxB,GAChByxB,OAAiBzxB,EAAU,EA2BvB2xB,EAAqB/S,IACzB6S,EAAiB7S,EAAM,EAGzB,OACExjB,IAAAA,cAACkF,IAAeD,EAAAA,EAAAA,GAAA,CAAC8G,YAAY,YAAcC,EAAAA,EAAAA,GAAkB7K,IAC3DnB,IAAAA,cAAA,QACEsY,QAASA,KAAA,IAAAke,EAAA,OAAOhtB,IAA4B,QAApBgtB,EAAIxB,EAASnzB,eAAO,IAAA20B,OAAA,EAAhBA,EAAkBC,OAAM,EACpDxqB,UAAWC,IAAW,YAAa,CACjC1C,SAAUA,IAEZnL,MAAO,CAAEq4B,gBAAiBhD,GAASqC,GAAcjL,aAEjD9qB,IAAAA,cAACiW,IAAkBhR,EAAAA,EAAAA,GAAA,GACZ4wB,GAAed,GAAS,CAC7B12B,MAAO,CAAEmlB,MAAOkQ,GAASqC,GAAcvS,WAG3CxjB,IAAAA,cAACq0B,GAAY,CACXl0B,IAAK60B,EACL2B,WAAYr+B,EAAEi0B,GAAEuH,aAChBnvB,MAAM,QACNiyB,cAAc,EACdC,kBAAkB,EAClBvC,UAtCqBwC,KAAM,IAAAC,EAC/BjB,EAAeI,GACfF,EAAgBI,GAChB,MAAM3V,EAAWyV,SAAAA,EAAchS,IAC3B,IAAKgS,EAAc1S,MAAO4S,QAC1BxxB,EACJ9D,SAAAA,EAAW2f,GACK,QAAhBsW,EAAA/B,EAASnzB,eAAO,IAAAk1B,GAAhBA,EAAkBC,OAAO,EAgCrBtc,QA3CmBuc,KACvBX,GAAa,EA2CT9B,OAlDkB0C,KACtBf,EAAgBN,GAChBQ,EAAiBN,GACjBP,EAAkBL,EAAa,GAiD3Bn1B,IAAAA,cAAA,OAAKiM,UAAU,qBACbjM,IAAAA,cAAA,OACEiM,UAAU,YACV5N,MAAO,CAAEq4B,gBAAiBhD,GAAS0C,GAAetL,aAElD9qB,IAAAA,cAACiW,IAAkBhR,EAAAA,EAAAA,GAAA,GACZixB,GAAgBnB,GAAS,CAC9B12B,MAAO,CAAEmlB,MAAOkQ,GAAS0C,GAAe5S,UAEzC0S,GACCl2B,IAAAA,cAAA,OAAKiM,UAAU,iBAAiBqM,QAASA,IAAMge,KAC7Ct2B,IAAAA,cAAA,OAAKiM,UAAU,eACbjM,IAAAA,cAACiW,GAAkB,CACjBiO,IAAI,UACJ0M,SAAS,UACT3Y,KAAK,SACL5Z,MAAO,CAAEmlB,MAAO,+BAM1BxjB,IAAAA,cAAA,QAAMiM,UAAU,qBAAqBiqB,aAAY,EAAZA,EAAcje,OAErDjY,IAAAA,cAAA,OAAKiM,UAAU,yBAEXjM,IAAAA,cAAAA,IAAAA,SAAA,KACEA,IAAAA,cAAA,QAAMiM,UAAU,SAAS3T,EAAEi0B,GAAEsH,OAAO,KACpC7zB,IAAAA,cAAA,OAAKiM,UAAU,qBACZsC,OAAOwD,KAAKkhB,IAAYzwB,KAAKjH,GAE1ByE,IAAAA,cAAA,OACEiM,UAAU,YACV5N,MAAO,CAAEq4B,gBAAiBhD,GAASn4B,GAAMioB,OACzC3f,IAAKtI,EACL+c,QAASA,IAAMie,EAAkBh7B,OAIvCyE,IAAAA,cAAA,OACEiM,UAAU,wBACVqM,QAASA,IAAMie,OAAkB3xB,IAEjC5E,IAAAA,cAAA,OAAKiM,UAAU,kBAKvBjM,IAAAA,cAAA,QAAMiM,UAAU,SAAS3T,EAAEi0B,GAAEqH,MAAM,KACnC5zB,IAAAA,cAAA,OAAKiM,UAAU,oBACbjM,IAAAA,cAAA,OAAKiM,UAAU,0BACbjM,IAAAA,cAACy0B,GAAa,CACZ9zB,MAAOw0B,EAAaO,EACpB5yB,YAAaxK,EAAEi0B,GAAEwH,oBACjBpV,SAAWtmB,IACT,MAAM8+B,EAAkB,IAAKhC,EAAcO,EAAGr9B,EAAE8U,QAChDioB,EAAgB+B,GAChB3B,EAAkB2B,EAAgB,IAGtCn3B,IAAAA,cAACm0B,GAAmB,CAClBt9B,QAASo+B,aAAQ,EAARA,EAAUzyB,KAAK0hB,IACf,CACL3a,MAAO2a,EAAIxL,MACX/X,MAAOujB,EAAIA,QAGfvjB,MAAOw0B,EAAajR,IACpBnF,cAAgB1mB,IACd,MAAM8+B,EAAkB,IACnBhC,EACHjR,IAAK7rB,EAAE8U,OAAOxM,OAEhBy0B,EAAgB+B,GAChB3B,EAAkB2B,EAAgB,KAIxCn3B,IAAAA,cAAA,OAAKiM,UAAU,aACZopB,EAAS7yB,KAAK40B,GAEXp3B,IAAAA,cAAA,OACE6D,IAAK/L,KAAKC,UAAUq/B,EAASnf,MAC7BS,MAAO0e,EAAS1e,MAChBzM,UAAU,iBACVqM,QAASA,KArHDL,QAsHWmf,EAASnf,KArH5Cke,EAAgBle,EAqHiC,GAGjCjY,IAAAA,cAACiW,GAAuBmhB,EAASnf,MACjCjY,IAAAA,cAAA,OAAKiM,UAAU,aAAamrB,EAAS1e,cAUzD,CC3XO,IAAK6T,GAAC,SAADA,GAAC,OAADA,EAAC,gBAADA,EAAC,gCAADA,EAAC,oCAADA,EAAC,oDAADA,CAAC,MAOb,MAeaC,GAAK,uCAEL6K,GAAU,CAAE3K,GAjBN,CACjB4K,OAAQ,SACRC,eAAgB,0BAChBC,iBAAkB,sDAClBC,yBACE,iEAYyB7K,GATV,CACjB0K,OAAQ,KACRC,eAAgB,QAChBC,iBAAkB,iCAClBC,yBAA0B,4EChB5B,IAAIxqB,GAAM,EAEH,MAAMyqB,GAA2BC,OAAOC,IAAI,mBAExBD,OAAOC,IAAI,eAM/B,IAAKC,GAAY,SAAZA,GAAY,OAAZA,EAAY,QAAZA,EAAY,QAAZA,EAAY,QAAZA,CAAY,MAMjB,MAkDMC,GAAgB,SAC3BC,EACAC,GAEG,IADHC,EAAkBlxB,UAAAtP,OAAA,QAAAmN,IAAAmC,UAAA,GAAAA,UAAA,GAAG8wB,GAAaK,GAElC,OAAO,IAAIxa,SAAQ,CAACC,EAASwa,KAC3B,GAAIJ,GAAQC,EAAW,CACrB,MAAMI,EAAY,CAChB,CAACP,GAAaQ,IAAK,KACnB,CAACR,GAAaK,IAAK,QACnB,CAACL,GAAaS,IAAK,YAGrBP,EAAK1jB,KAAO2jB,EAAYI,EAAUH,GAC9Bta,EAAQoa,GACRI,EACE,IAAIr5B,MACFy5B,GAAAA,KAAKjgC,EAAE,GAAGk0B,MAAMD,GAAEkL,2BAA4B,CAAEO,YAAWC,UAGrE,MACEta,EAAQoa,EACV,GAEJ,EC3CO,SAASS,GAAOr3B,GACrB,MAAM,SACJs3B,EAAQ,WACRC,EAAU,WACVC,EAAU,SACV73B,EAAQ,WACR83B,EAAa,OAAM,OACnBC,EAAM,OACNtzB,EAAM,OACNuzB,EAAM,SACNC,EAAQ,UACRf,EAAS,iBACTgB,EAAmB,UAAS,uBAC5BC,EAAyB,GAAE,8BAC3BC,EAA6B,SAC7Bha,GACE/d,EAEEmf,GAAW/e,EAAAA,EAAAA,QAAyB,OAEnC43B,EAAsBC,IAA2B/3B,EAAAA,EAAAA,UACtD,KAGFmC,EAAAA,EAAAA,YAAU,KACR41B,EAAwBj4B,EAAMk4B,UAAY,GAAG,GAC5C,CAACl4B,EAAMk4B,WAEV,MAAMC,EAAoBC,GACjBA,EAAM5qB,QAAQopB,GD5DMyB,EAACzB,EAAY0B,KAC1C,MAAMC,EAAgB,GAAgBriC,OAAOoiC,GAAW,IAAItW,QAC1D,CAACC,EAAKC,IACJD,EAAI/rB,OACFgsB,EACGzqB,MAAM,KACN4J,KAAK6G,GAAMA,EAAE8oB,SACbxjB,OAAOrD,WAEd,IAGF,GAAIysB,GAAQ2B,EAAajiC,OAAQ,CAC/B,MAAMkiC,GAAiB5B,EAAKr/B,MAAQ,IAAIkhC,cAClCC,EAAW9B,EAAK1sB,MAAQ,GACxByuB,EAAeD,EAASjhC,MAAM,KAAK,GAEzC,OAAO8gC,EAAavpB,MAAM2oB,IAExB,GAAI,CAAC,IAAK,OAAOpqB,SAASoqB,GACxB,OAAO,EAIT,GAAIA,EAAOiB,WAAW,KAAM,CAC1B,MAAMC,EAAYlB,EAAOc,cACzB,IAAIK,EAAY,CAACD,GAKjB,MAJI,CAAC,OAAQ,SAAStrB,SAASsrB,KAC7BC,EAAY,CAAC,OAAQ,UAGhBA,EAAU9pB,MAAM+pB,GAAUP,EAAcQ,SAASD,IAC1D,CAGA,OAAIpB,EAAOqB,SAAS,MACXL,IAAiBhB,EAAOlgC,MAAM,MAAM,GAIzCihC,IAAaf,CAIL,GAEhB,CACA,OAAO,CAAI,ECaqBU,CAAgBzB,EAAMe,KA6HhDsB,EAAmBtZ,UACvB,MAAMuZ,EAAc,IAAId,GACxB,IACIe,EADAC,EAAwB,GAG5B,GAAIxB,GAAYj7B,OAAOi7B,GAAY,EAAG,CACpC,MAAMyB,EAAerB,EAAqB1hC,OAC1C,GAAI+iC,EAAeH,EAAY5iC,QAAUshC,EACvCwB,EAAgBjB,EAAiBe,OAC5B,CACL,MACMI,EAAaJ,EAAY5iC,QADb+iC,EAAeH,EAAY5iC,OAASshC,GAG7B,WAArBC,EACFuB,EAAgBjB,EAAiBe,GAAapX,MAAM,EAAGwX,IAEvDF,EAAgBjB,EAAiBe,GAAapX,OAC3C8V,EACD2B,KAIAJ,EADEC,EAAc9iC,OAASshC,EACN,CAACwB,EAAc9iC,OAASshC,EAAU2B,KAElC,CAAC,EAAG,GAG7B,CACF,MACEH,EAAgBjB,EAAiBe,GAGnC,MAAMM,OA1JoB7Z,iBACJpD,QAAQkd,IAC5BrB,EAAM/2B,KAAKu1B,GACTra,QAAQmd,WAAW,CACjB9C,EACAD,GAAcC,EAAMC,MACjBiB,EAAuBz2B,KAAKqO,GAAcA,EAAUknB,EAAMwB,WAIpD/2B,KAAItC,IAAiC,IAA/B46B,KAAUC,GAAgB76B,EAC7C,MAAM63B,EAAQ+C,EAAuCn6B,MAC/Cq6B,EAAkB,GAMxB,OAJAD,EAAgB1rB,SAASpU,IACL,aAAlBA,EAAOggC,QAAyBD,EAAO3kC,KAAK4E,EAAOigC,OAAO,IAGrD,CAAEnD,OAAMiD,SAAQ,IAwIIG,CAAoBZ,GAC3Ca,OArIoBta,UAGnBpD,QAAQkd,IACbS,EAAa74B,KACXse,UAMM,IANC,KACLiX,EAAI,OACJiD,GAID1rB,EACC,MAAMrC,ED1GP,iBAAiB,IAAIquB,UAAYruB,KCwHhC,OAbA8qB,EAAK9qB,IAAMA,EAaJ,CAAEA,MAAK8qB,OAAMr/B,KAZPq/B,EAAKr/B,KAYQuiC,OAVGD,EAAOvjC,OAChC,QACAkhC,EACA,YACA,OAM8B4C,eAJXrC,aAA6B,EAA7BA,EACrBnB,EACAsD,IAE0CL,SAAQ,KA2GtBQ,CAAoBb,IACvDS,EAAsB3jC,QAAU6iC,IAC/BlB,GAAyBiC,IACvB,MAAMI,GACJnB,EACIe,EAAapY,SAASqX,GACtBe,GACJhkC,OAAO+jC,GAET,OADAt6B,SAAAA,EAAW26B,GACJA,CAAe,IAG1BL,EAAsB/rB,SACnBqsB,GAAiC,cAApBA,EAAST,QAjEPS,KAClB,MAAMtrB,EAAW,IAAIurB,SACfC,EAAkB,IAAIC,gBAC5BH,EAAShE,IAA4BkE,EACrCxrB,EAAS0rB,OAAOlD,EAAY8C,EAAS3D,KAAO2D,EAAS3D,KAAMr/B,MAE3D,MAAMqjC,EAAMC,GAAAA,KAAKC,QAAQpD,EAAS,CAChCtzB,SACAnD,KAAMgO,EACN8rB,OAAQN,EAAgBM,SAO1B,OAJAH,EACGne,MAAMue,GA9DiBC,EAACV,EAAoBS,KAC/C/C,GAAyBiC,IACvB,MAAMI,EAAkBJ,EAAa74B,KAAK65B,GACjCA,EAAUpvB,MAAQyuB,EAASzuB,IAC9B,IACKovB,EACHF,WACAlB,OAAQ,QAEVoB,IAGN,OADAv7B,SAAAA,EAAW26B,GACJA,CAAe,GACtB,EAiDoBW,CAAoBV,EAAUS,KACjDG,OAAOnwB,GA/CcowB,EAACb,EAAoBvvB,KAC7CitB,GAAyBiC,IACvB,MAAMI,EAAkBJ,EAAa74B,KAAK65B,IAAc,IAAAG,EACtD,OAAOH,EAAUpvB,MAAQyuB,EAASzuB,IAC9B,IACKovB,EACHrB,OAAwB,QAAlBwB,EAAEH,EAAUrB,cAAM,IAAAwB,OAAA,EAAhBA,EAAkBnlC,OAAO8U,GACjC8uB,OAAQ,SAEVoB,CAAS,IAGf,OADAv7B,SAAAA,EAAW26B,GACJA,CAAe,GACtB,EAkCkBc,CAAkBb,EAAUvvB,KAEzC4vB,CAAG,EAiDyCU,CAAWf,IAC7D,EASH,OACE17B,IAAAA,cAAAA,IAAAA,SAAA,KACEA,IAAAA,cAAA,SACEG,IAAKmgB,EACLjV,KAAK,OACL6T,SAAUA,EACV4Z,OAAQA,EACR4D,QAAM,EACN57B,SAdoBggB,UACxBxb,EAAMtB,kBACNo2B,EAAiB,IAAI90B,EAAMhH,OAAOi7B,QAClCj0B,EAAMhH,OAAOqC,MAAQ,EAAE,IAarBX,IAAAA,cAAA,OAAKiM,UAAU,kBACZwsB,EAASU,EAAsB,CAC9BwD,OAAQA,KAAA,IAAAC,EAAA,OAAsB,QAAtBA,EAAMtc,EAASze,eAAO,IAAA+6B,OAAA,EAAhBA,EAAkBC,OAAO,EACvCC,YAAcvD,GAAUa,EAAiBb,KAE3Cv5B,IAAAA,cAAA,OAAKiM,UAAU,aACZktB,EAAqB32B,KAAI,CAACk5B,EAAUr/B,KACnC,MAAM0gC,EAAU,CACd/lC,OAAQA,IApGE0kC,KACiB,IAAAsB,EAXbC,EAWA,cAApBvB,EAAST,SACuB,QAAlC+B,EAAAtB,EAAShE,WAAyB,IAAAsF,GAAlCA,EAAoCE,SAZdD,EAcPvB,EAbjBtC,GAAyBiC,IACvB,MAAMI,EAAkBJ,EAAa1sB,QAClC+sB,GAAaA,EAASzuB,MAAQgwB,EAAgBhwB,MAGjD,OADAnM,SAAAA,EAAW26B,GACJA,CAAe,GAQE,EAgGF0B,CAAazB,IAE7B,OACE17B,IAAAA,cAACA,IAAAA,SAAc,CAAC6D,IAAK63B,EAASzuB,KAC3ByrB,EAAWgD,EAAUvC,EAAsB4D,EAAS1gC,GACtC,MAO/B,gBC3RO,MAAM+gC,GAAWA,CACtBrF,EACAsF,IAEO,IAAI3f,SAAQ,CAACC,EAASwa,KAC3B,IAAImF,EAAM,GACU,iBAATvF,EACTuF,EAAMvF,EACGA,aAAgBwF,MAAQxF,EAAK1sB,KAAK0uB,WAAW,UACtDuD,EAAME,IAAIC,gBAAgB1F,GAE1BI,EAAO,IAAIr5B,MAAM,cAEnB,MAAM4+B,EAAQ,IAAIC,MAClBD,EAAME,IAAMN,EACZI,EAAMG,OAAS,KACbR,GAAaG,IAAIM,gBAAgBR,GACjC3f,EAAQ+f,EAAM,EAEhBA,EAAMK,QAAW5xB,GAAUgsB,EAAOhsB,EAAM,IAsB/B6xB,GAAoBld,UAC/B,MAAM4c,QAAcN,GAASrF,GAC7B,MAAO,CACLuF,IAAKI,EAAME,IACXllC,KAAMq/B,EAAKr/B,KACXulC,aAAcP,EAAMO,aACpBC,cAAeR,EAAMQ,cACrB7pB,KAAM8pB,GAAAA,MAAMC,WAAWrG,EAAK1jB,KAAM,SAAS3R,KAAK,IACjD,mFCpCH+pB,EAAAA,GAAAA,qBAAoBD,GAAI6K,IAExB,MAAQjyB,cAAa,GAAEC,SAAQ,GAAEC,MAAKA,KAAKE,EAAAA,EAAAA,oBAErC2f,IAAgBhgB,EAAAA,EAAAA,WAA+B,aAC/Ck5B,IAAel5B,EAAAA,EAAAA,WAA6B,YAC5CwV,IAAcxV,EAAAA,EAAAA,WAAyC,WACvDD,IAAkBC,EAAAA,EAAAA,WAAmC,gBAAgB,IAAAm5B,GAAA,IAAA14B,GAAA,IAAAD,QAAAE,GAAA,IAAAF,QAAAG,GAAA,IAAAH,QAAAI,GAAA,IAAAJ,QAAAK,GAAA,IAAAL,QAAAM,GAAA,IAAAN,QAAAO,GAAA,IAAAP,QAAAQ,GAAA,IAAAR,QAAAS,GAAA,IAAAT,QAAAU,GAAA,IAAAV,QAAA44B,GAAA,IAAA53B,QAoB3E,MAAA63B,WAI0B33B,EAAAA,EAAgDC,WAAAA,GAAA,SAAAC,YAAAC,EAAAA,EAAAA,GAAA,KAAAu3B,KACxEt3B,EAAAA,EAAAA,GAAA,KAAArB,GAAAwB,GAAA,QAMAH,EAAAA,EAAAA,GAAA,KAAApB,IAAAwB,GAAA,MAAAC,GAAA,SAMAL,EAAAA,EAAAA,GAAA,KAAAnB,IAAAyB,GAAA,MAAAC,GAAA,SAQAP,EAAAA,EAAAA,GAAA,KAAAlB,IAAA0B,GAAA,MAAAg3B,GAAA,SAMAx3B,EAAAA,EAAAA,GAAA,KAAAjB,IAAA04B,GAAA,MAAAC,GAAA,SAQA13B,EAAAA,EAAAA,GAAA,KAAAhB,IAAA24B,GAAA,MAAAC,GAAA,SAQA53B,EAAAA,EAAAA,GAAA,KAAAf,IAAA44B,GAAA,MAAAC,GAAA,SAQA93B,EAAAA,EAAAA,GAAA,KAAAd,IAAA64B,GAAA,MAAA52B,GAAA,SAQAnB,EAAAA,EAAAA,GAAA,KAAAb,IAAAiC,GAAA,MAAAK,GAAA,SAQAzB,EAAAA,EAAAA,GAAA,KAAAZ,IAAAsC,GAAA,MAAAqpB,GAAA,SAAAjpB,EAAAA,EAAAA,GAAA,qBAAAkpB,GAAA,MAKgBgN,IACd1hC,KAAKoD,MAAQs+B,GACbh2B,EAAAA,EAAAA,GAAAs1B,GAAAhhC,KAAK20B,IAAQ/oB,KAAK81B,EAAU,GAC7B,SAtEQvmC,GAAI,OAAA0Q,EAAAA,EAAAA,GAAAxD,GAAA,cAAJlN,CAAI2Q,IAAAC,EAAAA,EAAAA,GAAA1D,GAAA,KAAAyD,EAAA,UAMJE,GAAK,OAAAH,EAAAA,EAAAA,GAAAvD,GAAA,eAAL0D,CAAKF,IAAAC,EAAAA,EAAAA,GAAAzD,GAAA,KAAAwD,EAAA,UAQL1I,GAAK,OAAAyI,EAAAA,EAAAA,GAAAtD,GAAA,eAALnF,CAAK0I,IAAAC,EAAAA,EAAAA,GAAAxD,GAAA,KAAAuD,EAAA,eAML61B,GAAU,OAAA91B,EAAAA,EAAAA,GAAArD,GAAA,oBAAVm5B,CAAU71B,IAAAC,EAAAA,EAAAA,GAAAvD,GAAA,KAAAsD,EAAA,aAQV0vB,GAAQ,OAAA3vB,EAAAA,EAAAA,GAAApD,GAAA,kBAAR+yB,CAAQ1vB,IAAAC,EAAAA,EAAAA,GAAAtD,GAAA,KAAAqD,EAAA,aAQR6V,GAAQ,OAAA9V,EAAAA,EAAAA,GAAAnD,GAAA,kBAARiZ,CAAQ7V,IAAAC,EAAAA,EAAAA,GAAArD,GAAA,KAAAoD,EAAA,cAQR2uB,GAAS,OAAA5uB,EAAAA,EAAAA,GAAAlD,GAAA,mBAAT8xB,CAAS3uB,IAAAC,EAAAA,EAAAA,GAAApD,GAAA,KAAAmD,EAAA,aAQTO,GAAQ,OAAAR,EAAAA,EAAAA,GAAAjD,GAAA,kBAARyD,CAAQP,IAAAC,EAAAA,EAAAA,GAAAnD,GAAA,KAAAkD,EAAA,YAQRQ,GAAO,OAAAT,EAAAA,EAAAA,GAAAhD,GAAA,iBAAPyD,CAAOR,IAAAC,EAAAA,EAAAA,GAAAlD,GAAA,KAAAiD,EAAA,CAYhBY,MAAAA,GACE,OACEjK,IAAAA,cAACm/B,GAAoB,CACnB/0B,YAAa7M,KAAK8M,iBAClBF,WAAY5M,KACZ7E,KAAM6E,KAAK7E,KACX6Q,MAAOhM,KAAKgM,MACZ5I,MAAOpD,KAAKoD,MACZiJ,SAAUrM,KAAKqM,SACfC,QAAStM,KAAKsM,QACdkvB,SAAUx7B,KAAKw7B,SACfmG,WAAY3hC,KAAK2hC,WACjBhgB,SAAU3hB,KAAK2hB,SACf8Y,UAAWz6B,KAAKy6B,UAChB1tB,UAAW/M,KAAK+M,UAChBE,UAAWjN,KAAKiN,UAChB1J,SAAUvD,KAAKuO,aACfpB,QAAQ,gBAGd,EACD00B,GAAAZ,KAAAnmC,GAAA+O,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAg3B,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAA52B,GAAAC,GAAAK,GAAAC,GAAAqpB,GAAAE,GAAAY,GAAAb,IAAAlnB,GAAAuzB,GAAAtzB,MAAAC,EAAAA,EAAAA,GAAAm0B,GAAA,CAtGAh6B,GAAc,kBAAmB,CAChC8F,WAAY,CAACC,GAAAA,GACbC,MAAO,CAAC,wBACR,EAKC/F,KAAU,WAMVA,KAAU,YAMVA,GAAS,CACRkG,WAAW,IACX,YAMDlG,KAAU,iBAMVA,GAAS,CACRgG,KAAMvN,SACN,eAMDuH,GAAS,CACRgG,KAAMC,UACN,eAMDjG,GAAS,CACRgG,KAAMvN,SACN,gBAMDuH,GAAS,CACRgG,KAAMC,UACN,eAMDjG,GAAS,CACRkG,WAAW,IACX,cAMDjG,GAAM,CAAE+F,KAAM,WAAW,WAAAnN,IAAAkL,EAAAA,EAAAA,GAAA/C,GAAAnI,GAAA,CAAAA,EAAAmL,KAAAC,EAAAA,EAAAA,GAAAjD,GAAAnI,EAAAmL,KAAA,GAAA7Q,GAAA+lC,GAAA9yB,KAAAC,EAAAA,EAAAA,GAAAlT,KAtEFqO,EAAAA,IAAmBmE,KAoG7C,MAAMq0B,GAAoB,CACxBnb,IAAK,OACLjM,KAAM,SACNkM,MAAO,YAGHmb,GAAa,CACjBpb,IAAK,UACL0M,SAAU,UACV3Y,KAAM,UAGFsnB,GAAY,CAChBrb,IAAK,OACLC,MAAO,WACPlM,KAAM,SAOD,SAASknB,GAAqBh+B,GACnC,MAAM,MAAER,EAAK,WAAEu+B,EAAU,SAAEhgB,EAAQ,SAAE6Z,EAAQ,SAAEj4B,EAAQ,UAAEk3B,GAAc72B,GACjE,EAAE7I,IAAMi3B,EAAAA,GAAAA,gBAAe/C,IACvBgT,GAAoBj+B,EAAAA,EAAAA,QAAc,MAoFxC,OACEvB,IAAAA,cAACkF,IAAeD,EAAAA,EAAAA,GAAA,CACd8G,YAAY,YACRC,EAAAA,EAAAA,GAAkB7K,GAAM,CAC5B0P,UAXe4uB,GACbA,SAAAA,EAAUtvB,MAAM4nB,GAAyB,cAAhBA,EAAKkD,SACzB3iC,EAAEi0B,GAAEgL,gBAEN,KASLv3B,IAAAA,cAACw4B,GAAM,CACLE,WAxEaA,CACjBgD,EACAgE,EACA3C,EACA1gC,KAEA,MAAM,IAAE4Q,EAAG,IAAEqwB,EAAG,KAAE5kC,EAAI,SAAE6iC,EAAQ,OAAEN,EAAS,OAAM,OAAED,GAAWU,EAE9D,OACE17B,IAAAA,cAAA,OACE6D,IAAKoJ,EACLhB,UAAWC,IAAW,aAAc,CAClC,kBAA8B,SAAX+uB,EACnB,uBAAmC,cAAXA,EACxB,mBAA+B,UAAXA,KAGtBj7B,IAAAA,cAAA,OAAKiM,UAAU,oBACbjM,IAAAA,cAAA,OACEiM,UAAU,QACV2xB,IAAKN,IAAO/B,aAAQ,EAARA,EAAU+B,KACtBhlB,QAASA,IAAMknB,EAAkB39B,QAAS40B,KAAKp6B,KAEjD2D,IAAAA,cAAA,OAAKiM,UAAU,SACbjM,IAAAA,cAAA,OAAKiM,UAAU,aAAavT,GAChB,cAAXuiC,GAA0Bj7B,IAAAA,cAAA,OAAKiM,UAAU,aAC1CjM,IAAAA,cAAA,OAAKiM,UAAU,aACD,SAAXgvB,GAAqBM,GACpBv7B,IAAAA,cAAA,OAAKiM,UAAU,cACZ,eAAesvB,aAAQ,EAARA,EAAU0C,gBAAgB1C,aAAQ,EAARA,EAAU2C,iBAG5C,UAAXjD,GACCj7B,IAAAA,cAAA,OAAKiM,UAAU,cACZ+uB,aAAM,EAANA,EACGx4B,KAAK6G,GACEA,aAAavK,MAAQuK,EAAEQ,QAAUR,IAEzC3G,KAAK,OAGC,SAAXu4B,GAAgC,UAAXA,KAAuBM,aAAQ,EAARA,EAAUlnB,OACtDrU,IAAAA,cAAA,OAAKiM,UAAU,aAAasvB,EAASlnB,QAI3CrU,IAAAA,cAAA,OAAKiM,UAAU,aACbjM,IAAAA,cAAC2a,IAAW1V,EAAAA,EAAAA,GAAA,CACVgH,UAAU,eACM,SAAXgvB,EAAoBqE,GAAaC,GAAS,CAC/CjnB,QAASykB,EAAQ/lC,YAInB,EAmBJqiC,SAAU14B,EACVg4B,YAAY,EACZC,WAAW,OACXC,OAAQ,IAAG8G,EAAAA,GAAAA,2FAA0FT,WACrG35B,OAAO,MACPuzB,OAAO,UACPC,SAAUA,EACV7Z,SAAUA,EACV8Y,UAAWA,EACXiB,uBAAwB,CAAElB,GDvPJjX,OAC5BiX,GAGO,IAAIra,SAAQ,CAACC,EAASwa,KASzBxa,EAAQoa,EACV,ICyOuC6H,CAAe7H,IAClDmB,8BAA+B8E,GAC/Bl9B,SArGgB++B,IACpB,MAAMC,EAAkBD,aAAM,EAANA,EAAQr9B,KAAKk7B,IAAU,IAAAqC,EAC7C,MAAMzC,EACK,QADFyC,EACPrC,EAAMJ,WAAG,IAAAyC,EAAAA,EACRrC,EAAMvB,SACH,IAAGwD,EAAAA,GAAAA,2FAA0FT,YAC3FxB,EAAMvB,SAAS1jB,KAAKunB,kBAEtBp7B,EACN,MAAO,IACF84B,EACHJ,MACD,IAEHx8B,SAAAA,EAAWg/B,EAAgB,IAyFtB,CAACzE,EAA2B4E,IAEzBjgC,IAAAA,cAAAA,IAAAA,SAAA,KACEA,IAAAA,cAACmlB,GAAa,CACZlN,KAAMonB,GACN/mB,QAAS2nB,EAActD,QAEtBrkC,EAAEi0B,GAAE+K,SAEPt3B,IAAAA,cAACq+B,GAAY,CACXl+B,IAAKq/B,EACLU,aAAa,EACbC,QAAS9E,EAAa74B,KAAKjH,IAAI,IAAA6kC,EAAA,MAAM,CACnCxC,IAAKriC,EAAK+hC,MAAoB,QAAjB8C,EAAI7kC,EAAKggC,gBAAQ,IAAA6E,OAAA,EAAbA,EAAe9C,KACjC,SAQjB,4FCjSA,MAAMp4B,IAAkBC,EAAAA,EAAAA,WAAmC,gBACrD8Q,IAAqB9Q,EAAAA,EAAAA,WAAyC,YAc5DC,cAAa,GAAEC,SAAQ,GAAEC,MAAKA,KAAKE,EAAAA,EAAAA,oBAE3C,IAAA66B,GAAA,IAAAz6B,GAAA,IAAAD,QAAAE,GAAA,IAAAF,QAAAG,GAAA,IAAAH,QAAAI,GAAA,IAAAJ,QAAAK,GAAA,IAAAL,QAAAM,GAAA,IAAAN,QAAAO,GAAA,IAAAP,QAAAQ,GAAA,IAAAR,QAAAS,GAAA,IAAAT,QAAAU,GAAA,IAAAV,QAAA26B,GAAA,IAAA35B,QAMA,MAAA45B,WAI4B15B,EAAAA,EAAoBC,WAAAA,GAAA,SAAAC,YAAAC,EAAAA,EAAAA,GAAA,KAAAs5B,KAC9Cr5B,EAAAA,EAAAA,GAAA,KAAArB,GAAAwB,GAAA,QAKAH,EAAAA,EAAAA,GAAA,KAAApB,IAAAwB,GAAA,MAAAC,GAAA,SAKAL,EAAAA,EAAAA,GAAA,KAAAnB,IAAAyB,GAAA,MAAAC,GAAA,SAMAP,EAAAA,EAAAA,GAAA,KAAAlB,IAAA0B,GAAA,MAAAG,GAAA,SAMAX,EAAAA,EAAAA,GAAA,KAAAjB,IAAA6B,GAAA,MAAA6K,GAAA,SAKAzL,EAAAA,EAAAA,GAAA,KAAAhB,IAAA0M,GAAA,MAAA6tB,GAAA,SAKAv5B,EAAAA,EAAAA,GAAA,KAAAf,IAAAu6B,GAAA,MAAAC,GAAA,SAKAz5B,EAAAA,EAAAA,GAAA,KAAAd,IAAAw6B,GAAA,MAAAC,GAAA,SAQA35B,EAAAA,EAAAA,GAAA,KAAAb,IAAAy6B,GAAA,MAAAC,GAAA,SAQA75B,EAAAA,EAAAA,GAAA,KAAAZ,IAAA06B,GAAA,MAAAC,GAAA,SAAAj4B,EAAAA,EAAAA,GAAA,qBAAAk4B,GAAA,MAKgBtgC,IACd+c,QAAQC,UAAUC,MAAK,MACrB3U,EAAAA,EAAAA,GAAAq3B,GAAA/iC,KAAK2jC,IAAa/3B,KAAKxI,EAAM,GAC7B,GACH,SA3DoBjI,GAAI,OAAA0Q,EAAAA,EAAAA,GAAAxD,GAAA,cAAJlN,CAAI2Q,IAAAC,EAAAA,EAAAA,GAAA1D,GAAA,KAAAyD,EAAA,UAKJE,GAAK,OAAAH,EAAAA,EAAAA,GAAAvD,GAAA,eAAL0D,CAAKF,IAAAC,EAAAA,EAAAA,GAAAzD,GAAA,KAAAwD,EAAA,UAMjB1I,GAAK,OAAAyI,EAAAA,EAAAA,GAAAtD,GAAA,eAALnF,CAAK0I,IAAAC,EAAAA,EAAAA,GAAAxD,GAAA,KAAAuD,EAAA,aAMLG,GAAQ,OAAAJ,EAAAA,EAAAA,GAAArD,GAAA,kBAARyD,CAAQH,IAAAC,EAAAA,EAAAA,GAAAvD,GAAA,KAAAsD,EAAA,SAKIgL,GAAI,OAAAjL,EAAAA,EAAAA,GAAApD,GAAA,cAAJqO,CAAIhL,IAAAC,EAAAA,EAAAA,GAAAtD,GAAA,KAAAqD,EAAA,gBAKJ83B,GAAW,OAAA/3B,EAAAA,EAAAA,GAAAnD,GAAA,qBAAXk7B,CAAW93B,IAAAC,EAAAA,EAAAA,GAAArD,GAAA,KAAAoD,EAAA,kBAKX+3B,GAAa,OAAAh4B,EAAAA,EAAAA,GAAAlD,GAAA,uBAAbk7B,CAAa/3B,IAAAC,EAAAA,EAAAA,GAAApD,GAAA,KAAAmD,EAAA,gBAQzBg4B,GAAW,OAAAj4B,EAAAA,EAAAA,GAAAjD,GAAA,qBAAXk7B,CAAWh4B,IAAAC,EAAAA,EAAAA,GAAAnD,GAAA,KAAAkD,EAAA,kBAQXi4B,GAAa,OAAAl4B,EAAAA,EAAAA,GAAAhD,GAAA,uBAAbk7B,CAAaj4B,IAAAC,EAAAA,EAAAA,GAAAlD,GAAA,KAAAiD,EAAA,CAYtBY,MAAAA,GACE,OACEjK,IAAAA,cAACuhC,GAAsB,CACrBn3B,YAAa7M,KAAK8M,iBAClBF,WAAY5M,KACZiM,SAAUjM,KAAKiM,SACf6K,KAAM9W,KAAK8W,KACX1T,MAAOpD,KAAKoD,MACZ6gC,SAAUjkC,KAAKkkC,aACfN,YAAa5jC,KAAK4jC,YAClBC,cAAe7jC,KAAK6jC,cACpBC,YAAa9jC,KAAK8jC,YAClBC,cAAe/jC,KAAK+jC,cACpB5oC,KAAM6E,KAAK7E,KACX6Q,MAAOhM,KAAKgM,MACZe,UAAW/M,KAAK+M,UAChBE,UAAWjN,KAAKiN,UAChBD,WAAYhN,KAAKgN,WACjBG,QAAQ,gBAGd,EAGK,SAAS62B,GAAuBpgC,GACrC,MAAM,cACJmgC,EAAa,YACbD,EAAW,YACXF,EAAW,cACXC,EAAa,MACbzgC,EAAK,SACL6I,EAAQ,KACR6K,GACElT,GACGsQ,EAASiwB,IAAcrgC,EAAAA,EAAAA,YAQ9B,OAPAmC,EAAAA,EAAAA,YAAU,KACRk+B,EAAW/gC,EAAM,GAChB,CAACA,IAMFX,IAAAA,cAACkF,IAAeD,EAAAA,EAAAA,GAAA,CAAC8G,YAAY,YAAcC,EAAAA,EAAAA,GAAkB7K,IAC3DnB,IAAAA,cAAA,UACEwJ,SAAUA,EACVyC,UAAWC,IAAWmI,EAAM,CAC1B,iBAAkB5C,EAClB,kBAAmBjI,IAErB8O,QAZqBqpB,KACzBxgC,EAAMqgC,UAAU/vB,GAChBiwB,GAAYjwB,EAAQ,GAYhBzR,IAAAA,cAAA,OAAKiM,UAAU,kBACfjM,IAAAA,cAAA,QAAMiM,UAAU,gBACbo1B,GAAe5vB,GACdzR,IAAAA,cAACiW,GAAuBorB,GAEzBC,IAAkB7vB,GACjBzR,IAAAA,cAACiW,GAAuBqrB,GAGzB7vB,EAAU0vB,EAAcC,IAKnC,CA5CCQ,GAAArB,KAAAloC,GAAA+O,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAG,GAAAC,GAAA6K,GAAAC,GAAA6tB,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAE,GAAAW,GAAAZ,IAAAl2B,GAAAs1B,GAAAr1B,MAAAC,EAAAA,EAAAA,GAAA22B,GAAA,CA1FAx8B,GAAc,YAAa,CAC1B8F,WAAY,CAACC,GAAAA,GACbC,MAAO,CAAC,0BACR,EAKC/F,KAAU,WAKVA,KAAU,YAKVA,GAAS,CAAEgG,KAAMC,UAAU,YAM3BjG,GAAS,CAAEgG,KAAMC,UAAU,eAM3BjG,KAAU,WAKVA,KAAU,kBAKVA,KAAU,oBAKVA,GAAS,CACRkG,WAAW,IACX,kBAMDlG,GAAS,CACRkG,WAAW,IACX,oBAMDjG,GAAM,CAAE+F,KAAM,WAAW,gBAAAnN,IAAAkL,EAAAA,EAAAA,GAAA/C,GAAAnI,GAAA,CAAAA,EAAAmL,KAAAC,EAAAA,EAAAA,GAAAjD,GAAAnI,EAAAmL,KAAA,GAAA7Q,GAAA8nC,GAAA70B,KAAAC,EAAAA,EAAAA,GAAAlT,KAzDAqO,EAAAA,IAAmBmE,wKChB/CyhB,EAAAA,GAAAA,qBAAoBD,GAAI6K,IAExB,MAAQjyB,cAAa,GAAEC,SAAQ,GAAEC,MAAKA,KAAKE,EAAAA,EAAAA,oBAErC2f,IAAgBhgB,EAAAA,EAAAA,WAA+B,aAC/CwV,IAAcxV,EAAAA,EAAAA,WAAyC,WACvD28B,IAAqB38B,EAAAA,EAAAA,WACzB,mBAEI48B,IAAiB58B,EAAAA,EAAAA,WAAmC,cACpDD,IAAkBC,EAAAA,EAAAA,WAAmC,gBAAgB,IAAA68B,GAAA,IAAAp8B,GAAA,IAAAD,QAAAE,GAAA,IAAAF,QAAAG,GAAA,IAAAH,QAAAI,GAAA,IAAAJ,QAAAK,GAAA,IAAAL,QAAAM,GAAA,IAAAN,QAAAO,GAAA,IAAAP,QAAAQ,GAAA,IAAAR,QAAAS,GAAA,IAAAT,QAAAU,GAAA,IAAAV,QAAAW,GAAA,IAAAX,QAAAY,GAAA,IAAAZ,QAAAa,GAAA,IAAAb,QAAAc,GAAA,IAAAd,QAAAsV,GAAA,IAAAtV,QAAAuV,GAAA,IAAAvV,QAAAwV,GAAA,IAAAxV,QAAAyV,GAAA,IAAAzV,QAAA0V,GAAA,IAAA1V,QAAA2V,GAAA,IAAA3V,QAAAs8B,GAAA,IAAAt7B,QA8B3E,MAAAu7B,WAG2Br7B,EAAAA,EAA+CC,WAAAA,GAAA,SAAAC,YAAAC,EAAAA,EAAAA,GAAA,KAAAi7B,KACxEh7B,EAAAA,EAAAA,GAAA,KAAArB,GAAA0B,GAAA,QAMAL,EAAAA,EAAAA,GAAA,KAAApB,IAAA0B,GAAA,MAAAH,GAAA,SAMAH,EAAAA,EAAAA,GAAA,KAAAnB,IAAAuB,GAAA,MAAAe,GAAA,SAQAnB,EAAAA,EAAAA,GAAA,KAAAlB,IAAAsC,GAAA,MAAAK,GAAA,SAQAzB,EAAAA,EAAAA,GAAA,KAAAjB,IAAA2C,GAAA,MAAAnB,GAAA,SAQAP,EAAAA,EAAAA,GAAA,KAAAhB,IAAAwB,GAAA,MAAAo3B,GAAA,SAQA53B,EAAAA,EAAAA,GAAA,KAAAf,IAAA44B,GAAA,MAAAqD,GAAA,SAMAl7B,EAAAA,EAAAA,GAAA,KAAAd,IAAAi8B,GAAA,MAAAzD,GAAA,SAQA13B,EAAAA,EAAAA,GAAA,KAAAb,IAAAw4B,GAAA,MAAAG,GAAA,SAQA93B,EAAAA,EAAAA,GAAA,KAAAZ,IAAA24B,GAAA,MAAAqD,GAAA,SAOAp7B,EAAAA,EAAAA,GAAA,KAAAX,IAAAg8B,GAAA,MAAAC,GAAA,SAMAt7B,EAAAA,EAAAA,GAAA,KAAAV,IAAAi8B,GAAA,MAAAC,GAAA,KAMwC,CACtCve,IAAK,OACLjM,KAAM,SACNkM,MAAO,gBAGTld,EAAAA,EAAAA,GAAA,KAAAT,IAAAk8B,GAAA,MAAAC,GAAA,KAIkD,cAElD17B,EAAAA,EAAAA,GAAA,KAAAR,IAAAm8B,GAAA,MAAAC,GAAA,SAQA57B,EAAAA,EAAAA,GAAA,KAAAgU,IAAA6nB,GAAA,MAAAC,GAAA,SAMA97B,EAAAA,EAAAA,GAAA,KAAAiU,IAAA8nB,GAAA,MAAAC,GAAA,MAM+B,MAE/Bh8B,EAAAA,EAAAA,GAAA,KAAAkU,IAAA+nB,GAAA,MAAAC,GAAA,SAMAl8B,EAAAA,EAAAA,GAAA,KAAAmU,IAAAgoB,GAAA,MAAAC,GAAA,KAI0B,WAE1Bp8B,EAAAA,EAAAA,GAAA,KAAAoU,IAAAioB,GAAA,MAAAC,GAAA,KAI8B,WAE9Bt8B,EAAAA,EAAAA,GAAA,KAAAqU,IAAAkoB,GAAA,MAAAxR,GAAA,SAAAjpB,EAAAA,EAAAA,GAAA,qBAAAkpB,GAAA,MAKgBoJ,IACd99B,KAAKoD,MAAQ06B,GACbpyB,EAAAA,EAAAA,GAAAg5B,GAAA1kC,KAAK20B,IAAQ/oB,KAAKkyB,EAAa,GAChC,UA7IQ9xB,GAAK,OAAAH,EAAAA,EAAAA,GAAAxD,GAAA,eAAL2D,CAAKF,IAAAC,EAAAA,EAAAA,GAAA1D,GAAA,KAAAyD,EAAA,SAML3Q,GAAI,OAAA0Q,EAAAA,EAAAA,GAAAvD,GAAA,cAAJnN,CAAI2Q,IAAAC,EAAAA,EAAAA,GAAAzD,GAAA,KAAAwD,EAAA,aAQJO,GAAQ,OAAAR,EAAAA,EAAAA,GAAAtD,GAAA,kBAAR8D,CAAQP,IAAAC,EAAAA,EAAAA,GAAAxD,GAAA,KAAAuD,EAAA,YAQRQ,GAAO,OAAAT,EAAAA,EAAAA,GAAArD,GAAA,iBAAP8D,CAAOR,IAAAC,EAAAA,EAAAA,GAAAvD,GAAA,KAAAsD,EAAA,UAQP1I,GAAK,OAAAyI,EAAAA,EAAAA,GAAApD,GAAA,eAALrF,CAAK0I,IAAAC,EAAAA,EAAAA,GAAAtD,GAAA,KAAAqD,EAAA,aAQL6V,GAAQ,OAAA9V,EAAAA,EAAAA,GAAAnD,GAAA,kBAARiZ,CAAQ7V,IAAAC,EAAAA,EAAAA,GAAArD,GAAA,KAAAoD,EAAA,WAMRyvB,GAAM,OAAA1vB,EAAAA,EAAAA,GAAAlD,GAAA,gBAAN4yB,CAAMzvB,IAAAC,EAAAA,EAAAA,GAAApD,GAAA,KAAAmD,EAAA,aAQN0vB,GAAQ,OAAA3vB,EAAAA,EAAAA,GAAAjD,GAAA,kBAAR4yB,CAAQ1vB,IAAAC,EAAAA,EAAAA,GAAAnD,GAAA,KAAAkD,EAAA,cAQR2uB,GAAS,OAAA5uB,EAAAA,EAAAA,GAAAhD,GAAA,mBAAT4xB,CAAS3uB,IAAAC,EAAAA,EAAAA,GAAAlD,GAAA,KAAAiD,EAAA,eAOTo6B,GAAU,OAAAr6B,EAAAA,EAAAA,GAAA/C,GAAA,oBAAVo9B,CAAUp6B,IAAAC,EAAAA,EAAAA,GAAAjD,GAAA,KAAAgD,EAAA,eAMVq6B,GAAU,OAAAt6B,EAAAA,EAAAA,GAAA9C,GAAA,oBAAVo9B,CAAUr6B,IAAAC,EAAAA,EAAAA,GAAAhD,GAAA,KAAA+C,EAAA,eAQVs6B,GAAU,OAAAv6B,EAAAA,EAAAA,GAAA7C,GAAA,oBAAVo9B,CAAUt6B,IAAAC,EAAAA,EAAAA,GAAA/C,GAAA,KAAA8C,EAAA,qBAUV2vB,GAAgB,OAAA5vB,EAAAA,EAAAA,GAAA5C,GAAA,0BAAhBwyB,CAAgB3vB,IAAAC,EAAAA,EAAAA,GAAA9C,GAAA,KAAA6C,EAAA,oBAQhBu6B,GAAe,OAAAx6B,EAAAA,EAAAA,GAAA3C,GAAA,yBAAfm9B,CAAev6B,IAAAC,EAAAA,EAAAA,GAAA7C,GAAA,KAAA4C,EAAA,uBAMfw6B,GAAkB,OAAAz6B,EAAAA,EAAAA,GAAA6R,GAAA,4BAAlB4oB,CAAkBx6B,IAAAC,EAAAA,EAAAA,GAAA2R,GAAA,KAAA5R,EAAA,eAQlBsvB,GAAU,OAAAvvB,EAAAA,EAAAA,GAAA8R,GAAA,oBAAVyd,CAAUtvB,IAAAC,EAAAA,EAAAA,GAAA4R,GAAA,KAAA7R,EAAA,QAMVi0B,GAAG,OAAAl0B,EAAAA,EAAAA,GAAA+R,GAAA,aAAHmiB,CAAGj0B,IAAAC,EAAAA,EAAAA,GAAA6R,GAAA,KAAA9R,EAAA,WAMH9D,GAAM,OAAA6D,EAAAA,EAAAA,GAAAgS,GAAA,gBAAN7V,CAAM8D,IAAAC,EAAAA,EAAAA,GAAA8R,GAAA,KAAA/R,EAAA,eAMNuvB,GAAU,OAAAxvB,EAAAA,EAAAA,GAAAiS,GAAA,oBAAVud,CAAUvvB,IAAAC,EAAAA,EAAAA,GAAA+R,GAAA,KAAAhS,EAAA,CAYnBY,MAAAA,GACE,OACEjK,IAAAA,cAAC8jC,GAAqB,CACpB15B,YAAa7M,KAAK8M,iBAClBF,WAAY5M,KACZgM,MAAOhM,KAAKgM,MACZ7Q,KAAM6E,KAAK7E,KACXkR,SAAUrM,KAAKqM,SACfC,QAAStM,KAAKsM,QACdlJ,MAAOpD,KAAKoD,MACZue,SAAU3hB,KAAK2hB,SACf4Z,OAAQv7B,KAAKu7B,OACbC,SAAUx7B,KAAKw7B,SACff,UAAWz6B,KAAKy6B,UAChByL,WAAYlmC,KAAKkmC,WACjBE,WAAYpmC,KAAKomC,WACjBD,WAAYnmC,KAAKmmC,WACjB1K,iBAAkBz7B,KAAKy7B,iBACvB4K,gBAAiBrmC,KAAKqmC,gBACtBC,mBAAoBtmC,KAAKsmC,mBACzBlL,WAAYp7B,KAAKo7B,WACjB2E,IAAK//B,KAAK+/B,IACV/3B,OAAQhI,KAAKgI,OACb+E,UAAW/M,KAAK+M,UAChBE,UAAWjN,KAAKiN,UAChBouB,WAAYr7B,KAAKq7B,WACjBluB,QAAQ,eACR5J,SAAUvD,KAAKuO,cAGrB,EACDi4B,GAAA7B,KAAA7pC,GAAAiP,GAAAC,GAAAH,GAAAC,GAAAe,GAAAC,GAAAK,GAAAC,GAAAnB,GAAAC,GAAAo3B,GAAAC,GAAAqD,GAAAC,GAAAzD,GAAAC,GAAAG,GAAAC,GAAAqD,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAxR,GAAAE,GAAAY,GAAAb,IAAAlnB,GAAAi3B,GAAAh3B,MAAAC,EAAAA,EAAAA,GAAA84B,GAAA,CAtLA3+B,GAAc,iBAAkB,CAC/B8F,WAAY,CAACC,GAAAA,MACb,EAKC9F,KAAU,YAMVA,KAAU,WAMVA,GAAS,CACRgG,KAAMC,UACN,eAMDjG,GAAS,CACRkG,WAAW,IACX,cAMDlG,GAAS,CACRkG,WAAW,IACX,YAMDlG,GAAS,CACRgG,KAAMC,UACN,eAMDjG,KAAU,aAMVA,GAAS,CACRgG,KAAMvN,SACN,eAMDuH,GAAS,CACRgG,KAAMvN,SACN,gBAODuH,KAAU,iBAMVA,KAAU,iBAMVA,GAAS,CACRkG,WAAW,IACX,iBAUDlG,KAAU,uBAMVA,GAAS,CACRgG,KAAMC,UACN,sBAMDjG,KAAU,yBAMVA,GAAS,CACRgG,KAAMC,UACN,iBAMDjG,KAAU,UAMVA,KAAU,aAMVA,KAAU,iBAMVC,GAAM,CAAE+F,KAAM,WAAW,WAAAnN,IAAAkL,EAAAA,EAAAA,GAAAkS,GAAApd,GAAA,CAAAA,EAAAmL,KAAAC,EAAAA,EAAAA,GAAAgS,GAAApd,EAAAmL,KAAA,GAAA7Q,GAAAypC,GAAAx2B,KAAAC,EAAAA,EAAAA,GAAAlT,KA7IDqO,EAAAA,IAAmBmE,KAqL9C,MAAMs0B,GAAa,CACjBpb,IAAK,UACL0M,SAAU,UACV3Y,KAAM,UAGFsnB,GAAY,CAChBrb,IAAK,OACLC,MAAO,WACPlM,KAAM,SAGF+rB,GAAe,CACnB9f,IAAK,OACLjM,KAAM,YACNkM,MAAO,YAGH8f,GAAc,CAClB/f,IAAK,OACLjM,KAAM,UACNkM,MAAO,YAOF,SAAS2f,GAAsB3iC,GACpC,MAAM,MACJR,EAAK,SACLue,EAAQ,OACR4Z,EAAM,SACNC,EAAQ,UACRf,EAAS,WACT2L,EAAU,WACVF,EAAU,WACVC,EAAU,iBACV1K,EAAgB,gBAChB4K,EAAe,mBACfC,EAAkB,WAClBlL,EAAU,IACV2E,EAAG,OACH/3B,EAAM,WACNqzB,EAAU,SACV93B,GACEK,GACE,EAAE7I,IAAMi3B,EAAAA,GAAAA,gBAAe/C,IACvBrI,GAAQ+f,EAAAA,GAAAA,oBAEPC,EAAYC,IAAiB/iC,EAAAA,EAAAA,WAAS,GAqD7C,OACErB,IAAAA,cAACkF,IAAeD,EAAAA,EAAAA,GAAA,CACd8G,YAAY,YACRC,EAAAA,EAAAA,GAAkB7K,GAAM,CAC5B0P,UAXe4uB,GACbA,SAAAA,EAAUtvB,MAAM4nB,GAAyB,cAAhBA,EAAKkD,SACzB3iC,EAAEi0B,GAAEgL,gBAEN,KASLv3B,IAAAA,cAACw4B,GAAM,CACLE,WAtDaA,CACjBgD,EACAgE,EACA3C,KAEA,MAAM,IAAE9vB,EAAG,KAAEvU,EAAI,OAAEuiC,EAAS,OAAM,OAAED,GAAWU,EAE/C,OACE17B,IAAAA,cAAC+hC,GAAc,CAACjY,QAASkR,aAAM,EAANA,EAAQx4B,KAAKjH,GAASA,EAAKsO,UAASnH,KAAK,OAChE1C,IAAAA,cAAA,OACE6D,IAAKoJ,EACLhB,UAAWC,IACT,wBACA+uB,GAAU,yBAAyBA,MAGrCj7B,IAAAA,cAAA,OAAKiM,UAAU,qBACbjM,IAAAA,cAAC2a,IAAW1V,EAAAA,EAAAA,GAAA,CACVgH,UAAWC,IACT,mBACW,cAAX+uB,GAA0B,gBAEZ,cAAXA,EAAyBgJ,GAAcD,KAE9ChkC,IAAAA,cAAA,OAAKiM,UAAU,qBACbjM,IAAAA,cAAA,OAAKiM,UAAU,yBAAyBvT,IAE1CsH,IAAAA,cAAA,OAAKiM,UAAU,yBACbjM,IAAAA,cAAC2a,IAAW1V,EAAAA,EAAAA,GAAA,CACVgH,UAAU,eACM,SAAXgvB,EAAoBqE,GAAaC,GAAS,CAC/CjnB,QAASykB,EAAQ/lC,aAKV,EAmBfqiC,SAAU14B,EACVue,SAAUA,EACV4Z,OAAQA,EACRC,SAAUA,EACVf,UAAWA,EACXgB,iBAAkBA,EAClBL,WAAYA,EACZE,OAAQyE,EACR/3B,OAAQA,EACRqzB,WAAYA,EACZ93B,SArEgBu6B,IACpBv6B,SAAAA,EAAWu6B,EAAa,IAsEnB,CAACA,EAA0B4E,KAC1B,MAAMoE,OACSz/B,IAAbm0B,GAA0BsC,EAAa5jC,QAAUshC,EAEnD,OAAO6K,EACL5jC,IAAAA,cAAA,OACEiM,UAAWC,IACT,qBACAi4B,GAAc,gCAEhB7rB,QAAS2nB,EAActD,OACvB2H,YAAcjsC,IACZA,EAAE0L,iBACFqgC,GAAc,EAAK,EAErBG,WAAalsC,IACXA,EAAE0L,gBAAgB,EAEpBygC,YAAaA,KACXJ,GAAc,EAAM,EAEtBK,OAASpsC,IAAM,IAAAqsC,EACbrsC,EAAE0L,iBACFqgC,GAAc,IACM,QAApBM,EAAArsC,EAAEssC,aAAapL,aAAK,IAAAmL,OAAA,EAApBA,EAAsBjtC,SACpBwoC,EAAcnD,YAAYzkC,EAAEssC,aAAapL,MAAM,GAGnDv5B,IAAAA,cAAA,OAAKiM,UAAU,4BACbjM,IAAAA,cAAC8hC,GAAkB,CACjB71B,UAAU,0BACV2kB,SAAS,iBACT3Y,KAAe,WAATkM,EAAqB,cAAgB,iBAE7CnkB,IAAAA,cAAA,OAAKiM,UAAU,oBACbjM,IAAAA,cAAC4kC,GAAAA,MAAK,CACJC,QAASvsC,EAAEi0B,GAAEiL,kBACbsN,WAAY,CACVC,MAAO/kC,IAAAA,cAAA,mBAIZ6jC,GACC7jC,IAAAA,cAAA,OAAKiM,UAAU,mBAAmB43B,KAKxC7jC,IAAAA,cAACmlB,GAAa,CACZ3b,SAAU66B,EACVh5B,KAAMq4B,EACNzrB,KAAM0rB,EACNrrB,QAAS2nB,EAActD,QAEtB8G,GAAcnrC,EAAEi0B,GAAE+K,QAEtB,IAKX,8GC5ZA,MAAQlyB,cAAa,GAAEC,SAAQ,GAAEC,MAAKA,KAAKE,EAAAA,EAAAA,oBACrCN,IAAkBC,EAAAA,EAAAA,WAAmC,gBAErDgsB,IAAehsB,EAAAA,EAAAA,WACnB,WACA,CACErE,SAAU,WAEZ,IAAAkkC,GAAA,IAAAp/B,GAAA,IAAAD,QAAAE,GAAA,IAAAF,QAAAG,GAAA,IAAAH,QAAAI,GAAA,IAAAJ,QAAAK,GAAA,IAAAL,QAAAM,GAAA,IAAAN,QAAAO,GAAA,IAAAP,QAAAQ,GAAA,IAAAR,QAAAS,GAAA,IAAAT,QAAAU,GAAA,IAAAV,QAAAW,GAAA,IAAAX,QAAAY,GAAA,IAAAZ,QAAAa,GAAA,IAAAb,QAAAs/B,GAAA,IAAAt+B,QAyCF,MAAAu+B,WAG2Br+B,EAAAA,EAAoBC,WAAAA,GAAA,SAAAC,YAAAC,EAAAA,EAAAA,GAAA,KAAAi+B,KAC7Ch+B,EAAAA,EAAAA,GAAA,KAAArB,GAAAwB,GAAA,QAKAH,EAAAA,EAAAA,GAAA,KAAApB,IAAAwB,GAAA,MAAAK,GAAA,SAKAT,EAAAA,EAAAA,GAAA,KAAAnB,IAAA6B,GAAA,MAAAL,GAAA,SAKAL,EAAAA,EAAAA,GAAA,KAAAlB,IAAAwB,GAAA,MAAAyV,GAAA,SAQA/V,EAAAA,EAAAA,GAAA,KAAAjB,IAAAiX,GAAA,MAAArV,GAAA,SAMAX,EAAAA,EAAAA,GAAA,KAAAhB,IAAA4B,GAAA,MAAAO,GAAA,SAAAnB,EAAAA,EAAAA,GAAA,KAAAf,IAAAmC,GAAA,MAAAb,GAAA,SAQAP,EAAAA,EAAAA,GAAA,KAAAd,IAAAsB,GAAA,MAAA8O,GAAA,SAOAtP,EAAAA,EAAAA,GAAA,KAAAb,IAAAoQ,GAAA,MAAA2uB,GAAA,SAKAl+B,EAAAA,EAAAA,GAAA,KAAAZ,IAAA++B,GAAA,MAAAC,GAAA,SAQAp+B,EAAAA,EAAAA,GAAA,KAAAX,IAAAg/B,GAAA,MAAAC,GAAA,SAKAt+B,EAAAA,EAAAA,GAAA,KAAAV,IAAAi/B,GAAA,MAAA98B,GAAA,SAOAzB,EAAAA,EAAAA,GAAA,KAAAT,IAAAmC,GAAA,MAAAsO,GAAA,SAAAlO,EAAAA,EAAAA,GAAA,0BAAAmO,GAAA,MAKqBvW,IACnBpD,KAAKoD,MAAQA,GACbsI,EAAAA,EAAAA,GAAAg8B,GAAA1nC,KAAK8Z,IAAalO,KAAKxI,EAAM,GAC9B,SA1EoBjI,GAAI,OAAA0Q,EAAAA,EAAAA,GAAAxD,GAAA,cAAJlN,CAAI2Q,IAAAC,EAAAA,EAAAA,GAAA1D,GAAA,KAAAyD,EAAA,gBAKJvG,GAAW,OAAAsG,EAAAA,EAAAA,GAAAvD,GAAA,qBAAX/C,CAAWuG,IAAAC,EAAAA,EAAAA,GAAAzD,GAAA,KAAAwD,EAAA,UAKXE,GAAK,OAAAH,EAAAA,EAAAA,GAAAtD,GAAA,eAALyD,CAAKF,IAAAC,EAAAA,EAAAA,GAAAxD,GAAA,KAAAuD,EAAA,eAQjBkV,GAAU,OAAAnV,EAAAA,EAAAA,GAAArD,GAAA,oBAAVwY,CAAUlV,IAAAC,EAAAA,EAAAA,GAAAvD,GAAA,KAAAsD,EAAA,aAMVG,GAAQ,OAAAJ,EAAAA,EAAAA,GAAApD,GAAA,kBAARwD,CAAQH,IAAAC,EAAAA,EAAAA,GAAAtD,GAAA,KAAAqD,EAAA,aAKqBO,GAAQ,OAAAR,EAAAA,EAAAA,GAAAnD,GAAA,kBAAR2D,CAAQP,IAAAC,EAAAA,EAAAA,GAAArD,GAAA,KAAAoD,EAAA,UAGrC1I,GAAK,OAAAyI,EAAAA,EAAAA,GAAAlD,GAAA,eAALvF,CAAK0I,IAAAC,EAAAA,EAAAA,GAAApD,GAAA,KAAAmD,EAAA,YAOLxS,GAAO,OAAAuS,EAAAA,EAAAA,GAAAjD,GAAA,iBAAPtP,CAAOwS,IAAAC,EAAAA,EAAAA,GAAAnD,GAAA,KAAAkD,EAAA,oBAKsBo8B,GAAe,OAAAr8B,EAAAA,EAAAA,GAAAhD,GAAA,yBAAfq/B,CAAep8B,IAAAC,EAAAA,EAAAA,GAAAlD,GAAA,KAAAiD,EAAA,cAQ5CwH,GAAS,OAAAzH,EAAAA,EAAAA,GAAA/C,GAAA,mBAATwK,CAASxH,IAAAC,EAAAA,EAAAA,GAAAjD,GAAA,KAAAgD,EAAA,YAKGuH,GAAO,OAAAxH,EAAAA,EAAAA,GAAA9C,GAAA,iBAAPsK,CAAOvH,IAAAC,EAAAA,EAAAA,GAAAhD,GAAA,KAAA+C,EAAA,YAKaQ,GAAO,OAAAT,EAAAA,EAAAA,GAAA7C,GAAA,iBAAPsD,CAAOR,IAAAC,EAAAA,EAAAA,GAAA/C,GAAA,KAAA8C,EAAA,CAchDY,MAAAA,GACE,OACEjK,IAAAA,cAAC0lC,GAAuB,CACtBv7B,WAAY5M,KACZ6M,YAAa7M,KAAK8M,iBAClB3R,KAAM6E,KAAK7E,KACX6Q,MAAOhM,KAAKgM,MACZzG,YAAavF,KAAKuF,YAClB0G,SAAUjM,KAAKiM,SACf+U,WAAYhhB,KAAKghB,WACjB3U,SAAUrM,KAAKqM,SACfC,QAAStM,KAAKsM,QACdlJ,MAAOpD,KAAKoD,MACZ9J,QAAS0G,KAAK1G,QACd0T,WAAYhN,KAAKgN,WACjBC,UAAWjN,KAAKiN,UAChBF,UAAW/M,KAAK+M,UAChBuG,UAAWtT,KAAKsT,UAChBD,QAASrT,KAAKqT,QACd60B,gBAAiBloC,KAAKkoC,gBACtBh7B,cAAelN,KAAKkN,cACpBC,QAAQ,oBACR5J,SAAUvD,KAAKqN,mBAGrB,EAGK,SAAS86B,GAAwBvkC,GACtC,MAAM,SACJL,EAAQ,WACRyd,EAAU,SACV/U,EAAQ,YACR1G,EAAW,gBACX2iC,EAAe,cACfh7B,GACEtJ,GACGtK,EAASghB,IAAcxW,EAAAA,EAAAA,UAASF,EAAMtK,SAAW,KACjD8uC,EAAiBC,IAAsBvkC,EAAAA,EAAAA,UAAgB,KACvDijB,EAAQuhB,IAAaxkC,EAAAA,EAAAA,WAAS,IAC9BV,EAAOS,IAAYC,EAAAA,EAAAA,UAAiB,IACrCif,GAAW/e,EAAAA,EAAAA,UACXb,GAAea,EAAAA,EAAAA,QAAuB,MAEtCukC,GAAgC1wB,EAAAA,EAAAA,UAAQ,KAC5C,MAAM2wB,EAAelvC,IAAmD,IAAAsf,EACtE,OAA6B,QAA7BA,EAAOP,GAAc/e,UAAQ,IAAAsf,OAAA,EAAtBA,EAAwB3T,KAAKuT,GAC9B,YAAaA,GAAMzE,MAAMC,QAAQwE,EAAGlf,SAC/B,IAAKkf,EAAIlf,QAASkvC,EAAYhwB,EAAGlf,UAEjCkf,GAET,EAGJ,OAAOgwB,EAAYlvC,EAAQ,GAC1B,CAACA,KAyBJ2M,EAAAA,EAAAA,YAAU,MACHsU,EAAAA,GAAAA,SAAQ3W,EAAMtK,QAASA,IAC1BghB,EAAW1W,EAAMtK,SAAW,GAC9B,GACC,CAACsK,EAAMtK,WAEV2M,EAAAA,EAAAA,YAAU,KACRpC,EAASD,EAAMR,OAAS,GAAG,GAC1B,CAACQ,EAAMR,SAEV6C,EAAAA,EAAAA,YAAU,KACRoiC,EAAmBE,EAAgB,GAClC,CAACA,KAEJtiC,EAAAA,EAAAA,YAAU,KACR,MAAMgf,EAAuBnqB,IAAkB,IAAAukC,EAC7CvkC,EAAE2L,kBACF,MAAMye,EAAOpqB,EAAEqqB,eACTsjB,EAAmBtlC,EAAamB,QAClCmkC,GAAoBvjB,EAAK/T,SAASs3B,KACtCH,GAAU,GACM,QAAhBjJ,EAAAtc,EAASze,eAAO,IAAA+6B,GAAhBA,EAAkBqJ,OAAM,EAG1B,OADAnvC,SAAS6rB,iBAAiB,QAASH,GAC5B,KACL1rB,SAAS8rB,oBAAoB,QAASJ,EAAoB,CAC3D,GACA,IAEH,MAAMc,EAAcA,CAACvL,EAAgB1b,IAEjC2D,IAAAA,cAAA,OACE6D,IAAK,GAAGkU,EAAOxO,SAASlN,IACxB4P,UAAWC,IAAW,mBAAoB,CACxC,kBAAmBvL,IAAUoX,EAAOpX,QAEtC2X,QAASA,KACPlX,EAAS2W,EAAOpX,OAChBklC,GAAU,GACV/kC,SAAAA,EAAWiX,EAAOpX,MAAM,GAG1BX,IAAAA,cAAA,OAAKiM,UAAU,SAAS8L,EAAOxO,OAC9BwO,EAAOkM,SAAWjkB,IAAAA,cAAA,OAAKiM,UAAU,WAAW8L,EAAOkM,UAK1D,OACEjkB,IAAAA,cAACkF,IAAeD,EAAAA,EAAAA,GAAA,CAAC8G,YAAY,YAAcC,EAAAA,EAAAA,GAAkB7K,IAC3DnB,IAAAA,cAAA,OAAKiM,UAAU,qBAAqB9L,IAAKO,GACvCV,IAAAA,cAACmxB,GAAY,CACXhxB,IAAKmgB,EACL3f,MAAOA,EACPmC,YAAaA,EACb0G,SAAUA,EACV+U,WAAYA,EACZ9T,cAAeA,EACfy7B,QAASA,KACPL,GAAU,EAAK,EAEjB/kC,SApFczI,IACpB+I,EAAS/I,EAAE8U,QACX,MAAMg5B,EAAUtvC,IACd,IAAK,IAAIqE,EAAIrE,EAAQY,OAAS,EAAGyD,GAAK,EAAGA,IAAK,KAAAkrC,EAAAC,EAC5C,MAAMtuB,EAASlhB,EAAQqE,GACL,QAAlBkrC,EAAIruB,EAAOlhB,eAAO,IAAAuvC,GAAdA,EAAgB3uC,QAClB0uC,EAAOpuB,EAAOlhB,SAGC,QAAfwvC,EAACtuB,EAAOlhB,eAAO,IAAAwvC,GAAdA,EAAgB5uC,SAChB6uC,EAAAA,GAAAA,SAAQvuB,EAAOxO,OAAOmF,UAAS43B,EAAAA,GAAAA,SAAQjuC,EAAE8U,UACxCs4B,IACCa,EAAAA,GAAAA,SAASvuB,EAAekM,SAASvV,UAAS43B,EAAAA,GAAAA,SAAQjuC,EAAE8U,UAEvDtW,EAAQkF,OAAOb,EAAG,EAEtB,CACA,OAAOrE,CAAO,EAEVoE,EAASkrC,GAAOI,EAAAA,GAAAA,WAAUT,IAChCF,EAAmB3qC,GACnB6F,SAAAA,EAAWzI,EAAE8U,OAAO,IAiEfmX,GAAUqhB,EAAgBluC,OACzBuI,IAAAA,cAAA,OAAKiM,UAAU,oBACbjM,IAAAA,cAAA,OAAKiM,UAAU,iBACZ05B,EAAgBnjC,KAAI,CAACgkC,EAAQnqC,KAAK,IAAAoqC,EAAA,OACxB,QAATA,EAAAD,EAAE3vC,eAAO,IAAA4vC,GAATA,EAAWhvC,OACTuI,IAAAA,cAAA,OAAK6D,IAAK,GAAG2iC,EAAEj9B,SAASlN,IAAS4P,UAAU,iBACzCjM,IAAAA,cAAA,OAAKiM,UAAU,cAAcu6B,EAAEj9B,OAC9Bi9B,EAAE3vC,QAAQ2L,KAAI,CAACuV,EAAa7c,IAC3BooB,EAAYvL,EAAQ7c,MAIxBooB,EAAYkjB,EAAGnqC,EAChB,KAGL2D,IAAAA,cAAA,QAAMtH,KAAK,qBAEX,MAIZ,CA5ICguC,GAAAxB,KAAA7sC,GAAA+O,GAAAC,GAAAK,GAAAC,GAAAL,GAAAC,GAAAyV,GAAAC,GAAArV,GAAAC,GAAAO,GAAAC,GAAAb,GAAAC,GAAA8O,GAAAC,GAAA2uB,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAA98B,GAAAC,GAAAsO,GAAAI,GAAAyB,GAAA5B,IAAAnM,GAAAi6B,GAAAh6B,MAAAC,EAAAA,EAAAA,GAAAy7B,GAAA,CA7GAthC,GAAc,mBAAoB,CACjC8F,WAAY,CAACC,GAAAA,MACb,EAKC9F,KAAU,WAKVA,KAAU,kBAKVA,KAAU,YAKVA,GAAS,CACRkG,WAAW,IACX,iBAMDlG,GAAS,CAAEgG,KAAMC,UAAU,eAM3BjG,GAAS,CAAEgG,KAAMC,UAAU,eAE3BjG,KAAU,YAOVA,GAAS,CAAEkG,WAAW,IAAQ,cAM9BlG,GAAS,CAAEgG,KAAMC,UAAU,sBAK3BjG,GAAS,CACRkG,WAAW,IACX,gBAMDlG,KAAU,cAKVA,GAAS,CAAEkG,WAAW,IAAQ,cAO9BjG,GAAM,CAAE+F,KAAM,WAAW,gBAAAnN,IAAAkL,EAAAA,EAAAA,GAAA5C,GAAAtI,GAAA,CAAAA,EAAAmL,KAAAC,EAAAA,EAAAA,GAAA9C,GAAAtI,EAAAmL,KAAA,GAAA7Q,GAAAysC,GAAAx5B,KAAAC,EAAAA,EAAAA,GAAAlT,KAzEDqO,EAAAA,IAAmBmE,oFC1D9C,MACE27B,WAAYC,GACZC,YAAaC,IACX,KACED,GAA2B,cAAiB,CAAC1lC,EAAOhB,IAAsB,gBAAoB2mC,GAAqBv4B,OAAOw4B,OAAO,CAAC,EAAG5lC,EAAO,CAChJ6lC,OAAQ,OACRjpB,UAAMnZ,EACNzE,IAAKA,OAEDwmC,GAA0B,cAAiB,CAACM,EAAI9mC,KACpD,IAAI,MACA+mC,EAAK,kBACLC,EAAiB,QACjBC,EAAO,SACPC,GACEJ,EACJK,EA7BgC,SAAUptC,EAAG7B,GAC/C,IAAIC,EAAI,CAAC,EACT,IAAK,IAAIyF,KAAK7D,EAAOqU,OAAOlR,UAAUkqC,eAAej5B,KAAKpU,EAAG6D,IAAM1F,EAAEmvC,QAAQzpC,GAAK,IAAGzF,EAAEyF,GAAK7D,EAAE6D,IAC9F,GAAS,MAAL7D,GAAqD,mBAAjCqU,OAAOk5B,sBAA2C,KAAIvsC,EAAI,EAAb,IAAgB6C,EAAIwQ,OAAOk5B,sBAAsBvtC,GAAIgB,EAAI6C,EAAEtG,OAAQyD,IAClI7C,EAAEmvC,QAAQzpC,EAAE7C,IAAM,GAAKqT,OAAOlR,UAAUqqC,qBAAqBp5B,KAAKpU,EAAG6D,EAAE7C,MAAK5C,EAAEyF,EAAE7C,IAAMhB,EAAE6D,EAAE7C,IADuB,CAGvH,OAAO5C,CACT,CAsBgBqvC,CAAOV,EAAI,CAAC,QAAS,oBAAqB,UAAW,aAKnE,MAAOW,IAAiB,QAAW,aAAcR,EAASC,GACpDQ,EAA4B,WAAc,IAC1CV,GAGAD,QAAJ,GAIC,CAACA,EAAOC,IACX,OAAoB,gBAAoBP,GAAoBr4B,OAAOw4B,OAAO,CAAC,EAAGO,EAAW,CACvFvpB,UAAMnZ,EACNzE,IAAKA,EACLgnC,kBAAmBU,EACnBT,QAASQ,IACR,IAOC,IAAY,QAAajB,GAAY,kBAAc/hC,EAAW,UACpE+hC,GAAWmB,uCAAyC,GACpDnB,GAAWE,YAAcA,GACzBF,GAAWmB,uCAAyC,GACpD,2LC1CAC,KAAAA,OAAaC,MAEb,MAAQ5iC,cAAa,GAAEC,SAAQ,GAAEC,MAAKA,KAAKE,EAAAA,EAAAA,oBACrCN,IAAkBC,EAAAA,EAAAA,WAAmC,gBAAgB,IAAA8iC,GAAA,IAAAriC,GAAA,IAAAD,QAAAE,GAAA,IAAAF,QAAAG,GAAA,IAAAH,QAAAI,GAAA,IAAAJ,QAAAK,GAAA,IAAAL,QAAAM,GAAA,IAAAN,QAAAO,GAAA,IAAAP,QAAAQ,GAAA,IAAAR,QAAAS,GAAA,IAAAT,QAAAuiC,GAAA,IAAAvhC,QAAAN,GAAA,IAAAV,QAAAW,GAAA,IAAAX,QAAAwiC,GAAA,IAAAxiC,QAkB3E,MAAAyiC,WAG2BvhC,EAAAA,EAAoBC,WAAAA,GAAA,SAAAC,YAAAC,EAAAA,EAAAA,GAAA,KAAAkhC,KAC7CjhC,EAAAA,EAAAA,GAAA,KAAArB,GAAAwB,GAAA,QAKAH,EAAAA,EAAAA,GAAA,KAAApB,IAAAwB,GAAA,MAAAC,GAAA,SAKAL,EAAAA,EAAAA,GAAA,KAAAnB,IAAAyB,GAAA,MAAAC,GAAA,SAKAP,EAAAA,EAAAA,GAAA,KAAAlB,IAAA0B,GAAA,MAAAC,GAAA,SAMAT,EAAAA,EAAAA,GAAA,KAAAjB,IAAA2B,GAAA,MAAAe,GAAA,SAMAzB,EAAAA,EAAAA,GAAA,KAAAhB,IAAA0C,GAAA,MAAAf,GAAA,SAKAX,EAAAA,EAAAA,GAAA,KAAAf,IAAA2B,GAAA,MAAAO,GAAA,SAKAnB,EAAAA,EAAAA,GAAA,KAAAd,IAAAkC,GAAA,MAAAggC,GAAA,SAMAphC,EAAAA,EAAAA,GAAA,KAAAb,IAAAkiC,GAAA,MAAArxB,GAAA,SAMAhQ,EAAAA,EAAAA,GAAA,KAAAZ,IAAA6Q,GAAA,MAAAqxB,GAAA,SAMAthC,EAAAA,EAAAA,GAAA,KAAAX,IAAAkiC,GAAA,MAAAC,GAAA,SAAA1/B,EAAAA,EAAAA,GAAA,qBAAA2/B,GAAA,MAMgB/nC,IACdpD,KAAKoD,MAAQA,GACbsI,EAAAA,EAAAA,GAAAi/B,GAAA3qC,KAAK8Z,IAAalO,KAAKxI,EAAM,KAE/BsG,EAAAA,EAAAA,GAAA,KAAAkhC,IAAoB,CAACQ,EAAehoC,KAC9BgoC,GACF1/B,EAAAA,EAAAA,GAAAi/B,GAAA3qC,KAAKqrC,IAAWz/B,KAAKxI,IAErBsI,EAAAA,EAAAA,GAAAi/B,GAAA3qC,KAAKsrC,IAAY1/B,KAAKxI,EACxB,GACA,SApEmBjI,GAAI,OAAA0Q,EAAAA,EAAAA,GAAAxD,GAAA,cAAJlN,CAAI2Q,IAAAC,EAAAA,EAAAA,GAAA1D,GAAA,KAAAyD,EAAA,UAKJE,GAAK,OAAAH,EAAAA,EAAAA,GAAAvD,GAAA,eAAL0D,CAAKF,IAAAC,EAAAA,EAAAA,GAAAzD,GAAA,KAAAwD,EAAA,UAKL1I,GAAK,OAAAyI,EAAAA,EAAAA,GAAAtD,GAAA,eAALnF,CAAK0I,IAAAC,EAAAA,EAAAA,GAAAxD,GAAA,KAAAuD,EAAA,gBAMjBvG,GAAW,OAAAsG,EAAAA,EAAAA,GAAArD,GAAA,qBAAXjD,CAAWuG,IAAAC,EAAAA,EAAAA,GAAAvD,GAAA,KAAAsD,EAAA,YAMXQ,GAAO,OAAAT,EAAAA,EAAAA,GAAApD,GAAA,iBAAP6D,CAAOR,IAAAC,EAAAA,EAAAA,GAAAtD,GAAA,KAAAqD,EAAA,aAKsBG,GAAQ,OAAAJ,EAAAA,EAAAA,GAAAnD,GAAA,kBAARuD,CAAQH,IAAAC,EAAAA,EAAAA,GAAArD,GAAA,KAAAoD,EAAA,aAKRO,GAAQ,OAAAR,EAAAA,EAAAA,GAAAlD,GAAA,kBAAR0D,CAAQP,IAAAC,EAAAA,EAAAA,GAAApD,GAAA,KAAAmD,EAAA,gBAMrCy/B,GAAW,OAAA1/B,EAAAA,EAAAA,GAAAjD,GAAA,qBAAX2iC,CAAWz/B,IAAAC,EAAAA,EAAAA,GAAAnD,GAAA,KAAAkD,EAAA,CAgCpBY,MAAAA,GACE,OACEjK,IAAAA,cAAC+oC,GAAqB,CACpB5+B,WAAY5M,KACZ6M,YAAa7M,KAAK8M,iBAClBy+B,YAAavrC,KAAKurC,YAClBpwC,KAAM6E,KAAK7E,KACX6Q,MAAOhM,KAAKgM,MACZzI,SAAUvD,KAAKuO,aACfpB,QAAQ,eACRs+B,cAAc5/B,EAAAA,EAAAA,GAAK++B,GAAL5qC,MACduF,YAAavF,KAAKuF,YAClBnC,MAAOpD,KAAKoD,MACZiJ,SAAUrM,KAAKqM,SACfC,QAAStM,KAAKsM,QACdS,UAAW/M,KAAK+M,UAChBC,WAAYhN,KAAKgN,WACjBC,UAAWjN,KAAKiN,UAChBy+B,WAAY1rC,KAAK0rC,WACjBz/B,SAAUjM,KAAKiM,UAGrB,EAGK,SAASu/B,GAAsB5nC,GAA0B,IAAAjB,EAC9D,MAAM,YACJ4oC,EAAc,CAAC,EAAC,SAChBhoC,EAAQ,aACRkoC,EAAY,SACZx/B,EAAQ,YACR1G,GACE3B,EACE+nC,GAAehF,EAAAA,GAAAA,mBACfrpC,EACJ09B,GAAAA,KAAK4Q,UAA4C,OAAhC5Q,GAAAA,KAAK4Q,SAASvwC,MAAM,KAAK,GAAcwwC,GAAAA,EAAOC,GAAAA,GAC1D1oC,EAAOS,IAAYC,EAAAA,EAAAA,UAAuB,MAC3CioC,EAAoC,QAAtBppC,EAAI4oC,EAAYQ,cAAM,IAAAppC,EAAAA,EAAe,YACzDsD,EAAAA,EAAAA,YAAU,MACHyL,EAAAA,GAAAA,OAAM9N,EAAMR,OAGfS,EAAS,MAFTA,EAAS2mC,KAAM5mC,EAAMR,MAAO2oC,GAG9B,GACC,CAACnoC,EAAMR,MAAO2oC,IAEjB,MAUMC,GAAQn0B,EAAAA,EAAAA,UAAQ,KACbo0B,EAAAA,GAAAA,OACN,IAEH,OACExpC,IAAAA,cAACkF,IAAeD,EAAAA,EAAAA,GAAA,CAAC8G,YAAY,YAAcC,EAAAA,EAAAA,GAAkB7K,IAC3DnB,IAAAA,cAACypC,GAAAA,GAAc,CACb5uC,OAAQA,EACRspB,MAAO,CACLulB,UACmB,YAAjBR,EACI/kB,GAAAA,EAAMwlB,cACNxlB,GAAAA,EAAMylB,mBAGd5pC,IAAAA,cAAC6pC,GAAAA,GAAa,CAAC5lC,UAAW9C,EAAM8nC,WAA0Ba,MAAOP,GAC/DvpC,IAAAA,cAAA,OACEc,SAAWzI,IACTA,EAAE2L,iBAAiB,GAGrBhE,IAAAA,cAAC2mC,IAAU1hC,EAAAA,EAAAA,GAAA,GACL6jC,EAAW,CACfiB,kBAAoBr/B,GAAYA,EAChC/J,MAAOA,EAEPG,SApCSgL,CAACk+B,EAAqBC,KACzCnpC,SAAAA,EAAWmpC,EAAW,EAoCZjB,aAjCcL,IACxBK,SAAAA,EACEL,GACC15B,EAAAA,GAAAA,OAAMtO,GAA4D,GAAlDonC,KAAMpnC,GAAgB2oC,OAAOA,GAC/C,EA8BS9/B,SAAUA,EACV1G,YAAaA,EACbonC,WAAYpB,EAAYoB,iBAOtC,CAtECC,GAAA/B,KAAA/vC,GAAA+O,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAe,GAAAC,GAAAf,GAAAC,GAAAO,GAAAC,GAAAggC,GAAAC,GAAArxB,GAAAI,GAAAyB,GAAA5B,GAAAqxB,GAAAK,GAAAwB,GAAA5B,GAAAC,GAAAI,GAAAwB,GAAA3B,IAAA39B,GAAAk9B,GAAAj9B,MAAAC,EAAAA,EAAAA,GAAAk/B,GAAA,CApGA/kC,GAAc,iBAAkB,CAC/B8F,WAAY,CAACC,GAAAA,EAAWm/B,GAAAA,MACxB,EAKCjlC,KAAU,WAKVA,KAAU,YAKVA,KAAU,YAKVA,KAAU,kBAMVA,GAAS,CAAEkG,WAAW,IAAQ,cAM9BlG,GAAS,CAAEgG,KAAMC,UAAU,eAK3BjG,GAAS,CAAEgG,KAAMC,UAAU,eAK3BjG,GAAS,CAAEkG,WAAW,IAAQ,kBAM9BjG,GAAM,CAAE+F,KAAM,WAAW,gBAAAnN,IAAAkL,EAAAA,EAAAA,GAAAhD,GAAAlI,GAAA,CAAAA,EAAAmL,KAAAC,EAAAA,EAAAA,GAAAlD,GAAAlI,EAAAmL,IAAA,CAMzB/D,GAAM,CAAE+F,KAAM,SAAS,cAAAnN,IAAAkL,EAAAA,EAAAA,GAAA/C,GAAAnI,GAAA,CAAAA,EAAAmL,KAAAC,EAAAA,EAAAA,GAAAjD,GAAAnI,EAAAmL,IAAA,CAMvB/D,GAAM,CAAE+F,KAAM,UAAU,eAAAnN,IAAAkL,EAAAA,EAAAA,GAAA9C,GAAApI,GAAA,CAAAA,EAAAmL,KAAAC,EAAAA,EAAAA,GAAAhD,GAAApI,EAAAmL,KAAA,GAAA7Q,GAAA2vC,GAAA18B,KAAAC,EAAAA,EAAAA,GAAAlT,KA3DAqO,EAAAA,IAAmBmE,oBC5CvC,IAAKuhB,GAAC,SAADA,GAAC,OAADA,EAAC,oBAADA,EAAC,cAADA,EAAC,oBAADA,EAAC,sBAADA,EAAC,sBAADA,EAAC,sBAADA,EAAC,wBAADA,EAAC,wBAADA,EAAC,wBAADA,EAAC,4BAADA,EAAC,4BAADA,EAAC,4BAADA,EAAC,sBAADA,EAAC,sBAADA,EAAC,sBAADA,EAAC,8BAADA,EAAC,gCAADA,EAAC,8BAADA,EAAC,gCAADA,CAAC,MAsBb,MA4CaC,GAAK,2GChElB,SADmB,CAAE,KAAQ,CAAE,IAAO,MAAO,MAAS,CAAE,QAAW,gBAAiB,UAAa,SAAW,SAAY,CAAC,CAAE,IAAO,OAAQ,MAAS,CAAE,EAAK,4LAAgM,KAAQ,OAAQ,MAAS,YCMnX,IAAI,GAAe,SAAsBrrB,EAAOhB,GAC9C,OAAoB,gBAAoBonB,GAAAC,GAAU,OAAS,CAAC,EAAGrmB,EAAO,CACpEhB,IAAKA,EACL8X,KAAM,KAEV,EAOA,SAJ2B,aAAiB,gKCqB5CsyB,EAAAA,GAAAA,gBAAe/d,GHgCQ,CAAEE,GA9CN,CACjB8d,SAAU,WACVC,MAAO,QACPC,SAAU,eACVC,UAAW,YACXC,UAAW,YACXC,UAAW,gBACXC,WAAY,aACZC,WAAY,aACZC,WAAY,iBACZC,aAAc,eACdC,aAAc,eACdC,aAAc,mBACdC,UAAW,YACXC,UAAW,YACXC,UAAW,gBACXC,cAAe,gBACfC,eAAgB,iBAChBC,cAAe,gBACfC,eAAgB,kBA2BW9e,GAxBV,CACjB4d,SAAU,KACVC,MAAO,KACPC,SAAU,KACVC,UAAW,KACXC,UAAW,KACXC,UAAW,KACXC,WAAY,KACZC,WAAY,KACZC,WAAY,KACZC,aAAc,MACdC,aAAc,MACdC,aAAc,MACdC,UAAW,KACXC,UAAW,KACXC,UAAW,KACXC,cAAe,OACfC,eAAgB,OAChBC,cAAe,OACfC,eAAgB,UG1BlB3D,KAAAA,OAAaC,MACbD,KAAAA,OAAa4D,MACb5D,KAAAA,OAAa5oC,MACb4oC,KAAAA,OAAa6D,MAkCb,MAAQxmC,cAAa,GAAEC,SAAQ,GAAEC,MAAKA,KAAKE,EAAAA,EAAAA,oBACrCN,IAAkBC,EAAAA,EAAAA,WAAmC,gBACrDwV,IAAcxV,EAAAA,EAAAA,WAAyC,WAE7D,IAAA0mC,GAAA,IAAAjmC,GAAA,IAAAD,QAAAE,GAAA,IAAAF,QAAAG,GAAA,IAAAH,QAAAI,GAAA,IAAAJ,QAAAK,GAAA,IAAAL,QAAAM,GAAA,IAAAN,QAAAO,GAAA,IAAAP,QAAAQ,GAAA,IAAAR,QAAAS,GAAA,IAAAT,QAAAU,GAAA,IAAAV,QAAAW,GAAA,IAAAX,QAAAY,GAAA,IAAAZ,QAAAa,GAAA,IAAAb,QAAAc,GAAA,IAAAd,QAAAsV,GAAA,IAAAtV,QAAAmmC,GAAA,IAAAnlC,QAAAuU,GAAA,IAAAvV,QAAAomC,GAAA,IAAApmC,QAMA,MAAAqmC,WAG2BnlC,EAAAA,EAAoBC,WAAAA,GAAA,SAAAC,YAAAC,EAAAA,EAAAA,GAAA,KAAA8kC,KAC7C7kC,EAAAA,EAAAA,GAAA,KAAArB,GAAAwB,GAAA,QAIAH,EAAAA,EAAAA,GAAA,KAAApB,IAAAwB,GAAA,MAAAC,GAAA,SAKAL,EAAAA,EAAAA,GAAA,KAAAnB,IAAAyB,GAAA,MAAAC,GAAA,SAKAP,EAAAA,EAAAA,GAAA,KAAAlB,IAAA0B,GAAA,MAAAC,GAAA,SAMAT,EAAAA,EAAAA,GAAA,KAAAjB,IAAA2B,GAAA,MAAAe,GAAA,SAMAzB,EAAAA,EAAAA,GAAA,KAAAhB,IAAA0C,GAAA,MAAAf,GAAA,SAKAX,EAAAA,EAAAA,GAAA,KAAAf,IAAA2B,GAAA,MAAAO,GAAA,SAKAnB,EAAAA,EAAAA,GAAA,KAAAd,IAAAkC,GAAA,MAAA4jC,GAAA,SAQAhlC,EAAAA,EAAAA,GAAA,KAAAb,IAAA8lC,GAAA,MAAAC,GAAA,SAMAllC,EAAAA,EAAAA,GAAA,KAAAZ,IAAA+lC,GAAA,MAAAC,GAAA,SAMAplC,EAAAA,EAAAA,GAAA,KAAAX,IAAAgmC,GAAA,MAAAC,GAAA,SAMAtlC,EAAAA,EAAAA,GAAA,KAAAV,IAAAimC,GAAA,MAAAC,GAAA,SAMAxlC,EAAAA,EAAAA,GAAA,KAAAT,IAAAkmC,GAAA,MAAAC,GAAA,SAMA1lC,EAAAA,EAAAA,GAAA,KAAAR,IAAAmmC,GAAA,MAAA5vB,GAAA,SAQA/V,EAAAA,EAAAA,GAAA,KAAAgU,IAAAgC,GAAA,MAAAhG,GAAA,SAMAhQ,EAAAA,EAAAA,GAAA,KAAAiU,IAAAhE,GAAA,MAAA21B,GAAA,SAAA9jC,EAAAA,EAAAA,GAAA,qBAAA+jC,GAAA,MAMgBnsC,IACdpD,KAAKoD,MAAQA,GACbsI,EAAAA,EAAAA,GAAA6iC,GAAAvuC,KAAK8Z,IAAalO,KAAKxI,EAAM,KAE/BsG,EAAAA,EAAAA,GAAA,KAAA8kC,IAAaprC,KACXsI,EAAAA,EAAAA,GAAA6iC,GAAAvuC,KAAKwvC,IAAS5jC,KAAKxI,EAAM,GACzB,SAjGmBjI,GAAI,OAAA0Q,EAAAA,EAAAA,GAAAxD,GAAA,cAAJlN,CAAI2Q,IAAAC,EAAAA,EAAAA,GAAA1D,GAAA,KAAAyD,EAAA,UAIJE,GAAK,OAAAH,EAAAA,EAAAA,GAAAvD,GAAA,eAAL0D,CAAKF,IAAAC,EAAAA,EAAAA,GAAAzD,GAAA,KAAAwD,EAAA,UAKL1I,GAAK,OAAAyI,EAAAA,EAAAA,GAAAtD,GAAA,eAALnF,CAAK0I,IAAAC,EAAAA,EAAAA,GAAAxD,GAAA,KAAAuD,EAAA,gBAMjBvG,GAAW,OAAAsG,EAAAA,EAAAA,GAAArD,GAAA,qBAAXjD,CAAWuG,IAAAC,EAAAA,EAAAA,GAAAvD,GAAA,KAAAsD,EAAA,YAMXQ,GAAO,OAAAT,EAAAA,EAAAA,GAAApD,GAAA,iBAAP6D,CAAOR,IAAAC,EAAAA,EAAAA,GAAAtD,GAAA,KAAAqD,EAAA,aAKsBG,GAAQ,OAAAJ,EAAAA,EAAAA,GAAAnD,GAAA,kBAARuD,CAAQH,IAAAC,EAAAA,EAAAA,GAAArD,GAAA,KAAAoD,EAAA,aAKRO,GAAQ,OAAAR,EAAAA,EAAAA,GAAAlD,GAAA,kBAAR0D,CAAQP,IAAAC,EAAAA,EAAAA,GAAApD,GAAA,KAAAmD,EAAA,aAQrC2jC,GAAQ,OAAA5jC,EAAAA,EAAAA,GAAAjD,GAAA,kBAAR6mC,CAAQ3jC,IAAAC,EAAAA,EAAAA,GAAAnD,GAAA,KAAAkD,EAAA,WAMRigC,GAAM,OAAAlgC,EAAAA,EAAAA,GAAAhD,GAAA,gBAANkjC,CAAMjgC,IAAAC,EAAAA,EAAAA,GAAAlD,GAAA,KAAAiD,EAAA,WAMN29B,GAAM,OAAA59B,EAAAA,EAAAA,GAAA/C,GAAA,gBAAN2gC,CAAM39B,IAAAC,EAAAA,EAAAA,GAAAjD,GAAA,KAAAgD,EAAA,uBAMN4jC,GAAkB,OAAA7jC,EAAAA,EAAAA,GAAA9C,GAAA,4BAAlB2mC,CAAkB5jC,IAAAC,EAAAA,EAAAA,GAAAhD,GAAA,KAAA+C,EAAA,iBAMlB6jC,GAAY,OAAA9jC,EAAAA,EAAAA,GAAA7C,GAAA,sBAAZ2mC,CAAY7jC,IAAAC,EAAAA,EAAAA,GAAA/C,GAAA,KAAA8C,EAAA,qBAMZ8jC,GAAgB,OAAA/jC,EAAAA,EAAAA,GAAA5C,GAAA,0BAAhB2mC,CAAgB9jC,IAAAC,EAAAA,EAAAA,GAAA9C,GAAA,KAAA6C,EAAA,eAQhBkV,GAAU,OAAAnV,EAAAA,EAAAA,GAAA3C,GAAA,oBAAV8X,CAAUlV,IAAAC,EAAAA,EAAAA,GAAA7C,GAAA,KAAA4C,EAAA,CAqBnBY,MAAAA,GACE,OACEjK,IAAAA,cAACotC,GAAqB,CACpBjjC,WAAY5M,KACZ6M,YAAa7M,KAAK8M,iBAClB4+B,WAAY1rC,KAAK0rC,WACjB1/B,MAAOhM,KAAKgM,MACZ7Q,KAAM6E,KAAK7E,KACXiI,MAAOpD,KAAKoD,MACZkJ,QAAStM,KAAKsM,QACdD,SAAUrM,KAAKqM,SACf9G,YAAavF,KAAKuF,YAClByH,WAAYhN,KAAKgN,WACjBC,UAAWjN,KAAKiN,UAChB+T,WAAYhhB,KAAKghB,WACjB/U,SAAUjM,KAAKiM,SACf0jC,aAAc3vC,KAAK2vC,aACnB5iC,UAAW/M,KAAK+M,UAChB2iC,mBAAoB1vC,KAAK0vC,mBACzBjG,OAAQzpC,KAAKypC,OACbsC,OAAQ/rC,KAAK+rC,OACb0D,SAAUzvC,KAAKyvC,SACflsC,SAAUvD,KAAKuO,aACfpB,QAAS,eACT2iC,MAAMjkC,EAAAA,EAAAA,GAAK2iC,GAALxuC,MACN4vC,iBAAkB5vC,KAAK4vC,kBAG7B,EACDG,GAAAtB,KAAA3zC,GAAA+O,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAe,GAAAC,GAAAf,GAAAC,GAAAO,GAAAC,GAAA4jC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAA5vB,GAAAC,GAAAhG,GAAAI,GAAAyB,GAAA5B,GAAA21B,GAAAE,GAAAQ,GAAAT,IAAA/hC,GAAA8gC,GAAA7gC,MAAAC,EAAAA,EAAAA,GAAAqiC,GAAA,CAtIAloC,GAAc,iBAAkB,CAC/B8F,WAAY,CAACC,GAAAA,MACb,EAKC9F,KAAU,WAIVA,KAAU,YAKVA,KAAU,YAKVA,KAAU,kBAMVA,GAAS,CAAEkG,WAAW,IAAQ,cAM9BlG,GAAS,CAAEgG,KAAMC,UAAU,eAK3BjG,GAAS,CAAEgG,KAAMC,UAAU,eAK3BjG,GAAS,CACRgG,KAAMC,UACN,eAMDjG,KAAU,aAMVA,GAAS,CAAEkG,WAAW,IAAQ,aAM9BlG,GAAS,CAAEgG,KAAMC,UAAU,yBAM3BjG,GAAS,CAAEkG,WAAW,IAAQ,mBAM9BlG,GAAS,CAAEgG,KAAMC,UAAU,uBAM3BjG,GAAS,CACRkG,WAAW,IACX,iBAMDjG,GAAM,CAAE+F,KAAM,WAAW,gBAAAnN,IAAAkL,EAAAA,EAAAA,GAAA6R,GAAA/c,GAAA,CAAAA,EAAAmL,KAAAC,EAAAA,EAAAA,GAAA2R,GAAA/c,EAAAmL,IAAA,CAMzB/D,GAAM,CAAE+F,KAAM,OAAO,YAAAnN,IAAAkL,EAAAA,EAAAA,GAAA8R,GAAAhd,GAAA,CAAAA,EAAAmL,KAAAC,EAAAA,EAAAA,GAAA4R,GAAAhd,EAAAmL,KAAA,GAAA7Q,GAAAuzC,GAAAtgC,KAAAC,EAAAA,EAAAA,GAAAlT,KA5FGqO,EAAAA,IAAmBmE,KAqI9C,MAAMwiC,GACJC,IAEA,MAAMC,EAAW,IAAIlgB,IACfmgB,EAA6B,GASnC,MARA,GAAGF,IAAa70C,MAAM,KAAKyW,SAAS8a,IAClC,GAAIA,EAAKzb,SAAS,KAAM,CACtB,MAAMk/B,EAAQzjB,EAAKvxB,MAAM,KAAK4J,KAAK6G,GAAMvL,OAAOuL,KAChDskC,EAAOt3C,KAAKu3C,EACd,KAA2B,KAAhBzjB,EAAKgI,QAAkBr0B,OAAO+vC,MAAM/vC,OAAOqsB,KACpDujB,EAAS7vC,IAAIC,OAAOqsB,GACtB,IAEK,CAAEujB,WAAUC,SAAQ,EAGvBG,GAAuBA,CAC3BzqB,EACA0qB,KAEA,MAAM,SAAEL,EAAQ,OAAEC,GAAWI,EAC7B,OAAyB,IAAlBL,EAASr5B,MAAgC,IAAlBs5B,EAAOl2C,QAEjCi2C,EAASjiC,IAAI4X,IACXsqB,EAAOx9B,MAAKjQ,IAAA,IAAEkD,EAAKD,GAAIjD,EAAA,OAAKmjB,GAAOjgB,GAAOigB,GAAOlgB,CAAG,GAAC,EAGvD6qC,GACJD,IAEA,MAAM,SAAEL,EAAQ,OAAEC,GAAWI,EAC7B,OAAyB,IAAlBL,EAASr5B,MAAgC,IAAlBs5B,EAAOl2C,MAAY,EAG7Cw2C,GACJF,IAEA,MAAM,SAAEL,EAAQ,OAAEC,GAAWI,EAC7B,IAAIl4B,EAAS,IAAI63B,GAIjB,OAHAC,EAAOt+B,SAAQC,IAAgB,IAAdlM,EAAKD,GAAImM,EACxBuG,EAASA,EAAOxe,OAAO,IAAIia,MAAMnO,EAAM,GAAG4O,QAAQkR,MAAM7f,GAAK,IAExD,IAAI,IAAIoqB,IAAI3X,GAAQ,EAGtB,SAASq4B,GACd/sC,GAEA,MAAM,OACJ6lC,EAAM,OACNsC,EAAM,SACN0D,EAAQ,WACRzuB,EAAU,aACV2uB,EAAY,mBACZD,EAAkB,iBAClBE,EAAgB,YAChBrqC,EAAW,SACX0G,EAAQ,SACR1I,EAAQ,KACRusC,GACElsC,GAEGR,EAAOS,IAAYC,EAAAA,EAAAA,UAASF,EAAMR,QAClCwtC,EAAiBC,IAAsB/sC,EAAAA,EAAAA,WAAS,GACjDgtC,GAAUj5B,EAAAA,EAAAA,UAAQ,IACjB83B,EAGG,GAAsB71C,OAAO61C,GAAc1qC,KAAKjH,IACtD,MAAM,OAAE+yC,EAAM,OAAEC,EAAM,KAAEC,EAAI,KAAEhvC,EAAI,MAAE5B,EAAK,QAAE6wC,EAAO,KAAEvvC,GAAS3D,EACvDmzC,EAAwBlB,GAAqBgB,GAC7CG,EAA0BnB,GAAqBe,GAC/CK,EAA0BpB,GAAqBc,GAC/CO,EAAwBrB,GAAqBtuC,GAC7C4vC,EAAyBtB,GAAqB5vC,GAC9CmxC,EAAwBvB,GAAqBhuC,GAC7CwvC,EAAwBxB,GAAqBiB,GACnD,MAAO,CACL54B,OAAQ,CACN24B,KAAME,EACNH,OAAQI,EACRL,OAAQM,EACR1vC,KAAM2vC,EACNjxC,MAAOkxC,EACPtvC,KAAMuvC,EACNN,QAASO,GAEXC,UACEjB,GAAwBa,IACxBb,GAAwBc,IACxBd,GAAwBe,IACxBf,GAAwBgB,GAC1BE,UACElB,GAAwBU,IACxBV,GAAwBW,IACxBX,GAAwBY,GAC3B,IA9BM,IAgCR,CAAC1B,KAEJ1pC,EAAAA,EAAAA,YAAU,KACRpC,EAASD,EAAMR,MAAM,GACpB,CAACQ,EAAMR,QAEV,MAqBMwuC,EAA4B3vC,GACzBA,GAAQA,EAAOuoC,OAmElBqH,EAA0B,SAAXpI,EACfqI,EAA6B,YAAXrI,EAElBsI,GAAYptC,EAAAA,EAAAA,cAAY,KAC5B,MA2BMqtC,EA3BwB,CAC5B/vC,KAAM,CACJ+4B,GAAAA,KAAKjgC,EAAE,GAAGk0B,MAAMD,GAAEme,YAClBnS,GAAAA,KAAKjgC,EAAE,GAAGk0B,MAAMD,GAAEke,SAClBlS,GAAAA,KAAKjgC,EAAE,GAAGk0B,MAAMD,GAAEie,aAEpBgF,KAAM,CACJjX,GAAAA,KAAKjgC,EAAE,GAAGk0B,MAAMD,GAAEse,aAClBtS,GAAAA,KAAKjgC,EAAE,GAAGk0B,MAAMD,GAAEqe,aAClBrS,GAAAA,KAAKjgC,EAAE,GAAGk0B,MAAMD,GAAEoe,cAEpB/sC,MAAO,CACL26B,GAAAA,KAAKjgC,EAAE,GAAGk0B,MAAMD,GAAEye,cAClBzS,GAAAA,KAAKjgC,EAAE,GAAGk0B,MAAMD,GAAEwe,cAClBxS,GAAAA,KAAKjgC,EAAE,GAAGk0B,MAAMD,GAAEue,eAEpBxtC,QAAS,CACPi7B,GAAAA,KAAKjgC,EAAE,GAAGk0B,MAAMD,GAAE4e,gBAClB5S,GAAAA,KAAKjgC,EAAE,GAAGk0B,MAAMD,GAAE2e,gBAClB3S,GAAAA,KAAKjgC,EAAE,GAAGk0B,MAAMD,GAAE0e,iBAEpB/rC,KAAM,CACJq5B,GAAAA,KAAKjgC,EAAE,GAAGk0B,MAAMD,GAAE+e,aAClB/S,GAAAA,KAAKjgC,EAAE,GAAGk0B,MAAMD,GAAE8e,aAClB9S,GAAAA,KAAKjgC,EAAE,GAAGk0B,MAAMD,GAAE6e,eAGFpE,GACdyI,EAAc9uC,GAASonC,OA6E7B,OACE/nC,IAAAA,cAAA,OACEiM,UAAWC,IAAW,gBAAiB,CACrCwjC,mBAAoBlmC,KAGtBxJ,IAAAA,cAAA,OAAKiM,UAAWC,IAAW,OAAQoM,QAASA,IAlF1Bq3B,MACpB,IAAIC,EACJ,OAAQ5I,GACN,IAAK,OACH4I,EAAUH,EAAYI,QAAQC,SAAS,EAAG,QAC1C,MACF,IAAK,OACHF,EAAUH,EAAYI,QAAQC,SAAS,EAAG,SAC1C,MACF,IAAK,QACHF,EAAUH,EAAYI,QAAQC,SAAS,EAAG,UAC1C,MACF,IAAK,UACHF,EAAUH,EAAYI,QAAQC,SAAS,EAAG,YAC1C,MACF,IAAK,OACHF,EAAUH,EAAYI,QAAQC,SAAS,EAAG,SAC1C,MACF,QACEF,EAAUH,EAGd3uC,SAAAA,EAAW8uC,EAAS7H,KAAM6H,GAAStG,OAAOA,IAC1CloC,EAASwuC,EAAQ,EA2DmCD,IAChD3vC,IAAAA,cAAC+vC,GAAY,CAAChkB,IAAI,KAClB/rB,IAAAA,cAAA,YAAOuvC,EAAK,KAEdvvC,IAAAA,cAAA,OAAKiM,UAAU,UAAUqM,QAASA,IA7DhB03B,MACpB,IAAIC,EACJ,OAAQjJ,GACN,IAAK,OAML,IAAK,QAML,IAAK,OACHiJ,EAAUlI,OACV,MAXF,IAAK,OACHkI,EAAUlI,OAAQ9pC,QAAQ,QAC1B,MAIF,IAAK,UACHgyC,EAAUlI,OAAQ9pC,QAAQ,WAC1B,MAIF,QACEgyC,EAAUR,EAGd3uC,SAAAA,EAAWmvC,EAASlI,KAAMkI,GAAS3G,OAAOA,IAC1CloC,EAAS6uC,EAAQ,EAsCyBD,IACrCT,EAAK,IAERvvC,IAAAA,cAAA,OACEiM,UAAWC,IAAW,CACpBgkC,MAAM,EACNC,aACElD,GACAkC,EACEM,EACGI,QACAhyC,IAAI,EAAc,SAAXmpC,EAAoB,OAAUA,MAG9C1uB,QAASA,IAlDQ83B,MACrB,IAAIC,EACJ,OAAQrJ,GACN,IAAK,OACHqJ,EAAWZ,EAAYI,QAAQhyC,IAAI,EAAG,QACtC,MACF,IAAK,OACHwyC,EAAWZ,EAAYI,QAAQhyC,IAAI,EAAG,SACtC,MACF,IAAK,QACHwyC,EAAWZ,EAAYI,QAAQhyC,IAAI,EAAG,UACtC,MACF,IAAK,UACHwyC,EAAWZ,EAAYI,QAAQhyC,IAAI,EAAG,YACtC,MACF,IAAK,OACHwyC,EAAWZ,EAAYI,QAAQhyC,IAAI,EAAG,SACtC,MACF,QACEwyC,EAAWZ,EAGf3uC,SAAAA,EAAWuvC,EAAUtI,KAAMsI,GAAU/G,OAAOA,IAC5CloC,EAASivC,EAAS,EA2BCD,IAEfpwC,IAAAA,cAAA,YAAOuvC,EAAK,IACZvvC,IAAAA,cAACswC,GAAAA,EAAa,CAACvkB,IAAI,MAEjB,GAEP,CAACprB,EAAOqmC,EAAQiG,IAEbsD,GAAaruC,EAAAA,EAAAA,cACjB,CACEL,EACA2uC,KAEA,MAAMC,EAAa,CACjB,EAAGlY,GAAAA,KAAKjgC,EAAE,GAAGk0B,MAAMD,GAAEgf,iBACrB,EAAGhT,GAAAA,KAAKjgC,EAAE,GAAGk0B,MAAMD,GAAEif,kBACrB,EAAGjT,GAAAA,KAAKjgC,EAAE,GAAGk0B,MAAMD,GAAEkf,iBACrB,EAAGlT,GAAAA,KAAKjgC,EAAE,GAAGk0B,MAAMD,GAAEmf,mBAEjBgF,EAA0B3I,KAAMpnC,GAAOrD,UACvCqzC,EAAyB5I,KAAMlmC,GAASvE,UAC9C,MAAkB,YAAX0pC,EACLhnC,IAAAA,cAAA,OACEiM,UAAWC,IAAW,iBAAkB,CACtCwkC,gBAAiBA,IAAoBC,KAGtCF,EAAWE,IAGdH,EAAKI,UACN,GAEH,CAACjwC,EAAOqmC,IAGV,OACEhnC,IAAAA,cAAA,OACEiM,UAAU,aACVnL,SAAWzI,IACTA,EAAE2L,iBAAiB,GAGrBhE,IAAAA,cAAC6wC,GAAAA,EAAU,CACTN,WAAYA,CAAC1uC,EAAS2uC,IACbD,EAAW1uC,EAAS2uC,GAE7B7vC,MAAOA,EACPopC,kBAAoBr/B,GAAYA,EAChComC,eAAgB5kC,IAAW,CACzB6kC,cAAe1B,EACflB,gBAAiBA,IAEnB7E,OAAQA,EACR0D,SAAUoC,EAAepC,OAAWpoC,EAEpC9D,SAAUA,EACVzC,MAAOkgB,EACPzb,YAAaA,EACbuqC,KAAMA,EACN2D,WAAYhxC,IAAAA,cAAC2a,GAAW,CAAC1C,KAAK,WAAWiM,IAAI,YAC7C8iB,OAAQA,EACRkG,aACGD,GAAsBkC,GACtBjC,GA/RmB1tC,KAC1B,MAAMyxC,EAAUzxC,EAAKN,OACfgyC,EAAW1xC,EAAK5B,QAAU,EAC1BqyC,EAAUzwC,EAAKA,OACf2xC,EAAa3xC,EAAKR,aACxB,OAAOqvC,EAAQl+B,MAAMihC,IACnB,MAAM,UAAEnC,EAAS,UAAEC,EAAS,OAAEr5B,GAAWu7B,EAEzC,GAAInC,IAAcC,EAChB,OAAO,EAET,MAAM,KAAEhwC,EAAI,MAAEtB,EAAK,QAAE6wC,EAAO,KAAEjvC,GAASqW,EACvC,OACEi4B,GAAqBmD,EAAS/xC,IAC9B4uC,GAAqBoD,EAAUtzC,IAC/BkwC,GAAqBqD,EAAY1C,IACjCX,GAAqBmC,EAASzwC,EAAK,GAErC,GA+QE6xC,aAAcnE,GAxQQ1tC,KAC1B,IAAKA,EAAM,OACX,MAAMyxC,EAAUzxC,EAAKN,OACfgyC,EAAW1xC,EAAK5B,QAAU,EAC1BqyC,EAAUzwC,EAAKA,OACf2xC,EAAa3xC,EAAKR,aAClBsyC,EAAU9xC,EAAKgvC,OACf+C,EAAY/xC,EAAK+uC,SACjBiD,EAAgBhyC,EAAK8uC,SAC3B,IAAImD,EAA0B,GAC1BC,EAA4B,GAC5BC,EAA4B,GAC5BC,GAAe,EA6CnB,OA5CAvD,EAAQh/B,SAAS+hC,IACf,MAAM,UAAElC,EAAS,OAAEr5B,GAAWu7B,EAE9B,GAAIlC,EAAW,OACf,MAAM,KAAEV,EAAI,OAAED,EAAM,OAAED,EAAM,KAAEpvC,EAAI,MAAEtB,EAAK,QAAE6wC,EAAO,KAAEjvC,GAASqW,EACvDg8B,EACJ/D,GAAqBmD,EAAS/xC,IAC9B4uC,GAAqBoD,EAAUtzC,IAC/BkwC,GAAqBqD,EAAY1C,IACjCX,GAAqBmC,EAASzwC,GAOhC,GANAoyC,EACEA,GACCC,GACC/D,GAAqBwD,EAAS9C,IAC9BV,GAAqByD,EAAWhD,IAChCT,GAAqB0D,EAAelD,GACpCuD,EAAa,CACf,MAAMC,EAAa9D,GAAwBQ,GACvC,IAAIl9B,MAAM,IAAIS,QACdk8B,GAA+BO,GAC7BuD,EAAe/D,GAAwBO,GACzC,IAAIj9B,MAAM,IAAIS,QACdk8B,GAA+BM,GAC7ByD,EAAehE,GAAwBM,GACzC,IAAIh9B,MAAM,IAAIS,QACdk8B,GAA+BK,GAE/BR,GAAqBwD,EAAS9C,KAE5BV,GAAqByD,EAAWhD,KAClCoD,EAAkBA,EAAgBt6C,OAAO,IAAI26C,KAGnB,KAAxBA,EAAav6C,SACfi6C,EAAkBA,EAAgBr6C,OAAO,IAAI06C,MAIrB,KAAxBA,EAAat6C,QAAyC,KAAxBu6C,EAAav6C,SAC7Cg6C,EAAgBA,EAAcp6C,OAAO,IAAIy6C,IAE7C,KAEF1D,EAAmBwD,GACZ,CACLH,cAAeA,IAAMA,EACrBC,gBAAiBA,IAAMA,EACvBC,gBAAiBA,IAAMA,EACxB,GA4MGnoC,SAAUA,IAEX2jC,GAAoBntC,IAAAA,cAACsvC,EAAS,MAGrC,CAEO,SAASlC,GACdjsC,GAEA,MAAM,OAAE6lC,EAAS,UAAWM,GAAcnmC,EASpC+nC,GAAehF,EAAAA,GAAAA,mBACfrpC,EACJ09B,GAAAA,KAAK4Q,UAA4C,OAAhC5Q,GAAAA,KAAK4Q,SAASvwC,MAAM,KAAK,GAAcwwC,GAAAA,EAAOC,GAAAA,EAC3D+F,EAA0B,SAAXpI,EACfsC,EAASnoC,EAAMmoC,QAXG,CACtB9pC,KAAM,aACNgwC,KAAM,WACN5xC,MAAO,WACPN,QAAS,YACT4B,KAAM,QAMuC8nC,GASzCuC,GAAQn0B,EAAAA,EAAAA,UAAQ,KACbo0B,EAAAA,GAAAA,OACN,IAEG7oC,GAA2ByU,EAAAA,EAAAA,UAAQ,KACvC,MAAM68B,EAAa9wC,EAAMR,MACzB,GAAIsxC,EACF,OAAK9wC,EAAMmoC,QAAsB,SAAXtC,GAAgC,YAAXA,EAIlCe,KAAMkK,EAAY3I,GAFlBvB,KAAMmK,KAAOD,EAAY3I,GAAQA,SAI5C,GACC,CAACnoC,EAAMR,MAAO2oC,IAEjB,OACEtpC,IAAAA,cAACkF,IAAeD,EAAAA,EAAAA,GAAA,CAAC8G,YAAY,YAAcC,EAAAA,EAAAA,GAAkB7K,IAC3DnB,IAAAA,cAACypC,GAAAA,GAAc,CACb5uC,OAAQA,EACRspB,MAAO,CACLulB,UACmB,YAAjBR,EACI/kB,GAAAA,EAAMwlB,cACNxlB,GAAAA,EAAMylB,mBAGd5pC,IAAAA,cAAC6pC,GAAAA,GAAa,CAAC5lC,UAAW9C,EAAM8nC,WAA0Ba,MAAOP,GAC/DvpC,IAAAA,cAACkuC,IAAuBjpC,EAAAA,EAAAA,GAAA,GAClBqiC,EAAS,CACb3mC,MAAOA,EACP2oC,OAAQA,EACRxoC,SAvCWgL,CAACqmC,EAAqBC,KAA6B,IAAAp6B,EACxD,QAAdA,EAAA7W,EAAML,gBAAQ,IAAAkX,GAAdA,EAAA1J,KAAAnN,EAAiBixC,EAAW,EAuCpB/E,KAAM+B,EApCE5vC,IAAsB,IAAA6yC,EAC5B,QAAVA,EAAAlxC,EAAMksC,YAAI,IAAAgF,GAAVA,EAAA/jC,KAAAnN,EAAa3B,aAAI,EAAJA,EAAM8pC,OAAOnoC,EAAMmoC,QAAQ,OAmCA1kC,EAChCoiC,OAAQA,OAMpB,gBC9qBO,IAAKza,GAAC,SAADA,GAAC,OAADA,EAAC,cAADA,EAAC,sBAADA,EAAC,wBAADA,EAAC,4BAADA,EAAC,sBAADA,EAAC,oEAADA,EAAC,0CAADA,EAAC,sCAADA,CAAC,MAYb,MAsBaC,GAAK,gICIlB+d,EAAAA,GAAAA,gBAAe/d,GDFQ,CAAEE,GAxBN,CACjB+d,MAAO,QACPG,UAAW,YACXG,WAAY,aACZG,aAAc,eACdG,UAAW,YACXiH,iCAAkC,2CAClCC,oBAAqB,yBACrBC,kBAAmB,wBAgBQ5lB,GAbV,CACjB6d,MAAO,KACPG,UAAW,KACXG,WAAY,KACZG,aAAc,MACdG,UAAW,KACXiH,iCAAkC,gBAClCC,oBAAqB,SACrBC,kBAAmB,YCQrBzK,KAAAA,OAAaC,MACbD,KAAAA,OAAa4D,MACb5D,KAAAA,OAAa5oC,MACb4oC,KAAAA,OAAa6D,MAEb,MAAQxmC,cAAa,GAAEC,SAAQ,GAAEC,MAAKA,KAAKE,EAAAA,EAAAA,oBACrCN,IAAkBC,EAAAA,EAAAA,WAAmC,gBACrDwV,IAAcxV,EAAAA,EAAAA,WAAyC,WAEvDstC,GAA6B,CACjCC,UAAW,WACXC,QAAS,YAGJ,IAMNC,GANWC,GAAe,SAAfA,GAAe,OAAfA,EAAe,WAAfA,EAAe,cAAfA,EAAe,eAAfA,EAAe,kBAAfA,EAAe,cAAfA,CAAe,MAM1B,IAAAjtC,GAAA,IAAAD,QAAAE,GAAA,IAAAF,QAAAG,GAAA,IAAAH,QAAAI,GAAA,IAAAJ,QAAAK,GAAA,IAAAL,QAAAM,GAAA,IAAAN,QAAAO,GAAA,IAAAP,QAAAQ,GAAA,IAAAR,QAAAS,GAAA,IAAAT,QAAAU,GAAA,IAAAV,QAAAW,GAAA,IAAAX,QAAAY,GAAA,IAAAZ,QAAAmtC,GAAA,IAAAnsC,QAAAosC,GAAA,IAAAptC,QAAAqtC,GAAA,IAAArtC,QAgCD,MAAAstC,WAGgCpsC,EAAAA,EAAoBC,WAAAA,GAAA,SAAAC,YAAAC,EAAAA,EAAAA,GAAA,KAAA8rC,KAClD7rC,EAAAA,EAAAA,GAAA,KAAArB,GAAAwB,GAAA,QAKAH,EAAAA,EAAAA,GAAA,KAAApB,IAAAwB,GAAA,MAAAC,GAAA,SAKAL,EAAAA,EAAAA,GAAA,KAAAnB,IAAAyB,GAAA,MAAAC,GAAA,SAMAP,EAAAA,EAAAA,GAAA,KAAAlB,IAAA0B,GAAA,MAAAW,GAAA,SAKAnB,EAAAA,EAAAA,GAAA,KAAAjB,IAAAqC,GAAA,MAAA6qC,GAAA,SAMAjsC,EAAAA,EAAAA,GAAA,KAAAhB,IAAAktC,GAAA,MAAAzrC,GAAA,SAMAT,EAAAA,EAAAA,GAAA,KAAAf,IAAAyB,GAAA,MAAAqV,GAAA,SAOA/V,EAAAA,EAAAA,GAAA,KAAAd,IAAA8W,GAAA,MAAAm2B,GAAA,SAMAnsC,EAAAA,EAAAA,GAAA,KAAAb,IAAAitC,GAAA,MAAAC,GAAA,MAKiD,MAEjDrsC,EAAAA,EAAAA,GAAA,KAAAZ,IAAAktC,GAAA,MAAAC,GAAA,SAAAvsC,EAAAA,EAAAA,GAAA,KAAAX,IAAAmtC,GAAA,MAAApO,GAAA,SAYAp+B,EAAAA,EAAAA,GAAA,KAAAV,IAAA++B,GAAA,MAAAruB,GAAA,SAAAlO,EAAAA,EAAAA,GAAA,qBAAAmO,GAAA,MAMgBvW,IACdpD,KAAKoD,MAAQA,GACbsI,EAAAA,EAAAA,GAAA6pC,GAAAv1C,KAAK8Z,IAAalO,KAAKxI,EAAM,KAE/BoI,EAAAA,EAAAA,GAAA,gBACWpI,GACLA,EAAM+xC,WAAa/xC,EAAMgyC,SAAWhyC,EAAM+xC,YAAc/xC,EAAMgyC,QACzDpa,GAAAA,KAAKjgC,EAAE,GAAGk0B,MAAMD,GAAE+lB,oCAEpB,MAETvpC,EAAAA,EAAAA,GAAA,0BACqBpI,IACdA,EAAM+xC,WAAan1C,KAAKqM,SACpB2uB,GAAAA,KAAKjgC,EAAE,GAAGk0B,MAAMD,GAAEgmB,uBAEpB,MAETxpC,EAAAA,EAAAA,GAAA,wBACmBpI,IACZA,EAAMgyC,SAAWp1C,KAAKqM,SAClB2uB,GAAAA,KAAKjgC,EAAE,GAAGk0B,MAAMD,GAAEimB,qBAEpB,MAGTvrC,EAAAA,EAAAA,GAAA,KAAA8rC,GAA8D,CAC5Dx1C,KAAKm2C,QACLn2C,KAAKo2C,kBACLp2C,KAAKq2C,mBAGP3sC,EAAAA,EAAAA,GAAA,KAAA+rC,GAAiB,WAAW,SApGPt6C,GAAI,OAAA0Q,EAAAA,EAAAA,GAAAxD,GAAA,cAAJlN,CAAI2Q,IAAAC,EAAAA,EAAAA,GAAA1D,GAAA,KAAAyD,EAAA,UAKJE,GAAK,OAAAH,EAAAA,EAAAA,GAAAvD,GAAA,eAAL0D,CAAKF,IAAAC,EAAAA,EAAAA,GAAAzD,GAAA,KAAAwD,EAAA,UAMe1I,GAAK,OAAAyI,EAAAA,EAAAA,GAAAtD,GAAA,eAALnF,CAAK0I,IAAAC,EAAAA,EAAAA,GAAAxD,GAAA,KAAAuD,EAAA,aAKRO,GAAQ,OAAAR,EAAAA,EAAAA,GAAArD,GAAA,kBAAR6D,CAAQP,IAAAC,EAAAA,EAAAA,GAAAvD,GAAA,KAAAsD,EAAA,cAMrCwqC,GAAS,OAAAzqC,EAAAA,EAAAA,GAAApD,GAAA,mBAAT6tC,CAASxqC,IAAAC,EAAAA,EAAAA,GAAAtD,GAAA,KAAAqD,EAAA,gBAMTvG,GAAW,OAAAsG,EAAAA,EAAAA,GAAAnD,GAAA,qBAAXnD,CAAWuG,IAAAC,EAAAA,EAAAA,GAAArD,GAAA,KAAAoD,EAAA,eAKqBkV,GAAU,OAAAnV,EAAAA,EAAAA,GAAAlD,GAAA,oBAAVqY,CAAUlV,IAAAC,EAAAA,EAAAA,GAAApD,GAAA,KAAAmD,EAAA,mBAQ1CyqC,GAAc,OAAA1qC,EAAAA,EAAAA,GAAAjD,GAAA,wBAAd2tC,CAAczqC,IAAAC,EAAAA,EAAAA,GAAAnD,GAAA,KAAAkD,EAAA,qBAOd0qC,GAAgB,OAAA3qC,EAAAA,EAAAA,GAAAhD,GAAA,0BAAhB2tC,CAAgB1qC,IAAAC,EAAAA,EAAAA,GAAAlD,GAAA,KAAAiD,EAAA,iBAOhB2qC,GAAY,OAAA5qC,EAAAA,EAAAA,GAAA/C,GAAA,sBAAZ2tC,CAAY3qC,IAAAC,EAAAA,EAAAA,GAAAjD,GAAA,KAAAgD,EAAA,cAKZwH,GAAS,OAAAzH,EAAAA,EAAAA,GAAA9C,GAAA,mBAATuK,CAASxH,IAAAC,EAAAA,EAAAA,GAAAhD,GAAA,KAAA+C,EAAA,CAyClBY,MAAAA,GACE,IAAIq/B,GAASlgC,EAAAA,EAAAA,GAAK4pC,GAALz1C,MACb,OAAQA,KAAKs2C,WACX,IAAK,OACHvK,EAAS,aACT,MACF,IAAK,WACHA,EAAS,eAAclgC,EAAAA,EAAAA,GAAK4pC,GAALz1C,QACvB,MACF,IAAK,SACH+rC,EAAS,QACT,MACF,IAAK,OAGL,IAAK,QAGL,IAAK,UAGL,IAAK,OACHA,EAAS,GAGb,OACEtpC,IAAAA,cAACi0C,GAA0B,CACzB9pC,WAAY5M,KACZ6M,YAAa7M,KAAK8M,iBAClB3R,KAAM6E,KAAK7E,KACX6Q,MAAOhM,KAAKgM,MACZ5I,MAAOpD,KAAKoD,MACZ2J,UAAW/M,KAAK+M,UAChBC,WAAYhN,KAAKgN,WACjBC,UAAWjN,KAAKiN,UAChBspC,eAAgBv2C,KAAKu2C,eACrBC,iBAAkBx2C,KAAKw2C,iBACvBF,UAAWt2C,KAAKs2C,UAChBjqC,SAAUrM,KAAKqM,SACf0/B,OAAQA,EACRxmC,YAAavF,KAAKuF,YAClByb,WAAYhhB,KAAKghB,WACjB1N,UACGtT,KAAKsT,WACFzH,EAAAA,EAAAA,GAAK2pC,GAALx1C,MAAuBlG,OAAOkG,KAAKsT,YACnCzH,EAAAA,EAAAA,GAAK2pC,GAALx1C,MAENy2C,aAAcz2C,KAAKy2C,aACnBlzC,SAAUvD,KAAKuO,aACfm9B,WAAY1rC,KAAK0rC,WACjBp3B,cAAc,EACdnH,QAAQ,gBAGd,EACDwpC,GAAAjB,KAAA56C,GAAA+O,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAW,GAAAC,GAAA6qC,GAAAC,GAAAzrC,GAAAC,GAAAqV,GAAAC,GAAAm2B,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAApO,GAAAC,GAAAruB,GAAAI,GAAAyB,GAAA5B,IAAAnM,GAAA6nC,GAAA5nC,MAAAC,EAAAA,EAAAA,GAAAipC,GAAA,CAnKA9uC,GAAc,uBAAwB,CACrC8F,WAAY,CAACC,GAAAA,EAAWm/B,GAAAA,MACxB,EAKCjlC,KAAU,WAKVA,KAAU,YAMVA,GAAS,CAAEkG,WAAW,IAAQ,YAK9BlG,GAAS,CAAEgG,KAAMC,UAAU,eAK3BjG,GAAS,CAAEkG,WAAW,IAAQ,gBAM9BlG,GAAS,CAAEkG,WAAW,IAAQ,kBAM9BlG,GAAS,CAAEkG,WAAW,IAAQ,iBAO9BlG,GAAS,CAAEgG,KAAMvN,SAAS,qBAO1BuH,GAAS,CAAEgG,KAAMC,UAAU,uBAO3BjG,GAAS,CAAEkG,WAAW,IAAQ,mBAG9BlG,GAAS,CACRkG,WAAW,IACX,gBAMDjG,GAAM,CAAE+F,KAAM,WAAW,gBAAAnN,IAAAkL,EAAAA,EAAAA,GAAA7C,GAAArI,GAAA,CAAAA,EAAAmL,KAAAC,EAAAA,EAAAA,GAAA/C,GAAArI,EAAAmL,KAAA,GAAA7Q,GAAAw6C,GAAAvnC,KAAAC,EAAAA,EAAAA,GAAAlT,KArEIqO,EAAAA,IAAmBmE,KAkKnD,MAAMmpC,GAAa,CACjB30C,KAAM,GACN40C,SAAU,GACV5E,KAAM,CAACqD,GAAgBwB,OACvBz2C,MAAO,CAACi1C,GAAgBwB,MAAOxB,GAAgByB,UAC/Ch3C,QAAS,CACPu1C,GAAgBwB,MAChBxB,GAAgByB,SAChBzB,GAAgB0B,WAElBr1C,KAAM,CACJ2zC,GAAgBwB,MAChBxB,GAAgByB,SAChBzB,GAAgB0B,UAChB1B,GAAgB2B,cAIb,SAASC,GACdtzC,GACoB,IAAAuzC,EACpB,MAAM,MACJ/zC,EAAK,eACLmzC,EAAc,OACdxK,EAAM,iBACNyK,EAAgB,aAChBC,EAAY,SACZlzC,EAAQ,YACRsJ,EAAW,YACXtH,EAAW,WACXyb,GACEpd,EACEwzC,EAAQ,CAAC,OAAQ,UACjBd,EAA2B,QAAlBa,EAAGvzC,EAAM0yC,iBAAS,IAAAa,EAAAA,EAAI,OAC/BE,EAAQD,EAAMjmC,SAASmlC,GAAa,GAAK9L,OAAQuB,OAAO,cACxDuL,EAAY,CAChBnC,UAAWkC,GAASA,EAAQ,IAAM,IAAMnC,GAAgBC,UACxDC,QAASiC,GAASA,EAAQ,IAAM,IAAMnC,GAAgBE,SAGlDmC,GACHhkC,EAAAA,GAAAA,SAAQnQ,aAAK,EAALA,EAAO+xC,aAAe5hC,EAAAA,GAAAA,SAAQnQ,aAAK,EAALA,EAAOgyC,SAE1CkC,EADCl0C,GAGA+xC,EAAWqC,IAAgB1zC,EAAAA,EAAAA,UAChC0mC,KAAM+M,EAAUpC,UAAWpJ,KAEtB0L,EAAeC,IAAoB5zC,EAAAA,EAAAA,UAASqxC,aAAS,EAATA,EAAW7C,UACvD8C,EAASuC,IAAc7zC,EAAAA,EAAAA,UAAS0mC,KAAM+M,EAAUnC,QAASrJ,KACzD6L,EAAaC,IAAkB/zC,EAAAA,EAAAA,UAASsxC,aAAO,EAAPA,EAAS9C,UAkBxDrsC,EAAAA,EAAAA,YAAU,KACJuwC,IAAqB5yC,EAAMR,QAAUyJ,GAAetJ,GACtDA,EAAS6zC,EAAMjmC,SAASmlC,GAAapB,GAAkBoC,EACzD,GACC,KAEHrxC,EAAAA,EAAAA,YAAU,KACR,GAAI7C,SAAAA,EAAO+xC,UAAW,CACpB,MAAM2C,EAAQtN,KAAMpnC,EAAM+xC,UAAWpJ,GAAU,cAC/CyL,EAAaM,GACbJ,EAAiBI,EACnB,CACA,GAAI10C,SAAAA,EAAOgyC,QAAS,CAClB,MAAM2C,EAAMvN,KAAMpnC,EAAMgyC,QAASrJ,GAAU,cAC3C4L,EAAWI,GACXF,EAAeE,EACjB,IACC,CAAC30C,IAEJ,MAAM40C,EACJv1C,IAAAA,cAAA,OAAKiM,UAAU,YAAY5N,MAAOkgB,GAChCve,IAAAA,cAAC2mC,GAAU,CACHpwC,IAAIi/C,EAAAA,GAAAA,UAAS,eAEnB10C,SAxCoB20C,CAACC,EAAoBzL,KAC7CyL,GAAQX,EAAaW,GACrB50C,SAAAA,EAAW,CACT4xC,UAAWzI,EACX0I,QAASA,aAAO,EAAPA,EAASrJ,OAAOA,IACzB,EAoCES,kBAAoBr/B,GAAYA,EAChC/J,OAAQmQ,EAAAA,GAAAA,SAAQnQ,aAAK,EAALA,EAAO+xC,gBAAyB9tC,EAAZ8tC,EACpCpJ,OAAQA,EACRxmC,YAAaA,IAEf9C,IAAAA,cAAA,QAAMiM,UAAU,kBAAiB,KACjCjM,IAAAA,cAAC2mC,GAAU,CACHpwC,IAAIi/C,EAAAA,GAAAA,UAAS,aAEnB10C,SA1CkB60C,CAACD,EAAoBzL,KAC3CyL,GAAQR,EAAWQ,GACnB50C,SAAAA,EAAW,CACT6xC,QAAS1I,EACTyI,UAAWA,aAAS,EAATA,EAAWpJ,OAAOA,IAC7B,EAsCES,kBAAoBr/B,GAAYA,EAChC/J,OAAQmQ,EAAAA,GAAAA,SAAQnQ,aAAK,EAALA,EAAOgyC,cAAqB/tC,EAAV+tC,EAClCrJ,OAAQA,EACRxmC,YAAaA,KAIb8yC,EAAiB,CACrB,CAAC/C,GAAgBwB,OAAQ,CACvB,CAAC9b,GAAAA,KAAKjgC,EAAE,GAAGk0B,MAAMD,GAAEke,UAAW,CAAC1C,OAAQ9pC,QAAQ,OAAQ8pC,SAEzD,CAAC8K,GAAgByB,UAAW,CAC1B,CAAC/b,GAAAA,KAAKjgC,EAAE,GAAGk0B,MAAMD,GAAEqe,cAAe,CAChC7C,OAAQ9pC,QAAQ,QAChB8pC,OAAQ5pC,MAAM,UAGlB,CAAC00C,GAAgB0B,WAAY,CAC3B,CAAChc,GAAAA,KAAKjgC,EAAE,GAAGk0B,MAAMD,GAAEwe,eAAgB,CACjChD,OAAQ9pC,QAAQ,SAChB8pC,OAAQ5pC,MAAM,WAGlB,CAAC00C,GAAgB2B,aAAc,CAC7B,CAACjc,GAAAA,KAAKjgC,EAAE,GAAGk0B,MAAMD,GAAE2e,iBAAkB,CACnCnD,OAAQ9pC,QAAQ,WAChB8pC,OAAQ5pC,MAAM,aAGlB,CAAC00C,GAAgBgD,UAAW,CAC1B,CAACtd,GAAAA,KAAKjgC,EAAE,GAAGk0B,MAAMD,GAAE8e,cAAe,CAChCtD,OAAQ9pC,QAAQ,QAChB8pC,OAAQ5pC,MAAM,WAKd23C,GAAc1gC,EAAAA,EAAAA,UAAQ,KAC1B,MAAM2gC,EAAc,GACpB,IAAKjC,IAAmBa,EAAMjmC,SAASmlC,GAAY,CACjD,MAAMmC,GAAkBC,EAAAA,GAAAA,YACtBjC,EACCG,GAAmBN,IAEtB,IAAK,MAAM34C,KAAK86C,EAAiB,CAC/B,MAAM56C,EAAOmT,OAAOlK,QAAQuxC,EAAe16C,IAAI,GAC/C66C,EAAY1/C,KAAK,CAAEkT,MAAOnO,EAAK,GAAIuF,MAAOvF,EAAK,IACjD,CACF,CACA,OAAO26C,CAAW,GACjB,CAAClC,EAAWC,EAAgBE,IAUzBkC,GAAc30C,EAAAA,EAAAA,SAAO,GA4BrB40C,GAAc/gC,EAAAA,EAAAA,UAAQ,KAEvBtE,EAAAA,GAAAA,SAAQnQ,aAAK,EAALA,EAAO+xC,aAAe5hC,EAAAA,GAAAA,SAAQnQ,aAAK,EAALA,EAAOgyC,SAE1C,GADA,CAACD,EAAWC,IAGjB,CAACA,EAASD,EAAW/xC,aAAK,EAALA,EAAOgyC,QAAShyC,aAAK,EAALA,EAAO+xC,YAEzC0D,EACJp2C,IAAAA,cAAC6wC,GAAAA,EAAWhK,YAAW,CACrBxoC,MAAOkgB,EACPyuB,SAAuC,aAA5B6G,EACX7M,OAAqC,aAA5B6M,EAAyC,OAASA,EAC3DlzC,MAAOw1C,EACPE,QAASP,EACTxM,OAAQA,EACRxoC,SArDiBw1C,IACnBvB,EAAauB,aAAK,EAALA,EAAQ,IACrBpB,EAAWoB,aAAK,EAALA,EAAQ,IACnBx1C,SAAAA,EAAW,CACT4xC,UAAW4D,aAAK,EAALA,EAAQ,GAAGhN,OAAOA,GAAU,cACvCqJ,QAAS2D,aAAK,EAALA,EAAQ,GAAGhN,OAAOA,GAAU,eACrC,EAgDAN,aA5CkBvS,KACfA,GAAQyf,EAAYr0C,SACvBkzC,EAAaC,GACbE,EAAWC,IAEXe,EAAYr0C,SAAU,CACxB,EAuCEwrC,KApCakJ,IAAsB,IAAAC,EAAAC,EACrCP,EAAYr0C,SAAU,EACtB,MAAMy0C,EAAQC,EACdtB,EAAiBqB,SAAU,QAALE,EAALF,EAAQ,UAAE,IAAAE,OAAA,EAAVA,EAAY3G,SAC7BuF,EAAekB,SAAU,QAALG,EAALH,EAAQ,UAAE,IAAAG,OAAA,EAAVA,EAAY5G,QAAQ,EAiCjC3C,aA9BkBrrC,KACfiyC,MAIHjyC,GAAWkmC,OAAQ+H,SAASgE,EAAgB,SAC5CjyC,EAAUkmC,OAAQ5pC,MAAM,QAyBxB2E,YAAaA,EACb4zC,UAAW,IACX3M,kBAAoBr/B,GAAYA,EAChCsmC,WAAYhxC,IAAAA,cAAC2a,GAAW,CAAC1C,KAAK,WAAWiM,IAAI,cAG3C0pB,EAAQ+G,EAAMjmC,SAASmlC,GAAa0B,EAAYa,EAEtD,OAAOp2C,IAAAA,cAAA,WAAM4tC,EACf,CAEO,SAASqG,GAA2B9yC,GACzC,MAAM+nC,GAAehF,EAAAA,GAAAA,mBACfrpC,EACJ09B,GAAAA,KAAK4Q,UAA4C,OAAhC5Q,GAAAA,KAAK4Q,SAASvwC,MAAM,KAAK,GAAcwwC,GAAAA,EAAOC,GAAAA,EAE3DE,GAAQn0B,EAAAA,EAAAA,UAAQ,KACbo0B,EAAAA,GAAAA,OACN,IACH,OACExpC,IAAAA,cAACkF,IAAeD,EAAAA,EAAAA,GAAA,CAAC8G,YAAY,YAAcC,EAAAA,EAAAA,GAAkB7K,IAC3DnB,IAAAA,cAACypC,GAAAA,GAAc,CACb5uC,OAAQA,EACRspB,MAAO,CACLulB,UACmB,YAAjBR,EACI/kB,GAAAA,EAAMwlB,cACNxlB,GAAAA,EAAMylB,mBAGd5pC,IAAAA,cAAC6pC,GAAAA,GAAa,CAAC5lC,UAAW9C,EAAM8nC,WAA0Ba,MAAOP,GAC/DvpC,IAAAA,cAAA,OACEc,SAAWzI,IACTA,EAAE2L,iBAAiB,GAGrBhE,IAAAA,cAACy0C,GAAmB,CAClBnL,OAAQnoC,EAAMmoC,OACd3oC,MAAOQ,EAAMR,MACbkzC,UAAW1yC,EAAM0yC,UACjB/yC,SAAUK,EAAML,SAChBizC,iBAAkB5yC,EAAM4yC,iBACxBD,eAAgB3yC,EAAM2yC,eACtBE,aAAc7yC,EAAM6yC,aACpB5pC,YAAajJ,EAAMiJ,YACnBtH,YAAa3B,EAAM2B,YACnByb,WAAYpd,EAAMod,gBAOhC,mHC7fA,MAAQnZ,cAAa,GAAEC,SAAQ,GAAEC,MAAKA,KAAKE,EAAAA,EAAAA,oBACrCN,IAAkBC,EAAAA,EAAAA,WAAmC,gBAAgB,IAAAwxC,GAAA,IAAA/wC,GAAA,IAAAD,QAAAE,GAAA,IAAAF,QAAAG,GAAA,IAAAH,QAAAI,GAAA,IAAAJ,QAAAK,GAAA,IAAAL,QAAAM,GAAA,IAAAN,QAAAO,GAAA,IAAAP,QAAAQ,GAAA,IAAAR,QAAAS,GAAA,IAAAT,QAAAU,GAAA,IAAAV,QAAAW,GAAA,IAAAX,QAAAY,GAAA,IAAAZ,QAAAixC,GAAA,IAAAjwC,QAkB3E,MAAAkwC,WAG4BhwC,EAAAA,EAAkDC,WAAAA,GAAA,SAAAC,YAAAC,EAAAA,EAAAA,GAAA,KAAA4vC,KAC5E3vC,EAAAA,EAAAA,GAAA,KAAArB,GAAAwB,GAAA,QAMAH,EAAAA,EAAAA,GAAA,KAAApB,IAAAwB,GAAA,MAAAC,GAAA,SAKAL,EAAAA,EAAAA,GAAA,KAAAnB,IAAAyB,GAAA,MAAAC,GAAA,SAMAP,EAAAA,EAAAA,GAAA,KAAAlB,IAAA0B,GAAA,MAAAqvC,GAAA,SAKA7vC,EAAAA,EAAAA,GAAA,KAAAjB,IAAA+wC,GAAA,MAAA3uC,GAAA,SAKAnB,EAAAA,EAAAA,GAAA,KAAAhB,IAAAoC,GAAA,MAAA2uC,GAAA,SAKA/vC,EAAAA,EAAAA,GAAA,KAAAf,IAAA+wC,GAAA,MAAAvkC,GAAA,SAOAzL,EAAAA,EAAAA,GAAA,KAAAd,IAAAwM,GAAA,MAAAukC,GAAA,SAKAjwC,EAAAA,EAAAA,GAAA,KAAAb,IAAA+wC,GAAA,MAAAvvC,GAAA,SAMAX,EAAAA,EAAAA,GAAA,KAAAZ,IAAAwB,GAAA,MAAAskC,GAAA,SAMAllC,EAAAA,EAAAA,GAAA,KAAAX,IAAA8lC,GAAA,MAAA/D,GAAA,SAMAphC,EAAAA,EAAAA,GAAA,KAAAV,IAAA+hC,GAAA,MAAArxB,GAAA,SAAAlO,EAAAA,EAAAA,GAAA,qBAAAmO,GAAA,MAKgBvW,IACdpD,KAAKoD,MAAQA,GACbsI,EAAAA,EAAAA,GAAA2tC,GAAAr5C,KAAK8Z,IAAalO,KAAKxI,EAAM,GAC9B,SAlEQjI,GAAI,OAAA0Q,EAAAA,EAAAA,GAAAxD,GAAA,cAAJlN,CAAI2Q,IAAAC,EAAAA,EAAAA,GAAA1D,GAAA,KAAAyD,EAAA,UAMJE,GAAK,OAAAH,EAAAA,EAAAA,GAAAvD,GAAA,eAAL0D,CAAKF,IAAAC,EAAAA,EAAAA,GAAAzD,GAAA,KAAAwD,EAAA,UAKL1I,GAAK,OAAAyI,EAAAA,EAAAA,GAAAtD,GAAA,eAALnF,CAAK0I,IAAAC,EAAAA,EAAAA,GAAAxD,GAAA,KAAAuD,EAAA,iBAML+tC,GAAY,OAAAhuC,EAAAA,EAAAA,GAAArD,GAAA,sBAAZqxC,CAAY/tC,IAAAC,EAAAA,EAAAA,GAAAvD,GAAA,KAAAsD,EAAA,aAKZO,GAAQ,OAAAR,EAAAA,EAAAA,GAAApD,GAAA,kBAAR4D,CAAQP,IAAAC,EAAAA,EAAAA,GAAAtD,GAAA,KAAAqD,EAAA,eAKR6gC,GAAU,OAAA9gC,EAAAA,EAAAA,GAAAnD,GAAA,oBAAVikC,CAAU7gC,IAAAC,EAAAA,EAAAA,GAAArD,GAAA,KAAAoD,EAAA,SAMVgL,GAAI,OAAAjL,EAAAA,EAAAA,GAAAlD,GAAA,cAAJmO,CAAIhL,IAAAC,EAAAA,EAAAA,GAAApD,GAAA,KAAAmD,EAAA,aAMJguC,GAAQ,OAAAjuC,EAAAA,EAAAA,GAAAjD,GAAA,kBAARkxC,CAAQhuC,IAAAC,EAAAA,EAAAA,GAAAnD,GAAA,KAAAkD,EAAA,aAKRG,GAAQ,OAAAJ,EAAAA,EAAAA,GAAAhD,GAAA,kBAARoD,CAAQH,IAAAC,EAAAA,EAAAA,GAAAlD,GAAA,KAAAiD,EAAA,WAORigC,GAAM,OAAAlgC,EAAAA,EAAAA,GAAA/C,GAAA,gBAANijC,CAAMjgC,IAAAC,EAAAA,EAAAA,GAAAjD,GAAA,KAAAgD,EAAA,gBAKNy/B,GAAW,OAAA1/B,EAAAA,EAAAA,GAAA9C,GAAA,qBAAXwiC,CAAWz/B,IAAAC,EAAAA,EAAAA,GAAAhD,GAAA,KAAA+C,EAAA,CAYpBY,MAAAA,GACE,OACEjK,IAAAA,cAACkF,GAAe,CACd6G,YAAY,UACZ5B,WAAY5M,KACZ6M,YAAa7M,KAAK8M,iBAClBd,MAAOhM,KAAKgM,MACZ7Q,KAAM6E,KAAK7E,KACXkR,SAAUrM,KAAKqM,SACfU,UAAW/M,KAAK+M,UAChBE,UAAWjN,KAAKiN,UAChBD,WAAYhN,KAAKgN,WACjBG,QAAQ,gBAER1K,IAAAA,cAACs3C,GAAsB,CACrBhO,OAAQ/rC,KAAK+rC,OACb3oC,MAAOpD,KAAKoD,MACZ0T,KAAM9W,KAAK8W,KACX7K,SAAUjM,KAAKiM,SACf1I,SAAUvD,KAAKuO,aACfm9B,WAAY1rC,KAAK0rC,WACjBH,YAAavrC,KAAKurC,YAClBuO,SAAU95C,KAAK85C,SACfnN,WAAY3sC,KAAK2sC,WACjBkN,aAAc75C,KAAK65C,eAI3B,EAGK,SAASE,GACdn2C,GAEA,MAAM+nC,GAAehF,EAAAA,GAAAA,oBACdoF,EAAQiO,IAAal2C,EAAAA,EAAAA,UAC1BF,EAAMmoC,QAEFQ,GAAQ10B,EAAAA,EAAAA,UAAQ,KACbo0B,EAAAA,GAAAA,OACN,IACH,OACExpC,IAAAA,cAACypC,GAAAA,GAAc,CACbtlB,MAAO,CACLulB,UACmB,YAAjBR,EACI/kB,GAAAA,EAAMwlB,cACNxlB,GAAAA,EAAMylB,mBAGd5pC,IAAAA,cAAC6pC,GAAAA,GAAa,CAAC5lC,UAAW9C,EAAM8nC,WAA0Ba,MAAOA,GAC/D9pC,IAAAA,cAACw3C,GAAAA,GAAWvyC,EAAAA,EAAAA,GAAA,GACN9D,EAAM2nC,YAAW,CACrBiB,kBAAoBr/B,GAAYA,EAAQ+sC,cACxC92C,MAAOQ,EAAMR,MACb6I,SAAUrI,EAAMqI,SAChB0gC,WAAY/oC,EAAM+oC,WAClBkN,aAAcj2C,EAAMi2C,aACpB/iC,KAAMlT,EAAMkT,KACZgjC,SAAUl2C,EAAMk2C,SAChB/N,OAAQA,EACRoO,eAAgBH,EAChBz2C,SAAWH,IAAU,IAAAqX,EACnB,IAAI2/B,EAAch3C,EAAMi3C,cACxB,OAAQz2C,EAAMmoC,QACZ,IAAK,MACHqO,EAAch3C,EAAMk3C,cACpB,MACF,IAAK,MACHF,EAAch3C,EAAMm3C,cACpB,MACF,QACEH,EAAch3C,EAAMi3C,cAGV,QAAd5/B,EAAA7W,EAAML,gBAAQ,IAAAkX,GAAdA,EAAA1J,KAAAnN,EAAiBw2C,EAAY,EAE/BI,QAASA,KAAM,IAAA9rB,EACC,QAAdA,EAAA9qB,EAAML,gBAAQ,IAAAmrB,GAAdA,EAAA3d,KAAAnN,EAAkB,MAM9B,CAvDC62C,GAAAnB,KAAAx+C,GAAA+O,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAqvC,GAAAC,GAAA3uC,GAAAC,GAAA2uC,GAAAC,GAAAvkC,GAAAC,GAAAukC,GAAAC,GAAAvvC,GAAAC,GAAAskC,GAAAC,GAAA/D,GAAAC,GAAArxB,GAAAI,GAAAyB,GAAA5B,IAAAnM,GAAA4rC,GAAA3rC,MAAAC,EAAAA,EAAAA,GAAA+sC,GAAA,CAzGA5yC,GAAc,kBAAmB,CAChC8F,WAAY,CAACC,GAAAA,MACb,EAKC9F,KAAU,WAMVA,KAAU,YAKVA,KAAU,YAMVA,KAAU,mBAKVA,GAAS,CAAEgG,KAAMC,UAAU,eAK3BjG,GAAS,CAAEgG,KAAMC,UAAU,iBAM3BjG,GAAS,CAAEkG,WAAW,IAAQ,WAM9BlG,GAAS,CAAEgG,KAAMC,UAAU,eAK3BjG,GAAS,CAAEgG,KAAMC,UAAU,eAO3BjG,GAAS,CAAEkG,WAAW,IAAQ,aAK9BlG,GAAS,CAAEkG,WAAW,IAAQ,kBAM9BjG,GAAM,CAAE+F,KAAM,WAAW,gBAAAnN,IAAAkL,EAAAA,EAAAA,GAAA7C,GAAArI,GAAA,CAAAA,EAAAmL,KAAAC,EAAAA,EAAAA,GAAA/C,GAAArI,EAAAmL,KAAA,GAAA7Q,GAAAo+C,GAAAnrC,KAAAC,EAAAA,EAAAA,GAAAlT,KAlEAqO,EAAAA,IAAmBmE,mFC9B3C5U,QAA0B,GAA4B,KAE1DA,EAAwBC,KAAK,CAACC,EAAOC,GAAI,m+BAAo+B,KAE7gC,QAAeH,EAAwBI,yFCJnCJ,QAA0B,GAA4B,KAE1DA,EAAwBC,KAAK,CAACC,EAAOC,GAAI,k5BAAm5B,KAE57B,QAAeH,EAAwBI","sources":["webpack:///./src/upload/upload-image/styles.shadow.css","webpack:///../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js","webpack:///./src/checkbox/checkbox.shadow.css","webpack:///./src/submit-buttons/index.shadow.css","webpack:///../../node_modules/style-loader/dist/runtime/styleDomAPI.js","webpack:///./src/time-picker/fix-style.shadow.css","webpack:///./src/radio/host-context.css","webpack:///../../node_modules/dayjs/locale/zh-cn.js","webpack:///../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js","webpack:///../../node_modules/style-loader/dist/runtime/insertStyleElement.js","webpack:///../../node_modules/style-loader/dist/runtime/styleTagTransform.js","webpack:///./src/search/styles.shadow.css","webpack:///../../node_modules/dayjs/plugin/quarterOfYear.js","webpack:///./src/select/index.shadow.css","webpack:///./src/time-picker/styles.shadow.css","webpack:///./src/radio/index.shadow.css","webpack:///./src/upload/upload-file/styles.shadow.css","webpack:///./src/color-picker/styles.shadow.css","webpack:///./src/icon-select/styles.shadow.css","webpack:///./src/time-range-picker/styles.shadow.css","webpack:///./src/general-switch/styles.shadow.css","webpack:///./src/dynamic-form-item/dynamic-form-item.shadow.css","webpack:///../../node_modules/style-loader/dist/runtime/insertBySelector.js","webpack:///./src/date-picker/styles.shadow.css","webpack:///../../node_modules/dayjs/plugin/isoWeek.js","webpack:///../../../src/utils/calculateAutoSizeStyle.ts","webpack:///../../src/TextareaAutoResize.tsx","webpack:///./src/textarea/index.tsx","webpack:///../../src/PubSub.ts","webpack:///../../src/FormStore.ts","webpack:///./src/form/index.tsx","webpack:///./src/utils/formatOptions.ts","webpack:///./src/radio/host-context.css?b01e","webpack:///./src/radio/index.tsx","webpack:///./src/select/empty.svg","webpack:///./src/select/index.tsx","webpack:///./src/submit-buttons/index.tsx","webpack:///../../node_modules/@ant-design/icons-svg/es/asn/CaretRightOutlined.js","webpack:///../../node_modules/@ant-design/icons/es/icons/CaretRightOutlined.js","webpack:///./src/checkbox/index.tsx","webpack:///./src/dynamic-form-item/i18n.ts","webpack:///./src/dynamic-form-item/index.tsx","webpack:///./src/search/index.tsx","webpack:///./src/icon-select/i18n.ts","webpack:///./src/icon-select/utils.ts","webpack:///./src/icon-select/index.tsx","webpack:///./src/upload/i18n.ts","webpack:///./src/upload/utils.ts","webpack:///./src/upload/Upload.tsx","webpack:///./src/upload/upload-image/utils.ts","webpack:///./src/upload/upload-image/index.tsx","webpack:///./src/general-switch/index.tsx","webpack:///./src/upload/upload-file/index.tsx","webpack:///./src/auto-complete/index.tsx","webpack:///../../node_modules/antd/es/time-picker/index.js","webpack:///./src/time-picker/index.tsx","webpack:///./src/date-picker/i18n.ts","webpack:///../../node_modules/@ant-design/icons-svg/es/asn/LeftOutlined.js","webpack:///../../node_modules/@ant-design/icons/es/icons/LeftOutlined.js","webpack:///./src/date-picker/index.tsx","webpack:///./src/time-range-picker/i18n.ts","webpack:///./src/time-range-picker/index.tsx","webpack:///./src/color-picker/index.tsx","webpack:///./src/auto-complete/styles.shadow.css","webpack:///./src/textarea/textarea.shadow.css"],"sourcesContent":["// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `:host{display:block}:host([hidden]){display:none}*,\n*::before,\n*::after{box-sizing:border-box}eo-icon{line-height:0.25em}.upload-wrapper{line-height:initial}.file-list{margin-top:12px;display:flex;flex-direction:column;gap:7px}.image-item{padding:12px 20px;border-radius:var(--larger-border-radius);cursor:pointer}.image-item-inner{position:relative;display:flex;gap:12px}.image{width:38px;height:38px}.infos{flex:1;display:flex;flex-direction:column}.file-name{font-size:14px;font-weight:var(--font-weight-500);color:var(--text-color-default);line-height:20px;margin-bottom:4px}.progress{width:100%;height:4px;background:#ffffff;border-radius:var(--small-border-radius);margin:8px 0}.more-info{display:flex;align-items:center;gap:10px}.image-size{font-size:12px;color:var(--text-color-default);line-height:18px}.file-size{font-size:12px;font-weight:var(--font-weight-500);color:var(--text-color-disabled);line-height:18px}.progress-info{font-size:12px;font-weight:var(--font-weight-500);color:var(--text-color-disabled);line-height:18px}.error-info{font-size:12px;color:var(--color-error);line-height:18px}.operators{position:absolute;top:0;right:0}.delete-icon{opacity:0;font-size:16px}.image-item-done{background:var(--antd-upload-list-type-picture-bg);border:1px solid var(--antd-upload-list-type-picture-border-color)}.image-item-done:hover{background:var(--palette-blue-1);border-color:var(--palette-blue-1)}.image-item-done:hover .delete-icon{opacity:1}.image-item-done .delete-icon{color:var(--text-color-disabled)}.image-item-done .delete-icon:hover{color:var(--color-error)}.image-item-uploading{background:var(--antd-upload-list-type-picture-bg);border:1px dashed var(--antd-upload-list-type-picture-border-color)}.image-item-uploading:hover{background:var(--antd-upload-list-type-picture-hover-bg);border-color:var(--antd-upload-list-type-picture-hover-bg)}.image-item-uploading:hover .delete-icon{opacity:1}.image-item-uploading .delete-icon{color:var(--text-color-disabled)}.image-item-uploading .delete-icon:hover{color:var(--text-color-default)}.image-item-error{background:var(--palette-red-1);border:1px solid var(--theme-orangered-border-color)}.image-item-error .delete-icon{opacity:1;color:var(--color-error)}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","\"use strict\";\n\n/* istanbul ignore next */\nfunction setAttributesWithoutAttributes(styleElement) {\n var nonce = typeof __webpack_nonce__ !== \"undefined\" ? __webpack_nonce__ : null;\n if (nonce) {\n styleElement.setAttribute(\"nonce\", nonce);\n }\n}\nmodule.exports = setAttributesWithoutAttributes;","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.checkboxWrapper{display:flex;flex-wrap:wrap;gap:12px 16px}.checkboxLabel{font-size:14px;line-height:1.57;display:inline-flex;align-items:baseline;cursor:pointer;line-height:22px;min-height:22px;text-align:left;padding:1px 4px;border-radius:var(--medius-border-radius)}.checkboxLabelDisabled{cursor:not-allowed;color:var(--text-color-disabled)}.checkboxInputWrapper{position:relative;top:0.2em}.checkboxInputWrapperDisabled{cursor:not-allowed}.checkboxLabel .checkboxInput{height:16px;width:16px;z-index:1;cursor:pointer;margin:0px;position:absolute;opacity:0}.checkboxLabel .checkboxInput[type=\"checkbox\"]:checked{color:black;background-color:var(--color-info-icon-bg)}.checkboxLabel .checkboxInner{border-radius:3px;position:relative;top:0;left:0;display:block;width:16px;height:16px;direction:ltr;background-color:var(--color-fill-bg-container-1);border:1px solid var(--color-border-divider-line);box-sizing:border-box;border-collapse:separate;transition:all 0.3s}.checkboxLabel:hover .checkboxInner{background-color:var(--color-fill-bg-base-1)}.checkboxLabel:active .checkboxInner{background-color:var(--color-info-icon-bg)}.checkboxLabel .checkboxInputCheck .checkboxInner,\n.checkboxLabel .checkboxInputPartCheck .checkboxInner{background-color:var(--antd-checkbox-color);border-color:var(--antd-checkbox-color)}.checkboxLabelDisabled .checkboxInputCheck .checkboxInner{background-color:inherit;border-color:var(--color-disabled-text)}.checkboxLabelDisabled .checkboxInputCheck .checkboxInner::after{background-color:inherit;border-color:var(--color-disabled-text)}.checkboxLabel .checkboxInner::after{position:absolute;top:45%;left:3px;display:table;width:0.2em;height:0.5em;border:2px solid #fff;border-top:0;border-left:0;transform:rotate(45deg) scale(0) translate(-50%,-50%);opacity:0;transition:all 0.1s cubic-bezier(0.71,-0.46,0.88,0.6),opacity 0.1s;content:\" \"}.checkboxLabel .checkboxInputCheck .checkboxInner::after{transform:rotate(45deg) scale(1) translate(-50%,-50%);opacity:1;transition:all 0.2s cubic-bezier(0.12,0.4,0.29,1.46) 0.1s}.checkboxLabelCheck{background:var(--checkbox-bg-active)}.checkboxLabel .checkboxInputPartCheck .checkboxInner::after{height:2px;background-color:#fff;width:8px;border:0;left:50%;opacity:1;transform:translate(-50%,-50%) scale(1)}.checkboxLabel .checkboxInputDisabled{cursor:not-allowed}.checkboxLabel:hover{background:var(--checkbox-bg-hover)}.checkboxLabel .checkboxText{padding:0 8px}.checkboxText:empty{display:none}.iconCheckbox,\n.disabledIconCheckbox{position:relative;display:inline-block;width:104px;height:104px;margin-right:12px;text-align:center;cursor:pointer}.iconCustomCheckbox,\n.disabledIconCustomCheckbox{width:186px;height:114px;margin:0 15px 20px 0}.disabledIconCheckbox,\n.disabledIconCustomCheckbox{background-color:var(--input-outline-disabled)}.disabledIconCheckbox input[type=\"checkbox\"]::before{cursor:not-allowed}.disabledIconCustomCheckbox input[type=\"checkbox\"]::before{cursor:not-allowed}.disabledIconCheckbox .content .text,.disabledIconCustomCheckbox .content .text{color:var(--antd-checkbox-custom-type-disabled-color)}.iconCheckbox:hover input[type=\"checkbox\"]::before{border:1px solid var(--color-brand-hover)}.iconCheckbox input[type=\"checkbox\"]:checked::before{border:1px solid var(--color-brand-hover)}.iconCustomCheckbox:hover input[type=\"checkbox\"]::before{border:1px solid var(--color-brand-hover)}.iconCustomCheckbox input[type=\"checkbox\"]:checked::before{border:1px solid var(--color-brand-hover)}.iconCheckbox.content{position:absolute;width:100%;height:100%;top:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.inputBox{padding:5px;text-align:right;line-height:15px}.inputBox input[type=\"checkbox\"]::before{content:\"\";position:absolute;width:100%;height:100%;border-radius:6px;border:1px solid var(--color-border-divider-line);cursor:pointer;top:0;left:0}.collapse-wrapper{margin-top:4px}.collapse-header{padding:0px 16px 12px 40px;position:relative;margin-left:0px;margin-top:-4px}.collapse-content{padding:0px 16px 12px 40px;margin-top:-4px;display:none}.collapse-content-visible{display:block}.collapse-header .collapse-icon{position:absolute;left:16px}.collapse-header .checkboxLabel{margin-left:0px}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.submitBtn{margin-right:8px}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","\"use strict\";\n\n/* istanbul ignore next */\nfunction apply(styleElement, options, obj) {\n var css = \"\";\n if (obj.supports) {\n css += \"@supports (\".concat(obj.supports, \") {\");\n }\n if (obj.media) {\n css += \"@media \".concat(obj.media, \" {\");\n }\n var needLayer = typeof obj.layer !== \"undefined\";\n if (needLayer) {\n css += \"@layer\".concat(obj.layer.length > 0 ? \" \".concat(obj.layer) : \"\", \" {\");\n }\n css += obj.css;\n if (needLayer) {\n css += \"}\";\n }\n if (obj.media) {\n css += \"}\";\n }\n if (obj.supports) {\n css += \"}\";\n }\n var sourceMap = obj.sourceMap;\n if (sourceMap && typeof btoa !== \"undefined\") {\n css += \"\\n/*# sourceMappingURL=data:application/json;base64,\".concat(btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap)))), \" */\");\n }\n\n // For old IE\n /* istanbul ignore if */\n options.styleTagTransform(css, styleElement, options.options);\n}\nfunction removeStyleElement(styleElement) {\n // istanbul ignore if\n if (styleElement.parentNode === null) {\n return false;\n }\n styleElement.parentNode.removeChild(styleElement);\n}\n\n/* istanbul ignore next */\nfunction domAPI(options) {\n if (typeof document === \"undefined\") {\n return {\n update: function update() {},\n remove: function remove() {}\n };\n }\n var styleElement = options.insertStyleElement(options);\n return {\n update: function update(obj) {\n apply(styleElement, options, obj);\n },\n remove: function remove() {\n removeStyleElement(styleElement);\n }\n };\n}\nmodule.exports = domAPI;","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.ant-picker{border-radius:var(--small-border-radius);height:30px}.ant-picker-dropdown .ant-picker-panel-container{border:var(--medius-border-radius)}.ant-picker-dropdown .ant-picker-panel > .ant-picker-time-panel{padding-top:0}.ant-picker-dropdown\n .ant-picker-time-panel-column\n > li.ant-picker-time-panel-cell{margin-left:0;margin-right:0}.ant-picker-dropdown\n .ant-picker-time-panel-column\n > li.ant-picker-time-panel-cell\n .ant-picker-time-panel-cell-inner{width:auto;border-radius:0}.ant-picker-dropdown .ant-picker-time-panel-column{margin:0}.ant-picker-dropdown .ant-picker-ranges{margin-top:0px;padding:3px 10px;background-color:var(--color-fill-bg-base-3)}.ant-btn{box-shadow:none}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `:root{--radio-dashboard-selected-bg:#ffffff;--radio-dashboard-disabled-bg:#e8e8e8}html[data-theme=\"dark\"],\nhtml[data-theme=\"dark-v2\"]{--radio-dashboard-selected-bg:#414145;--radio-dashboard-disabled-bg:#3d3d43}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___;\n","!function(e,_){\"object\"==typeof exports&&\"undefined\"!=typeof module?module.exports=_(require(\"dayjs\")):\"function\"==typeof define&&define.amd?define([\"dayjs\"],_):(e=\"undefined\"!=typeof globalThis?globalThis:e||self).dayjs_locale_zh_cn=_(e.dayjs)}(this,(function(e){\"use strict\";function _(e){return e&&\"object\"==typeof e&&\"default\"in e?e:{default:e}}var t=_(e),d={name:\"zh-cn\",weekdays:\"星期日_星期一_星期二_星期三_星期四_星期五_星期六\".split(\"_\"),weekdaysShort:\"周日_周一_周二_周三_周四_周五_周六\".split(\"_\"),weekdaysMin:\"日_一_二_三_四_五_六\".split(\"_\"),months:\"一月_二月_三月_四月_五月_六月_七月_八月_九月_十月_十一月_十二月\".split(\"_\"),monthsShort:\"1月_2月_3月_4月_5月_6月_7月_8月_9月_10月_11月_12月\".split(\"_\"),ordinal:function(e,_){return\"W\"===_?e+\"周\":e+\"日\"},weekStart:1,yearStart:4,formats:{LT:\"HH:mm\",LTS:\"HH:mm:ss\",L:\"YYYY/MM/DD\",LL:\"YYYY年M月D日\",LLL:\"YYYY年M月D日Ah点mm分\",LLLL:\"YYYY年M月D日ddddAh点mm分\",l:\"YYYY/M/D\",ll:\"YYYY年M月D日\",lll:\"YYYY年M月D日 HH:mm\",llll:\"YYYY年M月D日dddd HH:mm\"},relativeTime:{future:\"%s内\",past:\"%s前\",s:\"几秒\",m:\"1 分钟\",mm:\"%d 分钟\",h:\"1 小时\",hh:\"%d 小时\",d:\"1 天\",dd:\"%d 天\",M:\"1 个月\",MM:\"%d 个月\",y:\"1 年\",yy:\"%d 年\"},meridiem:function(e,_){var t=100*e+_;return t<600?\"凌晨\":t<900?\"早上\":t<1100?\"上午\":t<1300?\"中午\":t<1800?\"下午\":\"晚上\"}};return t.default.locale(d,null,!0),d}));","\"use strict\";\n\nvar stylesInDOM = [];\nfunction getIndexByIdentifier(identifier) {\n var result = -1;\n for (var i = 0; i < stylesInDOM.length; i++) {\n if (stylesInDOM[i].identifier === identifier) {\n result = i;\n break;\n }\n }\n return result;\n}\nfunction modulesToDom(list, options) {\n var idCountMap = {};\n var identifiers = [];\n for (var i = 0; i < list.length; i++) {\n var item = list[i];\n var id = options.base ? item[0] + options.base : item[0];\n var count = idCountMap[id] || 0;\n var identifier = \"\".concat(id, \" \").concat(count);\n idCountMap[id] = count + 1;\n var indexByIdentifier = getIndexByIdentifier(identifier);\n var obj = {\n css: item[1],\n media: item[2],\n sourceMap: item[3],\n supports: item[4],\n layer: item[5]\n };\n if (indexByIdentifier !== -1) {\n stylesInDOM[indexByIdentifier].references++;\n stylesInDOM[indexByIdentifier].updater(obj);\n } else {\n var updater = addElementStyle(obj, options);\n options.byIndex = i;\n stylesInDOM.splice(i, 0, {\n identifier: identifier,\n updater: updater,\n references: 1\n });\n }\n identifiers.push(identifier);\n }\n return identifiers;\n}\nfunction addElementStyle(obj, options) {\n var api = options.domAPI(options);\n api.update(obj);\n var updater = function updater(newObj) {\n if (newObj) {\n if (newObj.css === obj.css && newObj.media === obj.media && newObj.sourceMap === obj.sourceMap && newObj.supports === obj.supports && newObj.layer === obj.layer) {\n return;\n }\n api.update(obj = newObj);\n } else {\n api.remove();\n }\n };\n return updater;\n}\nmodule.exports = function (list, options) {\n options = options || {};\n list = list || [];\n var lastIdentifiers = modulesToDom(list, options);\n return function update(newList) {\n newList = newList || [];\n for (var i = 0; i < lastIdentifiers.length; i++) {\n var identifier = lastIdentifiers[i];\n var index = getIndexByIdentifier(identifier);\n stylesInDOM[index].references--;\n }\n var newLastIdentifiers = modulesToDom(newList, options);\n for (var _i = 0; _i < lastIdentifiers.length; _i++) {\n var _identifier = lastIdentifiers[_i];\n var _index = getIndexByIdentifier(_identifier);\n if (stylesInDOM[_index].references === 0) {\n stylesInDOM[_index].updater();\n stylesInDOM.splice(_index, 1);\n }\n }\n lastIdentifiers = newLastIdentifiers;\n };\n};","\"use strict\";\n\n/* istanbul ignore next */\nfunction insertStyleElement(options) {\n var element = document.createElement(\"style\");\n options.setAttributes(element, options.attributes);\n options.insert(element, options.options);\n return element;\n}\nmodule.exports = insertStyleElement;","\"use strict\";\n\n/* istanbul ignore next */\nfunction styleTagTransform(css, styleElement) {\n if (styleElement.styleSheet) {\n styleElement.styleSheet.cssText = css;\n } else {\n while (styleElement.firstChild) {\n styleElement.removeChild(styleElement.firstChild);\n }\n styleElement.appendChild(document.createTextNode(css));\n }\n}\nmodule.exports = styleTagTransform;","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `:host{display:inline-block}:host([hidden]){display:none}*,\n*::before,\n*::after{box-sizing:border-box}eo-input{display:block}.search-button{width:16px;font-size:16px;color:var(--color-secondary-text);cursor:pointer}.search-button:hover{color:var(--color-normal-text)}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","!function(t,n){\"object\"==typeof exports&&\"undefined\"!=typeof module?module.exports=n():\"function\"==typeof define&&define.amd?define(n):(t=\"undefined\"!=typeof globalThis?globalThis:t||self).dayjs_plugin_quarterOfYear=n()}(this,(function(){\"use strict\";var t=\"month\",n=\"quarter\";return function(e,i){var r=i.prototype;r.quarter=function(t){return this.$utils().u(t)?Math.ceil((this.month()+1)/3):this.month(this.month()%3+3*(t-1))};var s=r.add;r.add=function(e,i){return e=Number(e),this.$utils().p(i)===n?this.add(3*e,t):s.bind(this)(e,i)};var u=r.startOf;r.startOf=function(e,i){var r=this.$utils(),s=!!r.u(i)||i;if(r.p(e)===n){var o=this.quarter()-1;return s?this.month(3*o).startOf(t).startOf(\"day\"):this.month(3*o+2).endOf(t).endOf(\"day\")}return u.bind(this)(e,i)}}}));","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.select{width:100%;margin:0;padding:0;color:var(--antd-text-color);font-size:14px;position:relative;cursor:text;min-width:100px}*{box-sizing:border-box}.select-selector{position:relative;border:1px solid var(--antd-border-color-base);border-radius:var(--small-border-radius);box-sizing:border-box;background-color:var(--antd-component-background);transition:all 0.3s cubic-bezier(0.645,0.045,0.355,1);padding-right:24px}.select:not(.select-disabled):hover .select-selector{border-color:var(--antd-input-hover-border-color);z-index:1}.select:not(.select-disabled):hover .close-btn{display:block}.select-multiple .select-selector{min-height:30px;height:auto}.select-selection-overflow{position:relative;display:flex;flex:auto;flex-wrap:wrap;max-width:100%;padding-left:10px}.select-multiple .select-selection-overflow{padding-left:4px}.select-single .select-selection-overflow{width:100%;padding:0 10px}.selected-item{flex:none;align-self:center;max-width:100%;line-height:1;margin-top:2px}.selected-item .label{display:inline-block;margin-right:4px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.selector-focused{border-color:var(--antd-input-focus-border-color);border-width:1px;outline:0;box-shadow:0 0 0 2px rgb(0 113 235/20%)}.select-single-item{line-height:1}.selector-focused .selected-single-item{color:var(--antd-input-placeholder-color)}.select-single .select-selection-search{position:absolute;top:-2px;right:25px;bottom:0;left:10px}.select-multiple .select-selection-search{left:4px}.select-single-item{flex:1;min-width:0}.select-single-item .label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;justify-content:space-between}.select-single-item .label .text{margin-right:4px;flex:1;overflow:hidden;text-overflow:ellipsis}.selector-focused .select-single-item .text{color:var(--antd-input-placeholder-color)}.select-multiple .select-selection-search{padding-right:22px}.select-selection-search-input{margin:0;padding:0;background:transparent;border:none;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:30px;cursor:pointer;color:var(--antd-text-color)}.select-disabled .select-selector{color:var(--text-color-disabled);background:var(--antd-input-disabled-bg);cursor:not-allowed}.select-disabled .select-selection-search-input{cursor:not-allowed}.select-selector.is-error{border-color:var(--antd-error-color)}.close-btn{display:none}.anticon{display:inline-block;color:inherit;font-style:normal;line-height:0;text-align:center;text-transform:none;vertical-align:-0.125em;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.select-arrow{display:inline-block;color:inherit;cursor:pointer;font-style:normal;line-height:0;text-transform:none;vertical-align:-0.125em;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;position:absolute;top:53%;right:11px;width:12px;height:12px;margin-top:-6px;color:var(--text-color-disabled);font-size:12px;line-height:1;text-align:center}.anticon{vertical-align:top;transition:0.4s rotate ease}.anticon.focus{rotate:-180deg}.select-dropdown-popup::part(popup){z-index:1050}.select-dropdown{line-height:1.5715;padding:2px;overflow:hidden;background-color:var(--color-fill-bg-container-4);border-radius:var(--medius-border-radius);box-shadow:var(--feedback-container-shadow)}.dropdown-list{max-height:256px;overflow-y:scroll;overflow-anchor:none}.dropdown-inner{display:flex;flex-direction:column}.select-item{position:relative;display:block;padding:5px 12px;color:var(--antd-text-color);font-weight:normal;font-size:14px;line-height:22px;cursor:pointer;transition:background 0.3s ease;margin:2px}.select-item-option{display:flex;border-radius:var(--medius-border-radius);margin:2px}.select-item-option.disabled{cursor:not-allowed;color:var(--color-disabled-text);background:var(--antd-input-disabled-bg)}.select-option-hover{background-color:var(--antd-select-item-active-bg)}.select-item-option-content{position:relative;flex:auto;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.select-item-option-content .option{display:flex;align-items:center;justify-content:space-between}.select-option-selected .option:not(:last-child){margin-right:22px}.select-item-option-content .text-container{display:flex;flex-direction:column}.dropdown-list .option .text-container .label{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.dropdown-list .option .text-container .caption{font-size:var(--auxiliary-font-size-small);color:var(--color-secondary-text);font-weight:var(--font-weight-400);line-height:20px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.dropdown-list .option .label:not(:last-child){margin-right:8px}.select-option-selected{background-color:var(--color-info-icon-bg)}.select-option-hover{background-color:var(--antd-select-item-active-bg)}.is-checked{display:none;position:absolute;right:0px;top:0;color:var(--color-brand)}.select-option-selected .is-checked{display:block}.input-item{min-height:28px;display:flex;align-items:center;min-width:0}.select-single .input-item{flex:1}.empty-tips{display:flex;flex-direction:column;justify-content:center;align-items:center;font-size:14px;color:var(--palette-gray-8);padding:20px}.empty-tips > span{margin-left:-4px;margin-top:8px;color:var(--color-secondary-text)}.select-group-wrapper .select-group-label{padding-left:12px;color:var(--antd-text-color-secondary);font-size:12px;cursor:default}.select-group-wrapper .select-item-option{padding-left:24px}.dropdown-list-loading-container{height:40px;display:flex;align-items:center;justify-content:center;background:rgba(var(--antd-component-background),0.7);font-size:24px}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `:host{display:inline-block}:host([hidden]){display:none}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.radio-group{display:flex;flex-wrap:wrap;gap:12px 16px}:host([type]):not(.does-not-exist):not(.does-not-exist) .radio-item.disabled{color:var(--color-disabled-text)}:host([type]):host([ui]) .radio-item.disabled{color:var(--color-disabled-text)}:host([type=\"default\"]) .radio-item{position:relative;display:inline-flex;align-items:center;text-align:center;cursor:pointer;gap:8px}:host([type=\"default\"]) .radio-item .radio{box-sizing:border-box;margin:0;padding:0;color:var(--ant-color-text);font-size:var(--ant-font-size);line-height:var(--ant-line-height);list-style:none;position:relative;display:inline-block;outline:none;cursor:pointer;align-self:center;border-radius:50%}:host([type=\"default\"]) .radio-item .radio input[type=\"radio\"]{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;cursor:pointer;opacity:0}:host([type=\"default\"]) .radio-item .radio::after{position:absolute;top:0;left:0;width:100%;height:100%;border:1px solid var(--color-brand);border-radius:50%;visibility:hidden;content:\"\"}:host([type=\"default\"]) .radio-item .radio .radio-inner{box-sizing:border-box;position:relative;top:0;left:0;display:block;width:16px;height:16px;background-color:var(--color-fill-bg-container-1);border:1px solid var(--color-border-divider-line);border-radius:50%;transition:all 0.3s}:host([type=\"default\"]) .radio-item .radio .radio-inner.checked{border-color:var(--color-brand);background-color:var(--color-brand)}:host([type=\"default\"]) .radio-item .radio .radio-inner.checked::after{transform:scale(0.375);opacity:1}:host([type=\"default\"]) .radio-item .radio .radio-inner::after{box-sizing:border-box;position:absolute;top:50%;left:50%;display:block;width:16px;height:16px;margin-top:-8px;margin-left:-8px;background-color:var(--color-fill-bg-container-1);border-top:0;border-left:0;border-radius:16px;transform:scale(0);opacity:0;transition:all 0.3s cubic-bezier(0.78,0.14,0.15,0.86);content:\"\"}:host([type=\"default\"]) .radio-item input[type=\"radio\"]{width:16px;height:16px;vertical-align:middle;margin:0px}:host([type=\"default\"]) .radio-item .content{display:flex;align-items:center}:host([type=\"default\"]) .radio-item.disabled .radio input[type=\"radio\"]{cursor:not-allowed}:host([type=\"default\"]) .radio-item.disabled .radio-inner{background-color:var(--input-outline-disabled)}:host([type=\"default\"]) .radio-item.disabled .radio-inner.checked{background-color:var(--color-disabled-text);border-color:var(--color-disabled-text)}:host([type=\"default\"]) .radio-item:not(.disabled):hover .radio-inner{border:1px solid var(--color-brand)}:host([type=\"icon\"]) .radio-item{position:relative;display:inline-block;width:104px;height:104px;text-align:center;cursor:pointer;color:var(--color-normal-text)}:host([type=\"icon\"]) .radio-item input[type=\"radio\"]{width:0px;height:0px}:host([type=\"icon\"]) .radio-item.checked .content{border-color:var(--color-brand);color:var(--color-brand)}:host([type=\"icon\"]) .radio-item .content{position:absolute;width:100%;height:100%;top:0;display:flex;flex-direction:column;justify-content:center;align-items:center;background:var(--color-fill-bg-container-1);border-radius:var(--medius-border-radius);border:var(--border-width-base) solid var(--color-border-divider-line)}:host([type=\"icon\"]) .radio-item:not(.disabled):hover .content{border-color:var(--color-brand-hover)}:host([type=\"icon\"]) .radio-item.disabled .content{background-color:var(--input-outline-disabled)}:host([type=\"icon\"]) .radio-item.disabled.checked .content{color:var(--color-disabled-text);border-color:var(--color-disabled-text);background-color:var(--color-border-divider-line)}:host([type=\"button\"]){width:max-content;-webkit-appearance:none!important}:host([type=\"button\"]) .radio-group{gap:0}:host([type=\"button\"]) .radio-item{position:relative;display:inline-block;margin:0;margin-left:-1px;padding:0;color:var(--antd-btn-default-color);font-size:14px;background:var(--antd-btn-default-bg);border:1px solid var(--antd-border-color-base);cursor:pointer;transition:color 0.3s,box-shadow 0.3s}:host([type=\"button\"]) .radio-item:first-child{border-radius:var(--small-border-radius) 0 0 var(--small-border-radius);margin-left:0px}:host([type=\"button\"]) .radio-item:last-child{border-radius:0 var(--small-border-radius) var(--small-border-radius) 0}:host([type=\"button\"]) .radio-item.checked.disabled{background-color:var(--color-border-divider-line)}:host([type=\"button\"]) .radio-item.checked:not(.disabled){border-color:var(--antd-radio-dot-color);background-color:var(--antd-radio-dot-color);color:#fff;margin-right:-1px;z-index:1}:host([type=\"button\"]) .radio-item.checked:not(.disabled):hover{color:#fff}:host([type=\"button\"]) .radio-item:not(.disabled):hover{color:var(--antd-radio-dot-color)}:host([type=\"button\"]) .radio-item input[type=\"radio\"]{width:0;height:0;position:absolute;-webkit-appearance:none;-moz-appearance:none;appearance:none}:host([type=\"button\"]) .radio-item .content{padding:0 15px}:host([type=\"button\"]):host([ui=\"dashboard\"]) .radio-group{border-radius:var(--small-border-radius);border:none;background-color:var(--antd-dashboard-radio-bg)}:host([type=\"button\"]):host([ui=\"dashboard\"]) .radio-item{background:var(--antd-dashboard-radio-item-bg);font-size:14px;color:var(--antd-dashboard-radio-item-color);border:none;margin:3px 0;border-radius:var(--medius-border-radius)}:host([type=\"button\"]):host([ui=\"dashboard\"]) .radio-item:first-child{margin-left:3px}:host([type=\"button\"]):host([ui=\"dashboard\"]) .radio-item:last-child{margin-right:3px}:host([type=\"button\"]):host([ui=\"dashboard\"]) .radio-item:not(.disabled):hover{color:var(--antd-dashboard-radio-item-checked-color)}:host([type=\"button\"]):host([ui=\"dashboard\"]) .radio-item.checked:not(.disabled){color:var(--antd-dashboard-radio-item-checked-color);background-color:var(--radio-dashboard-selected-bg);border-radius:var(--small-border-radius);font-weight:var(--font-weight-500)}:host([type=\"button\"]):host([ui=\"dashboard\"]) .radio-item.checked.disabled{background-color:var(--radio-dashboard-disabled-bg)}:host([type=\"button\"]):host([ui=\"dashboard\"]) .radio-item:not(:last-child):after{position:absolute;top:50%;right:0px;display:block;box-sizing:content-box;width:1px;height:calc(100% - 14px);background-color:var(--antd-border-color-base);transition:background-color 0.3s;content:\"\";transform:translateY(-50%)}:host([type=\"button\"]):host([ui=\"dashboard\"]) .radio-item.checked:after{width:0}:host([type=\"button\"]):host([ui=\"dashboard\"]) .radio-item.checked:not(:first-child){margin-left:-1px}:host([type=\"icon-circle\"]) .radio-item{position:relative;display:inline-block;width:auto;text-align:center;cursor:pointer;line-height:1;color:var(--color-normal-text)}:host([type=\"icon-square\"]) .radio-item{position:relative;display:inline-block;width:auto;text-align:center;cursor:pointer;line-height:1;color:var(--color-normal-text)}:host([type=\"icon-circle\"]) .radio-item input[type=\"radio\"]{width:0;height:0;-webkit-appearance:none;-moz-appearance:none;appearance:none}:host([type=\"icon-square\"]) .radio-item input[type=\"radio\"]{width:0;height:0;-webkit-appearance:none;-moz-appearance:none;appearance:none}:host([type=\"icon-circle\"]) .radio-item:not(.disabled):hover .content .icon{border-color:var(--color-brand-hover)}:host([type=\"icon-square\"]) .radio-item:not(.disabled):hover .content .icon{border-color:var(--color-brand-hover)}:host([type=\"icon-circle\"]) .radio-item .content > span{width:93px;display:inline-block;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}:host([type=\"icon-square\"]) .radio-item .content > span{width:93px;display:inline-block;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}:host([type=\"icon-circle\"]) .radio-item .content .icon{display:flex;flex-direction:column;justify-content:center;align-items:center;margin:auto auto 6px;background:var(--color-fill-bg-container-1);border:1px solid var(--color-border-divider-line);width:94px;height:94px;font-size:46px;box-sizing:border-box}:host([type=\"icon-square\"]) .radio-item .content .icon{display:flex;flex-direction:column;justify-content:center;align-items:center;margin:auto auto 6px;background:var(--color-fill-bg-container-1);border:1px solid var(--color-border-divider-line);width:94px;height:94px;font-size:46px;box-sizing:border-box}:host([type=\"icon-circle\"]) .radio-item .content .icon.circle-icon{border-radius:50%}:host([type=\"icon-square\"]) .radio-item .content .icon.circle-icon{border-radius:50%}:host([type=\"icon-circle\"]) .radio-item.disabled .content .icon{background-color:var(--input-outline-disabled)}:host([type=\"icon-square\"]) .radio-item.disabled .content .icon{background-color:var(--input-outline-disabled)}:host([type=\"icon-circle\"]) .radio-item.disabled.checked .content .icon{color:var(--color-disabled-text);border-color:var(--color-disabled-text);background-color:var(--color-border-divider-line)}:host([type=\"icon-square\"]) .radio-item.disabled.checked .content .icon{color:var(--color-disabled-text);border-color:var(--color-disabled-text);background-color:var(--color-border-divider-line)}:host([type=\"icon-circle\"]) .radio-item.checked .content .icon{border:1px solid var(--color-brand);color:var(--color-brand);border-width:var(--border-width-double-base)}:host([type=\"icon-square\"]) .radio-item.checked .content .icon{border:1px solid var(--color-brand);color:var(--color-brand);border-width:var(--border-width-double-base)}:host([type=\"custom\"]) .radio-item{position:relative;display:inline-block;width:212px;height:271px;text-align:center;cursor:pointer;color:var(--color-normal-text)}:host([type=\"custom\"]) .radio-item input[type=\"radio\"]{width:0;height:0}:host([type=\"custom\"]) .radio-item input[type=\"radio\"]:checked ~ .content{box-shadow:var(--hover-shadow)}:host([type=\"custom\"]) .radio-item .content{position:absolute;width:100%;height:100%;top:0;border-radius:var(--small-border-radius)}:host([type=\"custom\"]) .radio-item:not(.disabled):hover .content{box-shadow:var(--hover-shadow)}.radio-item.small{height:24px;font-size:13px;line-height:24px}.radio-item.medium{height:32px;font-size:14px}.radio-item.large{height:40px;font-size:18px;line-height:40px}.disabled,\n.disabled .content{cursor:not-allowed}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `:host{display:block}:host([hidden]){display:none}*,\n*::before,\n*::after{box-sizing:border-box}@keyframes loadingCircle{100%{transform:rotate(360deg)}}eo-icon{line-height:0.25em}.upload-wrapper{line-height:initial}.upload-drag-button{padding:36px 0 24px 0;border-radius:var(--larger-border-radius);background:var(--antd-upload-drag-bg);border:1px dashed var(--antd-upload-drag-border-color);cursor:pointer}.upload-drag-button:hover,\n.upload-drag-button-drag-over{background:var(--antd-upload-drag-hover-bg);border-color:var(--antd-upload-drag-hover-border-color)}.upload-drag-button-inner{display:flex;flex-direction:column;align-items:center;pointer-events:none}.upload-drag-button-icon{height:42px;font-size:153.6px}.upload-drag-text{margin-top:15px;font-size:14px;color:var(--text-color-title);line-height:20px}.upload-drag-text strong{color:var(--color-brand)}.upload-drag-tip{margin-top:8px;font-size:12px;color:var(--text-color-secondary);line-height:17px}.file-list{margin-top:12px;display:flex;flex-direction:column;gap:7px}.upload-item-container{padding:2px 8px;border-radius:var(--larger-border-radius);overflow:hidden;cursor:pointer}.upload-item-inner{position:relative;display:flex;align-items:center;gap:5px}.upload-item-icon{font-size:14px}.upload-icon{animation:loadingCircle 1s infinite linear}.upload-item-infos{flex:1;display:flex;flex-direction:column;padding-right:16px;gap:5px}.upload-item-file-name{font-size:12px;line-height:17px}.upload-item-operators{position:absolute;top:1px;right:0}.delete-icon{opacity:0;font-size:14px}.upload-item-container-uploading .upload-item-icon{color:var(--text-color-secondary)}.upload-item-container-uploading .upload-item-file-name{color:var(--text-color-default)}.upload-item-container-uploading .delete-icon{color:var(--text-color-disabled)}.upload-item-container-uploading:hover{background:var(--antd-upload-list-type-picture-bg)}.upload-item-container-uploading:hover .delete-icon{opacity:1}.upload-item-container-uploading .delete-icon:hover{color:var(--text-color-default)}.upload-item-container-done .upload-item-icon,\n.upload-item-container-done .upload-item-file-name{color:var(--text-color-default)}.upload-item-container-done .delete-icon{color:var(--text-color-disabled)}.upload-item-container-done:hover{background:var(--antd-upload-list-type-picture-hover-bg)}.upload-item-container-done:hover .upload-item-icon,\n.upload-item-container-done:hover .upload-item-file-name{color:var(--color-brand)}.upload-item-container-done:hover .delete-icon{opacity:1}.upload-item-container-done .delete-icon:hover{color:var(--color-error)}.upload-item-container-error .upload-item-icon,\n.upload-item-container-error .upload-item-file-name{color:var(--color-error)}.upload-item-container-error .delete-icon{opacity:1;color:var(--color-error)}.upload-item-container-error:hover{background:var(--palette-red-1)}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `:host{display:inline-block}:host([hidden]){display:none}.ant-color-picker-trigger{align-items:center;padding:0 3px;border-radius:3px}.ant-color-picker-trigger-text{min-width:95px}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `:host{display:inline-block}:host([hidden]){display:none}*,\n*::before,\n*::after{box-sizing:border-box}.show-icon{display:grid;justify-items:center;align-items:center;width:54px;height:54px;font-size:27px;line-height:54px;border-radius:50%;cursor:pointer}.show-icon.disabled{cursor:not-allowed}.preview-container{display:grid;justify-items:center;margin-bottom:20px}.show-area{display:grid;justify-items:center;align-items:center;position:relative;font-size:35px;height:70px;width:70px;border-radius:50%}.delete-wrapper{display:grid;justify-items:center;align-items:center;position:absolute;top:0;cursor:pointer;width:100%;height:100%;border-radius:50%;background-color:rgba(0,0,0,0.15);opacity:0;transition:opacity 0.3s}.show-area:hover .delete-wrapper{opacity:1}.delete-icon{display:grid;justify-items:center;align-items:center;font-size:14px;background:#ffffff;width:36px;height:36px;border-radius:50%;border:1px solid rgba(238,239,243,1)}.delete-icon:focus{background-color:#f2f2f2}.preview-icon-name{text-align:center}.select-icon-container{display:grid;grid-template-columns:80px auto;row-gap:20px}.label{text-align:right;line-height:32px;font-size:14px;font-weight:400;color:rgba(102,102,102,1)}.select-color-area{display:flex}.color-box{width:38px;height:38px;border-radius:var(--larger-border-radius);cursor:pointer}.empty-color{border:var(--border-width-double-base) solid var(--color-border-divider-line);background-color:var(--color-info-white);position:relative;overflow:hidden}.empty-line{background:var(--palette-red-6);position:absolute;transform:translateX(-10px) rotate(-45deg);width:50px;margin:19px 0;height:var(--border-width-double-base)}.color-box:not(:last-child){margin-right:30px}.color-box:first-child{margin-left:22px}.select-icon-area{margin-left:22px}.select-icon-search-bar{display:flex;align-items:center;gap:10px;margin-bottom:12px}.icon-area{padding-top:20px;display:grid;grid-template-columns:repeat(8,12.5%);overflow:auto;width:616px;height:218px;font-size:20px;background:var(--color-fill-bg-base-4);border-radius:var(--larger-border-radius)}.icon-container{display:flex;flex-direction:column;justify-content:center;align-items:center;overflow:hidden;color:var(--color-normal-text);height:50px}.icon-container:hover{cursor:pointer;color:var(--color-brand)}.icon-container .icon-name{width:100%;text-align:center;font-size:10px;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;visibility:hidden}.icon-container:hover .icon-name{visibility:visible}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `:host{display:inline-block}:host([hidden]){display:none}.timeRange{display:flex;align-items:center;width:-moz-fit-content;width:fit-content}.timeRange .timeRangeSplit{width:32px!important;height:30px;background:var(--input-fill-bg);pointer-events:none;border-left:0;border-right:0;display:inline-flex;justify-content:center;pointer-events:none;border-color:var(--antd-border-color-base);border-style:solid;border-top-width:1px;border-bottom-width:1px;align-items:center;color:var(--text-color-disabled);box-sizing:border-box}.timeRange .ant-picker:first-child{margin-right:0;border-top-right-radius:0px;border-bottom-right-radius:0px;flex:1}.timeRange .ant-picker:last-child{margin-right:0;border-top-left-radius:0px;border-bottom-left-radius:0px;flex:1}.timeRange\n .ant-picker-dropdown\n .ant-picker-panel-container\n .ant-picker-footer\n .ant-picker-ranges{margin-top:0px}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `:host([hidden]){display:none}button{line-height:22px;margin:0;padding:0;color:var(--antd-text-color);font-size:14px;font-variant:tabular-nums;line-height:1.5715;list-style:none;font-feature-settings:\"tnum\";position:relative;display:inline-block;box-sizing:border-box;min-width:44px;height:22px;line-height:22px;vertical-align:middle;background-color:var(--text-color-disabled);border:0;border-radius:100px;cursor:pointer;transition:all 0.2s;-webkit-user-select:none;user-select:none}.switch-checked{background-color:var(--antd-switch-color)}.switch-handle{position:absolute;top:2px;left:2px;width:18px;height:18px;transition:all 0.2s ease-in-out}.switch-checked .switch-handle{left:calc(100% - 18px - 2px)}.switch-checked .switch-inner{margin:0 25px 0 7px}.switch-handle::before{position:absolute;top:0;right:0;bottom:0;left:0;background-color:var(--antd-switch-bg);border-radius:9px;box-shadow:0 2px 4px 0 rgba(0,35,11,0.2);transition:all 0.2s ease-in-out;content:\"\"}.switch-inner{display:flex;align-items:center;margin:0 7px 0 25px;transition:margin 0.2s;color:#fff}.switch-disabled{cursor:not-allowed;opacity:0.4}.small{min-width:28px;height:16px;line-height:16px}.small .switch-handle{width:12px;height:12px}.small.switch-checked .switch-handle{left:calc(100% - 12px - 2px)}.small .switch-inner{margin:0 7px 0 18px}.small.switch-checked .switch-inner{margin:0 18px 0 7px}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.dynamic-form-wrapper{border-radius:6px;padding:16px;background:var(--color-fill-bg-base-1)}.remove-btn{cursor:pointer;justify-content:center;display:flex;align-items:center;width:16px;height:16px;border:1px solid;border-radius:50%;line-height:12px;padding:2px;margin-left:8px;color:var(--color-secondary-text)}.remove-btn:hover{color:var(--color-auxiliary-text)}.remove-btn:active{color:var(--color-strong-text)}.remove-btn-wrapper{padding-top:4px}.dynamic-form > *:not(.remove-btn-wrapper){flex:1;margin-right:8px}.add-btn{width:calc(100% - 38px)}.add-btn-wrapper-disabled{cursor:not-allowed}.add-btn-disabled{pointer-events:none}.dynamic-form-item:first-child .dynamic-form:has([label]) .remove-btn-wrapper{margin-top:22px}.remove-btn-disabled-wrapper{cursor:not-allowed}.remove-btn-disabled{pointer-events:none;cursor:not-allowed;color:var(--text-color-disabled)}.add-btn-hide{display:none}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","\"use strict\";\n\nvar memo = {};\n\n/* istanbul ignore next */\nfunction getTarget(target) {\n if (typeof memo[target] === \"undefined\") {\n var styleTarget = document.querySelector(target);\n\n // Special case to return head of iframe instead of iframe itself\n if (window.HTMLIFrameElement && styleTarget instanceof window.HTMLIFrameElement) {\n try {\n // This will throw an exception if access to iframe is blocked\n // due to cross-origin restrictions\n styleTarget = styleTarget.contentDocument.head;\n } catch (e) {\n // istanbul ignore next\n styleTarget = null;\n }\n }\n memo[target] = styleTarget;\n }\n return memo[target];\n}\n\n/* istanbul ignore next */\nfunction insertBySelector(insert, style) {\n var target = getTarget(insert);\n if (!target) {\n throw new Error(\"Couldn't find a style target. This probably means that the value for the 'insert' parameter is invalid.\");\n }\n target.appendChild(style);\n}\nmodule.exports = insertBySelector;","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `:host{display:inline-block}:host([hidden]){display:none}.confirmDisabled .ant-picker-ok .ant-btn{color:var(--text-color-disabled);background:\"red\";border-color:var(--antd-border-color-base);text-shadow:none;box-shadow:none;pointer-events:none}.quarterPicker .quarterContent{left:auto;display:flex;align-items:center;justify-content:center;width:60%;padding:4px}.quarterPicker .quarterContent:hover{background:var(--antd-picker-basic-cell-hover-bg)}.quarterPicker .selectedQuarter{color:var(--antd-picker-panel-cell-selected-color);background:var(--antd-picker-panel-cell-selected-bg)}.quarterPicker .ant-picker-quarter-panel .ant-picker-content tr{display:flex;flex-wrap:wrap}.quarterPicker .ant-picker-quarter-panel .ant-picker-content td{display:flex;align-items:center;justify-content:center;width:50%;height:50%;padding:20px}.quarterPicker .ant-picker-cell-selected::before{color:var(--antd-picker-panel-cell-selected-color);background:var(--antd-picker-panel-cell-selected-bg)}.quarterPicker .ant-picker-cell::before{right:auto;left:auto;display:flex;align-items:center;justify-content:center;width:60%;display:none}.quarterPicker .ant-picker-cell:hover::before{background:var(--antd-picker-basic-cell-hover-bg);cursor:not-allowed}.pickerBtnWrap{box-sizing:border-box;margin:0;padding:0;color:var(--antd-text-color);font-size:14px;font-variant:tabular-nums;list-style:none;font-feature-settings:\"tnum\";padding:0 8px;position:relative;display:inline-flex;align-items:center;background:var(--antd-component-background);border:1px solid var(--antd-border-color-base);border-radius:4px;-webkit-user-select:none;user-select:none}.pre,\n.current,\n.next{position:relative;display:flex;align-items:center;line-height:1;padding:4px;cursor:pointer}.pre:hover,\n.current:hover,\n.next:hover{color:var(--antd-link-color)}.pre:hover .anticon-left,\n.pre:hover .anticon-right,\n.current:hover .anticon-left,\n.current:hover .anticon-right,\n.next:hover .anticon-left,\n.next:hover .anticon-right{color:var(--antd-link-color)}.nextDisabled{color:var(--text-color-disabled);background:var(--antd-background-color-base);pointer-events:none}.pickerWrap{display:flex;gap:10px}.pickerWrap .current{padding:4px 20px}.pickerWrap .current::after,\n.pickerWrap .current::before{content:\"\";position:absolute;top:50%;width:1px;height:70%;transform:translateY(-50%);background:var(--antd-border-color-base)}.pickerWrap .current::after{right:10px}.pickerWrap .current::before{left:10px}.pickerWrap .anticon-left,\n.pickerWrap .anticon-right{color:var(--antd-border-color-base);font-size:\" 11px\"}.pickerWrap .disabledFastSelect{pointer-events:none;color:var(--text-color-disabled);background:var(--antd-background-color-base)}.ant-picker-dropdown .ant-picker-panel-container{border-radius:4px}.ant-picker-dropdown .ant-picker-cell.ant-picker-cell-today .ant-picker-cell-inner:before{border-radius:50%}.ant-picker-dropdown .ant-picker-cell .ant-picker-cell-inner{border-radius:50%}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","!function(e,t){\"object\"==typeof exports&&\"undefined\"!=typeof module?module.exports=t():\"function\"==typeof define&&define.amd?define(t):(e=\"undefined\"!=typeof globalThis?globalThis:e||self).dayjs_plugin_isoWeek=t()}(this,(function(){\"use strict\";var e=\"day\";return function(t,i,s){var a=function(t){return t.add(4-t.isoWeekday(),e)},d=i.prototype;d.isoWeekYear=function(){return a(this).year()},d.isoWeek=function(t){if(!this.$utils().u(t))return this.add(7*(t-this.isoWeek()),e);var i,d,n,o,r=a(this),u=(i=this.isoWeekYear(),d=this.$u,n=(d?s.utc:s)().year(i).startOf(\"year\"),o=4-n.isoWeekday(),n.isoWeekday()>4&&(o+=7),n.add(o,e));return r.diff(u,\"week\")+1},d.isoWeekday=function(e){return this.$utils().u(e)?this.day()||7:this.day(this.day()%7?e:e-7)};var n=d.startOf;d.startOf=function(e,t){var i=this.$utils(),s=!!i.u(t)||t;return\"isoweek\"===i.p(e)?s?this.date(this.date()-(this.isoWeekday()-1)).startOf(\"day\"):this.date(this.date()-1-(this.isoWeekday()-1)+7).endOf(\"day\"):n.bind(this)(e,t)}}}));","// istanbul ignore file\nimport type React from \"react\";\n\nconst HIDDEN_TEXTAREA_STYLE = `\n min-height: 0!important;\n max-height: none!important;\n height: 0!important;\n visibility: hidden!important;\n overflow: hidden!important;\n position: absolute!important;\n z-index: -1000!important;\n top: 0!important;\n right: 0!important;\n pointer-events: none!important;\n`;\n\nconst SIZING_STYLE = [\n \"letter-spacing\",\n \"line-height\",\n \"padding-top\",\n \"padding-bottom\",\n \"font-family\",\n \"font-weight\",\n \"font-size\",\n \"font-variant\",\n \"text-rendering\",\n \"text-transform\",\n \"width\",\n \"text-indent\",\n \"padding-left\",\n \"padding-right\",\n \"border-width\",\n \"box-sizing\",\n \"word-break\",\n \"white-space\",\n];\n\nlet hiddenTextarea: HTMLTextAreaElement | undefined;\n\nexport interface AutoSizeOptions {\n minRows?: number | null;\n maxRows?: number | null;\n borderSize?: number;\n paddingSize?: number;\n}\n\n/**\n * 计算 textarea 高度\n * https://github.com/react-component/textarea/blob/1c0026fbe30e5f7dff1fca695b2cf262246381ca/src/calculateNodeHeight.tsx\n */\nexport default function calculateAutoSizeStyle(\n uiTextNode: HTMLTextAreaElement,\n options?: AutoSizeOptions\n): React.CSSProperties {\n const {\n minRows = null,\n maxRows = null,\n borderSize = 2,\n paddingSize = 8,\n } = options ?? {};\n\n if (!hiddenTextarea) {\n hiddenTextarea = document.createElement(\"textarea\");\n hiddenTextarea.setAttribute(\"tab-index\", \"-1\");\n hiddenTextarea.setAttribute(\"aria-hidden\", \"true\");\n document.body.appendChild(hiddenTextarea);\n }\n\n const uiTextNodeStyle = window.getComputedStyle(uiTextNode);\n const sizingStyle = SIZING_STYLE.map(\n (name) => `${name}:${uiTextNodeStyle.getPropertyValue(name)}`\n ).join(\";\");\n\n // equal style\n hiddenTextarea.setAttribute(\n \"style\",\n `${sizingStyle};${HIDDEN_TEXTAREA_STYLE}`\n );\n hiddenTextarea.value = uiTextNode.value || uiTextNode.placeholder || \"\";\n\n let minHeight: number | undefined;\n let maxHeight: number | undefined;\n let overflowY: React.CSSProperties[\"overflowY\"];\n\n let height = hiddenTextarea.scrollHeight + borderSize;\n\n if (minRows !== null || maxRows !== null) {\n const singleRowHeight =\n process.env.NODE_ENV === \"test\"\n ? 22\n : parseFloat(\n window\n .getComputedStyle(hiddenTextarea)\n .getPropertyValue(\"line-height\")\n );\n if (minRows !== null) {\n minHeight = singleRowHeight * minRows + paddingSize + borderSize;\n height = Math.max(minHeight, height);\n }\n if (maxRows !== null) {\n maxHeight = singleRowHeight * maxRows + paddingSize + borderSize;\n if (height <= maxHeight) {\n overflowY = \"hidden\";\n }\n height = Math.min(maxHeight, height);\n }\n }\n\n const style: React.CSSProperties = {\n height,\n overflowY,\n resize: \"none\",\n };\n\n if (minHeight) {\n style.minHeight = minHeight;\n }\n if (maxHeight) {\n style.maxHeight = maxHeight;\n }\n\n return style;\n}\n","import React, {\n useCallback,\n useEffect,\n useImperativeHandle,\n useRef,\n useState,\n} from \"react\";\nimport { flushSync } from \"react-dom\";\nimport ResizeObserver from \"resize-observer-polyfill\";\nimport calculateAutoSizeStyle from \"./utils/calculateAutoSizeStyle.js\";\n\n// istanbul ignore next\nconst modKey = /Mac|iPod|iPhone|iPad/.test(navigator.platform)\n ? \"metaKey\"\n : \"ctrlKey\";\n\nexport interface TextareaAutoResizeProps\n extends React.DetailedHTMLProps<\n React.TextareaHTMLAttributes<HTMLTextAreaElement>,\n HTMLTextAreaElement\n > {\n /** @default true */\n autoResize?: boolean;\n minRows?: number | null;\n maxRows?: number | null;\n /** @default 2 */\n borderSize?: number;\n /** @default 8 */\n paddingSize?: number;\n containerRef?: React.RefObject<HTMLElement>;\n submitWhen?: \"enter-without-shift\" | \"enter-with-mod\";\n}\n\nexport interface TextareaAutoResizeRef {\n focus(): void;\n}\n\nexport const TextareaAutoResize = React.forwardRef<\n TextareaAutoResizeRef,\n TextareaAutoResizeProps\n>(LegacyTextareaAutoResize);\n\nfunction LegacyTextareaAutoResize(\n {\n autoResize: _autoResize,\n minRows,\n maxRows,\n borderSize,\n paddingSize,\n containerRef,\n value: propValue,\n style,\n submitWhen,\n onChange,\n onSubmit,\n onKeyDown,\n onCompositionStart,\n onCompositionEnd,\n ...props\n }: TextareaAutoResizeProps,\n ref: React.ForwardedRef<TextareaAutoResizeRef>\n): React.JSX.Element {\n const autoResize = _autoResize ?? true;\n const [value, setValue] = useState(propValue ?? \"\");\n const textareaRef = useRef<HTMLTextAreaElement>(null);\n const [autoStyle, setAutoStyle] = useState<React.CSSProperties | null>(null);\n\n useImperativeHandle(\n ref,\n () => ({\n focus: () => {\n const textarea = textareaRef.current;\n // istanbul ignore else: defensive check\n if (textarea) {\n const valueLength = textarea.value?.length;\n textarea.focus();\n valueLength && textarea.setSelectionRange(valueLength, valueLength);\n }\n },\n }),\n []\n );\n\n const doAutoResize = useCallback(() => {\n const textarea = textareaRef.current;\n if (textarea && autoResize) {\n const style = calculateAutoSizeStyle(textarea, {\n minRows,\n maxRows,\n borderSize,\n paddingSize,\n });\n // istanbul ignore next\n if (process.env.NODE_ENV === \"test\") {\n setAutoStyle(style);\n } else {\n flushSync(() => {\n setAutoStyle(style);\n });\n }\n }\n }, [autoResize, maxRows, minRows, borderSize, paddingSize]);\n\n const handleInputChange = (\n e: React.ChangeEvent<HTMLTextAreaElement>\n ): void => {\n setValue(e.target.value);\n onChange?.(e);\n };\n\n useEffect(() => {\n setValue(propValue ?? \"\");\n }, [propValue]);\n\n useEffect(() => {\n doAutoResize();\n }, [doAutoResize, value]);\n\n const compositionRef = useRef(false);\n\n const handleCompositionStart = useCallback(\n (e: React.CompositionEvent<HTMLTextAreaElement>) => {\n compositionRef.current = true;\n onCompositionStart?.(e);\n },\n [onCompositionStart]\n );\n\n const handleCompositionEnd = useCallback(\n (e: React.CompositionEvent<HTMLTextAreaElement>) => {\n compositionRef.current = false;\n onCompositionEnd?.(e);\n },\n [onCompositionEnd]\n );\n\n const handleKeyDown = useCallback(\n (e: React.KeyboardEvent<HTMLTextAreaElement>) => {\n if (compositionRef.current) {\n // Ignore key events during composition\n return;\n }\n\n if (\n e.key === \"Enter\" &&\n (submitWhen === \"enter-without-shift\"\n ? !e.shiftKey\n : submitWhen === \"enter-with-mod\" && e[modKey])\n ) {\n e.preventDefault();\n e.stopPropagation();\n onSubmit?.(e);\n }\n\n onKeyDown?.(e);\n },\n [onKeyDown, onSubmit, submitWhen]\n );\n\n // istanbul ignore next\n useEffect(() => {\n const container = containerRef?.current;\n if (!container || !autoResize) {\n return;\n }\n let previousInlineSize: number | undefined;\n const observer = new ResizeObserver((entries) => {\n for (const entry of entries) {\n if (entry.target === container) {\n // istanbul ignore next: compatibility\n const currentInlineSize = entry.contentBoxSize\n ? entry.contentBoxSize[0]\n ? entry.contentBoxSize[0].inlineSize\n : (entry.contentBoxSize as unknown as ResizeObserverSize)\n .inlineSize\n : entry.contentRect.width;\n if (\n currentInlineSize !== undefined &&\n currentInlineSize !== previousInlineSize\n ) {\n const isInitial = !previousInlineSize;\n previousInlineSize = currentInlineSize;\n if (!isInitial) {\n requestAnimationFrame(doAutoResize);\n }\n }\n }\n }\n });\n observer.observe(container);\n return () => {\n observer.disconnect();\n };\n }, [autoResize, containerRef, doAutoResize]);\n\n return (\n <textarea\n {...props}\n ref={textareaRef}\n value={value}\n style={{\n ...style,\n ...autoStyle,\n }}\n onChange={handleInputChange}\n onCompositionStart={handleCompositionStart}\n onCompositionEnd={handleCompositionEnd}\n onKeyDown={handleKeyDown}\n />\n );\n}\n","import React, { createRef, forwardRef, useCallback, useRef } from \"react\";\nimport { createDecorators, type EventEmitter } from \"@next-core/element\";\nimport {\n FormItemElementBase,\n pickFormItemProps,\n TextareaAutoResize,\n} from \"@next-shared/form\";\nimport { wrapBrick } from \"@next-core/react-element\";\nimport classNames from \"classnames\";\nimport \"@next-core/theme\";\nimport type { FormItem, FormItemProps } from \"../form-item/index.jsx\";\nimport styleText from \"./textarea.shadow.css\";\n\nconst WrappedFormItem = wrapBrick<FormItem, FormItemProps>(\"eo-form-item\");\n\ntype AutoSize =\n | boolean\n | {\n minRows?: number;\n maxRows?: number;\n };\nexport interface TextareaComponentRef {\n focus(): void;\n}\n\nexport interface TextareaProps extends FormItemProps {\n name?: string;\n value?: string;\n placeholder?: string;\n disabled?: boolean;\n textareaStyle?: React.CSSProperties;\n minLength?: number;\n maxLength?: number;\n autoSize?: AutoSize;\n validateState?: string;\n}\n\nexport interface TextareaComponentProps extends TextareaProps {\n onInputChange: (value: string) => void;\n}\n\nconst { defineElement, property, event, method } = createDecorators();\n\n/**\n * 通用多行文本输入框构件\n * @author sailor\n * @category form-input-basic\n */\n@defineElement(\"eo-textarea\", {\n styleTexts: [styleText],\n alias: [\"form.general-textarea\"],\n})\nclass Textarea extends FormItemElementBase implements TextareaProps {\n #componentRef = createRef<TextareaComponentRef>();\n\n /**\n * 字段名称\n */\n @property() accessor name: string | undefined;\n\n /**\n * 标签文字\n */\n @property() accessor label: string | undefined;\n\n /**\n * 值\n */\n @property() accessor value: string | undefined;\n\n /**\n * 占位说明\n */\n @property() accessor placeholder: string | undefined;\n\n /**\n * 是否禁用\n */\n @property({\n type: Boolean,\n })\n accessor disabled: boolean | undefined;\n\n /**\n * 最小长度\n */\n @property({\n type: Number,\n })\n accessor minLength: number | undefined;\n\n /**\n * 最大长度\n */\n @property({\n type: Number,\n })\n accessor maxLength: number | undefined;\n\n /**\n * 大小自适应\n */\n @property({\n attribute: false,\n })\n accessor autoSize: AutoSize | undefined;\n\n /**\n * 是否必填\n */\n @property({\n type: Boolean,\n })\n accessor required: boolean | undefined;\n\n /**\n * 表单校验最大长度\n */\n @property({\n type: Number,\n })\n accessor max: number | undefined;\n\n /**\n * 表单校验最小长度\n */\n @property({\n type: Number,\n })\n accessor min: number | undefined;\n\n /**\n * 校验信息\n */\n @property({\n attribute: false,\n })\n accessor message: Record<string, string> | undefined;\n\n /**\n * 自定义样式\n */\n @property({ attribute: false }) accessor textareaStyle:\n | React.CSSProperties\n | undefined;\n\n /**\n * @detail\n * @description 值改变事件\n */\n @event({ type: \"change\" })\n accessor #InputChangeEvent!: EventEmitter<string>;\n\n /**\n * focus\n */\n @method({ bound: true })\n focusTextarea() {\n return this.#componentRef.current?.focus();\n }\n\n handleInputChange = (value: string) => {\n this.value = value;\n this.#InputChangeEvent.emit(value);\n };\n\n render() {\n return (\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n <TextareaComponent\n curElement={this}\n formElement={this.getFormElement()}\n name={this.name}\n label={this.label}\n value={this.value}\n required={this.required}\n placeholder={this.placeholder}\n disabled={this.disabled}\n minLength={this.minLength}\n maxLength={this.maxLength}\n autoSize={this.autoSize}\n notRender={this.notRender}\n labelBrick={this.labelBrick}\n helpBrick={this.helpBrick}\n textareaStyle={this.textareaStyle}\n validateState={this.validateState}\n max={this.max}\n min={this.min}\n message={this.message}\n trigger=\"handleInputChange\"\n ref={this.#componentRef}\n onInputChange={this.handleInputChange}\n />\n );\n }\n}\n\nexport const TextareaComponent = forwardRef<\n TextareaComponentRef,\n TextareaComponentProps\n>(function TextareaComponent(props, ref) {\n const {\n name,\n value,\n placeholder,\n disabled,\n textareaStyle,\n minLength,\n maxLength,\n autoSize,\n validateState,\n onInputChange,\n } = props;\n const [minRows, maxRows] = React.useMemo(() => {\n if (autoSize && typeof autoSize === \"object\") {\n return [autoSize.minRows, autoSize.maxRows];\n }\n\n return [];\n }, [autoSize]);\n\n const formItemRef = useRef<FormItem>(null);\n\n const handleChange = useCallback(\n (e: React.ChangeEvent<HTMLTextAreaElement>) => {\n onInputChange(e.target.value);\n },\n [onInputChange]\n );\n\n return (\n <WrappedFormItem\n exportparts=\"message\"\n {...pickFormItemProps(props)}\n ref={formItemRef}\n >\n <TextareaAutoResize\n ref={ref}\n containerRef={formItemRef}\n autoResize={!!autoSize}\n minRows={minRows}\n maxRows={maxRows}\n className={classNames({\n error: validateState === \"error\",\n })}\n name={name}\n value={value}\n disabled={disabled}\n style={{\n // Use the minimal height when auto-size enabled, prevent layout shift.\n // By default, the height is 22px each row + 10px (padding & border).\n ...(autoSize\n ? {\n height:\n (typeof autoSize === \"object\" ? (autoSize.minRows ?? 1) : 1) *\n 22 +\n 10,\n }\n : null),\n ...textareaStyle,\n }}\n placeholder={placeholder}\n minLength={minLength}\n maxLength={maxLength}\n onChange={handleChange}\n />\n </WrappedFormItem>\n );\n});\n\nexport { Textarea };\n","import { remove } from \"lodash\";\n\nexport class PubSub {\n #topics: Record<string, { token: string; func: Function }[]> = {};\n #subUid = 0;\n\n publish(topic: string, body: any): void {\n if (!this.#topics[topic]) {\n return;\n }\n const subscribers = this.#topics[topic];\n let len = subscribers ? subscribers.length : 0;\n while (len--) {\n subscribers[len].func(topic, body);\n }\n }\n\n subscribe(topic: string, fn: (topic: string, detail: any) => void): string {\n if (!this.#topics[topic]) {\n this.#topics[topic] = [];\n }\n const token = (++this.#subUid).toString();\n this.#topics[topic].push({\n token: token,\n func: fn,\n });\n return token;\n }\n\n unsubscribe(token: string): void {\n for (const m in this.#topics) {\n if (this.#topics[m]) {\n remove(this.#topics[m], (item) => item.token === token);\n }\n }\n }\n}\n","import { isEmpty, isNil } from \"lodash\";\nimport { PubSub } from \"./PubSub.js\";\n\ninterface FormStoreOptions {\n onValuesChanged?: (data: any) => void;\n}\n\nexport interface FieldDetail {\n name: string;\n label?: string;\n notRender?: boolean;\n originProps?: Record<string, any>;\n validate: Validate;\n [k: string]: any;\n}\n\nexport interface MessageBody {\n message: string;\n type: string;\n}\n\nexport interface WatchOptions {\n needValidate?: boolean;\n}\n\ninterface Validate {\n required?: boolean;\n pattern?: string;\n type?: string;\n min?: number;\n max?: number;\n message?: {\n required?: string;\n pattern?: string;\n min?: string;\n max?: string;\n };\n validator?: (value: any) => MessageBody | string;\n}\n\nlet uid = 0;\n\nclass Field {\n field: string;\n detail: FieldDetail;\n constructor(name: string, detail: FieldDetail) {\n this.field = name;\n this.detail = detail;\n }\n}\n\nexport class FormStore extends PubSub {\n static uid: number;\n static instance: Map<number, FormStore> = new Map();\n static getInstance(options?: FormStoreOptions): FormStore {\n if (!this.instance.get(uid)) {\n this.uid = uid;\n this.instance.set(this.uid, new FormStore(options));\n uid += 1;\n }\n return this.instance.get(this.uid) as FormStore;\n }\n\n #fields: Map<string, Field> = new Map();\n #options: FormStoreOptions | undefined;\n #formData!: Record<string, unknown>;\n #initData: Record<string, unknown> | undefined;\n\n constructor(options?: FormStoreOptions) {\n super();\n this.#formData = {};\n this.#options = options;\n }\n\n setField(name: string, detail: FieldDetail) {\n this.#fields.set(name, new Field(name, detail));\n }\n #getAllFields() {\n return [...this.#fields.keys()].filter((key) => {\n return !this.#fields.get(key)!.detail?.notRender;\n });\n }\n\n getAllValues() {\n const allFields = this.#getAllFields();\n const formData = Object.fromEntries(\n Object.entries(this.#formData)\n .map(([k, v]) => {\n if (allFields.includes(k)) {\n return [k, v];\n }\n return [];\n })\n .filter((item) => item.length)\n );\n return formData;\n }\n\n setInitValue(values: Record<string, unknown>, isEmitValuseChange = true) {\n this.#initData = values;\n this.setFieldsValue(values, isEmitValuseChange);\n }\n\n setFieldsValueByInitData(name: string) {\n const value = this.#initData?.[name];\n if (!isNil(value)) {\n this.#formData[name] = value;\n this.publish(`${name}.init.value`, value);\n }\n }\n\n setFieldsValue(values: Record<string, unknown>, isEmitValuseChange = true) {\n const newFormData: Record<string, unknown> = {\n ...this.#formData,\n };\n Object.entries(values).forEach(([k, v]) => {\n newFormData[k] = v;\n this.#initData && (this.#initData[k] = v);\n this.publish(`${k}.init.value`, v);\n });\n this.#formData = newFormData;\n\n if (isEmitValuseChange) {\n this.#options?.onValuesChanged?.({\n changedValues: values,\n allValues: this.getAllValues(),\n });\n }\n }\n\n resetFields(name?: string) {\n if (name) {\n delete this.#formData[name];\n this.publish(`${name}.reset.fields`, null);\n } else {\n this.#formData = {};\n this.publish(\"reset.fields\", null);\n }\n this.resetValidateState();\n }\n\n getFieldsValue(name?: string) {\n if (name) {\n return this.#formData[name];\n }\n return this.getAllValues();\n }\n\n removeField(name: string) {\n this.#fields.delete(name);\n }\n\n validateFields(\n callback: (err: boolean, value: any) => void\n ): boolean | Record<string, unknown> {\n const allFields = this.#getAllFields();\n const results: Array<MessageBody | undefined> = [];\n allFields.forEach((name) => {\n const field = this.#fields.get(name);\n if (field) {\n results.push(this.validateField(field.detail));\n }\n });\n\n if (results.some((result) => result?.type !== \"normal\")) {\n callback(\n true,\n results.filter((result) => result?.type !== \"normal\")\n );\n return false;\n } else {\n const formData = this.getAllValues();\n callback(false, formData);\n return formData;\n }\n }\n\n validateField(field: string | FieldDetail) {\n const fieldDetail =\n typeof field === \"string\" ? this.#fields.get(field)?.detail : field;\n if (!fieldDetail) return;\n const { name, label, validate } = fieldDetail;\n const validateValue = this.#formData[name];\n\n const messageBody = (message: string, type = \"error\") => {\n return {\n type,\n message,\n };\n };\n\n const getName = () => label ?? name;\n\n const valid = (\n validate: Validate,\n value: string | number | null | undefined\n ): MessageBody => {\n const { required, pattern, message, type, min, max, validator } =\n validate;\n const label = getName();\n\n if (\n typeof value === \"object\"\n ? isEmpty(value)\n : value === undefined || value === \"\"\n ) {\n if (required) {\n return messageBody(message?.required || `${label}为必填项`);\n }\n return messageBody(\"\", \"normal\");\n }\n\n const stringValue = String(value);\n\n if (pattern) {\n const reg = new RegExp(pattern);\n if (!reg.test(stringValue)) {\n return messageBody(\n message?.pattern || `${label}没有匹配正则 ${pattern}`\n );\n }\n }\n\n const checkMin = typeof min === \"number\";\n const checkMax = typeof max === \"number\";\n if (checkMin || checkMax) {\n if (type === \"number\") {\n const numberValue =\n typeof value === \"number\" ? value : parseFloat(value as string);\n if (checkMin && numberValue < min) {\n return messageBody(message?.min || `${label}不能小于 ${min}`);\n }\n if (checkMax && numberValue > max) {\n return messageBody(message?.max || `${label}不能大于 ${max}`);\n }\n } else {\n if (checkMin && stringValue.length < min) {\n return messageBody(\n message?.min || `${label}至少包含 ${min} 个字符`\n );\n }\n if (checkMax && stringValue.length > max) {\n return messageBody(\n message?.max || `${label}不能超过 ${max} 个字符`\n );\n }\n }\n }\n\n if (validator) {\n let result = \"\";\n let parsedValidator = [];\n if (Array.isArray(validator)) {\n parsedValidator = validator;\n } else {\n parsedValidator.push(validator);\n }\n\n for (const v of parsedValidator) {\n result = v(value);\n\n if (result) {\n break;\n }\n }\n return typeof result === \"string\"\n ? messageBody(result, result ? \"error\" : \"normal\")\n : (result as MessageBody);\n }\n\n return messageBody(\"\", \"normal\");\n };\n\n const result = { name, ...valid(validate, validateValue as string) };\n this.publish(`${name}.validate`, result);\n return result;\n }\n\n getValueFromEvent(e: React.ChangeEvent): any {\n if (!e || !e.target) {\n return e;\n }\n const target = e.target as HTMLInputElement;\n return target.type === \"checkbox\" ? target.checked : target.value;\n }\n\n resetValidateState() {\n this.publish(`reset.validate`, null);\n }\n\n onWatch(\n name: string,\n event: any,\n callback?: (v: string) => void,\n options?: WatchOptions\n ) {\n const field = this.#fields.get(name);\n\n if (field) {\n const value = this.getValueFromEvent(event);\n // default first params is value\n const realValue = Array.isArray(value) ? value[0] : value;\n\n this.setFieldsValue({\n [name]: realValue,\n });\n\n if (options?.needValidate ?? true) {\n this.validateField(field.detail);\n }\n callback?.apply(this, value);\n }\n }\n\n onChange(\n name: string,\n value: any,\n callback?: (v: string) => void,\n options?: WatchOptions\n ) {\n const field = this.#fields.get(name);\n\n if (field) {\n this.setFieldsValue({\n [name]: value,\n });\n\n if (options?.needValidate ?? true) {\n this.validateField(field.detail);\n }\n callback?.(value);\n }\n }\n}\n","import React, { useMemo } from \"react\";\nimport { createDecorators, type EventEmitter } from \"@next-core/element\";\nimport { ReactNextElement } from \"@next-core/react-element\";\nimport {\n AbstractForm,\n FormStore,\n MessageBody,\n ColProps,\n} from \"@next-shared/form\";\nimport { ComponentSize, Layout } from \"../interface.js\";\n\nconst { defineElement, property, event, method } = createDecorators();\n\ninterface FormProps {\n values?: Record<string, any>;\n layout?: Layout;\n size?: ComponentSize;\n}\n\nexport interface FormEvents {\n valuesChange?: Event;\n validateSuccess?: Event;\n validateError?: Event;\n}\n\nexport interface FormMapEvents {\n onValuesChange: \"values.change\";\n onValidateSuccess: \"validate.success\";\n onValidateError: \"validate.error\";\n}\n\n/**\n * 表单构件\n * @author sailor\n * @slot - 表单内容\n * @category form-input-basic\n */\n@defineElement(\"eo-form\", {\n alias: [\"form.general-form\"],\n})\nclass Form extends ReactNextElement implements FormProps, AbstractForm {\n formStore: FormStore;\n #values!: Record<string, unknown>;\n defaultEmitValuesChange = true;\n\n constructor() {\n super();\n this.formStore = FormStore.getInstance({\n onValuesChanged: this.handleValuesChange,\n });\n }\n\n get isFormElement(): true {\n return true;\n }\n\n set values(value: Record<string, unknown>) {\n this.#values = value;\n\n this.#setInitValue(value);\n }\n get values(): Record<string, unknown> {\n return this.#values;\n }\n\n #setInitValue(values: Record<string, unknown>) {\n this.formStore.setInitValue(values, this.defaultEmitValuesChange);\n }\n\n @property({\n attribute: false,\n })\n accessor staticValues: Record<string, unknown> | undefined;\n\n /**\n * 布局方式(默认 vertical 布局)\n * @default vertical\n */\n @property() accessor layout: Layout = \"vertical\";\n\n /**\n * 表单组件尺寸\n */\n @property() accessor size: ComponentSize | undefined;\n\n /**\n * 标签列布局样式(仅当 layout=\"horizontal\" 时有效)\n */\n @property({\n attribute: false,\n })\n accessor labelCol: ColProps = {\n sm: {\n span: 24,\n },\n md: {\n span: 24,\n },\n lg: {\n span: 7,\n },\n xl: {\n span: 5,\n },\n xxl: {\n span: 4,\n },\n };\n\n /**\n * 输入控件列布局样式(仅当 layout=\"horizontal\" 时有效)\n */\n @property({\n attribute: false,\n })\n accessor wrapperCol: ColProps = {\n sm: {\n span: 18,\n },\n md: {\n span: 18,\n },\n lg: {\n span: 13,\n },\n xl: {\n span: 16,\n },\n xxl: {\n span: 18,\n },\n };\n\n /**\n * 表单值变更事件\n * @detail\n */\n @event({ type: \"values.change\" }) accessor #valuesChangeEvent!: EventEmitter<\n Record<string, unknown>\n >;\n handleValuesChange = (values: Record<string, unknown>) => {\n this.#valuesChangeEvent.emit(values);\n };\n\n /**\n * 表单验证成功时触发事件\n */\n @event({ type: \"validate.success\" }) accessor #successEvent!: EventEmitter<\n Record<string, unknown>\n >;\n /**\n * 表单验证报错时触发事件\n */\n @event({ type: \"validate.error\" }) accessor #errorEvent!: EventEmitter<\n (MessageBody & { name: string })[]\n >;\n\n /**\n * 表单校验方法\n */\n @method()\n validate(): boolean | Record<string, unknown> {\n return this.formStore.validateFields((err, values) => {\n if (err) {\n this.#errorEvent.emit(values);\n } else {\n this.#successEvent.emit({\n ...(this.staticValues ?? {}),\n ...values,\n });\n }\n });\n }\n\n /**\n * 表单设置值方法\n */\n @method()\n setInitValue(\n values: Record<string, unknown>,\n options?: { runInMacrotask?: boolean; runInMicrotask?: boolean }\n ) {\n if (options) {\n options.runInMicrotask &&\n queueMicrotask(() => {\n this.values = values;\n });\n options.runInMacrotask &&\n setTimeout(() => {\n this.values = values;\n });\n } else {\n this.values = values;\n }\n }\n\n /**\n * 表单重置值方法\n */\n @method()\n resetFields(name?: string) {\n this.formStore.resetFields(typeof name === \"string\" ? name : undefined);\n }\n\n /**\n * 获取表单值方法\n */\n @method()\n getFieldsValue(name?: string) {\n return this.formStore.getFieldsValue(\n typeof name === \"string\" ? name : undefined\n );\n }\n\n @property({\n attribute: false,\n })\n accessor formStyle: React.CSSProperties | undefined;\n\n /**\n * 校验表单字段方法\n */\n @method()\n validateField(name: string) {\n this.formStore.validateField(name);\n }\n\n /**\n * 重置表单校验状态方法\n */\n @method()\n resetValidateState() {\n this.formStore.resetValidateState();\n }\n\n render() {\n return (\n <FormComponent\n layout={this.layout}\n size={this.size}\n labelCol={this.labelCol}\n wrapperCol={this.wrapperCol}\n formStyle={this.formStyle}\n />\n );\n }\n}\n\ninterface FormComponentProps extends FormProps {\n formStyle?: React.CSSProperties;\n labelCol?: ColProps;\n wrapperCol?: ColProps;\n onValuesChange?: (value: Record<string, any>) => void;\n onValidateSuccess?: () => void;\n onValidateError?: () => void;\n}\n\nexport function FormComponent({\n layout = \"vertical\",\n formStyle,\n}: FormComponentProps) {\n const computedStyle = useMemo((): React.CSSProperties => {\n switch (layout) {\n case \"vertical\":\n case \"horizontal\": {\n return {\n display: \"flex\",\n flexDirection: \"column\",\n };\n }\n case \"inline\": {\n return {\n display: \"flex\",\n gap: 10,\n };\n }\n default:\n return {};\n }\n }, [layout]);\n\n return (\n <form>\n <slot\n style={{\n ...computedStyle,\n ...(formStyle ? formStyle : {}),\n }}\n />\n </form>\n );\n}\n\nexport { Form, FormProps };\n","import { get, uniqBy } from \"lodash\";\nimport { GeneralOption, GeneralComplexOption } from \"../interface.js\";\n\nexport function formatOptions(\n options: GeneralOption[] = [],\n fields?: { label?: string; value?: string }\n) {\n return uniqBy(\n options.map((op) => {\n if (typeof op === \"number\" || typeof op === \"string\") {\n return { label: op, value: op };\n }\n if (typeof op === \"boolean\") {\n return { label: String(op), value: op };\n }\n if (fields) {\n return {\n ...op,\n label: get(op, fields.label || \"label\"),\n value: get(op, fields.value || \"value\"),\n };\n }\n return { ...op, label: op.label, value: op.value };\n }),\n \"value\"\n ) as GeneralComplexOption[];\n}\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[0].use[2]!./host-context.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\noptions.insert = insertFn.bind(null, \"head\");\noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[0].use[2]!./host-context.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React, { CSSProperties } from \"react\";\nimport { createDecorators, EventEmitter } from \"@next-core/element\";\nimport { wrapBrick } from \"@next-core/react-element\";\nimport { ReactUseBrick } from \"@next-core/react-runtime\";\nimport { FormItemElementBase, pickFormItemProps } from \"@next-shared/form\";\nimport type {\n RadioType,\n GeneralOption,\n GeneralComplexOption,\n UIType,\n RadioGroupButtonStyle,\n ComponentSize,\n} from \"../interface.js\";\nimport styleText from \"./index.shadow.css\";\nimport classNames from \"classnames\";\nimport \"@next-core/theme\";\nimport type { FormItem, FormItemProps } from \"../form-item/index.jsx\";\nimport { UseSingleBrickConf } from \"@next-core/types\";\nimport type {\n GeneralIcon,\n GeneralIconProps,\n} from \"@next-bricks/icons/general-icon\";\nimport { formatOptions } from \"../utils/formatOptions.js\";\nimport { isBoolean, isEqual } from \"lodash\";\nimport \"./host-context.css\";\n\nconst WrappedGeneralIcon = wrapBrick<GeneralIcon, GeneralIconProps>(\"eo-icon\");\n\nconst WrappedFormItem = wrapBrick<FormItem, FormItemProps>(\"eo-form-item\");\n\ninterface CustomOptions {\n url: string;\n description?: string;\n title: string;\n backgroundColor?: string;\n value: string;\n [propName: string]: any;\n}\n\nexport interface RadioProps {\n type?: RadioType;\n options: GeneralOption[] | CustomOptions[] | undefined;\n value?: any;\n disabled?: boolean;\n buttonStyle?: RadioGroupButtonStyle;\n size?: ComponentSize;\n ui?: UIType;\n useBrick?: UseSingleBrickConf;\n customStyle?: React.CSSProperties;\n}\nexport interface RadioEvents {\n change: CustomEvent<GeneralComplexOption>;\n optionsChange: CustomEvent<{\n options: GeneralComplexOption[];\n name: string;\n }>;\n}\nexport interface RadioEventsMapping {\n onValueChange: \"change\";\n onOptionsChange: \"optionsChange\";\n}\n\nconst { defineElement, property, event } = createDecorators();\n\n/**\n * 通用单选构件\n * @author sailor\n * @category form-input-basic\n */\n@defineElement(\"eo-radio\", {\n styleTexts: [styleText],\n alias: [\"form.general-radio\"],\n})\nclass Radio extends FormItemElementBase {\n #formatOptions: GeneralComplexOption[] | undefined;\n /**\n * 下拉框字段名\n */\n @property() accessor name: string | undefined;\n\n /**\n * 单选框字段说明\n */\n @property() accessor label: string | undefined;\n\n /**\n * 单选框选项表\n * @required\n */\n @property({ attribute: false })\n accessor options: GeneralOption[] | undefined;\n\n /**\n * 单选框当前选中始值\n */\n @property({\n attribute: false,\n })\n accessor value: any | undefined;\n\n /**\n * 是否必填\n */\n @property({ type: Boolean }) accessor required: boolean | undefined;\n\n /**\n * 校验文本信息\n */\n @property({ attribute: false }) accessor message:\n | Record<string, string>\n | undefined;\n\n /**\n * 是否禁用\n */\n @property({ type: Boolean })\n accessor disabled: boolean | undefined;\n\n /**\n * 单选框样式类型\n * @default \"default\"\n */\n @property()\n accessor type: RadioType = \"default\";\n\n /**\n * UI样式\n * @default \"default\"\n */\n @property()\n accessor ui: UIType | undefined;\n\n /**\n * 大小,只对按钮样式生效\n * @default \"medium\"\n */\n @property()\n accessor size: ComponentSize | undefined;\n\n /**\n * 自定义radio的外层样式\n */\n @property({\n attribute: false,\n })\n accessor customStyle: React.CSSProperties | undefined;\n\n /**\n * 自定义radio的内容\n */\n @property({\n attribute: false,\n })\n accessor useBrick: UseSingleBrickConf | undefined;\n\n /**\n * 值变化事件\n */\n @event({ type: \"change\" }) accessor #changeEvent!: EventEmitter<\n GeneralComplexOption | undefined\n >;\n\n /**\n * 选项列表变化事件\n */\n @event({ type: \"options.change\" }) accessor #optionsChange!: EventEmitter<{\n options: {\n label: string;\n value: any;\n [key: string]: any;\n };\n name: string;\n }>;\n\n handleChange = (value: any): void => {\n this.value = value;\n this.#changeEvent.emit(\n this.#formatOptions?.find((item) => item?.value === value)\n );\n };\n\n #handleOptionsChange = (\n options: {\n label: string;\n value: any;\n [key: string]: any;\n },\n name: string\n ): void => {\n this.#optionsChange.emit({ options, name });\n };\n\n render() {\n this.#formatOptions = formatOptions(this.options);\n return (\n <RadioComponent\n curElement={this}\n formElement={this.getFormElement()}\n name={this.name}\n label={this.label}\n useBrick={this.useBrick}\n disabled={this.disabled}\n size={this.size}\n options={this.#formatOptions}\n type={this.type}\n value={this.value}\n required={this.required}\n message={this.message}\n onChange={this.handleChange}\n notRender={this.notRender}\n helpBrick={this.helpBrick}\n labelBrick={this.labelBrick}\n trigger=\"handleChange\"\n optionsChange={this.#handleOptionsChange}\n customStyle={this.customStyle}\n />\n );\n }\n}\n\ninterface RadioComponentProps\n extends RadioProps,\n Omit<FormItemProps, \"type\" | \"ui\"> {\n onChange?: (value: any) => void;\n optionsChange?: (options: any, name: string) => void;\n}\n\nexport function RadioComponent(props: RadioComponentProps) {\n const { name, disabled, type, customStyle, optionsChange, size } = props;\n const [value, setValue] = React.useState(props.value);\n const [options, setOptions] = React.useState(props.options);\n\n React.useEffect(() => {\n setValue(props.value);\n }, [props.value]);\n\n React.useEffect(() => {\n if (!isEqual(options, props.options)) {\n setOptions(props.options);\n optionsChange?.(props.options, name as string);\n }\n }, [name, options, optionsChange, props.options]);\n\n const handleChange = (\n e: React.ChangeEvent | React.MouseEvent,\n option: GeneralComplexOption\n ): void => {\n e.stopPropagation();\n setValue((option as GeneralComplexOption)?.value as any);\n props.onChange?.(option.value);\n };\n\n return (\n <WrappedFormItem exportparts=\"message\" {...pickFormItemProps(props)}>\n <div className=\"radio-group\">\n {options?.map((item: any) => {\n const icon = item.icon;\n const iconStyle: CSSProperties = icon?.iconStyle;\n const key = isBoolean(item.value)\n ? item.value.toString()\n : item.value;\n const isDisabled = item.disabled || disabled;\n return (\n <label\n htmlFor={key}\n style={customStyle}\n className={classNames(\"radio-item\", {\n disabled: isDisabled,\n checked: value === item.value,\n [size || \"medium\"]: type === \"button\",\n })}\n key={key}\n onClick={(e) => !isDisabled && handleChange(e, item)}\n >\n <span className=\"radio\">\n <input\n type=\"radio\"\n name={name}\n disabled={isDisabled}\n checked={value === item.value}\n onChange={(e) => !isDisabled && handleChange(e, item)}\n />\n <span\n className={classNames(\"radio-inner\", {\n checked: value === item.value,\n })}\n ></span>\n </span>\n {type === \"icon\" ? (\n <div className=\"content\">\n {icon && (\n <WrappedGeneralIcon\n {...icon}\n style={{\n fontSize: \"32px\",\n ...iconStyle,\n }}\n />\n )}\n <div>{item.label}</div>\n </div>\n ) : type === \"custom\" ? (\n <div className=\"content\">\n {props.useBrick && (\n <ReactUseBrick\n useBrick={props.useBrick}\n data={item}\n ></ReactUseBrick>\n )}\n </div>\n ) : type === \"icon-circle\" || type === \"icon-square\" ? (\n <div className=\"content\">\n {item.icon && (\n <div\n className={classNames(\"icon\", {\n \"circle-icon\": type === \"icon-circle\",\n \"square-icon\": type === \"icon-square\",\n })}\n >\n <WrappedGeneralIcon\n {...icon}\n style={{\n fontSize: \"46px\",\n ...iconStyle,\n }}\n />\n </div>\n )}\n <span title={item.label}>{item.label}</span>\n </div>\n ) : type === \"button\" ? (\n <div className=\"content\">\n <span>\n {icon && (\n <WrappedGeneralIcon\n {...icon}\n style={{\n fontSize: \"22px\",\n marginRight: \"4px\",\n verticalAlign: \"-0.25em\",\n ...iconStyle,\n }}\n />\n )}\n {item.label}\n </span>\n </div>\n ) : (\n <span className=\"content\">\n {icon && (\n <WrappedGeneralIcon\n {...icon}\n style={{\n fontSize: \"22px\",\n marginRight: \"8px\",\n verticalAlign: \"-0.25em\",\n ...iconStyle,\n }}\n />\n )}\n {item.label}\n </span>\n )}\n </label>\n );\n })}\n </div>\n </WrappedFormItem>\n );\n}\nexport { Radio };\n","import * as React from \"react\";\nconst SvgEmpty = props => <svg xmlns=\"http://www.w3.org/2000/svg\" xmlnsXlink=\"http://www.w3.org/1999/xlink\" width={56} height={53} {...props}><defs><linearGradient id=\"a\" x1=\"5.718%\" x2=\"83.05%\" y1=\"4.311%\" y2=\"88.915%\"><stop offset=\"0%\" stopColor=\"#D4D8E4\" /><stop offset=\"100%\" stopColor=\"#A9B0C4\" /></linearGradient><linearGradient id=\"g\" x1=\"41.823%\" x2=\"8.813%\" y1=\"24.795%\" y2=\"86.427%\"><stop offset=\"0%\" stopColor=\"#CCD0DD\" /><stop offset=\"100%\" stopColor=\"#9DA3B9\" /></linearGradient><filter id=\"b\" width=\"233.4%\" height=\"233.4%\" x=\"-57.2%\" y=\"-47.7%\" filterUnits=\"objectBoundingBox\"><feOffset dx={1} dy={2} in=\"SourceAlpha\" result=\"shadowOffsetOuter1\" /><feGaussianBlur in=\"shadowOffsetOuter1\" result=\"shadowBlurOuter1\" stdDeviation={2} /><feComposite in=\"shadowBlurOuter1\" in2=\"SourceAlpha\" operator=\"out\" result=\"shadowBlurOuter1\" /><feColorMatrix in=\"shadowBlurOuter1\" values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.22 0\" /></filter><filter id=\"e\" width=\"288.7%\" height=\"288.7%\" x=\"-94.4%\" y=\"-121.3%\" filterUnits=\"objectBoundingBox\"><feOffset dy={-2} in=\"SourceAlpha\" result=\"shadowOffsetOuter1\" /><feGaussianBlur in=\"shadowOffsetOuter1\" result=\"shadowBlurOuter1\" stdDeviation={2} /><feColorMatrix in=\"shadowBlurOuter1\" values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.25 0\" /></filter><path id=\"c\" d=\"M23.672 23.607h2.492a4 4 0 0 1 4 4v2.491a4 4 0 0 1-4 4h-2.492a4 4 0 0 1-4-4v-2.491a4 4 0 0 1 4-4\" /><path id=\"f\" d=\"M37.311 12.459a4 4 0 0 1 4 4v3.419l-7.418-7.419z\" /></defs><g fill=\"none\" fillRule=\"evenodd\"><path fill=\"#A6AAC3\" d=\"M39.682 33.967H10.81a2.8 2.8 0 0 0-1.94.782l-5.197 4.999v6.98a5.6 5.6 0 0 0 5.6 5.6H41.22a5.6 5.6 0 0 0 5.6-5.6v-6.98l-5.196-4.999a2.8 2.8 0 0 0-1.942-.782\" /><path fill=\"url(#a)\" d=\"m33.893 12.459 7.418 7.419v22.568a2.8 2.8 0 0 1-2.8 2.8h-26.53a2.8 2.8 0 0 1-2.8-2.8V18.459a6 6 0 0 1 6-6z\" /><use xlinkHref=\"#c\" fill=\"#000\" filter=\"url(#b)\" /><path fill=\"url(#d)\" stroke=\"#FFF\" strokeLinejoin=\"round\" d=\"M26.164 24.107c.966 0 1.841.391 2.475 1.025a3.5 3.5 0 0 1 1.025 2.475v2.491a3.5 3.5 0 0 1-1.025 2.475 3.5 3.5 0 0 1-2.475 1.025h-2.492a3.5 3.5 0 0 1-2.475-1.025 3.5 3.5 0 0 1-1.025-2.475v-2.491a3.5 3.5 0 0 1 1.025-2.475 3.5 3.5 0 0 1 2.475-1.025Z\" /><g transform=\"rotate(180 37.602 16.168)\"><use xlinkHref=\"#f\" fill=\"#000\" filter=\"url(#e)\" /><use xlinkHref=\"#f\" fill=\"url(#g)\" /></g><path fill=\"#D6D8E4\" d=\"M54.164 27.541c.253 0 .459.205.459.459v.918h.918a.459.459 0 1 1 0 .918h-.918v.918a.459.459 0 0 1-.918 0v-.918h-.918a.459.459 0 0 1 0-.918h.918V28c0-.254.205-.459.459-.459M1.377 20.197c.19 0 .344.154.344.344v.574h.574a.459.459 0 1 1 0 .918h-.574v.574a.344.344 0 0 1-.688 0l-.001-.574H.459a.459.459 0 0 1 0-.918h.573v-.574c0-.19.155-.344.345-.344\" opacity={0.3} /><path fill=\"#D6D8E4\" d=\"M24.787 43.53h.014c7.087.143 9.817-3.834 12.785-4.046l.19-.008h9.044v10.052a2.8 2.8 0 0 1-2.63 2.795l-.17.005H6.472l-.17-.005a2.8 2.8 0 0 1-2.63-2.795V39.475h8.126l.144-.004c2.485.004 5.214 3.898 12.83 4.06z\" /><path fill=\"#D6D8E4\" d=\"M13.77 2.2s2.308-.555 2.962-2.2c.943 1.35 1.429 1.933 2.547 2.189-1.522.453-2.183.963-2.704 2.401-.598-1.695-1.142-1.914-2.805-2.39\" opacity={0.5} /><path fill=\"#D6D8E4\" d=\"M41.311 6.64S47.464 5.194 49.21.917c2.514 3.508 3.81 5.025 6.791 5.691-4.059 1.18-5.822 2.503-7.21 6.243-1.594-4.406-3.045-4.976-7.479-6.213\" opacity={0.8} /></g></svg>;\nexport default SvgEmpty;","import React, {\n useCallback,\n useEffect,\n useLayoutEffect,\n useMemo,\n useRef,\n useState,\n} from \"react\";\nimport { createDecorators, EventEmitter } from \"@next-core/element\";\nimport { wrapBrick } from \"@next-core/react-element\";\nimport { FormItemElementBase, pickFormItemProps } from \"@next-shared/form\";\nimport type { GeneralComplexOption, GeneralOption } from \"../interface.js\";\nimport styleText from \"./index.shadow.css\";\nimport classNames from \"classnames\";\nimport \"@next-core/theme\";\nimport type { FormItem, FormItemProps } from \"../form-item/index.jsx\";\nimport { formatOptions } from \"../utils/formatOptions.js\";\nimport type {\n Tag,\n TagProps,\n TagMapEvents,\n TagEvents,\n} from \"@next-bricks/basic/tag\";\nimport type {\n GeneralIcon,\n GeneralIconProps,\n} from \"@next-bricks/icons/general-icon\";\nimport { isEmpty, groupBy, isNil, debounce } from \"lodash\";\nimport { UseSingleBrickConf } from \"@next-core/types\";\nimport { ReactUseBrick } from \"@next-core/react-runtime\";\nimport { handleHttpError, fetchByProvider } from \"@next-core/runtime\";\nimport Empty from \"./empty.svg\";\n\ninterface UseBackendConf {\n provider: string;\n args: any[] | ((...args: any[]) => any[]);\n transform?: (data: any) => void;\n}\n\nexport type Placement =\n | \"top\"\n | \"top-start\"\n | \"top-end\"\n | \"bottom\"\n | \"bottom-start\"\n | \"bottom-end\"\n | \"right\"\n | \"right-start\"\n | \"right-end\"\n | \"left\"\n | \"left-start\"\n | \"left-end\";\n\nexport type Sync = \"width\" | \"height\" | \"both\";\n\nexport interface SlPopupProps {\n active?: boolean;\n placement?: Placement;\n strategy?: \"absolute\" | \"fixed\";\n distance?: number;\n sync?: Sync;\n flip?: boolean;\n}\n\nexport interface SlPopupElement extends HTMLElement, SlPopupProps {}\n\nexport const WrappedSlPopup = wrapBrick<SlPopupElement, SlPopupProps>(\n \"sl-popup\"\n);\n\nconst WrappedFormItem = wrapBrick<FormItem, FormItemProps>(\"eo-form-item\");\n\nconst WrappedTag = wrapBrick<Tag, TagProps, TagEvents, TagMapEvents>(\"eo-tag\", {\n onCheck: \"check\",\n onClose: \"close\",\n});\n\nconst WrappedIcon = wrapBrick<GeneralIcon, GeneralIconProps>(\"eo-icon\");\n\nconst isSearchable = (value: UseBackendConf): value is UseBackendConf => {\n return typeof value?.provider === \"string\";\n};\n\nconst applyArgs = (\n args: any[] | ((query: string) => any[]),\n query: string\n): any => {\n if (Array.isArray(args)) {\n return args.map((arg) => applyArgs(arg, query));\n }\n if (typeof args === \"function\") {\n return (args as (query: string) => any[]).call(null, query);\n }\n\n return args;\n};\n\ntype RequestStatus = \"loading\" | \"success\" | \"error\";\n\nexport interface SelectProps extends FormItemProps {\n value?: any;\n options: GeneralComplexOption[];\n placeholder?: string;\n mode?: \"tags\" | \"multiple\";\n tokenSeparators?: string[];\n maxTagCount?: number;\n groupBy?: string;\n suffix?: { useBrick: UseSingleBrickConf };\n fields?: { label?: string; value?: string };\n useBackend?: UseBackendConf & {\n onValueChangeArgs?: any[] | ((...args: any[]) => any[]);\n // emptyConfig?: Partial<Record<RequestStatus, EasyopsEmptyProps>>;\n };\n debounceSearchDelay?: number;\n clearable?: boolean;\n disabled?: boolean;\n inputStyle?: React.CSSProperties;\n dropdownStyle?: React.CSSProperties;\n dropdownHoist?: boolean;\n validateState?: string;\n onChange?: (value: any, options: GeneralComplexOption[]) => void;\n onValueChange?: (value: any) => void;\n optionsChange?: (options: any, name: string) => void;\n onSelectFocus?: () => void;\n onSearch?: (value: string) => void;\n}\n\nconst { defineElement, property, event } = createDecorators();\n\n/**\n * 通用下拉选择构件\n * @author sailorshe\n * @category form-input-basic\n */\n@defineElement(\"eo-select\", {\n styleTexts: [styleText],\n alias: [\"form.general-select\"],\n})\nclass Select extends FormItemElementBase {\n /**\n * 字段名称\n */\n @property() accessor name: string | undefined;\n\n /**\n * 占位说明\n */\n @property() accessor placeholder: string | undefined;\n\n /**\n * 字段文本\n */\n @property() accessor label: string | undefined;\n\n /**\n * 选项列表\n * @required\n */\n @property({ attribute: false })\n accessor options!: GeneralComplexOption[];\n\n /**\n * 值\n */\n @property({\n attribute: false,\n })\n accessor value: any | undefined;\n\n /**\n * 是否必填\n */\n @property({ type: Boolean }) accessor required: boolean | undefined;\n\n /**\n * 校验文本信息\n */\n @property({ attribute: false }) accessor message:\n | Record<string, string>\n | undefined;\n\n /**\n * 是否禁用\n */\n @property({ type: Boolean })\n accessor disabled: boolean | undefined;\n\n /**\n * 类型\n */\n @property()\n accessor mode: \"tags\" | \"multiple\" | undefined;\n\n /**\n * 自动分词的分隔符,仅在 mode=\"tags\" 时生效\n */\n @property({\n attribute: false,\n })\n accessor tokenSeparators: string[] | undefined;\n\n /**\n * 最多显示多少个 tag, 剩余的 tag 将被隐藏\n */\n @property()\n accessor maxTagCount: number | undefined;\n\n /**\n * 分组字段\n */\n @property()\n accessor groupBy: string | undefined;\n\n /**\n */\n @property({\n attribute: false,\n })\n accessor suffix: { useBrick: UseSingleBrickConf } | undefined;\n\n /**\n * 是否支持清除\n * @default true\n */\n @property({ type: Boolean })\n accessor clearable: boolean | undefined;\n\n /**\n * 列表指定字段作为 label 和 value\n */\n @property({\n attribute: false,\n })\n accessor fields: { label?: string; value?: string } | undefined;\n\n /**\n * 后端搜索\n */\n @property({\n attribute: false,\n })\n accessor useBackend: UseBackendConf | undefined;\n\n /**\n * 设置时,同时对 useBackend 和 search 事件进行防抖。\n * 未设置时,useBackend 有默认的 300ms 防抖。\n */\n @property({\n type: Number,\n })\n accessor debounceSearchDelay: number | undefined;\n\n /**\n * 输入框样式\n */\n @property({\n attribute: false,\n })\n accessor inputStyle: React.CSSProperties | undefined;\n\n /**\n * 下拉框样式\n */\n @property({\n attribute: false,\n })\n accessor dropdownStyle: React.CSSProperties | undefined;\n\n /**\n * 下拉框是否使用固定定位防止内容被裁切\n */\n @property({ type: Boolean })\n accessor dropdownHoist: boolean | undefined;\n\n /**\n * 下拉选择事件\n */\n @event({ type: \"change\" }) accessor #changeEvent!: EventEmitter<{\n value: string | string[];\n options: GeneralComplexOption[];\n }>;\n\n /**\n * 下拉框search事件\n */\n @event({ type: \"search\" }) accessor #searchEvent!: EventEmitter<{\n value: string;\n }>;\n\n /**\n * 下拉框focus事件\n *\n * 注:之前事件类型为 \"focus\",这和原生事件冲突,可能导致多次触发,现改为 \"select.focus\"\n */\n @event({ type: \"select.focus\" }) accessor #focusEvent!: EventEmitter<void>;\n\n /**\n * 选项列表变化事件\n */\n @event({ type: \"options.change\" }) accessor #optionsChange!: EventEmitter<{\n options: {\n label: string;\n value: any;\n [key: string]: any;\n };\n name: string;\n }>;\n\n handleChange = (\n value: string | string[],\n options: GeneralComplexOption[]\n ): void => {\n this.value = value;\n\n this.#changeEvent.emit({\n value,\n options,\n });\n };\n\n #handleOptionsChange = (\n options: {\n label: string;\n value: any;\n [key: string]: any;\n },\n name: string\n ): void => {\n Promise.resolve().then(() => {\n this.#optionsChange.emit({ options, name });\n });\n };\n\n handleSearch = (value: string) => {\n this.#searchEvent.emit({\n value,\n });\n };\n\n #handleSelectFocus = () => {\n this.#focusEvent.emit();\n };\n\n render() {\n return (\n <SelectComponent\n curElement={this}\n formElement={this.getFormElement()}\n name={this.name}\n label={this.label}\n value={this.value}\n disabled={this.disabled}\n placeholder={this.placeholder}\n required={this.required}\n mode={this.mode}\n tokenSeparators={this.tokenSeparators}\n maxTagCount={this.maxTagCount}\n groupBy={this.groupBy}\n suffix={this.suffix}\n fields={this.fields}\n useBackend={this.useBackend}\n debounceSearchDelay={this.debounceSearchDelay}\n clearable={this.clearable}\n trigger=\"handleChange\"\n inputStyle={this.inputStyle}\n dropdownStyle={this.dropdownStyle}\n dropdownHoist={this.dropdownHoist}\n validateState={this.validateState}\n notRender={this.notRender}\n helpBrick={this.helpBrick}\n labelBrick={this.labelBrick}\n options={this.options}\n onChange={this.handleChange}\n optionsChange={this.#handleOptionsChange}\n onSearch={this.handleSearch}\n onSelectFocus={this.#handleSelectFocus}\n />\n );\n }\n}\n\nexport function SelectComponent(props: SelectProps) {\n const {\n curElement,\n name,\n disabled,\n mode,\n tokenSeparators,\n maxTagCount,\n suffix,\n fields,\n useBackend,\n debounceSearchDelay,\n clearable = true,\n inputStyle,\n dropdownStyle,\n dropdownHoist,\n placeholder,\n validateState,\n optionsChange,\n onChange,\n onSelectFocus,\n onValueChange,\n onSearch,\n } = props;\n\n const debouncedOnSearch = useMemo(() => {\n return debounceSearchDelay\n ? debounce(onSearch!, debounceSearchDelay)\n : onSearch;\n }, [debounceSearchDelay, onSearch]);\n\n const multiple = useMemo(\n () => mode && [\"multiple\", \"tags\"].includes(mode),\n [mode]\n );\n const selectRef = useRef<HTMLDivElement>(null);\n const inputSpanRef = useRef<HTMLSpanElement>(null);\n const shouldTriggerOnValueChangeArgs = useRef(true);\n const [inputValue, setInputValue] = useState<string>(\"\");\n const [inputWidth, setInputWidth] = useState<number>();\n const [value, setValue] = useState<any>(mode ? [] : undefined);\n const [requestStatus, setRequestStatus] = useState<RequestStatus>();\n const [options, setOptions] = useState<any[]>(\n formatOptions(props.options, fields) ?? []\n );\n const [isDropHidden, setIsDropHidden] = useState<boolean>(true);\n const [isFocused, setIsFocused] = useState<boolean>(false);\n const [selectedOptions, setSelectedOptions] = useState<\n GeneralComplexOption[]\n >([]);\n const [renderOptions, setRenderOptions] = useState<any[]>([]);\n const [focusOptionItem, setFocusOptionItem] = useState<GeneralComplexOption>(\n {} as GeneralComplexOption\n );\n const inputRef = useRef<HTMLInputElement>(null);\n\n useEffect(() => {\n setOptions(\n formatOptions(\n (props.options ?? []).concat(\n mode === \"tags\" && props.value ? props.value : []\n ),\n fields\n )\n );\n }, [props.options, fields, props.value, mode]);\n\n const handleSelectorClick = useCallback(() => {\n if (!value) {\n setIsDropHidden(false);\n setIsFocused(true);\n inputRef.current && inputRef.current.focus();\n onSelectFocus?.();\n } else if (!disabled) {\n setIsDropHidden(!isDropHidden);\n setIsFocused(true);\n inputRef.current && inputRef.current.focus();\n onSelectFocus?.();\n }\n }, [disabled, isDropHidden, value, onSelectFocus]);\n\n const handleChange = useCallback(\n (option: GeneralComplexOption<any>): void => {\n shouldTriggerOnValueChangeArgs.current = false;\n let newValue;\n if (multiple) {\n newValue = (value ?? []).includes(option.value)\n ? (value as string[]).filter((item) => item !== option.value)\n : (((value as any[]) ?? []).concat(option.value) as string[]);\n } else {\n newValue = option.value;\n }\n const getSelectOptions = () => {\n const hadSelected = selectedOptions.find(\n (item) => item.value === option.value\n );\n return hadSelected\n ? selectedOptions.filter((item) => item.value !== option.value)\n : selectedOptions.concat(option);\n };\n const newOptions = multiple ? getSelectOptions() : [option];\n setSelectedOptions(newOptions);\n setValue(newValue);\n onChange?.(newValue, newOptions);\n onValueChange?.(newValue);\n setIsDropHidden(!multiple);\n setFocusOptionItem(option);\n !multiple && setIsFocused(false);\n multiple && inputRef.current && inputRef.current.focus();\n setInputValue(\"\");\n },\n [multiple, onChange, onValueChange, selectedOptions, value]\n );\n\n const handleMultipleItemClose = useCallback(\n (closeValue: string | number | boolean) => {\n const newOptions = selectedOptions.filter(\n (item) => item.value !== closeValue\n );\n setSelectedOptions(newOptions);\n onChange?.(\n newOptions.map((item) => item.value),\n newOptions\n );\n },\n [onChange, selectedOptions]\n );\n\n const handleClear = (e: React.MouseEvent): void => {\n e.stopPropagation();\n setSelectedOptions([]);\n onChange?.(undefined, []);\n };\n\n const handleSearchQuery = useCallback(\n async (value = \"\", type: \"valueChange\" | \"search\") => {\n if (useBackend && isSearchable(useBackend)) {\n const {\n provider,\n args,\n onValueChangeArgs,\n transform = (data) => data,\n } = useBackend;\n try {\n setRequestStatus(\"loading\");\n const actualArgs = applyArgs(\n type === \"search\" ? args : onValueChangeArgs!,\n value\n );\n const result = await fetchByProvider(provider, actualArgs);\n if (isNil(result)) return;\n const transformedData = transform(result);\n const actualData = formatOptions(\n transformedData as unknown as GeneralOption[],\n fields as any\n );\n setRequestStatus(\"success\");\n setOptions(actualData);\n // 值设置后,需要回填\n if (type === \"valueChange\") {\n setSelectedOptions(\n actualData.filter((item) =>\n Array.isArray(props.value)\n ? props.value.includes(item.value)\n : item.value === props.value\n )\n );\n }\n } catch (e) {\n setRequestStatus(\"error\");\n handleHttpError(e);\n }\n }\n },\n [useBackend, fields, props.value]\n );\n\n const handleDebounceBackendSearch = useMemo(() => {\n return debounce(handleSearchQuery, debounceSearchDelay || 300);\n }, [debounceSearchDelay, handleSearchQuery]);\n\n const computedOptions = React.useMemo((): GeneralComplexOption[] => {\n return (mode === \"tags\" && inputValue ? [inputValue] : [])\n .map((item) => ({\n key: item,\n label: item,\n value: item,\n }))\n .concat(\n selectedOptions.filter(\n (selected) =>\n !options.find((option) => option.value === selected.value)\n ) as any\n )\n .concat(options);\n }, [inputValue, mode, options, selectedOptions]);\n\n useEffect(() => {\n const computedValue =\n multiple && props.value && !Array.isArray(props.value)\n ? [props.value]\n : props.value;\n setValue(computedValue);\n // 设置回填option\n setSelectedOptions(\n computedValue\n ? computedOptions.filter((item) =>\n multiple\n ? computedValue.includes(item.value)\n : item.value === props.value\n )\n : []\n );\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [props.value, options]);\n\n useEffect(() => {\n optionsChange?.(computedOptions, name as string);\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [computedOptions]);\n\n useEffect(() => {\n props?.useBackend?.onValueChangeArgs &&\n shouldTriggerOnValueChangeArgs.current &&\n !(Array.isArray(props.value)\n ? props.value.length === 0\n : isNil(props.value)) &&\n handleSearchQuery(props.value, \"valueChange\");\n shouldTriggerOnValueChangeArgs.current = true;\n }, [handleSearchQuery, props?.useBackend?.onValueChangeArgs, props.value]);\n\n const handleInputChange = useCallback(\n (e: React.ChangeEvent<HTMLInputElement>) => {\n e.stopPropagation();\n const value = e.target.value;\n if (mode === \"tags\" && value) {\n const matchToken = tokenSeparators?.includes(value[value.length - 1]);\n const customValue =\n value && matchToken ? value.substring(0, value.length - 1) : value;\n if (matchToken) {\n handleChange({\n key: customValue,\n label: customValue,\n value: customValue,\n });\n } else {\n setInputValue(value);\n }\n } else {\n setInputValue(value);\n setIsDropHidden(false);\n debouncedOnSearch!(value);\n }\n handleDebounceBackendSearch(value, \"search\");\n },\n [\n handleChange,\n handleDebounceBackendSearch,\n mode,\n debouncedOnSearch,\n tokenSeparators,\n ]\n );\n\n const handleKeydown = useCallback(\n (e: KeyboardEvent): void => {\n if (isFocused) {\n if (e.code === \"Enter\") {\n focusOptionItem && handleChange(focusOptionItem);\n }\n if (\n e.code === \"Backspace\" &&\n multiple &&\n inputValue === \"\" &&\n selectedOptions?.length\n ) {\n selectedOptions.pop();\n setSelectedOptions([...selectedOptions]);\n value.pop();\n setValue([...value]);\n }\n }\n if (!isDropHidden && focusOptionItem) {\n if (e.code === \"ArrowDown\") {\n const index = renderOptions.findIndex(\n (item) => item.value === focusOptionItem.value\n );\n setFocusOptionItem(\n renderOptions[\n index + 1 > renderOptions.length - 1\n ? renderOptions.length - 1\n : index + 1\n ]\n );\n }\n if (e.code === \"ArrowUp\") {\n const index = renderOptions.findIndex(\n (item) => item.value === focusOptionItem.value\n );\n setFocusOptionItem(renderOptions[index - 1 < 0 ? 0 : index - 1]);\n }\n }\n },\n [\n isFocused,\n multiple,\n inputValue,\n selectedOptions,\n isDropHidden,\n focusOptionItem,\n handleChange,\n value,\n renderOptions,\n ]\n );\n\n const isEmptyValue = useMemo(() => {\n return typeof selectedOptions === \"object\"\n ? isEmpty(selectedOptions)\n : selectedOptions === undefined;\n }, [selectedOptions]);\n\n useLayoutEffect(() => {\n const renderOptions = computedOptions.filter((item) =>\n inputValue\n ? (item.label as string)\n .toLocaleUpperCase()\n .includes(inputValue.toLocaleUpperCase())\n : true\n );\n setRenderOptions(renderOptions);\n setFocusOptionItem(renderOptions?.[0]);\n\n if (inputSpanRef.current) {\n setInputWidth(\n inputSpanRef.current?.offsetWidth === 0\n ? 4\n : inputSpanRef.current?.offsetWidth\n );\n }\n }, [computedOptions, handleChange, inputValue, mode, tokenSeparators]);\n\n useEffect(() => {\n const handleDocumentClick = (e: MouseEvent) => {\n e.stopPropagation();\n const path = e.composedPath();\n if (curElement && path.includes(curElement)) return;\n setIsFocused(false);\n setIsDropHidden(true);\n setInputValue(\"\");\n };\n document.addEventListener(\"keydown\", handleKeydown);\n document.addEventListener(\"click\", handleDocumentClick);\n\n return () => {\n document.removeEventListener(\"keydown\", handleKeydown);\n document.removeEventListener(\"click\", handleDocumentClick);\n };\n }, [curElement, handleKeydown]);\n\n const renderSelector = useMemo(() => {\n let tagList: GeneralComplexOption[] = selectedOptions;\n if (maxTagCount) {\n const ellipsisInfo =\n selectedOptions.length - maxTagCount > 0\n ? {\n label: `+${selectedOptions.length - maxTagCount}`,\n key: \"$$key\",\n value: \"\",\n closable: false,\n }\n : null;\n tagList = selectedOptions.slice(0, maxTagCount);\n ellipsisInfo && tagList.push(ellipsisInfo);\n }\n const allOptions = computedOptions.reduce(\n (pre: any, cur: any) =>\n cur.options ? [...pre, ...cur.options] : [...pre, cur],\n []\n );\n\n const renderLabel = (option: GeneralComplexOption): React.ReactNode => {\n return (\n <div className=\"label\">\n <span className=\"text\">\n {multiple ? (\n <WrappedTag\n key={option.value as number}\n color={disabled ? \"#ddd\" : undefined}\n closable={option.closable ?? true}\n checkable={false}\n onClose={() => handleMultipleItemClose(option.value)}\n >\n {option.label}\n {multiple && suffix?.useBrick && (\n <ReactUseBrick useBrick={suffix.useBrick} data={option} />\n )}\n </WrappedTag>\n ) : (\n option.label\n )}\n </span>\n {!multiple && suffix?.useBrick && (\n <ReactUseBrick useBrick={suffix.useBrick} data={option} />\n )}\n </div>\n );\n };\n\n const renderMultipleLabel = (\n list: Array<GeneralComplexOption>\n ): React.ReactNode => {\n return list.map((item) => {\n let option: GeneralComplexOption;\n if (typeof item === \"object\") {\n option = item;\n } else {\n option =\n allOptions.find((option: any) => option.value === item) ??\n ({} as GeneralComplexOption);\n option.closeable = !disabled && option.closeable;\n }\n return renderLabel(option);\n });\n };\n\n return (\n <div\n className={classNames({\n \"selected-item\": multiple,\n \"select-single-item\": !multiple,\n })}\n style={\n isEmptyValue ? { color: \"var(--antd-input-placeholder-color)\" } : {}\n }\n >\n {selectedOptions?.length\n ? multiple\n ? renderMultipleLabel(tagList)\n : renderLabel(selectedOptions[0])\n : isFocused || inputValue\n ? \"\"\n : placeholder}\n </div>\n );\n }, [\n computedOptions,\n disabled,\n handleMultipleItemClose,\n inputValue,\n isEmptyValue,\n isFocused,\n maxTagCount,\n multiple,\n placeholder,\n selectedOptions,\n suffix,\n ]);\n\n const Options = useMemo(() => {\n const getSelectOption = (item: any): React.ReactNode => (\n <div\n key={item.value?.toString()}\n className={classNames(\"select-item\", \"select-item-option\", {\n disabled: item.disabled,\n \"select-option-hover\": item.value === focusOptionItem.value,\n \"select-option-selected\":\n typeof value !== \"object\"\n ? value === item?.value\n : (value as any[])?.includes(item.value),\n })}\n onClick={() => !item.disabled && handleChange(item)}\n onMouseOver={() => setFocusOptionItem(item)}\n onMouseLeave={() => setFocusOptionItem({} as any)}\n >\n <div className=\"select-item-option-content\">\n <div className=\"option\">\n <div className=\"text-container\">\n <span className=\"label\">{item.label}</span>\n {item.caption && <span className=\"caption\">{item.caption}</span>}\n </div>\n {suffix?.useBrick && (\n <ReactUseBrick useBrick={suffix.useBrick} data={item} />\n )}\n </div>\n {multiple && (\n <div className=\"is-checked\">\n <WrappedIcon\n {...{\n lib: \"antd\",\n icon: \"check\",\n theme: \"outlined\",\n }}\n />\n </div>\n )}\n </div>\n </div>\n );\n\n const renderGroupOption = (): React.ReactNode => {\n const optsGroup = Object.entries(groupBy(renderOptions, props.groupBy));\n\n return optsGroup.map(([group, options], index) =>\n group !== \"undefined\" ? (\n <div key={index} className=\"select-group-wrapper\">\n <div className=\"select-group-label\">{group}</div>\n {options.map((item) => getSelectOption(item))}\n </div>\n ) : (\n options.map((item) => getSelectOption(item))\n )\n );\n };\n\n const renderOption = () =>\n renderOptions.map((item: any) => {\n return getSelectOption(item);\n });\n\n return renderOptions.length > 0 ? (\n props.groupBy ? (\n renderGroupOption()\n ) : (\n renderOption()\n )\n ) : (\n <div className=\"empty-tips\">\n <Empty />\n <span>暂无数据</span>\n </div>\n );\n }, [\n renderOptions,\n props.groupBy,\n focusOptionItem,\n value,\n suffix,\n multiple,\n handleChange,\n ]);\n\n return (\n <WrappedFormItem exportparts=\"message\" {...pickFormItemProps(props)}>\n <div\n className={classNames(\"select\", {\n \"select-disabled\": disabled,\n \"select-allow-clear\": clearable,\n \"select-single\": !multiple,\n \"select-multiple\": multiple,\n })}\n style={inputStyle}\n ref={selectRef}\n >\n <WrappedSlPopup\n active={!isDropHidden}\n placement=\"bottom\"\n strategy={dropdownHoist ? \"fixed\" : \"absolute\"}\n distance={5}\n sync=\"width\"\n flip\n className=\"select-dropdown-popup\"\n data-testid=\"select-dropdown-popup\"\n >\n <div\n className={classNames(\"select-selector\", {\n \"selector-focused\": isFocused,\n \"is-error\": validateState === \"error\",\n })}\n slot=\"anchor\"\n onClick={handleSelectorClick}\n >\n <div className=\"select-selection-overflow\">\n {multiple && renderSelector}\n <div className=\"input-item\">\n <div className=\"select-selection-search\">\n <span\n style={{ position: \"absolute\", opacity: \"0\" }}\n ref={inputSpanRef}\n >\n {inputValue}\n </span>\n <input\n style={{ width: inputWidth }}\n type=\"text\"\n value={inputValue}\n ref={inputRef}\n className=\"select-selection-search-input\"\n onChange={handleInputChange}\n />\n </div>\n {!multiple ? !inputValue && renderSelector : null}\n </div>\n </div>\n <span className=\"select-arrow\">\n {!isEmptyValue && clearable ? (\n <WrappedIcon\n className=\"close-btn\"\n lib=\"antd\"\n icon=\"close-circle\"\n theme=\"filled\"\n onClick={(e) => handleClear(e)}\n />\n ) : (\n <span\n className={classNames(\n \"anticon\",\n \"anticon-down \",\n \"ant-select-suffix\",\n {\n focus: isFocused,\n }\n )}\n >\n <WrappedIcon icon=\"down\" lib=\"antd\" theme=\"outlined\" />\n </span>\n )}\n </span>\n </div>\n <div className=\"select-dropdown dropdown-list\" style={dropdownStyle}>\n {requestStatus === \"loading\" ? (\n <div className=\"dropdown-list-loading-container\">\n <WrappedIcon\n {...{\n icon: \"loading\",\n lib: \"antd\",\n theme: \"outlined\",\n spinning: true,\n }}\n />\n </div>\n ) : (\n <div className=\"dropdown-inner\">{Options}</div>\n )}\n </div>\n </WrappedSlPopup>\n </div>\n </WrappedFormItem>\n );\n}\n\nexport { Select };\n","import React from \"react\";\nimport { createDecorators, EventEmitter } from \"@next-core/element\";\nimport { wrapBrick } from \"@next-core/react-element\";\nimport { FormItemElementBase, pickFormItemProps } from \"@next-shared/form\";\nimport styleText from \"./index.shadow.css\";\nimport type { FormItem, FormItemProps } from \"../form-item/index.js\";\nimport type { Button, ButtonProps } from \"@next-bricks/basic/button\";\nimport type { ButtonType } from \"../interface.js\";\n\nconst WrappedFormItem = wrapBrick<FormItem, FormItemProps>(\"eo-form-item\");\nconst WrappedButton = wrapBrick<Button, ButtonProps>(\"eo-button\");\n\ninterface SubmitButtonsProps extends FormItemProps {\n curElement: HTMLElement;\n submitText?: string;\n submitType?: ButtonType;\n submitDisabled?: boolean;\n cancelText?: string;\n cancelType?: ButtonType;\n onSubmitClick?: (event: React.MouseEvent) => void;\n onCancelClick?: (event: React.MouseEvent) => void;\n}\n\nconst { defineElement, property, event } = createDecorators();\n\n/**\n * 表单提交按钮\n * @author zhendonghuang\n * @category form-input-basic\n */\n@defineElement(\"eo-submit-buttons\", {\n styleTexts: [styleText],\n alias: [\"form.submit-buttons\"],\n})\nclass SubmitButtons extends FormItemElementBase {\n /**\n * 提交按钮的文字\n * @default \"提交\"\n */\n @property() accessor submitText: string = \"提交\";\n\n /**\n * 取消按钮的文字,不设置则不显示取消按钮\n */\n @property()\n accessor cancelText: string | undefined;\n\n /**\n * 点击确定按钮后自动禁用\n */\n @property({ type: Boolean })\n accessor disableAfterClick: boolean | undefined;\n\n /**\n * 禁用提交按钮\n */\n @property({ type: Boolean }) accessor submitDisabled: boolean | undefined;\n\n /**\n * 提交按钮类型\n */\n @property() accessor submitType: ButtonType | undefined;\n\n /**\n * 取消按钮类型\n */\n @property() accessor cancelType: ButtonType | undefined;\n\n /**\n * 点击提交按钮触发的事件\n */\n @event({ type: \"submit\" }) accessor #submitEvent!: EventEmitter<void>;\n\n /**\n * 点击取消按钮触发的事件\n */\n @event({ type: \"cancel\" }) accessor #cancelEvent!: EventEmitter<void>;\n\n private _handleSubmitClick = (): void => {\n Promise.resolve().then(() => {\n this.#submitEvent.emit();\n if (this.getFormElement()) {\n (this.getFormElement() as any).validate();\n }\n if (this.disableAfterClick) {\n this.submitDisabled = true;\n }\n });\n };\n\n private _handleCancelClick = (): void => {\n Promise.resolve().then(() => {\n this.#cancelEvent.emit();\n });\n };\n\n render() {\n return (\n <ButtonsComponent\n formElement={this.getFormElement()}\n curElement={this}\n submitDisabled={this.submitDisabled}\n submitText={this.submitText}\n submitType={this.submitType}\n cancelText={this.cancelText}\n cancelType={this.cancelType}\n onCancelClick={this._handleCancelClick}\n onSubmitClick={this._handleSubmitClick}\n />\n );\n }\n}\n\nexport function ButtonsComponent(props: SubmitButtonsProps) {\n return (\n <WrappedFormItem exportparts=\"message\" {...pickFormItemProps(props)}>\n {props.submitText && (\n <WrappedButton\n className={\"submitBtn\"}\n type={props.submitType || \"primary\"}\n onClick={props.onSubmitClick}\n disabled={props.submitDisabled}\n >\n {props.submitText}\n </WrappedButton>\n )}\n {props.cancelText && (\n <WrappedButton\n data-test-id=\"cancelBtn\"\n type={props.cancelType || \"text\"}\n onClick={props.onCancelClick}\n >\n {props.cancelText}\n </WrappedButton>\n )}\n </WrappedFormItem>\n );\n}\nexport { SubmitButtons };\n","// This icon file is generated automatically.\nvar CaretRightOutlined = { \"icon\": { \"tag\": \"svg\", \"attrs\": { \"viewBox\": \"0 0 1024 1024\", \"focusable\": \"false\" }, \"children\": [{ \"tag\": \"path\", \"attrs\": { \"d\": \"M715.8 493.5L335 165.1c-14.2-12.2-35-1.2-35 18.5v656.8c0 19.7 20.8 30.7 35 18.5l380.8-328.4c10.9-9.4 10.9-27.6 0-37z\" } }] }, \"name\": \"caret-right\", \"theme\": \"outlined\" };\nexport default CaretRightOutlined;\n","import _extends from \"@babel/runtime/helpers/esm/extends\";\n// GENERATE BY ./scripts/generate.ts\n// DON NOT EDIT IT MANUALLY\n\nimport * as React from 'react';\nimport CaretRightOutlinedSvg from \"@ant-design/icons-svg/es/asn/CaretRightOutlined\";\nimport AntdIcon from \"../components/AntdIcon\";\nvar CaretRightOutlined = function CaretRightOutlined(props, ref) {\n return /*#__PURE__*/React.createElement(AntdIcon, _extends({}, props, {\n ref: ref,\n icon: CaretRightOutlinedSvg\n }));\n};\n\n/**![caret-right](data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTAiIGhlaWdodD0iNTAiIGZpbGw9IiNjYWNhY2EiIHZpZXdCb3g9IjAgMCAxMDI0IDEwMjQiIGZvY3VzYWJsZT0iZmFsc2UiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PHBhdGggZD0iTTcxNS44IDQ5My41TDMzNSAxNjUuMWMtMTQuMi0xMi4yLTM1LTEuMi0zNSAxOC41djY1Ni44YzAgMTkuNyAyMC44IDMwLjcgMzUgMTguNWwzODAuOC0zMjguNGMxMC45LTkuNCAxMC45LTI3LjYgMC0zN3oiIC8+PC9zdmc+) */\nvar RefIcon = /*#__PURE__*/React.forwardRef(CaretRightOutlined);\nif (process.env.NODE_ENV !== 'production') {\n RefIcon.displayName = 'CaretRightOutlined';\n}\nexport default RefIcon;","import React, { useEffect, useState, useMemo } from \"react\";\nimport { createDecorators, type EventEmitter } from \"@next-core/element\";\nimport { wrapBrick } from \"@next-core/react-element\";\nimport classNames from \"classnames\";\nimport \"@next-core/theme\";\nimport styleText from \"./checkbox.shadow.css\";\nimport type { FormItem, FormItemProps } from \"../form-item/index.js\";\nimport { formatOptions } from \"../utils/formatOptions.js\";\nimport { intersection, isEqual, uniq } from \"lodash\";\nimport type {\n GeneralIcon,\n GeneralIconProps,\n} from \"@next-bricks/icons/general-icon\";\nimport { FormItemElementBase, pickFormItemProps } from \"@next-shared/form\";\nimport { CaretRightOutlined } from \"@ant-design/icons\";\n\nconst { defineElement, property, event } = createDecorators();\n\nconst WrappedFormItem = wrapBrick<FormItem, FormItemProps>(\"eo-form-item\");\nconst WrappedIcon = wrapBrick<GeneralIcon, GeneralIconProps>(\"eo-icon\");\n\nexport type CheckboxType = \"default\" | \"icon\";\n\nexport declare type CheckboxValueType = string | number | boolean;\n\nexport interface CheckboxOptionType {\n label: React.ReactNode;\n value: any;\n style?: React.CSSProperties;\n disabled?: boolean;\n checkboxColor?: string;\n [propName: string]: any;\n}\n\nexport interface MenuIcon {\n [propName: string]: any;\n}\n\nexport interface OptionGroup {\n name: string;\n key: string;\n options: CheckboxOptionType[];\n}\n\nexport interface CheckboxProps extends FormItemProps {\n options?: CheckboxOptionType[];\n label?: string;\n value?: CheckboxValueType[];\n disabled?: boolean;\n type?: CheckboxType;\n isCustom?: boolean;\n isGroup?: boolean;\n optionGroups?: OptionGroup[];\n onChange?: (value: CheckboxValueType[]) => void;\n optionsChange?: (options: CheckboxOptionType[], name: string) => void;\n}\n\n/**\n * 表单复选框构件\n * @author derrickma\n * @category form-input-basic\n */\n@defineElement(\"eo-checkbox\", {\n styleTexts: [styleText],\n alias: [\"form.general-checkbox\"],\n})\nclass Checkbox extends FormItemElementBase {\n /**\n * 字段名称\n */\n @property()\n accessor name: string | undefined;\n\n /**\n * 字段说明\n */\n @property()\n accessor label: string | undefined;\n /**\n * 值\n */\n @property({ attribute: false })\n accessor value: CheckboxValueType[] | undefined;\n\n /**\n * 多选框选项表\n * @required\n */\n @property({ attribute: false })\n accessor options: CheckboxOptionType[] = [];\n\n /**\n * 类型\n * @default \"default\"\n */\n @property()\n accessor type: CheckboxType = \"default\";\n\n /**\n * 是否禁用\n */\n @property({ type: Boolean })\n accessor disabled: boolean | undefined;\n\n /**\n * 是否为自定义\n * @default false\n */\n @property({ type: Boolean })\n accessor isCustom: boolean = false;\n\n /**\n * 是否必填\n */\n @property({ type: Boolean })\n accessor required: boolean | undefined;\n\n /**\n * 校验文本\n */\n @property({ attribute: false })\n accessor message: Record<string, string> | undefined;\n\n /**\n * 是否为复选框,为true时,则可设置分组数据 optionGroups\n */\n @property({\n type: Boolean,\n })\n accessor isGroup: boolean | undefined;\n\n /**\n * 多选框选项分组数据,需要设置 isGroup 为 true 才生效\n */\n @property({\n attribute: false,\n })\n accessor optionGroups: OptionGroup[] | undefined;\n\n /**\n * 复选框变化事件\n */\n @event({ type: \"change\" })\n accessor #checkboxChangeEvent!: EventEmitter<CheckboxOptionType[]>;\n\n handleCheckboxChange = (detail: CheckboxValueType[]) => {\n this.value = detail;\n const currentOptions = this.optionGroups\n ? this.optionGroups.reduce(\n (before: CheckboxOptionType[], after) => [\n ...before,\n ...after.options,\n ],\n []\n )\n : this.options;\n const currentSelectOption = formatOptions(currentOptions).filter((item) =>\n typeof item.value === \"object\" ? true : detail.includes(item.value)\n );\n this.#checkboxChangeEvent.emit(currentSelectOption);\n };\n\n /**\n * 复选框变化事件\n */\n @event({ type: \"options.change\" })\n accessor #optionsChangeEvent!: EventEmitter<{\n options: CheckboxOptionType[];\n name: string;\n }>;\n\n #handleOptionsChange = (options: CheckboxOptionType[], name: string) => {\n this.#optionsChangeEvent.emit({\n options,\n name,\n });\n };\n\n render() {\n return (\n <CheckboxComponent\n curElement={this}\n formElement={this.getFormElement()}\n options={formatOptions(this.options)}\n label={this.label}\n name={this.name}\n value={this.value}\n type={this.type}\n disabled={this.disabled}\n isCustom={this.isCustom}\n required={this.required}\n message={this.message}\n notRender={this.notRender}\n helpBrick={this.helpBrick}\n labelBrick={this.labelBrick}\n trigger=\"handleCheckboxChange\"\n onChange={this.handleCheckboxChange}\n optionsChange={this.#handleOptionsChange}\n isGroup={this.isGroup}\n optionGroups={this.optionGroups}\n />\n );\n }\n}\n\nfunction CheckboxComponent(props: CheckboxProps) {\n const { isGroup } = props;\n const [values, setValues] = useState<CheckboxValueType[]>(props?.value ?? []);\n const [options, setOptions] = useState<CheckboxOptionType[]>(\n props.options || []\n );\n const [collapseKeys, setCollapseKeys] = useState<string[]>(\n (props.optionGroups || []).map((o) => o.key)\n );\n const [optionGroups, setOptionGroups] = useState(props.optionGroups);\n useEffect(() => {\n if (!isEqual(optionGroups, props.optionGroups)) {\n setCollapseKeys((optionGroups || []).map((o) => o.key));\n setOptionGroups(props.optionGroups);\n }\n }, [props.optionGroups]);\n\n useEffect(() => {\n if (!isEqual(options, props.options)) {\n setOptions(props.options || []);\n props.optionsChange?.(props.options ?? [], props.name as string);\n }\n }, [options, props, props.options]);\n\n useEffect(() => {\n setValues(props?.value || []);\n }, [props.value]);\n\n const handleInputClick = (\n e: React.ChangeEvent<HTMLInputElement>,\n item: CheckboxOptionType\n ) => {\n e.stopPropagation();\n let newValue: CheckboxValueType[] = [];\n if (e.target.checked) {\n newValue = [...values, item.value];\n }\n if (!e.target.checked && values?.includes(item.value)) {\n newValue = [...values];\n const index = newValue.findIndex((i) => i == item.value);\n newValue.splice(index, 1);\n }\n setValues(newValue);\n props.onChange?.(newValue);\n };\n\n const getIcon = (item: CheckboxOptionType) => {\n let iconNode = null;\n const { icon } = item;\n if (icon) {\n if (\"imgSrc\" in icon) {\n const mergedIcon: any = {\n ...icon,\n imgSrc: icon.imgSrc,\n imgStyle: {\n marginRight: \"8px\",\n verticalAlign: \"-0.42em\",\n ...icon.imgStyle,\n },\n };\n iconNode = icon && (\n <WrappedIcon {...(mergedIcon as GeneralIconProps)} />\n );\n } else {\n iconNode = icon && (\n <WrappedIcon\n {...(icon as GeneralIconProps)}\n style={{\n fontSize: \"22px\",\n marginRight: \"8px\",\n verticalAlign: \"-0.25em\",\n }}\n />\n );\n }\n }\n return iconNode;\n };\n\n const IconCheckbox = (props: CheckboxProps) => {\n const { name, disabled = false, isCustom = false } = props;\n return (\n <>\n {options.map((item: any) => (\n <label\n key={item.value}\n className={\n disabled || item?.disabled\n ? classNames({\n disabledIconCheckbox: true,\n disabledIconCustomCheckbox: isCustom,\n })\n : classNames({\n iconCheckbox: true,\n iconCustomCheckbox: isCustom,\n })\n }\n >\n <div className={classNames({ inputBox: true })}>\n <input\n type=\"checkbox\"\n value={item.value}\n name={name}\n defaultChecked={values?.includes(item.value)}\n disabled={disabled || item?.disabled}\n onChange={(e) => handleInputClick(e, item)}\n />\n </div>\n <div className={classNames({ content: true })}>\n {item.icon && (\n <WrappedIcon\n {...(item.icon as GeneralIconProps)}\n style={{\n fontSize: isCustom ? \"52px\" : \"32px\",\n }}\n ></WrappedIcon>\n )}\n <div className={classNames({ text: true })}>\n {item.label || item.value}\n </div>\n </div>\n </label>\n ))}\n </>\n );\n };\n\n const CheckboxItem = (props: CheckboxProps) => {\n return (\n <div\n style={{\n position: \"relative\",\n display: \"flex\",\n alignItems: \"center\",\n minHeight: \"30px\",\n }}\n >\n <div className=\"checkboxWrapper\" part=\"checkbox-wrapper\">\n {props.options?.map((item: CheckboxOptionType) => {\n const disabled = item.disabled || props.disabled;\n return (\n <label\n key={item.value}\n className={classNames({\n checkboxLabel: true,\n checkboxLabelDisabled: disabled,\n checkboxLabelCheck: values.includes(item.value),\n })}\n part=\"checkbox-option\"\n >\n <span\n style={{ color: item.checkboxColor }}\n className={classNames({\n checkboxInputWrapper: true,\n checkboxInputWrapperDisabled: disabled,\n checkboxInputCheck: values.includes(item.value),\n })}\n >\n <input\n onChange={(e) => !disabled && handleInputClick(e, item)}\n disabled={disabled}\n defaultChecked={values?.includes(item.value)}\n className={classNames({\n checkboxInput: true,\n checkboxInputDisabled: disabled,\n })}\n type=\"checkbox\"\n id={item.value}\n ></input>\n <span\n className={classNames({ checkboxInner: true })}\n style={\n values.includes(item.value) && item.checkboxColor\n ? {\n background: item.checkboxColor,\n borderColor: item.checkboxColor,\n }\n : {}\n }\n ></span>\n </span>\n\n <span className={classNames({ checkboxText: true })}>\n {getIcon(item)}\n {item.label}\n </span>\n </label>\n );\n })}\n </div>\n </div>\n );\n };\n const CheckGroupItem = (props: CheckboxProps) => {\n const _optionGroups = useMemo(() => {\n return optionGroups?.map((option) => {\n const newOptions = formatOptions(option.options);\n const newOptionsKeys = newOptions.map((n) => n.value);\n const checkOptions = intersection(values, newOptionsKeys);\n const checkType =\n checkOptions.length === newOptionsKeys.length\n ? \"all\"\n : checkOptions.length > 0 &&\n checkOptions.length !== newOptionsKeys.length\n ? \"part\"\n : \"none\";\n return {\n ...option,\n options: newOptions,\n checkType,\n keys: newOptionsKeys,\n };\n });\n }, [optionGroups, props.value]);\n return (\n <div className=\"collapse-wrapper\">\n {\" \"}\n {_optionGroups?.map((i) => (\n <div key={i.key}>\n <div\n onClick={() => {\n if (collapseKeys.includes(i.key)) {\n const newKeys = collapseKeys.filter((key) => key !== i.key);\n setCollapseKeys(newKeys);\n } else {\n setCollapseKeys([...collapseKeys, i.key]);\n }\n }}\n className={classNames(\"collapse-header\")}\n >\n <span className=\"collapse-icon\">\n <CaretRightOutlined\n rotate={collapseKeys.includes(i.key) ? 90 : 0}\n rev=\"\"\n />\n </span>\n <label\n onClick={(e) => {\n e.stopPropagation();\n }}\n className={classNames({\n checkboxLabel: true,\n checkboxLabelCheck: i.checkType === \"all\",\n })}\n >\n <span\n className={classNames({\n checkboxInputWrapper: true,\n checkboxInputCheck: i.checkType === \"all\",\n checkboxInputPartCheck: i.checkType === \"part\",\n })}\n >\n <input\n className={classNames({\n checkboxInput: true,\n })}\n onChange={(e) => {\n e.stopPropagation();\n if (i.checkType === \"all\") {\n const newValue = values.filter(\n (v) => !i.keys.includes(v)\n );\n props.onChange?.(newValue);\n } else {\n props.onChange?.(uniq([...values, ...i.keys]));\n }\n }}\n type=\"checkbox\"\n ></input>\n <span className={classNames({ checkboxInner: true })}></span>\n </span>\n\n <span className={classNames({ checkboxText: true })}>\n {i.name}\n </span>\n </label>\n </div>\n <div\n className={classNames(\"collapse-content\", {\n \"collapse-content-visible\": collapseKeys.includes(i.key),\n })}\n >\n <CheckboxItem\n {...{ ...props, options: i.options }}\n ></CheckboxItem>\n </div>\n </div>\n ))}\n </div>\n );\n };\n return (\n <WrappedFormItem exportparts=\"message\" {...pickFormItemProps(props)}>\n {props.type == \"icon\" ? (\n <IconCheckbox {...props}></IconCheckbox>\n ) : isGroup && props.optionGroups ? (\n <CheckGroupItem {...props}></CheckGroupItem>\n ) : (\n <CheckboxItem {...{ ...props, options: options }}></CheckboxItem>\n )}\n </WrappedFormItem>\n );\n}\n\nexport { Checkbox };\n","export enum K {\n UNIQUE = \"UNIQUE\",\n}\n\nconst en: Locale = {\n UNIQUE: \"{{ name }} can not repeat!\",\n};\n\nconst zh: Locale = {\n UNIQUE: \"{{ name }} 不能重复!\",\n};\n\nexport const NS = \"bricks/form/dynamic-form-item\";\n\nexport const locales = { en, zh };\n\ntype Locale = { [key in K]: string };\n","import React, {\n useCallback,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from \"react\";\nimport { EventEmitter, createDecorators } from \"@next-core/element\";\nimport { wrapBrick } from \"@next-core/react-element\";\nimport type { Button, ButtonProps } from \"@next-bricks/basic/button\";\nimport type {\n GeneralIcon,\n GeneralIconProps,\n} from \"@next-bricks/icons/general-icon\";\nimport type {\n Form,\n FormEvents,\n FormMapEvents,\n FormProps,\n} from \"../form/index.js\";\nimport type { FormItem, FormItemProps } from \"../form-item/index.jsx\";\nimport { ReactUseMultipleBricks } from \"@next-core/react-runtime\";\nimport { UseBrickConf, UseSingleBrickConf } from \"@next-core/types\";\nimport styleText from \"./dynamic-form-item.shadow.css\";\nimport \"@next-core/theme\";\nimport { isEqual, flatten, omit, isEmpty } from \"lodash\";\nimport { FormItemElementBase, pickFormItemProps } from \"@next-shared/form\";\nimport { K, NS, locales } from \"./i18n.js\";\nimport { useTranslation, initializeReactI18n } from \"@next-core/i18n/react\";\nimport classNames from \"classnames\";\n\ninitializeReactI18n(NS, locales);\n\nconst { defineElement, property, event } = createDecorators();\n\nconst WrappedIcon = wrapBrick<GeneralIcon, GeneralIconProps>(\"eo-icon\");\n\nconst WrappedButton = wrapBrick<Button, ButtonProps>(\"eo-button\");\n\nconst WrappedForm = wrapBrick<Form, FormProps, FormEvents, FormMapEvents>(\n \"eo-form\",\n {\n onValuesChange: \"values.change\",\n onValidateSuccess: \"validate.success\",\n onValidateError: \"validate.error\",\n }\n);\n\nconst WrappedFormItem = wrapBrick<FormItem, FormItemProps>(\"eo-form-item\");\n\nexport function uniqueValidatorFN(\n props: DynamicFormItemProps,\n properties: any,\n t: any\n) {\n return () => {\n const fieldValue = props?.curElement?.value?.map(\n (v: any) => v[properties.name as string]\n );\n if (new Set(fieldValue).size !== fieldValue.length) {\n return (\n (properties.message as any)?.unique ??\n t(K.UNIQUE, { name: properties.label ?? properties.name })\n );\n }\n return \"\";\n };\n}\n\ntype DynamicFormValuesItem = Record<string, any>;\n\ninterface DynamicFormItemProps extends FormItemProps {\n form?: Form;\n useBrick?: UseBrickConf;\n value?: DynamicFormValuesItem[];\n validateState?: string;\n needValidate?: boolean;\n onChange?: (value: DynamicFormValuesItem[]) => void;\n onValuesChange?: (values: DynamicFormValuesItem[]) => void;\n onAdd?: (value: rowDataType) => void;\n onRemove?: (value: rowDataType) => void;\n hideRemoveButton?:\n | boolean\n | ((row: Record<string, any>, index: number) => boolean);\n disabledRemoveButton?:\n | boolean\n | ((row: Record<string, any>, index: number) => boolean);\n hideAddButton?: boolean | ((value: Record<string, any>[]) => boolean);\n disabledAddButton?: boolean | ((value: Record<string, any>[]) => boolean);\n}\ntype rowDataType = {\n detail: Record<string, any>;\n index: number;\n};\n\nexport const getRealValue = (\n property: boolean | ((...args: any[]) => boolean),\n args: any[]\n): boolean => {\n if (typeof property === \"function\") {\n return property(...args);\n }\n return property;\n};\n/**\n * 动态表单\n * @author sailor\n * @category form-input-basic\n */\n@defineElement(\"eo-dynamic-form-item\", {\n styleTexts: [styleText],\n alias: [\"form.dynamic-form-item\"],\n})\nclass DynamicFormItem extends FormItemElementBase {\n /**\n * 字段名称\n */\n @property() accessor name: string | undefined;\n /**\n * 字段说明\n */\n @property() accessor label: string | undefined;\n /**\n * 是否必填\n */\n @property({\n type: Boolean,\n })\n accessor required: boolean | undefined;\n\n /**\n * 值\n */\n @property({\n attribute: false,\n })\n accessor value: DynamicFormValuesItem[] | undefined;\n\n /**\n * 校验文本\n */\n @property({ attribute: false })\n accessor message: Record<string, string> | undefined;\n\n /**\n * 是否隐藏每一行删除的按钮\n */\n @property({\n attribute: false,\n })\n accessor hideRemoveButton:\n | boolean\n | ((row: Record<string, any>, index: number) => boolean)\n | undefined;\n\n /**\n * 是否禁止每一行删除的按钮\n */\n @property({\n attribute: false,\n })\n accessor disabledRemoveButton:\n | boolean\n | ((row: Record<string, any>, index: number) => boolean)\n | undefined;\n\n /**\n * 是否隐藏添加的按钮\n */\n @property({\n attribute: false,\n })\n accessor hideAddButton:\n | boolean\n | ((value: Record<string, any>[]) => boolean)\n | undefined;\n\n /**\n * 是否禁止添加的按钮\n */\n @property({\n attribute: false,\n })\n accessor disabledAddButton:\n | boolean\n | ((value: Record<string, any>[]) => boolean)\n | undefined;\n\n /**\n * 动态表单子项构件列表\n */\n @property({\n attribute: false,\n })\n accessor useBrick: UseBrickConf | undefined;\n\n @event({ type: \"change\" })\n accessor #changeEvent!: EventEmitter<DynamicFormValuesItem[]>;\n\n /**\n * 增加一行时触发,detail为该行的默认值,index为该行的位置\n */\n @event({ type: \"row.add\" })\n accessor #addEvent!: EventEmitter<rowDataType>;\n\n /**\n * 移除一行时触发,detail为该行的值,index为该行的位置\n */\n @event({ type: \"row.remove\" })\n accessor #removeEvent!: EventEmitter<rowDataType>;\n\n #handleAdd = (value: rowDataType): void => {\n this.#addEvent.emit(value);\n };\n\n #handleRemove = (value: rowDataType): void => {\n this.#removeEvent.emit(value);\n };\n\n handleDynamicFormChange = (values: DynamicFormValuesItem[]) => {\n this.value = values;\n this.#changeEvent.emit(values);\n this.getFormElement()?.resetValidateState();\n };\n\n render() {\n return (\n <DynamicFormItemComponent\n formElement={this.getFormElement()}\n curElement={this}\n name={this.name}\n label={this.label}\n required={this.required}\n useBrick={this.useBrick}\n value={this.value}\n validateState={this.validateState}\n needValidate={false}\n notRender={this.notRender}\n helpBrick={this.helpBrick}\n labelBrick={this.labelBrick}\n trigger=\"handleDynamicFormChange\"\n onChange={this.handleDynamicFormChange}\n onValuesChange={this.handleDynamicFormChange}\n message={this.message}\n onAdd={this.#handleAdd}\n onRemove={this.#handleRemove}\n hideAddButton={this.hideAddButton}\n hideRemoveButton={this.hideRemoveButton}\n disabledAddButton={this.disabledAddButton}\n disabledRemoveButton={this.disabledRemoveButton}\n />\n );\n }\n}\n\nexport function DynamicFormItemComponent(props: DynamicFormItemProps) {\n const { t } = useTranslation(NS);\n const {\n value,\n hideAddButton = false,\n hideRemoveButton = false,\n disabledRemoveButton = false,\n disabledAddButton = false,\n } = props;\n const formWrapperRef = useRef<HTMLDivElement>(null);\n const [values, setValues] = useState<DynamicFormValuesItem[]>(value ?? []);\n\n const [bricks, setBricks] = useState<UseSingleBrickConf[]>([]);\n\n const bricksOfNoLabel = useMemo(\n () => bricks.map((brick: any) => omit(brick, \"properties.label\")),\n [bricks]\n );\n\n const handleAddItem = () => {\n props.onAdd?.({ detail: {}, index: values.length });\n setValues(values.concat({}));\n };\n\n useEffect(() => {\n if (!isEqual(value, values)) {\n setValues(value ?? []);\n }\n }, [value]);\n\n useEffect(() => {\n if (props.useBrick) {\n const parsedUseBrick: UseSingleBrickConf[] = flatten(\n new Array(props.useBrick)\n );\n\n setBricks(\n parsedUseBrick.map((brick) => {\n const { properties = {} } = brick;\n if (properties.unique) {\n let parsedValidator: any = [\n uniqueValidatorFN(props, properties, t),\n ];\n if (properties.validator) {\n parsedValidator = [\n ...flatten(new Array(properties.validator)),\n ...parsedValidator,\n ];\n }\n return {\n ...brick,\n properties: {\n ...brick.properties,\n validator: parsedValidator,\n },\n };\n } else {\n return brick;\n }\n })\n );\n }\n }, [props.useBrick, props.curElement]);\n // istanbul ignore next;\n const validate = () => {\n const formWrapper = formWrapperRef.current;\n const forms = formWrapper?.querySelectorAll(\n \".dynamic-form\"\n ) as unknown as Form[];\n const result: Array<boolean | Record<string, unknown>> = [];\n if (forms.length) {\n forms.forEach((item) => {\n result.push(item.validate());\n });\n }\n return result.every(Boolean) ? \"\" : \"动态表单校验失败\";\n };\n\n // istanbul ignore next;\n const handleValuesChange = useCallback(\n (value: CustomEvent<DynamicFormValuesItem>, index: number) => {\n props.onChange?.(\n values.map((item, i) => {\n if (i === index) {\n return value.detail.allValues;\n }\n return item;\n })\n );\n },\n [props, values]\n );\n\n const handleRemoveItem = useCallback(\n (index: number) => {\n const newValues = values.filter((_, i) => i !== index);\n setValues(newValues);\n props.onChange?.(newValues);\n props.onRemove?.({\n detail: values.find((_, i) => i === index) as Record<string, any>,\n index,\n });\n },\n [props, values]\n );\n const addButtonDisabled = useMemo(\n () => getRealValue(disabledAddButton, [values]),\n [disabledAddButton, values]\n );\n const addButtonHide = useMemo(\n () => getRealValue(hideAddButton, [values]),\n [hideAddButton, values]\n );\n\n return (\n <WrappedFormItem\n exportparts=\"message\"\n {...pickFormItemProps(props)}\n validator={validate}\n >\n <div className=\"dynamic-form-wrapper\" ref={formWrapperRef}>\n {values.map((value, index) => {\n const hideRemoveBtn = getRealValue(hideRemoveButton, [value, index]);\n const removeBtnDisabled = getRealValue(disabledRemoveButton, [\n value,\n index,\n ]);\n return (\n <div className=\"dynamic-form-item\" key={index}>\n {!isEmpty(bricks) && (\n <WrappedForm\n layout=\"vertical\"\n formStyle={{\n flexDirection: \"row\",\n alignItems: \"flex-start\",\n }}\n className=\"dynamic-form\"\n values={value}\n defaultEmitValuesChange={false}\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n onValuesChange={(value) => handleValuesChange(value, index)}\n >\n <ReactUseMultipleBricks\n useBrick={\n (index === 0\n ? bricks\n : bricksOfNoLabel) as UseSingleBrickConf[]\n }\n // NOTE: Passing changed `data={value}` will cause useBrick to re-render and lose state\n data={value}\n />\n {!hideRemoveBtn && (\n <div\n className={classNames(\"remove-btn-wrapper\", {\n \"remove-btn-disabled-wrapper\": removeBtnDisabled,\n })}\n >\n <WrappedIcon\n lib=\"easyops\"\n category=\"assets-inventory\"\n icon=\"out\"\n className={classNames(\"remove-btn\", {\n \"remove-btn-disabled\": removeBtnDisabled,\n })}\n onClick={() => handleRemoveItem(index)}\n />\n </div>\n )}\n </WrappedForm>\n )}\n </div>\n );\n })}\n <div\n className={classNames({\n \"add-btn-wrapper-disabled\": addButtonDisabled,\n })}\n >\n <WrappedButton\n className={classNames(\"add-btn\", {\n \"add-btn-hide\": addButtonHide,\n \"add-btn-disabled\": addButtonDisabled,\n })}\n icon={{\n category: \"assets-inventory\",\n icon: \"xin\",\n lib: \"easyops\",\n }}\n type=\"dashed\"\n buttonStyle={{\n width: \"100%\",\n color: addButtonDisabled ? \"var(--text-color-disabled)\" : \"\",\n }}\n onClick={handleAddItem}\n >\n 添加\n </WrappedButton>\n </div>\n </div>\n <slot name=\"helpSlot\"></slot>\n </WrappedFormItem>\n );\n}\n\nexport { DynamicFormItem };\n","import React, { useEffect, useState, useMemo, type CSSProperties } from \"react\";\nimport { EventEmitter, createDecorators } from \"@next-core/element\";\nimport { ReactNextElement, wrapBrick } from \"@next-core/react-element\";\nimport \"@next-core/theme\";\nimport styleText from \"./styles.shadow.css\";\nimport type {\n GeneralIcon,\n GeneralIconProps,\n} from \"@next-bricks/icons/general-icon\";\nimport { debounce } from \"lodash\";\nimport type {\n Input,\n InputEvents,\n InputEventsMap,\n InputProps,\n} from \"../input/index.jsx\";\n\nconst { defineElement, property, event } = createDecorators();\n\nconst WrappedIcon = wrapBrick<GeneralIcon, GeneralIconProps>(\"eo-icon\");\nconst WrappedInput = wrapBrick<Input, InputProps, InputEvents, InputEventsMap>(\n \"eo-input\",\n {\n onChange: \"change\",\n }\n);\n\nexport interface SearchProps {\n value?: string;\n placeholder?: string;\n autoFocus?: boolean;\n clearable?: boolean;\n trim?: boolean;\n debounceTime?: number;\n inputStyle?: CSSProperties;\n}\n\nexport interface SearchEvents {\n change: CustomEvent<string>;\n search: CustomEvent<string>;\n}\n\nexport interface SearchEventsMap {\n onChange: \"change\";\n onSearch: \"search\";\n}\n\n/**\n * 搜索框\n * @author nlicro\n * @category interact-basic\n */\nexport\n@defineElement(\"eo-search\", {\n styleTexts: [styleText],\n alias: [\"form.general-search\"],\n})\nclass GeneralSearch extends ReactNextElement implements SearchProps {\n /**\n * 搜索框的值\n */\n @property()\n accessor value: string = \"\";\n\n /**\n * 提示语\n */\n @property()\n accessor placeholder: string | undefined;\n\n /**\n * 是否自动聚焦\n */\n @property({\n type: Boolean,\n })\n accessor autoFocus: boolean | undefined;\n\n /**\n * 可以点击清除图标删除内容\n */\n @property({\n type: Boolean,\n })\n accessor clearable: boolean | undefined;\n\n /**\n * 是否剔除前后空格\n */\n @property({\n type: Boolean,\n })\n accessor trim: boolean | undefined;\n\n /**\n * 默认延迟时间\n */\n @property({\n type: Number,\n })\n accessor debounceTime: number = 0;\n\n /**\n * 输入框样式\n */\n @property({ attribute: false })\n accessor inputStyle: CSSProperties | undefined;\n\n /**\n * 输入的搜索字符,输入变化时触发\n */\n @event({ type: \"change\" })\n accessor #change!: EventEmitter<string>;\n #handleChange = (value: string) => {\n this.value = value;\n };\n #handleDebouncedChange = (value: string) => {\n this.#change.emit(this.trim ? value?.trim() : value);\n };\n\n /**\n * 搜索时触发\n */\n @event({ type: \"search\" })\n accessor #search!: EventEmitter<string>;\n #handleSearch = (value: string) => {\n this.#search.emit(this.trim ? value?.trim() : value);\n };\n\n render() {\n return (\n <GeneralSearchComponent\n value={this.value}\n placeholder={this.placeholder}\n autoFocus={this.autoFocus}\n clearable={this.clearable}\n debounceTime={this.debounceTime}\n onChange={this.#handleChange}\n onSearch={this.#handleSearch}\n inputStyle={this.inputStyle}\n onDebouncedChange={this.#handleDebouncedChange}\n />\n );\n }\n}\n\ninterface SearchComponentProps extends SearchProps {\n onSearch?: (value: string) => void;\n onChange?: (value: string) => void;\n onDebouncedChange?: (value: string) => void;\n}\n\nexport function GeneralSearchComponent(props: SearchComponentProps) {\n const {\n placeholder,\n autoFocus,\n clearable,\n debounceTime,\n inputStyle,\n onDebouncedChange,\n onChange,\n onSearch,\n } = props;\n\n const [value, setValue] = useState<string>();\n\n useEffect(() => {\n setValue(props.value);\n }, [props.value]);\n\n const _onDebouncedChange = useMemo(() => {\n return debounceTime\n ? debounce(onDebouncedChange!, debounceTime)\n : onDebouncedChange;\n }, [debounceTime]);\n\n const handleSearch = () => {\n onSearch?.(value!);\n };\n\n const handleChange = (e: CustomEvent<string>) => {\n setValue(e.detail);\n onChange?.(e.detail);\n _onDebouncedChange?.(e.detail);\n };\n\n return (\n <WrappedInput\n type=\"text\"\n // React has special treatment for autoFocus. So we set the autofocus attribute to eo-input.\n auto-focus={autoFocus}\n clearable={clearable}\n placeholder={placeholder}\n value={value}\n onChange={handleChange as any}\n onKeyDown={(e) => e.key === \"Enter\" && handleSearch()}\n inputStyle={inputStyle}\n >\n <WrappedIcon\n slot=\"suffix\"\n className=\"search-button\"\n lib=\"antd\"\n icon=\"search\"\n theme=\"outlined\"\n onClick={() => handleSearch()}\n onMouseDown={(e) => e.preventDefault()}\n />\n </WrappedInput>\n );\n}\n","export enum K {\n ICON = \"ICON\",\n COLOR = \"COLOR\",\n SELECT_ICON = \"SELECT_ICON\",\n SEARCH_PLACEHOLDER = \"SEARCH_PLACEHOLDER\",\n}\n\nconst en: Locale = {\n ICON: \"Icon\",\n COLOR: \"Color\",\n SELECT_ICON: \"Select Icon\",\n SEARCH_PLACEHOLDER: \"input keyword to search\",\n};\n\nconst zh: Locale = {\n ICON: \"图标\",\n COLOR: \"颜色\",\n SELECT_ICON: \"选择图标\",\n SEARCH_PLACEHOLDER: \"输入关键字搜索\",\n};\n\nexport const NS = \"bricks/form/icon-select\";\n\nexport const locales = { en, zh };\n\ntype Locale = { [key in K]: string };\n","export enum Colors {\n green = \"green\",\n red = \"red\",\n blue = \"blue\",\n orange = \"orange\",\n cyan = \"cyan\",\n purple = \"purple\",\n geekblue = \"geekblue\",\n gray = \"gray\",\n}\n\nexport const COLORS_MAP: Record<\n Colors,\n { color: string; background: string; borderColor: string }\n> = {\n [Colors.green]: {\n color: \"var(--theme-green-color)\",\n background: \"var(--theme-green-background)\",\n borderColor: \"var(--theme-green-border-color)\",\n },\n [Colors.red]: {\n color: \"var(--theme-red-color)\",\n background: \"var(--theme-red-background)\",\n borderColor: \"var(--theme-red-border-color)\",\n },\n [Colors.blue]: {\n color: \"var(--theme-blue-color)\",\n background: \"var(--theme-blue-background)\",\n borderColor: \"var(--theme-blue-border-color)\",\n },\n [Colors.orange]: {\n color: \"var(--theme-orange-color)\",\n background: \"var(--theme-orange-background)\",\n borderColor: \"var(--theme-orange-border-color)\",\n },\n [Colors.cyan]: {\n color: \"var(--theme-cyan-color)\",\n background: \"var(--theme-cyan-background)\",\n borderColor: \"var(--theme-cyan-border-color)\",\n },\n [Colors.purple]: {\n color: \"var(--theme-purple-color)\",\n background: \"var(--theme-purple-background)\",\n borderColor: \"var(--theme-purple-border-color)\",\n },\n [Colors.geekblue]: {\n color: \"var(--theme-geekblue-color)\",\n background: \"var(--theme-geekblue-background)\",\n borderColor: \"var(--theme-geekblue-border-color)\",\n },\n [Colors.gray]: {\n color: \"var(--theme-gray-color)\",\n background: \"var(--theme-gray-background)\",\n borderColor: \"var(--theme-gray-border-color)\",\n },\n};\n\n/**\n * 如果提供的颜色值是平台提供的规范颜色,则转换为使用平台规范的颜色定义,包括color、background、borderColor,不是的话则原样输出。\n * @param color {string} 颜色值\n * @return {color:string;background:string;borderColor:string;} 返回处理后的对应颜色值\n */\nexport function getColor(color?: string): {\n color: string;\n background: string;\n borderColor: string;\n} {\n if (!color) {\n return {\n color: \"var(--antd-avatar-color)\",\n background: \"var(--antd-avatar-bg)\",\n borderColor: \"var(--antd-avatar-color)\",\n };\n }\n return (\n COLORS_MAP[color as Colors] ?? {\n color,\n background: color,\n borderColor: color,\n }\n );\n}\n","import React, { useEffect, useRef, useState } from \"react\";\nimport { EventEmitter, createDecorators } from \"@next-core/element\";\nimport { wrapBrick } from \"@next-core/react-element\";\nimport { unwrapProvider } from \"@next-core/utils/general\";\nimport { useTranslation, initializeReactI18n } from \"@next-core/i18n/react\";\nimport { FormItemElementBase, pickFormItemProps } from \"@next-shared/form\";\nimport { K, NS, locales } from \"./i18n.js\";\nimport \"@next-core/theme\";\nimport styleText from \"./styles.shadow.css\";\nimport classNames from \"classnames\";\nimport type { FormItem, FormItemProps } from \"../form-item/index.js\";\nimport type {\n GeneralIcon,\n GeneralIconProps,\n LibIconProps,\n} from \"@next-bricks/icons/general-icon\";\nimport type {\n Modal,\n ModalProps,\n ModalEvents,\n ModalMapEvents,\n} from \"@next-bricks/containers/modal\";\nimport type {\n Radio,\n RadioProps,\n RadioEvents,\n RadioEventsMapping,\n} from \"../radio/index.js\";\nimport type {\n GeneralSearch,\n SearchProps,\n SearchEvents,\n SearchEventsMap,\n} from \"../search/index.js\";\nimport type {\n getLibs as _getLibs,\n LibInfo,\n IconInfo,\n} from \"@next-bricks/icons/data-providers/get-libs\";\nimport type { searchIcons as _searchIcons } from \"@next-bricks/icons/data-providers/search-icons\";\nimport { COLORS_MAP, getColor } from \"./utils.js\";\n\ninitializeReactI18n(NS, locales);\n\nconst { defineElement, property, event } = createDecorators();\n\nconst getLibs = unwrapProvider<typeof _getLibs>(\"icons.get-libs\");\nconst searchIcons = unwrapProvider<typeof _searchIcons>(\"icons.search-icons\");\nconst WrappedGeneralRadio = wrapBrick<\n Radio,\n RadioProps,\n RadioEvents,\n RadioEventsMapping\n>(\"eo-radio\", {\n onValueChange: \"change\",\n onOptionsChange: \"optionsChange\",\n});\nconst WrappedGeneralIcon = wrapBrick<GeneralIcon, GeneralIconProps>(\"eo-icon\");\nconst WrappedModal = wrapBrick<Modal, ModalProps, ModalEvents, ModalMapEvents>(\n \"eo-modal\",\n {\n onClose: \"close\",\n onConfirm: \"confirm\",\n onCancel: \"cancel\",\n onOpen: \"open\",\n }\n);\nconst WrappedSearch = wrapBrick<\n GeneralSearch,\n SearchProps,\n SearchEvents,\n SearchEventsMap\n>(\"eo-search\", {\n onChange: \"change\",\n onSearch: \"search\",\n});\nconst WrappedFormItem = wrapBrick<FormItem, FormItemProps>(\"eo-form-item\");\n\ntype Icon = LibIconProps & { color?: string };\n\nexport interface IconSelectProps {\n name?: string;\n label?: string;\n value?: Icon;\n disabled?: boolean;\n required?: boolean;\n message?: Record<string, string>;\n}\n\n/**\n * 图标选择构件\n * @author nlicro\n * @category form-input-basic\n */\nexport\n@defineElement(\"eo-icon-select\", {\n styleTexts: [styleText],\n alias: [\"form.icon-select\"],\n})\nclass IconSelect extends FormItemElementBase implements IconSelectProps {\n /**\n * 字段名称\n */\n @property()\n accessor name: string | undefined;\n\n /**\n * 字段说明\n */\n @property()\n accessor label: string | undefined;\n\n /**\n * 值\n */\n @property({\n attribute: false,\n })\n accessor value: Icon | undefined;\n\n /**\n * 是否禁用\n */\n @property({\n type: Boolean,\n })\n accessor disabled: boolean | undefined;\n\n /**\n * 是否必填\n */\n @property({\n type: Boolean,\n })\n accessor required: boolean | undefined;\n\n /**\n * 是否必填\n */\n @property({\n attribute: false,\n })\n accessor message: Record<string, string> | undefined;\n\n /**\n * 值变化时触发\n */\n @event({ type: \"change\" })\n accessor #change!: EventEmitter<Icon | undefined>;\n handleChange = (value?: Icon) => {\n this.value = value;\n this.#change.emit(value);\n };\n\n render() {\n return (\n <IconSelectComponent\n formElement={this.getFormElement()}\n curElement={this}\n name={this.name}\n label={this.label}\n value={this.value}\n required={this.required}\n disabled={this.disabled}\n message={this.message}\n notRender={this.notRender}\n helpBrick={this.helpBrick}\n labelBrick={this.labelBrick}\n onChange={this.handleChange}\n trigger=\"handleChange\"\n />\n );\n }\n}\n\nconst emptyIcon = {\n lib: \"easyops\",\n icon: \"empty-icon\",\n category: \"common\",\n} as Icon;\n\ninterface IconSelectComponentProps extends FormItemProps, IconSelectProps {\n onChange?: (value?: Icon) => void;\n}\n\nexport function IconSelectComponent(props: IconSelectComponentProps) {\n const { t } = useTranslation(NS);\n const { disabled, onChange } = props;\n\n const modalRef = useRef<Modal>(null);\n\n const [iconLibs, setIconLibs] = useState<LibInfo[]>([]);\n const [searchParams, setSearchParams] = useState<{\n q?: string;\n lib?: string;\n }>({});\n const [iconList, setIconList] = useState<IconInfo[]>([]);\n\n useEffect(() => {\n getLibs().then((libs) => {\n setIconLibs(libs);\n setSearchParams({ ...searchParams, lib: libs[0].lib });\n });\n }, []);\n\n const handleSearchIcons = (params: { q?: string; lib?: string }) => {\n searchIcons({ lib: params.lib, q: params.q, page: 1, pageSize: 100 }).then(\n (result) => setIconList(result.list)\n );\n };\n\n const [previewIcon, setPreviewIcon] = useState<LibIconProps>();\n const [previewColor, setPreviewColor] = useState<string>();\n\n useEffect(() => {\n setPreviewIcon(props.value?.lib ? props.value : undefined);\n setPreviewColor(props.value?.color);\n }, [props.value]);\n\n const [selectedIcon, setSelectedIcon] = useState<LibIconProps>();\n const [selectedColor, setSelectedColor] = useState<string>();\n\n const clearSelect = () => {\n setSelectedIcon(undefined);\n setSelectedColor(undefined);\n };\n\n const handleModalOpen = () => {\n setSelectedIcon(previewIcon);\n setSelectedColor(previewColor);\n handleSearchIcons(searchParams);\n };\n\n const handleModalClose = () => {\n clearSelect();\n };\n\n const handleModalConfirm = () => {\n setPreviewIcon(selectedIcon);\n setPreviewColor(selectedColor);\n const newValue = selectedIcon?.lib\n ? { ...selectedIcon, color: selectedColor }\n : undefined;\n onChange?.(newValue);\n modalRef.current?.close();\n };\n\n const handleIconSelect = (icon: LibIconProps) => {\n setSelectedIcon(icon);\n };\n\n const handleColorSelect = (color?: string) => {\n setSelectedColor(color);\n };\n\n return (\n <WrappedFormItem exportparts=\"message\" {...pickFormItemProps(props)}>\n <span\n onClick={() => !disabled && modalRef.current?.open()}\n className={classNames(\"show-icon\", {\n disabled: disabled,\n })}\n style={{ backgroundColor: getColor(previewColor).background }}\n >\n <WrappedGeneralIcon\n {...(previewIcon || emptyIcon)}\n style={{ color: getColor(previewColor).color }}\n />\n </span>\n <WrappedModal\n ref={modalRef}\n modalTitle={t(K.SELECT_ICON)!}\n width=\"778px\"\n maskClosable={false}\n closeWhenConfirm={false}\n onConfirm={handleModalConfirm}\n onClose={handleModalClose}\n onOpen={handleModalOpen}\n >\n <div className=\"preview-container\">\n <div\n className=\"show-area\"\n style={{ backgroundColor: getColor(selectedColor).background }}\n >\n <WrappedGeneralIcon\n {...(selectedIcon || emptyIcon)}\n style={{ color: getColor(selectedColor).color }}\n />\n {selectedIcon && (\n <div className=\"delete-wrapper\" onClick={() => clearSelect()}>\n <div className=\"delete-icon\">\n <WrappedGeneralIcon\n lib=\"easyops\"\n category=\"default\"\n icon=\"delete\"\n style={{ color: \"var(--theme-red-color)\" }}\n />\n </div>\n </div>\n )}\n </div>\n <span className=\"preview-icon-name\">{selectedIcon?.icon}</span>\n </div>\n <div className=\"select-icon-container\">\n {\n <>\n <span className=\"label\">{t(K.COLOR)}:</span>\n <div className=\"select-color-area\">\n {Object.keys(COLORS_MAP).map((item) => {\n return (\n <div\n className=\"color-box\"\n style={{ backgroundColor: getColor(item).color }}\n key={item}\n onClick={() => handleColorSelect(item)}\n />\n );\n })}\n <div\n className=\"color-box empty-color\"\n onClick={() => handleColorSelect(undefined)}\n >\n <div className=\"empty-line\" />\n </div>\n </div>\n </>\n }\n <span className=\"label\">{t(K.ICON)}:</span>\n <div className=\"select-icon-area\">\n <div className=\"select-icon-search-bar\">\n <WrappedSearch\n value={searchParams.q}\n placeholder={t(K.SEARCH_PLACEHOLDER)!}\n onSearch={(e) => {\n const newSearchParams = { ...searchParams, q: e.detail };\n setSearchParams(newSearchParams);\n handleSearchIcons(newSearchParams);\n }}\n />\n <WrappedGeneralRadio\n options={iconLibs?.map((lib) => {\n return {\n label: lib.title,\n value: lib.lib,\n };\n })}\n value={searchParams.lib}\n onValueChange={(e) => {\n const newSearchParams = {\n ...searchParams,\n lib: e.detail.value as string,\n };\n setSearchParams(newSearchParams);\n handleSearchIcons(newSearchParams);\n }}\n />\n </div>\n <div className=\"icon-area\">\n {iconList.map((iconInfo) => {\n return (\n <div\n key={JSON.stringify(iconInfo.icon)}\n title={iconInfo.title}\n className=\"icon-container\"\n onClick={() => {\n handleIconSelect(iconInfo.icon);\n }}\n >\n <WrappedGeneralIcon {...iconInfo.icon} />\n <div className=\"icon-name\">{iconInfo.title}</div>\n </div>\n );\n })}\n </div>\n </div>\n </div>\n </WrappedModal>\n </WrappedFormItem>\n );\n}\n","export enum K {\n UPLOAD = \"UPLOAD\",\n FILE_UPLOADING = \"FILE_UPLOADING\",\n DRAG_UPLOAD_TEXT = \"DRAG_UPLOAD_TEXT\",\n EXCEEDED_FILE_SIZE_LIMIT = \"EXCEEDED_FILE_SIZE_LIMIT\",\n}\n\nconst en: Locale = {\n UPLOAD: \"Upload\",\n FILE_UPLOADING: \"File is still uploading\",\n DRAG_UPLOAD_TEXT: \"Drag files here or <strong>click to upload</strong>\",\n EXCEEDED_FILE_SIZE_LIMIT:\n \"The uploaded file exceeded size limit: {{limitSize}} {{unit}}\",\n};\n\nconst zh: Locale = {\n UPLOAD: \"上传\",\n FILE_UPLOADING: \"文件上传中\",\n DRAG_UPLOAD_TEXT: \"将文件拖动到此处或<strong>点击上传</strong>\",\n EXCEEDED_FILE_SIZE_LIMIT: \"上传的文件超出大小限制: {{limitSize}} {{unit}}\",\n};\n\nexport const NS = \"bricks/form/eo-upload-file-and-image\";\n\nexport const locales = { en, zh };\n\ntype Locale = { [key in K]: string };\n","import { i18n } from \"@next-core/i18n\";\nimport { NS, K } from \"./i18n.js\";\n\nlet uid = 0;\n\nexport const symbolForAbortController = Symbol.for(\"AbortController\");\n\nexport const LIST_IGNORE = Symbol.for(\"list-ignore\");\n\nexport const getUid = () => {\n return `upload-image-${+new Date()}-${++uid}`;\n};\n\nexport enum FileSizeUnit {\n KB = \"KB\",\n MB = \"MB\",\n GB = \"GB\",\n}\n\nexport const acceptValidator = (file: File, accepts?: string | string[]) => {\n const validAccepts = ([] as string[]).concat(accepts || []).reduce(\n (pre, cur) =>\n pre.concat(\n cur\n .split(\",\")\n .map((v) => v.trim())\n .filter(Boolean)\n ),\n [] as string[]\n );\n\n if (file && validAccepts.length) {\n const lowerFileName = (file.name || \"\").toLowerCase();\n const mimeType = file.type || \"\";\n const baseMimeType = mimeType.split(\"/\")[0];\n\n return validAccepts.some((accept) => {\n // like *, */*\n if ([\"*\", \"*/*\"].includes(accept)) {\n return true;\n }\n\n // like .jpg, .png\n if (accept.startsWith(\".\")) {\n const lowerType = accept.toLowerCase();\n let affixList = [lowerType];\n if ([\".jpg\", \".jpeg\"].includes(lowerType)) {\n affixList = [\".jpg\", \".jpeg\"];\n }\n\n return affixList.some((affix) => lowerFileName.endsWith(affix));\n }\n\n // like image/*\n if (accept.endsWith(\"/*\")) {\n return baseMimeType === accept.split(\"/*\")[0];\n }\n\n // Full match\n if (mimeType === accept) {\n return true;\n }\n\n return false;\n });\n }\n return true;\n};\n\nexport const sizeValidator = (\n file: File,\n limitSize?: number,\n unit: FileSizeUnit = FileSizeUnit.MB\n) => {\n return new Promise((resolve, reject) => {\n if (file && limitSize) {\n const sizeConst = {\n [FileSizeUnit.KB]: 1024,\n [FileSizeUnit.MB]: 1024 * 1024,\n [FileSizeUnit.GB]: 1024 * 1024 * 1024,\n };\n\n file.size < limitSize * sizeConst[unit]\n ? resolve(file)\n : reject(\n new Error(\n i18n.t(`${NS}:${K.EXCEEDED_FILE_SIZE_LIMIT}`, { limitSize, unit })\n )\n );\n } else {\n resolve(file);\n }\n });\n};\n\nexport type UploadStatus = \"uploading\" | \"done\" | \"error\";\n\nexport interface FileData {\n uid: string;\n name: string;\n file?: File & { uid?: string };\n response?: any;\n userData?: any;\n status?: UploadStatus;\n errors?: Error[];\n [symbolForAbortController]?: AbortController;\n}\n","import React, { ChangeEvent, useEffect, useRef, useState } from \"react\";\nimport \"@next-core/theme\";\nimport { http } from \"@next-core/http\";\nimport {\n getUid,\n type FileData,\n symbolForAbortController,\n acceptValidator,\n sizeValidator,\n UploadStatus,\n} from \"./utils.js\";\n\nexport interface UploadActions {\n upload: () => void;\n uploadFiles: (files: FileList | File[]) => void;\n}\n\nexport interface ItemActions {\n remove: () => void;\n}\n\nexport interface UploadProps {\n children: (\n fileDataList: FileData[],\n uploadActions: UploadActions\n ) => React.ReactElement;\n itemRender: (\n fileData: FileData,\n fileDataList: FileData[],\n actions: ItemActions,\n index: number\n ) => React.ReactElement;\n fileList?: FileData[];\n autoUpload?: boolean;\n uploadName?: string;\n action?: string;\n method?: string;\n accept?: string;\n multiple?: boolean;\n maxCount?: number;\n limitSize?: number;\n overMaxCountMode?: \"ignore\" | \"replace\";\n beforeUploadValidators?: ((file: File, files: File[]) => Promise<unknown>)[];\n beforeUploadUserDataProcessor?: (\n file: File,\n fileDataList: { file: File; errors: Error[] }[]\n ) => Promise<any>;\n onChange?: (fileDataList: FileData[]) => void;\n}\n\nexport function Upload(props: UploadProps) {\n const {\n children,\n itemRender,\n autoUpload,\n onChange,\n uploadName = \"file\",\n action,\n method,\n accept,\n maxCount,\n limitSize,\n overMaxCountMode = \"replace\",\n beforeUploadValidators = [],\n beforeUploadUserDataProcessor,\n multiple,\n } = props;\n\n const inputRef = useRef<HTMLInputElement>(null);\n\n const [internalFileDataList, setInternalFileDataList] = useState<FileData[]>(\n []\n );\n\n useEffect(() => {\n setInternalFileDataList(props.fileList || []);\n }, [props.fileList]);\n\n const beforeLoadFilter = (files: File[]) => {\n return files.filter((file) => acceptValidator(file, accept));\n };\n\n const beforeLoadValidator = async (files: File[]) => {\n const results = await Promise.all(\n files.map((file) =>\n Promise.allSettled([\n file,\n sizeValidator(file, limitSize),\n ...beforeUploadValidators.map((validator) => validator(file, files)),\n ])\n )\n );\n return results.map(([_file, ...validatorResult]) => {\n const file = (_file as PromiseFulfilledResult<File>).value;\n const errors: Error[] = [];\n\n validatorResult.forEach((result) => {\n result.status === \"rejected\" && errors.push(result.reason);\n });\n\n return { file, errors };\n });\n };\n\n const beforeLoadProcessor = async (\n fileDataList: { file: File; errors: Error[] }[]\n ) => {\n return Promise.all(\n fileDataList.map(\n async ({\n file,\n errors,\n }: {\n file: File & { uid?: string };\n errors: Error[];\n }) => {\n const uid = getUid();\n file.uid = uid;\n const name = file.name;\n\n const status: UploadStatus = errors.length\n ? \"error\"\n : autoUpload\n ? \"uploading\"\n : \"done\";\n\n const userData = await beforeUploadUserDataProcessor?.(\n file,\n fileDataList\n );\n return { uid, file, name, status, userData, errors };\n }\n )\n );\n };\n\n const handleUploadSuccess = (fileData: FileData, response: unknown) => {\n setInternalFileDataList((fileDataList) => {\n const newFileDataList = fileDataList.map((_fileData) => {\n return _fileData.uid === fileData.uid\n ? {\n ..._fileData,\n response,\n status: \"done\" as UploadStatus,\n }\n : _fileData;\n });\n onChange?.(newFileDataList);\n return newFileDataList;\n });\n };\n\n const handleUploadError = (fileData: FileData, error: Error) => {\n setInternalFileDataList((fileDataList) => {\n const newFileDataList = fileDataList.map((_fileData) => {\n return _fileData.uid === fileData.uid\n ? {\n ..._fileData,\n errors: _fileData.errors?.concat(error),\n status: \"error\" as UploadStatus,\n }\n : _fileData;\n });\n onChange?.(newFileDataList);\n return newFileDataList;\n });\n };\n\n const handleFileRemove = (removedFileData: FileData) => {\n setInternalFileDataList((fileDataList) => {\n const newFileDataList = fileDataList.filter(\n (fileData) => fileData.uid !== removedFileData.uid\n );\n onChange?.(newFileDataList);\n return newFileDataList;\n });\n };\n\n const handleRemove = (fileData: FileData) => {\n if (fileData.status === \"uploading\") {\n fileData[symbolForAbortController]?.abort();\n }\n handleFileRemove(fileData);\n };\n\n const uploadFile = (fileData: FileData) => {\n const formData = new FormData();\n const abortController = new AbortController();\n fileData[symbolForAbortController] = abortController;\n formData.append(uploadName, fileData.file!, fileData.file!.name);\n\n const req = http.request(action!, {\n method,\n body: formData,\n signal: abortController.signal,\n });\n\n req\n .then((response) => handleUploadSuccess(fileData, response))\n .catch((error) => handleUploadError(fileData, error));\n\n return req;\n };\n\n const handleFileUpload = async (files: FileList | File[]) => {\n const originFiles = [...files];\n let filteredFiles: File[] = [];\n let existsFilesSlice: [number, number] | undefined;\n\n if (maxCount && Number(maxCount) > 0) {\n const existsLength = internalFileDataList.length;\n if (existsLength + originFiles.length <= maxCount) {\n filteredFiles = beforeLoadFilter(originFiles);\n } else {\n const overCount = existsLength + originFiles.length - maxCount;\n const allowCount = originFiles.length - overCount;\n\n if (overMaxCountMode === \"ignore\") {\n filteredFiles = beforeLoadFilter(originFiles).slice(0, allowCount);\n } else {\n filteredFiles = beforeLoadFilter(originFiles).slice(\n -maxCount,\n Infinity\n );\n\n if (filteredFiles.length < maxCount) {\n existsFilesSlice = [filteredFiles.length - maxCount, Infinity];\n } else {\n existsFilesSlice = [0, 0];\n }\n }\n }\n } else {\n filteredFiles = beforeLoadFilter(originFiles);\n }\n\n const validatedFiles = await beforeLoadValidator(filteredFiles);\n const processedFileDataList = await beforeLoadProcessor(validatedFiles);\n (processedFileDataList.length || existsFilesSlice) &&\n setInternalFileDataList((fileDataList) => {\n const newFileDataList = (\n existsFilesSlice\n ? fileDataList.slice(...existsFilesSlice)\n : fileDataList\n ).concat(processedFileDataList);\n onChange?.(newFileDataList);\n return newFileDataList;\n });\n\n processedFileDataList.forEach(\n (fileData) => fileData.status === \"uploading\" && uploadFile(fileData)\n );\n };\n\n const handleInputChange = async (event: ChangeEvent<HTMLInputElement>) => {\n event.stopPropagation();\n handleFileUpload([...event.target.files!]);\n event.target.value = \"\";\n };\n\n return (\n <>\n <input\n ref={inputRef}\n type=\"file\"\n multiple={multiple}\n accept={accept}\n hidden\n onChange={handleInputChange}\n />\n <div className=\"upload-wrapper\">\n {children(internalFileDataList, {\n upload: () => inputRef.current?.click(),\n uploadFiles: (files) => handleFileUpload(files),\n })}\n <div className=\"file-list\">\n {internalFileDataList.map((fileData, index) => {\n const actions = {\n remove: () => handleRemove(fileData),\n };\n return (\n <React.Fragment key={fileData.uid}>\n {itemRender(fileData, internalFileDataList, actions, index)}\n </React.Fragment>\n );\n })}\n </div>\n </div>\n </>\n );\n}\n","import { pipes } from \"@next-core/pipes\";\nimport { FileData } from \"../utils.js\";\n\nexport interface ImageData extends FileData {\n url?: string;\n}\n\nexport const getImage = (\n file: string | File,\n revokeUrl?: boolean\n): Promise<HTMLImageElement> => {\n return new Promise((resolve, reject) => {\n let url = \"\";\n if (typeof file === \"string\") {\n url = file;\n } else if (file instanceof Blob && file.type.startsWith(\"image/\")) {\n url = URL.createObjectURL(file);\n } else {\n reject(new Error(\"not Image\"));\n }\n const image = new Image();\n image.src = url;\n image.onload = () => {\n revokeUrl && URL.revokeObjectURL(url);\n resolve(image);\n };\n image.onerror = (error) => reject(error);\n });\n};\n\nexport const imageValidator = async (\n file: File,\n limit?: { width?: number; height?: number }\n) => {\n return new Promise((resolve, reject) => {\n if (file && limit) {\n getImage(file, true).then((image) => {\n (limit.width ? image.naturalWidth < limit.width : true) &&\n (limit.height ? image.naturalHeight < limit.height : true)\n ? resolve(file)\n : reject(new Error(\"Wrong image size!\"));\n });\n } else {\n resolve(file);\n }\n });\n};\n\nexport const userDataProcessor = async (file: File) => {\n const image = await getImage(file);\n return {\n url: image.src,\n name: file.name,\n naturalWidth: image.naturalWidth,\n naturalHeight: image.naturalHeight,\n size: pipes.unitFormat(file.size, \"bytes\").join(\"\"),\n };\n};\n","import React, { useRef } from \"react\";\nimport { EventEmitter, createDecorators } from \"@next-core/element\";\nimport { wrapBrick } from \"@next-core/react-element\";\nimport { getBasePath } from \"@next-core/runtime\";\nimport { useTranslation, initializeReactI18n } from \"@next-core/i18n/react\";\nimport { K, NS, locales } from \"../i18n.js\";\nimport \"@next-core/theme\";\nimport styleText from \"./styles.shadow.css\";\nimport type { Button, ButtonProps } from \"@next-bricks/basic/button\";\nimport type { Image, ImageProps } from \"@next-bricks/basic/image\";\nimport type {\n GeneralIcon,\n GeneralIconProps,\n} from \"@next-bricks/icons/general-icon\";\nimport { FormItemElementBase, pickFormItemProps } from \"@next-shared/form\";\nimport type { FormItem, FormItemProps } from \"../../form-item/index.js\";\nimport classNames from \"classnames\";\nimport { UploadActions, ItemActions, Upload } from \"../Upload.js\";\nimport { userDataProcessor, imageValidator, type ImageData } from \"./utils.js\";\n\ninitializeReactI18n(NS, locales);\n\nconst { defineElement, property, event } = createDecorators();\n\nconst WrappedButton = wrapBrick<Button, ButtonProps>(\"eo-button\");\nconst WrappedImage = wrapBrick<Image, ImageProps>(\"eo-image\");\nconst WrappedIcon = wrapBrick<GeneralIcon, GeneralIconProps>(\"eo-icon\");\nconst WrappedFormItem = wrapBrick<FormItem, FormItemProps>(\"eo-form-item\");\n\nexport interface UploadImageProps {\n label?: string;\n name?: string;\n required?: boolean;\n message?: Record<string, string>;\n value?: ImageData[];\n bucketName: string;\n maxCount?: number;\n multiple?: boolean;\n limitSize?: number;\n}\n\n/**\n * 上传图片构件\n * @author nlicro\n * @category form-input-basic\n */\nexport\n@defineElement(\"eo-upload-image\", {\n styleTexts: [styleText],\n alias: [\"form.upload-image\"],\n})\nclass UploadImage extends FormItemElementBase implements UploadImageProps {\n /**\n * 字段名称\n */\n @property()\n accessor name: string | undefined;\n\n /**\n * 字段说明\n */\n @property()\n accessor label: string | undefined;\n\n /**\n * 值\n */\n @property({\n attribute: false,\n })\n accessor value: ImageData[] | undefined;\n\n /**\n * 对象存储桶名字\n */\n @property()\n accessor bucketName!: string;\n\n /**\n * 最大上传数量\n */\n @property({\n type: Number,\n })\n accessor maxCount: number | undefined;\n\n /**\n * 是否支持选定的多张图片\n */\n @property({\n type: Boolean,\n })\n accessor multiple: boolean | undefined;\n\n /**\n * 上传大小限制(单位为 MB)\n */\n @property({\n type: Number,\n })\n accessor limitSize: number | undefined;\n\n /**\n * 是否必填\n */\n @property({\n type: Boolean,\n })\n accessor required: boolean | undefined;\n\n /**\n * 校验文本信息\n */\n @property({\n attribute: false,\n })\n accessor message: Record<string, string> | undefined;\n\n /**\n * 值变化时触发\n */\n @event({ type: \"change\" })\n accessor #change!: EventEmitter<ImageData[]>;\n handleChange = (imageList: ImageData[]) => {\n this.value = imageList;\n this.#change.emit(imageList);\n };\n\n render() {\n return (\n <UploadImageComponent\n formElement={this.getFormElement()}\n curElement={this}\n name={this.name}\n label={this.label}\n value={this.value}\n required={this.required}\n message={this.message}\n maxCount={this.maxCount}\n bucketName={this.bucketName}\n multiple={this.multiple}\n limitSize={this.limitSize}\n notRender={this.notRender}\n helpBrick={this.helpBrick}\n onChange={this.handleChange}\n trigger=\"handleChange\"\n />\n );\n }\n}\n\nconst defaultUploadIcon = {\n lib: \"antd\",\n icon: \"upload\",\n theme: \"outlined\",\n} as GeneralIconProps;\n\nconst deleteIcon = {\n lib: \"easyops\",\n category: \"default\",\n icon: \"delete\",\n} as GeneralIconProps;\n\nconst closeIcon = {\n lib: \"antd\",\n theme: \"outlined\",\n icon: \"close\",\n} as GeneralIconProps;\n\ninterface UploadImageComponentProps extends UploadImageProps, FormItemProps {\n onChange?: (imageList: ImageData[]) => void;\n}\n\nexport function UploadImageComponent(props: UploadImageComponentProps) {\n const { value, bucketName, multiple, maxCount, onChange, limitSize } = props;\n const { t } = useTranslation(NS);\n const wrapBrickImageRef = useRef<Image>(null);\n\n const handleChange = (images: ImageData[]) => {\n const processedImages = images?.map((image) => {\n const url =\n image.url ??\n (image.response\n ? `${getBasePath()}api/gateway/object_store.object_store.GetObject/api/v1/objectStore/bucket/${bucketName}/object/${\n image.response.data.objectName\n }`\n : undefined);\n return {\n ...image,\n url,\n };\n });\n onChange?.(processedImages);\n };\n\n const itemRender = (\n fileData: ImageData,\n _fileDataList: ImageData[],\n actions: ItemActions,\n index: number\n ) => {\n const { uid, url, name, userData, status = \"done\", errors } = fileData;\n\n return (\n <div\n key={uid}\n className={classNames(\"image-item\", {\n \"image-item-done\": status === \"done\",\n \"image-item-uploading\": status === \"uploading\",\n \"image-item-error\": status === \"error\",\n })}\n >\n <div className=\"image-item-inner\">\n <img\n className=\"image\"\n src={url || userData?.url}\n onClick={() => wrapBrickImageRef.current!.open(index)}\n />\n <div className=\"infos\">\n <div className=\"file-name\">{name}</div>\n {status === \"uploading\" && <div className=\"progress\"></div>}\n <div className=\"more-info\">\n {status === \"done\" && userData && (\n <div className=\"image-size\">\n {`LeaderBoard ${userData?.naturalWidth}*${userData?.naturalHeight}`}\n </div>\n )}\n {status === \"error\" && (\n <div className=\"error-info\">\n {errors\n ?.map((v) => {\n return v instanceof Error ? v.message : v;\n })\n .join(\" \")}\n </div>\n )}\n {(status === \"done\" || status === \"error\") && userData?.size && (\n <div className=\"file-size\">{userData.size}</div>\n )}\n </div>\n </div>\n <div className=\"operators\">\n <WrappedIcon\n className=\"delete-icon\"\n {...(status === \"done\" ? deleteIcon : closeIcon)}\n onClick={actions.remove}\n />\n </div>\n </div>\n </div>\n );\n };\n\n const validator = (curValue: ImageData[]) => {\n if (curValue?.some((file) => file.status === \"uploading\")) {\n return t(K.FILE_UPLOADING);\n }\n return \"\";\n };\n\n return (\n <WrappedFormItem\n exportparts=\"message\"\n {...pickFormItemProps(props)}\n validator={validator}\n >\n <Upload\n itemRender={itemRender}\n fileList={value}\n autoUpload={true}\n uploadName=\"file\"\n action={`${getBasePath()}api/gateway/object_store.object_store.PutObject/api/v1/objectStore/bucket/${bucketName}/object`}\n method=\"PUT\"\n accept=\"image/*\"\n maxCount={maxCount}\n multiple={multiple}\n limitSize={limitSize}\n beforeUploadValidators={[(file) => imageValidator(file)]}\n beforeUploadUserDataProcessor={userDataProcessor}\n onChange={handleChange}\n >\n {(fileDataList: ImageData[], uploadActions: UploadActions) => {\n return (\n <>\n <WrappedButton\n icon={defaultUploadIcon}\n onClick={uploadActions.upload}\n >\n {t(K.UPLOAD)}\n </WrappedButton>\n <WrappedImage\n ref={wrapBrickImageRef}\n onlyPreview={true}\n imgList={fileDataList.map((item) => ({\n src: item.url || item.userData?.url,\n }))}\n />\n </>\n );\n }}\n </Upload>\n </WrappedFormItem>\n );\n}\n","import React, { useEffect, useState } from \"react\";\nimport { createDecorators, EventEmitter } from \"@next-core/element\";\nimport { wrapBrick } from \"@next-core/react-element\";\nimport \"@next-core/theme\";\nimport styleText from \"./styles.shadow.css\";\nimport { FormItemElementBase, pickFormItemProps } from \"@next-shared/form\";\nimport type { FormItem, FormItemProps } from \"../form-item/index.js\";\nimport type {\n GeneralIcon,\n GeneralIconProps,\n} from \"@next-bricks/icons/general-icon\";\nimport type { ComponentSize } from \"../interface.js\";\nimport classNames from \"classnames\";\n\nconst WrappedFormItem = wrapBrick<FormItem, FormItemProps>(\"eo-form-item\");\nconst WrappedGeneralIcon = wrapBrick<GeneralIcon, GeneralIconProps>(\"eo-icon\");\n\ninterface SwitchProps extends FormItemProps {\n curElement: HTMLElement;\n onSwitch: (value: boolean) => void;\n disabled?: boolean;\n size?: ComponentSize;\n value?: boolean;\n checkedText?: string;\n unCheckedText?: string;\n checkedIcon?: GeneralIconProps;\n unCheckedIcon?: GeneralIconProps;\n}\n\nconst { defineElement, property, event } = createDecorators();\n\n/**\n * 开关\n * @author zhendonghuang\n * @category form-input-basic\n */\nexport\n@defineElement(\"eo-switch\", {\n styleTexts: [styleText],\n alias: [\"form.general-switch\"],\n})\nclass GeneralSwitch extends FormItemElementBase {\n /**\n * 字段名称\n */\n @property() accessor name: string | undefined;\n\n /**\n * 字段文本\n */\n @property() accessor label: string | undefined;\n\n /**\n * 初始值\n */\n @property({ type: Boolean })\n accessor value: boolean | undefined;\n\n /**\n * 是否禁用\n */\n @property({ type: Boolean })\n accessor disabled: boolean | undefined;\n\n /**\n * 按钮大小,目前只支持small和非small两种大小。\n */\n @property() accessor size: ComponentSize | undefined;\n\n /**\n * 选中时的文本\n */\n @property() accessor checkedText: string | undefined;\n\n /**\n * 非选中时的文本\n */\n @property() accessor unCheckedText: string | undefined;\n\n /**\n * 选中时的图标\n */\n @property({\n attribute: false,\n })\n accessor checkedIcon: GeneralIconProps | undefined;\n\n /**\n * 非选中时的文本\n */\n @property({\n attribute: false,\n })\n accessor unCheckedIcon: GeneralIconProps | undefined;\n\n /**\n * 开关改变时触发\n */\n @event({ type: \"switch\" }) accessor #switchEvent!: EventEmitter<boolean>;\n\n handleSwitch = (value: boolean) => {\n Promise.resolve().then(() => {\n this.#switchEvent.emit(value);\n });\n };\n render() {\n return (\n <GeneralSwitchComponent\n formElement={this.getFormElement()}\n curElement={this}\n disabled={this.disabled}\n size={this.size}\n value={this.value}\n onSwitch={this.handleSwitch}\n checkedText={this.checkedText}\n unCheckedText={this.unCheckedText}\n checkedIcon={this.checkedIcon}\n unCheckedIcon={this.unCheckedIcon}\n name={this.name}\n label={this.label}\n notRender={this.notRender}\n helpBrick={this.helpBrick}\n labelBrick={this.labelBrick}\n trigger=\"handleSwitch\"\n />\n );\n }\n}\n\nexport function GeneralSwitchComponent(props: SwitchProps) {\n const {\n unCheckedIcon,\n checkedIcon,\n checkedText,\n unCheckedText,\n value,\n disabled,\n size,\n } = props;\n const [checked, setChecked] = useState<boolean>();\n useEffect(() => {\n setChecked(value);\n }, [value]);\n const handleSwitchChange = () => {\n props.onSwitch(!checked);\n setChecked(!checked);\n };\n return (\n <WrappedFormItem exportparts=\"message\" {...pickFormItemProps(props)}>\n <button\n disabled={disabled}\n className={classNames(size, {\n \"switch-checked\": checked,\n \"switch-disabled\": disabled,\n })}\n onClick={handleSwitchChange}\n >\n <div className=\"switch-handle\"></div>\n <span className=\"switch-inner\">\n {checkedIcon && checked && (\n <WrappedGeneralIcon {...checkedIcon}></WrappedGeneralIcon>\n )}\n {unCheckedIcon && !checked && (\n <WrappedGeneralIcon {...unCheckedIcon}></WrappedGeneralIcon>\n )}\n\n {checked ? checkedText : unCheckedText}\n </span>\n </button>\n </WrappedFormItem>\n );\n}\n","import React, { useState } from \"react\";\nimport { EventEmitter, createDecorators } from \"@next-core/element\";\nimport { useCurrentTheme } from \"@next-core/react-runtime\";\nimport { wrapBrick } from \"@next-core/react-element\";\nimport type { Button, ButtonProps } from \"@next-bricks/basic/button\";\nimport type {\n GeneralIcon,\n GeneralIconProps,\n} from \"@next-bricks/icons/general-icon\";\nimport type {\n EasyOpsIcon,\n EasyOpsIconProps,\n} from \"@next-bricks/icons/easyops-icon\";\nimport { EoTooltip, ToolTipProps } from \"@next-bricks/basic/tooltip\";\nimport { FormItemElementBase, pickFormItemProps } from \"@next-shared/form\";\nimport type { FormItem, FormItemProps } from \"../../form-item/index.js\";\nimport \"@next-core/theme\";\nimport styleText from \"./styles.shadow.css\";\nimport { useTranslation, initializeReactI18n } from \"@next-core/i18n/react\";\nimport { Trans } from \"react-i18next\";\nimport { K, NS, locales } from \"../i18n.js\";\nimport { ItemActions, UploadActions, Upload } from \"../Upload.js\";\nimport { FileData } from \"../utils.js\";\nimport classNames from \"classnames\";\n\ninitializeReactI18n(NS, locales);\n\nconst { defineElement, property, event } = createDecorators();\n\nconst WrappedButton = wrapBrick<Button, ButtonProps>(\"eo-button\");\nconst WrappedIcon = wrapBrick<GeneralIcon, GeneralIconProps>(\"eo-icon\");\nconst WrappedEasyopsIcon = wrapBrick<EasyOpsIcon, EasyOpsIconProps>(\n \"eo-easyops-icon\"\n);\nconst WrappedTooltip = wrapBrick<EoTooltip, ToolTipProps>(\"eo-tooltip\");\nconst WrappedFormItem = wrapBrick<FormItem, FormItemProps>(\"eo-form-item\");\n\nexport interface UploadFileProps {\n label?: string;\n name?: string;\n required?: boolean;\n message?: Record<string, string>;\n value?: FileData[];\n multiple?: boolean;\n accept?: string;\n maxCount?: number;\n limitSize?: number;\n overMaxCountMode?: \"ignore\" | \"replace\";\n uploadDraggable?: boolean;\n draggableUploadTip?: string;\n autoUpload?: boolean;\n url?: string;\n method?: string;\n uploadName?: string;\n buttonText?: string;\n buttonType?: ButtonProps[\"type\"];\n buttonIcon?: GeneralIconProps;\n}\n\n/**\n * 上传文件\n * @author nlicro\n * @category form-input-basic\n */\nexport\n@defineElement(\"eo-upload-file\", {\n styleTexts: [styleText],\n})\nclass EoUploadFile extends FormItemElementBase implements UploadFileProps {\n /**\n * 字段说明\n */\n @property()\n accessor label: string | undefined;\n\n /**\n * 字段名称\n */\n @property()\n accessor name: string | undefined;\n\n /**\n * 是否必填\n */\n @property({\n type: Boolean,\n })\n accessor required: boolean | undefined;\n\n /**\n * 校验文本信息\n */\n @property({\n attribute: false,\n })\n accessor message: Record<string, string> | undefined;\n\n /**\n * 值\n */\n @property({\n attribute: false,\n })\n accessor value: FileData[] | undefined;\n\n /**\n * 是否支持多选\n */\n @property({\n type: Boolean,\n })\n accessor multiple: boolean | undefined;\n\n /**\n * 接受上传的文件类型,多个之间用 `,` 连接\n */\n @property()\n accessor accept: string | undefined;\n\n /**\n * 最大上传数量\n */\n @property({\n type: Number,\n })\n accessor maxCount: number | undefined;\n\n /**\n * 上传大小限制(单位为 MB)\n */\n @property({\n type: Number,\n })\n accessor limitSize: number | undefined;\n\n /**\n * 上传按钮文本\n * @default 上传\n */\n @property()\n accessor buttonText: string | undefined;\n\n /**\n * 上传按钮类型\n */\n @property()\n accessor buttonType: ButtonProps[\"type\"] | undefined;\n\n /**\n * 上传按钮类型\n */\n @property({\n attribute: false,\n })\n accessor buttonIcon: GeneralIconProps = {\n lib: \"antd\",\n icon: \"upload\",\n theme: \"outlined\",\n };\n\n /**\n * 超出最大上传数量时文件的保留方式\n */\n @property()\n accessor overMaxCountMode: \"ignore\" | \"replace\" = \"replace\";\n\n /**\n * 是否可以拖拽上传\n */\n @property({\n type: Boolean,\n })\n accessor uploadDraggable: boolean | undefined;\n\n /**\n * 拖拽上传的提示信息\n */\n @property()\n accessor draggableUploadTip: string | undefined;\n\n /**\n * 是否自动上传\n */\n @property({\n type: Boolean,\n })\n accessor autoUpload: boolean = false;\n\n /**\n * 自动上传的地址\n */\n @property()\n accessor url: string | undefined;\n\n /**\n * 自动上传的方法\n */\n @property()\n accessor method: string = \"POST\";\n\n /**\n * 自动上传的文件参数名\n */\n @property()\n accessor uploadName: string = \"file\";\n\n /**\n * 值变化时触发\n */\n @event({ type: \"change\" })\n accessor #change!: EventEmitter<FileData[]>;\n handleChange = (fileDataList: FileData[]) => {\n this.value = fileDataList;\n this.#change.emit(fileDataList);\n };\n\n render() {\n return (\n <EoUploadFileComponent\n formElement={this.getFormElement()}\n curElement={this}\n label={this.label}\n name={this.name}\n required={this.required}\n message={this.message}\n value={this.value}\n multiple={this.multiple}\n accept={this.accept}\n maxCount={this.maxCount}\n limitSize={this.limitSize}\n buttonText={this.buttonText}\n buttonIcon={this.buttonIcon}\n buttonType={this.buttonType}\n overMaxCountMode={this.overMaxCountMode}\n uploadDraggable={this.uploadDraggable}\n draggableUploadTip={this.draggableUploadTip}\n autoUpload={this.autoUpload}\n url={this.url}\n method={this.method}\n notRender={this.notRender}\n helpBrick={this.helpBrick}\n uploadName={this.uploadName}\n trigger=\"handleChange\"\n onChange={this.handleChange}\n />\n );\n }\n}\n\nconst deleteIcon = {\n lib: \"easyops\",\n category: \"default\",\n icon: \"delete\",\n} as GeneralIconProps;\n\nconst closeIcon = {\n lib: \"antd\",\n theme: \"outlined\",\n icon: \"close\",\n} as GeneralIconProps;\n\nconst fileTextIcon = {\n lib: \"antd\",\n icon: \"file-text\",\n theme: \"outlined\",\n} as GeneralIconProps;\n\nconst loadingIcon = {\n lib: \"antd\",\n icon: \"loading\",\n theme: \"outlined\",\n} as GeneralIconProps;\n\ninterface UploadFileComponentProps extends UploadFileProps, FormItemProps {\n onChange?: (fileDataList: FileData[]) => void;\n}\n\nexport function EoUploadFileComponent(props: UploadFileComponentProps) {\n const {\n value,\n multiple,\n accept,\n maxCount,\n limitSize,\n buttonIcon,\n buttonText,\n buttonType,\n overMaxCountMode,\n uploadDraggable,\n draggableUploadTip,\n autoUpload,\n url,\n method,\n uploadName,\n onChange,\n } = props;\n const { t } = useTranslation(NS);\n const theme = useCurrentTheme();\n\n const [isDragOver, setIsDragOver] = useState(false);\n\n const handleChange = (fileDataList: FileData[]) => {\n onChange?.(fileDataList);\n };\n\n const itemRender = (\n fileData: FileData,\n _fileDataList: FileData[],\n actions: ItemActions\n ) => {\n const { uid, name, status = \"done\", errors } = fileData;\n\n return (\n <WrappedTooltip content={errors?.map((item) => item.message).join(\", \")}>\n <div\n key={uid}\n className={classNames(\n \"upload-item-container\",\n status && `upload-item-container-${status}`\n )}\n >\n <div className=\"upload-item-inner\">\n <WrappedIcon\n className={classNames(\n \"upload-item-icon\",\n status === \"uploading\" && \"upload-icon\"\n )}\n {...(status === \"uploading\" ? loadingIcon : fileTextIcon)}\n />\n <div className=\"upload-item-infos\">\n <div className=\"upload-item-file-name\">{name}</div>\n </div>\n <div className=\"upload-item-operators\">\n <WrappedIcon\n className=\"delete-icon\"\n {...(status === \"done\" ? deleteIcon : closeIcon)}\n onClick={actions.remove}\n />\n </div>\n </div>\n </div>\n </WrappedTooltip>\n );\n };\n\n const validator = (curValue: FileData[]) => {\n if (curValue?.some((file) => file.status === \"uploading\")) {\n return t(K.FILE_UPLOADING);\n }\n return \"\";\n };\n\n return (\n <WrappedFormItem\n exportparts=\"message\"\n {...pickFormItemProps(props)}\n validator={validator}\n >\n <Upload\n itemRender={itemRender}\n fileList={value}\n multiple={multiple}\n accept={accept}\n maxCount={maxCount}\n limitSize={limitSize}\n overMaxCountMode={overMaxCountMode}\n autoUpload={autoUpload}\n action={url}\n method={method}\n uploadName={uploadName}\n onChange={handleChange}\n >\n {(fileDataList: FileData[], uploadActions: UploadActions) => {\n const isMaxQuantity =\n maxCount !== undefined && fileDataList.length >= maxCount;\n\n return uploadDraggable ? (\n <div\n className={classNames(\n \"upload-drag-button\",\n isDragOver && \"upload-drag-button-drag-over\"\n )}\n onClick={uploadActions.upload}\n onDragEnter={(e) => {\n e.preventDefault();\n setIsDragOver(true);\n }}\n onDragOver={(e) => {\n e.preventDefault();\n }}\n onDragLeave={() => {\n setIsDragOver(false);\n }}\n onDrop={(e) => {\n e.preventDefault();\n setIsDragOver(false);\n e.dataTransfer.files?.length &&\n uploadActions.uploadFiles(e.dataTransfer.files);\n }}\n >\n <div className=\"upload-drag-button-inner\">\n <WrappedEasyopsIcon\n className=\"upload-drag-button-icon\"\n category=\"colored-common\"\n icon={theme == \"dark-v2\" ? \"upload-dark\" : \"upload-light\"}\n />\n <div className=\"upload-drag-text\">\n <Trans\n i18nKey={t(K.DRAG_UPLOAD_TEXT)}\n components={{\n total: <strong />,\n }}\n />\n </div>\n {draggableUploadTip && (\n <div className=\"upload-drag-tip\">{draggableUploadTip}</div>\n )}\n </div>\n </div>\n ) : (\n <WrappedButton\n disabled={isMaxQuantity}\n type={buttonType}\n icon={buttonIcon}\n onClick={uploadActions.upload}\n >\n {buttonText || t(K.UPLOAD)}\n </WrappedButton>\n );\n }}\n </Upload>\n </WrappedFormItem>\n );\n}\n","import React, { useEffect, useRef, useMemo, useState } from \"react\";\nimport { EventEmitter, createDecorators } from \"@next-core/element\";\nimport \"@next-core/theme\";\nimport styleText from \"./styles.shadow.css\";\nimport { wrapBrick } from \"@next-core/react-element\";\nimport { formatOptions } from \"../utils/formatOptions.js\";\nimport { cloneDeep, isEqual, toLower } from \"lodash\";\nimport type {\n Input,\n InputEvents,\n InputEventsMap,\n InputProps,\n} from \"../input/index.jsx\";\nimport classNames from \"classnames\";\nimport {\n FormItemElementBase,\n MessageBody,\n pickFormItemProps,\n} from \"@next-shared/form\";\nimport type { FormItem, FormItemProps } from \"../form-item/index.jsx\";\n\nconst { defineElement, property, event } = createDecorators();\nconst WrappedFormItem = wrapBrick<FormItem, FormItemProps>(\"eo-form-item\");\n\nconst WrappedInput = wrapBrick<Input, InputProps, InputEvents, InputEventsMap>(\n \"eo-input\",\n {\n onChange: \"change\",\n }\n);\n\nexport interface AutoCompleteProps extends FormItemProps {\n curElement?: HTMLElement;\n value?: string;\n options?: string[] | OptionType[];\n placeholder?: string;\n inputStyle?: React.CSSProperties;\n disabled?: boolean;\n filterByCaption?: boolean;\n validateState?: string;\n onChange?: (v: any) => void;\n}\n\nexport interface AutoCompleteEvents {\n change: CustomEvent<string>;\n}\n\nexport interface AutoCompleteEventsMap {\n onChange: \"change\";\n}\nexport interface Option {\n label: string;\n caption?: string;\n value: any;\n}\n\nexport interface OptionGroup {\n label: string;\n options: Option[];\n}\n\nexport type OptionType = Option | OptionGroup;\n\n/**\n * 带候选项的输入框\n * @author zhendonghuang\n *\n * @category form-input-basic\n */\nexport\n@defineElement(\"eo-auto-complete\", {\n styleTexts: [styleText],\n})\nclass AutoComplete extends FormItemElementBase {\n /**\n * 字段名称\n */\n @property() accessor name: string | undefined;\n\n /**\n * 占位说明\n */\n @property() accessor placeholder: string | undefined;\n\n /**\n * 字段文本\n */\n @property() accessor label: string | undefined;\n\n /**\n * 输入框样式\n */\n @property({\n attribute: false,\n })\n accessor inputStyle: React.CSSProperties | undefined;\n\n /**\n * 是否禁用\n */\n @property({ type: Boolean })\n accessor disabled: boolean | undefined;\n\n /**\n * 是否必填\n */\n @property({ type: Boolean }) accessor required: boolean | undefined;\n\n @property()\n accessor value: string | undefined;\n\n /**\n * 选项列表\n * @required\n */\n @property({ attribute: false })\n accessor options: string[] | OptionType[] | undefined;\n\n /**\n * 搜索时是否根据caption过滤options\n */\n @property({ type: Boolean }) accessor filterByCaption: boolean | undefined;\n\n /**\n * 表单项校验方法\n */\n @property({\n attribute: false,\n })\n accessor validator: ((value: any) => MessageBody) | undefined;\n\n /**\n * 正则校验规则\n */\n @property() accessor pattern: string | undefined;\n\n /**\n * 校验文本信息\n */\n @property({ attribute: false }) accessor message:\n | Record<string, string>\n | undefined;\n\n /**\n * 值改变事件\n */\n @event({ type: \"change\" })\n accessor #changeEvent!: EventEmitter<string>;\n handleInputChange = (value: string) => {\n this.value = value;\n this.#changeEvent.emit(value);\n };\n\n render() {\n return (\n <EoAutoCompleteComponent\n curElement={this}\n formElement={this.getFormElement()}\n name={this.name}\n label={this.label}\n placeholder={this.placeholder}\n disabled={this.disabled}\n inputStyle={this.inputStyle}\n required={this.required}\n message={this.message}\n value={this.value}\n options={this.options}\n labelBrick={this.labelBrick}\n helpBrick={this.helpBrick}\n notRender={this.notRender}\n validator={this.validator}\n pattern={this.pattern}\n filterByCaption={this.filterByCaption}\n validateState={this.validateState}\n trigger=\"handleInputChange\"\n onChange={this.handleInputChange}\n />\n );\n }\n}\n\nexport function EoAutoCompleteComponent(props: AutoCompleteProps) {\n const {\n onChange,\n inputStyle,\n disabled,\n placeholder,\n filterByCaption,\n validateState,\n } = props;\n const [options, setOptions] = useState(props.options || []);\n const [filteredOptions, setFilteredOptions] = useState<any[]>([]);\n const [active, setActive] = useState(false);\n const [value, setValue] = useState<string>(\"\");\n const inputRef = useRef<any>();\n const containerRef = useRef<HTMLDivElement>(null);\n\n const originalOptions: OptionType[] = useMemo(() => {\n const walkOptions = (options: (OptionType | string)[]): OptionType[] => {\n return formatOptions(options)?.map((op) => {\n if (\"options\" in op && Array.isArray(op.options)) {\n return { ...op, options: walkOptions(op.options) } as OptionGroup;\n } else {\n return op;\n }\n });\n };\n\n return walkOptions(options);\n }, [options]);\n\n const handleChange = (e: CustomEvent<string>) => {\n setValue(e.detail);\n const search = (options: OptionType[]) => {\n for (let i = options.length - 1; i >= 0; i--) {\n const option = options[i] as OptionGroup;\n if (option.options?.length) {\n search(option.options);\n }\n if (\n !option.options?.length &&\n !toLower(option.label).includes(toLower(e.detail)) &&\n (!filterByCaption ||\n !toLower((option as any).caption).includes(toLower(e.detail)))\n ) {\n options.splice(i, 1);\n }\n }\n return options;\n };\n const result = search(cloneDeep(originalOptions));\n setFilteredOptions(result);\n onChange?.(e.detail);\n };\n useEffect(() => {\n if (!isEqual(props.options, options)) {\n setOptions(props.options || []);\n }\n }, [props.options]);\n\n useEffect(() => {\n setValue(props.value || \"\");\n }, [props.value]);\n\n useEffect(() => {\n setFilteredOptions(originalOptions);\n }, [originalOptions]);\n\n useEffect(() => {\n const handleDocumentClick = (e: MouseEvent) => {\n e.stopPropagation();\n const path = e.composedPath();\n const containerElement = containerRef.current;\n if (containerElement && path.includes(containerElement)) return;\n setActive(false);\n inputRef.current?.blur();\n };\n document.addEventListener(\"click\", handleDocumentClick);\n return () => {\n document.removeEventListener(\"click\", handleDocumentClick);\n };\n }, []);\n\n const renderLabel = (option: Option, index: number) => {\n return (\n <div\n key={`${option.label}_${index}`}\n className={classNames(\"option-container\", {\n \"selected-option\": value === option.value,\n })}\n onClick={() => {\n setValue(option.value);\n setActive(false);\n onChange?.(option.value);\n }}\n >\n <div className=\"label\">{option.label}</div>\n {option.caption && <div className=\"caption\">{option.caption}</div>}\n </div>\n );\n };\n\n return (\n <WrappedFormItem exportparts=\"message\" {...pickFormItemProps(props)}>\n <div className=\"complete-container\" ref={containerRef}>\n <WrappedInput\n ref={inputRef}\n value={value}\n placeholder={placeholder}\n disabled={disabled}\n inputStyle={inputStyle}\n validateState={validateState}\n onFocus={() => {\n setActive(true);\n }}\n onChange={handleChange as any}\n />\n {active && filteredOptions.length ? (\n <div className=\"dropdown-wrapper\">\n <div className=\"dropdown-list\">\n {filteredOptions.map((f: any, index) =>\n f.options?.length ? (\n <div key={`${f.label}_${index}`} className=\"group-wrapper\">\n <div className=\"group-item\">{f.label}</div>\n {f.options.map((option: any, i: number) =>\n renderLabel(option, i)\n )}\n </div>\n ) : (\n renderLabel(f, index)\n )\n )}\n </div>\n <slot name=\"options-toolbar\"></slot>\n </div>\n ) : null}\n </div>\n </WrappedFormItem>\n );\n}\n","\"use client\";\n\nvar __rest = this && this.__rest || function (s, e) {\n var t = {};\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];\n }\n return t;\n};\nimport * as React from 'react';\nimport genPurePanel from '../_util/PurePanel';\nimport { devUseWarning } from '../_util/warning';\nimport DatePicker from '../date-picker';\nimport useVariant from '../form/hooks/useVariants';\nconst {\n TimePicker: InternalTimePicker,\n RangePicker: InternalRangePicker\n} = DatePicker;\nconst RangePicker = /*#__PURE__*/React.forwardRef((props, ref) => (/*#__PURE__*/React.createElement(InternalRangePicker, Object.assign({}, props, {\n picker: \"time\",\n mode: undefined,\n ref: ref\n}))));\nconst TimePicker = /*#__PURE__*/React.forwardRef((_a, ref) => {\n var {\n addon,\n renderExtraFooter,\n variant,\n bordered\n } = _a,\n restProps = __rest(_a, [\"addon\", \"renderExtraFooter\", \"variant\", \"bordered\"]);\n if (process.env.NODE_ENV !== 'production') {\n const warning = devUseWarning('TimePicker');\n warning.deprecated(!addon, 'addon', 'renderExtraFooter');\n }\n const [mergedVariant] = useVariant('timePicker', variant, bordered);\n const internalRenderExtraFooter = React.useMemo(() => {\n if (renderExtraFooter) {\n return renderExtraFooter;\n }\n if (addon) {\n return addon;\n }\n return undefined;\n }, [addon, renderExtraFooter]);\n return /*#__PURE__*/React.createElement(InternalTimePicker, Object.assign({}, restProps, {\n mode: undefined,\n ref: ref,\n renderExtraFooter: internalRenderExtraFooter,\n variant: mergedVariant\n }));\n});\nif (process.env.NODE_ENV !== 'production') {\n TimePicker.displayName = 'TimePicker';\n}\n// We don't care debug panel\n/* istanbul ignore next */\nconst PurePanel = genPurePanel(TimePicker, 'popupAlign', undefined, 'picker');\nTimePicker._InternalPanelDoNotUseOrYouWillBeFired = PurePanel;\nTimePicker.RangePicker = RangePicker;\nTimePicker._InternalPanelDoNotUseOrYouWillBeFired = PurePanel;\nexport default TimePicker;","import React, { useEffect, useMemo, useState } from \"react\";\nimport { createDecorators, EventEmitter } from \"@next-core/element\";\nimport { wrapBrick } from \"@next-core/react-element\";\nimport \"@next-core/theme\";\nimport styleText from \"./styles.shadow.css\";\nimport fixStyleText from \"./fix-style.shadow.css\";\nimport { TimePicker, ConfigProvider, theme } from \"antd\";\nimport { useCurrentTheme } from \"@next-core/react-runtime\";\nimport { FormItemElementBase, pickFormItemProps } from \"@next-shared/form\";\nimport type { FormItem, FormItemProps } from \"../form-item/index.jsx\";\nimport { TimePickerProps } from \"antd/lib/time-picker\";\nimport { StyleProvider, createCache } from \"@ant-design/cssinjs\";\nimport { i18n } from \"@next-core/i18n\";\nimport { isNil } from \"lodash\";\nimport dayjs from \"dayjs\";\nimport type { Dayjs } from \"dayjs\";\nimport customParseFormat from \"dayjs/plugin/customParseFormat.js\";\nimport enUS from \"antd/locale/en_US.js\";\nimport zhCN from \"antd/locale/zh_CN.js\";\n\ndayjs.extend(customParseFormat);\n\nconst { defineElement, property, event } = createDecorators();\nconst WrappedFormItem = wrapBrick<FormItem, FormItemProps>(\"eo-form-item\");\n\ninterface EoTimePickerProps extends FormItemProps {\n shadowRoot: ShadowRoot | null;\n configProps?: Partial<TimePickerProps>;\n placeholder?: string;\n value?: string;\n disabled?: boolean;\n onChange?: (value: string) => void;\n onOpenChange?: (flag: boolean, value: string) => void;\n}\n\n/**\n * 时间选择器\n * @author zhendonghuang\n * @category form-input-basic\n */\nexport\n@defineElement(\"eo-time-picker\", {\n styleTexts: [styleText, fixStyleText],\n})\nclass EoTimePicker extends FormItemElementBase {\n /**\n * 时间选择器字段名\n */\n @property() accessor name: string | undefined;\n\n /**\n * 时间选择器说明\n */\n @property() accessor label: string | undefined;\n\n /**\n *时间选择器的初始值\n */\n @property() accessor value: string | undefined;\n\n /**\n * 时间选择器占位说明\n */\n @property()\n accessor placeholder: string | undefined;\n\n /**\n * 校验文本信息\n */\n @property({ attribute: false })\n accessor message: Record<string, string> | undefined;\n\n /**\n * 是否禁用\n */\n @property({ type: Boolean }) accessor disabled: boolean | undefined;\n\n /**\n * 是否必填\n */\n @property({ type: Boolean }) accessor required: boolean | undefined;\n\n /**\n * 透传 antd timePicker 属性 [timePickerProps](https://ant.design/components/time-picker-cn)\n */\n @property({ attribute: false })\n accessor configProps: Partial<TimePickerProps> | undefined;\n\n /**\n *时间变化时触发\n */\n @event({ type: \"change\" })\n accessor #changeEvent!: EventEmitter<string>;\n\n /**\n *面板打开时触发, 传出当前时间值\n */\n @event({ type: \"open\" })\n accessor #openEvent!: EventEmitter<string>;\n\n /**\n *面板关闭时触发,传出当前时间值\n */\n @event({ type: \"close\" })\n accessor #closeEvent!: EventEmitter<string>;\n\n handleChange = (value: string): void => {\n this.value = value;\n this.#changeEvent.emit(value);\n };\n #handleOpenChange = (flag: boolean, value: string): void => {\n if (flag) {\n this.#openEvent.emit(value);\n } else {\n this.#closeEvent.emit(value);\n }\n };\n\n render() {\n return (\n <EoTimePickerComponent\n curElement={this}\n formElement={this.getFormElement()}\n configProps={this.configProps}\n name={this.name}\n label={this.label}\n onChange={this.handleChange}\n trigger=\"handleChange\"\n onOpenChange={this.#handleOpenChange}\n placeholder={this.placeholder}\n value={this.value}\n required={this.required}\n message={this.message}\n notRender={this.notRender}\n labelBrick={this.labelBrick}\n helpBrick={this.helpBrick}\n shadowRoot={this.shadowRoot}\n disabled={this.disabled}\n />\n );\n }\n}\n\nexport function EoTimePickerComponent(props: EoTimePickerProps) {\n const {\n configProps = {},\n onChange,\n onOpenChange,\n disabled,\n placeholder,\n } = props;\n const currentTheme = useCurrentTheme();\n const locale =\n i18n.language && i18n.language.split(\"-\")[0] === \"en\" ? enUS : zhCN;\n const [value, setValue] = useState<Dayjs | null>(null);\n const format: string = (configProps.format as string) ?? \"HH:mm:ss\";\n useEffect(() => {\n if (!isNil(props.value)) {\n setValue(dayjs(props.value, format) as Dayjs);\n } else {\n setValue(null);\n }\n }, [props.value, format]);\n\n const handleChange = (_time: Dayjs | null, timeString: string): void => {\n onChange?.(timeString);\n };\n\n const handleOpenChange = (flag: boolean): void => {\n onOpenChange?.(\n flag,\n !isNil(value) ? (dayjs(value as Dayjs).format(format) as string) : \"\"\n );\n };\n const cahce = useMemo(() => {\n return createCache();\n }, []);\n\n return (\n <WrappedFormItem exportparts=\"message\" {...pickFormItemProps(props)}>\n <ConfigProvider\n locale={locale as any}\n theme={{\n algorithm:\n currentTheme === \"dark-v2\"\n ? theme.darkAlgorithm\n : theme.defaultAlgorithm,\n }}\n >\n <StyleProvider container={props.shadowRoot as ShadowRoot} cache={cahce}>\n <div\n onChange={(e) => {\n e.stopPropagation();\n }}\n >\n <TimePicker\n {...configProps}\n getPopupContainer={(trigger) => trigger}\n value={value}\n // Currently we don't support multiple pick mode\n onChange={handleChange as any}\n onOpenChange={handleOpenChange}\n disabled={disabled}\n placeholder={placeholder}\n allowClear={configProps.allowClear}\n />\n </div>\n </StyleProvider>\n </ConfigProvider>\n </WrappedFormItem>\n );\n}\n","export enum K {\n NEXT_DAY = \"NEXT_DAY\",\n TODAY = \"TODAY\",\n LAST_DAY = \"LAST_DAY\",\n NEXT_WEEK = \"NEXT_WEEK\",\n THIS_WEEK = \"THIS_WEEK\",\n LAST_WEEK = \"LAST_WEEK\",\n NEXT_MONTH = \"NEXT_MONTH\",\n THIS_MONTH = \"THIS_MONTH\",\n LAST_MONTH = \"LAST_MONTH\",\n NEXT_QUARTER = \"NEXT_QUARTER\",\n THIS_QUARTER = \"THIS_QUARTER\",\n LAST_QUARTER = \"LAST_QUARTER\",\n NEXT_YEAR = \"NEXT_YEAR\",\n THIS_YEAR = \"THIS_YEAR\",\n LAST_YEAR = \"LAST_YEAR\",\n FISRT_QUARTER = \"FISRT_QUARTER\",\n SECOND_QUARTER = \"SECOND_QUARTER\",\n THIRD_QUARTER = \"THIRD_QUARTER\",\n FOURTH_QUARTER = \"FOURTH_QUARTER\",\n}\n\nconst en: Locale = {\n NEXT_DAY: \"Next day\",\n TODAY: \"Today\",\n LAST_DAY: \"Previous day\",\n NEXT_WEEK: \"Next week\",\n THIS_WEEK: \"This week\",\n LAST_WEEK: \"Previous week\",\n NEXT_MONTH: \"Next month\",\n THIS_MONTH: \"This month\",\n LAST_MONTH: \"Previous month\",\n NEXT_QUARTER: \"Next quarter\",\n THIS_QUARTER: \"This quarter\",\n LAST_QUARTER: \"Previous quarter\",\n NEXT_YEAR: \"Next year\",\n THIS_YEAR: \"This year\",\n LAST_YEAR: \"Previous year\",\n FISRT_QUARTER: \"First quarter\",\n SECOND_QUARTER: \"Second quarter\",\n THIRD_QUARTER: \"Third quarter\",\n FOURTH_QUARTER: \"Fourth quarter\",\n};\n\nconst zh: Locale = {\n NEXT_DAY: \"下日\",\n TODAY: \"今日\",\n LAST_DAY: \"上日\",\n NEXT_WEEK: \"下周\",\n THIS_WEEK: \"本周\",\n LAST_WEEK: \"上周\",\n NEXT_MONTH: \"下月\",\n THIS_MONTH: \"本月\",\n LAST_MONTH: \"上月\",\n NEXT_QUARTER: \"下季度\",\n THIS_QUARTER: \"本季度\",\n LAST_QUARTER: \"上季度\",\n NEXT_YEAR: \"下年\",\n THIS_YEAR: \"今年\",\n LAST_YEAR: \"上年\",\n FISRT_QUARTER: \"第一季度\",\n SECOND_QUARTER: \"第二季度\",\n THIRD_QUARTER: \"第三季度\",\n FOURTH_QUARTER: \"第四季度\",\n};\n\nexport const NS = \"bricks/form/eo-date-picker\";\n\nexport const locales = { en, zh };\n\ntype Locale = { [key in K]: string };\n","// This icon file is generated automatically.\nvar LeftOutlined = { \"icon\": { \"tag\": \"svg\", \"attrs\": { \"viewBox\": \"64 64 896 896\", \"focusable\": \"false\" }, \"children\": [{ \"tag\": \"path\", \"attrs\": { \"d\": \"M724 218.3V141c0-6.7-7.7-10.4-12.9-6.3L260.3 486.8a31.86 31.86 0 000 50.3l450.8 352.1c5.3 4.1 12.9.4 12.9-6.3v-77.3c0-4.9-2.3-9.6-6.1-12.6l-360-281 360-281.1c3.8-3 6.1-7.7 6.1-12.6z\" } }] }, \"name\": \"left\", \"theme\": \"outlined\" };\nexport default LeftOutlined;\n","import _extends from \"@babel/runtime/helpers/esm/extends\";\n// GENERATE BY ./scripts/generate.ts\n// DON NOT EDIT IT MANUALLY\n\nimport * as React from 'react';\nimport LeftOutlinedSvg from \"@ant-design/icons-svg/es/asn/LeftOutlined\";\nimport AntdIcon from \"../components/AntdIcon\";\nvar LeftOutlined = function LeftOutlined(props, ref) {\n return /*#__PURE__*/React.createElement(AntdIcon, _extends({}, props, {\n ref: ref,\n icon: LeftOutlinedSvg\n }));\n};\n\n/**![left](data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTAiIGhlaWdodD0iNTAiIGZpbGw9IiNjYWNhY2EiIHZpZXdCb3g9IjY0IDY0IDg5NiA4OTYiIGZvY3VzYWJsZT0iZmFsc2UiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PHBhdGggZD0iTTcyNCAyMTguM1YxNDFjMC02LjctNy43LTEwLjQtMTIuOS02LjNMMjYwLjMgNDg2LjhhMzEuODYgMzEuODYgMCAwMDAgNTAuM2w0NTAuOCAzNTIuMWM1LjMgNC4xIDEyLjkuNCAxMi45LTYuM3YtNzcuM2MwLTQuOS0yLjMtOS42LTYuMS0xMi42bC0zNjAtMjgxIDM2MC0yODEuMWMzLjgtMyA2LjEtNy43IDYuMS0xMi42eiIgLz48L3N2Zz4=) */\nvar RefIcon = /*#__PURE__*/React.forwardRef(LeftOutlined);\nif (process.env.NODE_ENV !== 'production') {\n RefIcon.displayName = 'LeftOutlined';\n}\nexport default RefIcon;","import React, {\n useEffect,\n useState,\n useCallback,\n useMemo,\n CSSProperties,\n} from \"react\";\nimport { createDecorators, EventEmitter } from \"@next-core/element\";\nimport \"@next-core/theme\";\nimport styleText from \"./styles.shadow.css\";\nimport { wrapBrick } from \"@next-core/react-element\";\nimport { DatePicker, ConfigProvider, theme } from \"antd\";\nimport type {\n GeneralIcon,\n GeneralIconProps,\n} from \"@next-bricks/icons/general-icon\";\nimport { StyleProvider, createCache } from \"@ant-design/cssinjs\";\nimport { useCurrentTheme } from \"@next-core/react-runtime\";\nimport { FormItemElementBase, pickFormItemProps } from \"@next-shared/form\";\nimport type { FormItem, FormItemProps } from \"../form-item/index.jsx\";\nimport { i18n, initializeI18n } from \"@next-core/i18n\";\nimport { K, NS, locales } from \"./i18n.js\";\nimport dayjs from \"dayjs\";\nimport type { Dayjs } from \"dayjs\";\nimport customParseFormat from \"dayjs/plugin/customParseFormat.js\";\nimport enUS from \"antd/locale/en_US.js\";\nimport zhCN from \"antd/locale/zh_CN.js\";\nimport isoWeek from \"dayjs/plugin/isoWeek.js\";\nimport advancedFormat from \"dayjs/plugin/advancedFormat.js\";\nimport quarterOfYear from \"dayjs/plugin/quarterOfYear.js\";\nimport \"dayjs/locale/zh-cn.js\";\nimport classNames from \"classnames\";\nimport { DisabledDateType, PickerMode, DisabledDate } from \"../interface.js\";\nimport { LeftOutlined, RightOutlined } from \"@ant-design/icons\";\nimport moment from \"moment\";\n\ninitializeI18n(NS, locales);\ndayjs.extend(customParseFormat);\ndayjs.extend(advancedFormat);\ndayjs.extend(isoWeek);\ndayjs.extend(quarterOfYear);\n\ninterface InternalStateDatePickerProps {\n placeholder?: string;\n value?: Dayjs;\n showTime?: boolean;\n inputStyle?: React.CSSProperties;\n format?: string;\n picker?: PickerMode;\n disabledDate?: DisabledDateType;\n useFastSelectBtn?: boolean;\n futureDateDisabled?: boolean;\n disabled?: boolean;\n onChange?: (value: Dayjs | null, dateString: string) => void;\n onOk?: (date: Dayjs) => void;\n}\n\ninterface EoDatePickerProps\n extends Omit<InternalStateDatePickerProps, \"value\" | \"onChange\" | \"onOk\">,\n FormItemProps {\n shadowRoot: ShadowRoot | null;\n value?: string;\n onChange?: (value: string) => void;\n onOk?: (value: string) => void;\n}\n\ninterface FieldSetAndRanges {\n fieldSet: Set<number>;\n ranges: [number, number][];\n}\ntype PickerModeMap = {\n [K in PickerMode]: string[];\n};\n\nconst { defineElement, property, event } = createDecorators();\nconst WrappedFormItem = wrapBrick<FormItem, FormItemProps>(\"eo-form-item\");\nconst WrappedIcon = wrapBrick<GeneralIcon, GeneralIconProps>(\"eo-icon\");\n\n/**\n * 日期选择器\n * @author zhendonghuang\n * @category form-input-basic\n */\nexport\n@defineElement(\"eo-date-picker\", {\n styleTexts: [styleText],\n})\nclass EoDatePicker extends FormItemElementBase {\n /**\n * 日期选择器字段名\n */\n @property() accessor name: string | undefined;\n /**\n * 日期选择器说明\n */\n @property() accessor label: string | undefined;\n\n /**\n *日期选择器的初始值\n */\n @property() accessor value: string | undefined;\n\n /**\n * 日期选择器占位说明\n */\n @property()\n accessor placeholder: string | undefined;\n\n /**\n * 校验文本信息\n */\n @property({ attribute: false })\n accessor message: Record<string, string> | undefined;\n\n /**\n * 是否禁用\n */\n @property({ type: Boolean }) accessor disabled: boolean | undefined;\n\n /**\n * 是否必填\n */\n @property({ type: Boolean }) accessor required: boolean | undefined;\n\n /**\n * 是否显示时间, 当设为 `true` 时, 请同时设置 `format` 为 `YYYY-MM-DD HH:mm:ss` 使其也显示具体时,分,秒 的时间\n */\n @property({\n type: Boolean,\n })\n accessor showTime: boolean | undefined;\n\n /**\n * 显示预览的格式,具体配置参考 [dayjs](https://day.js.org/docs/zh-CN/display/format#%E6%94%AF%E6%8C%81%E7%9A%84%E6%A0%BC%E5%BC%8F%E5%8C%96%E5%8D%A0%E4%BD%8D%E7%AC%A6%E5%88%97%E8%A1%A8),注意,这里并非是定义给后台的数据格式,给后台的数据格式定义请参考 `general-form` 构件的 [valueTypes](developers/brick-book/brick/forms.general-form) 属性\n */\n @property()\n accessor format: string | undefined;\n\n /**\n * 设置选择器类型\n */\n @property({ attribute: false })\n accessor picker: PickerMode | undefined;\n\n /**\n * 不可选择未来日期,优先级高于disabledDate\n */\n @property({ type: Boolean })\n accessor futureDateDisabled: boolean | undefined;\n\n /**\n * 不可选择的日期\n */\n @property({ attribute: false })\n accessor disabledDate: DisabledDateType | undefined;\n\n /**\n *快速选项\n */\n @property({ type: Boolean })\n accessor useFastSelectBtn: boolean | undefined;\n\n /**\n * 输入框样式\n */\n @property({\n attribute: false,\n })\n accessor inputStyle: CSSProperties | undefined;\n\n /**\n *日期变化时触发\n */\n @event({ type: \"change\" })\n accessor #changeEvent!: EventEmitter<string>;\n\n /**\n *点击确定按钮触发(showTime 为 true 使用)\n */\n @event({ type: \"ok\" })\n accessor #okEvent!: EventEmitter<string>;\n\n handleChange = (value: string): void => {\n this.value = value;\n this.#changeEvent.emit(value);\n };\n #handleOk = (value: string): void => {\n this.#okEvent.emit(value);\n };\n render() {\n return (\n <EoDatePickerComponent\n curElement={this}\n formElement={this.getFormElement()}\n shadowRoot={this.shadowRoot}\n label={this.label}\n name={this.name}\n value={this.value}\n message={this.message}\n required={this.required}\n placeholder={this.placeholder}\n labelBrick={this.labelBrick}\n helpBrick={this.helpBrick}\n inputStyle={this.inputStyle}\n disabled={this.disabled}\n disabledDate={this.disabledDate}\n notRender={this.notRender}\n futureDateDisabled={this.futureDateDisabled}\n picker={this.picker}\n format={this.format}\n showTime={this.showTime}\n onChange={this.handleChange}\n trigger={\"handleChange\"}\n onOk={this.#handleOk}\n useFastSelectBtn={this.useFastSelectBtn}\n />\n );\n }\n}\n\nconst getFieldSetAndRanges = (\n expression?: string | number\n): FieldSetAndRanges => {\n const fieldSet = new Set<number>();\n const ranges: [number, number][] = [];\n `${expression}`.split(\",\").forEach((part) => {\n if (part.includes(\"-\")) {\n const range = part.split(\"-\").map((v) => Number(v)) as [number, number];\n ranges.push(range);\n } else if (part.trim() !== \"\" && !Number.isNaN(Number(part))) {\n fieldSet.add(Number(part));\n }\n });\n return { fieldSet, ranges };\n};\n\nconst isInFieldSetOrRanges = (\n cur: number,\n fieldSetAndRanges: FieldSetAndRanges\n): boolean => {\n const { fieldSet, ranges } = fieldSetAndRanges;\n return fieldSet.size === 0 && ranges.length === 0\n ? true\n : fieldSet.has(cur) ||\n ranges.some(([min, max]) => cur >= min && cur <= max);\n};\n\nconst isEmptyFieldSetOrRanges = (\n fieldSetAndRanges: FieldSetAndRanges\n): boolean => {\n const { fieldSet, ranges } = fieldSetAndRanges;\n return fieldSet.size === 0 && ranges.length === 0;\n};\n\nconst getFieldsFromFieldSetAndRanges = (\n fieldSetAndRanges: FieldSetAndRanges\n): number[] => {\n const { fieldSet, ranges } = fieldSetAndRanges;\n let fields = [...fieldSet];\n ranges.forEach(([min, max]) => {\n fields = fields.concat([...Array(max + 1).keys()].slice(min));\n });\n return [...new Set(fields)];\n};\n\nexport function InternalStateDatePicker(\n props: InternalStateDatePickerProps\n): React.ReactElement {\n const {\n picker,\n format,\n showTime,\n inputStyle,\n disabledDate,\n futureDateDisabled,\n useFastSelectBtn,\n placeholder,\n disabled,\n onChange,\n onOk,\n } = props;\n\n const [value, setValue] = useState(props.value);\n const [confirmDisabled, setConfirmDisabled] = useState(false);\n const crontab = useMemo(() => {\n if (!disabledDate) {\n return [];\n }\n return ([] as DisabledDate[]).concat(disabledDate).map((item) => {\n const { second, minute, hour, date, month, weekday, year } = item;\n const hourFieldSetAndRanges = getFieldSetAndRanges(hour);\n const minuteFieldSetAndRanges = getFieldSetAndRanges(minute);\n const secondFieldSetAndRanges = getFieldSetAndRanges(second);\n const yearFieldSetAndRanges = getFieldSetAndRanges(year);\n const monthFieldSetAndRanges = getFieldSetAndRanges(month);\n const dateFieldSetAndRanges = getFieldSetAndRanges(date);\n const weekFieldSetAndRanges = getFieldSetAndRanges(weekday);\n return {\n fields: {\n hour: hourFieldSetAndRanges,\n minute: minuteFieldSetAndRanges,\n second: secondFieldSetAndRanges,\n year: yearFieldSetAndRanges,\n month: monthFieldSetAndRanges,\n date: dateFieldSetAndRanges,\n weekday: weekFieldSetAndRanges,\n },\n isAllDate:\n isEmptyFieldSetOrRanges(yearFieldSetAndRanges) &&\n isEmptyFieldSetOrRanges(monthFieldSetAndRanges) &&\n isEmptyFieldSetOrRanges(dateFieldSetAndRanges) &&\n isEmptyFieldSetOrRanges(weekFieldSetAndRanges),\n isAllTime:\n isEmptyFieldSetOrRanges(hourFieldSetAndRanges) &&\n isEmptyFieldSetOrRanges(minuteFieldSetAndRanges) &&\n isEmptyFieldSetOrRanges(secondFieldSetAndRanges),\n };\n });\n }, [disabledDate]);\n\n useEffect(() => {\n setValue(props.value);\n }, [props.value]);\n\n const handleDisabledDate = (date: Dayjs): boolean => {\n const curYear = date.year();\n const curMonth = date.month() + 1;\n const curDate = date.date();\n const curWeekday = date.isoWeekday();\n return crontab.some((cron) => {\n const { isAllDate, isAllTime, fields } = cron;\n //没有限制日期或限制了时分秒,则该日可选\n if (isAllDate || !isAllTime) {\n return false;\n }\n const { year, month, weekday, date } = fields;\n return (\n isInFieldSetOrRanges(curYear, year) &&\n isInFieldSetOrRanges(curMonth, month) &&\n isInFieldSetOrRanges(curWeekday, weekday) &&\n isInFieldSetOrRanges(curDate, date)\n );\n });\n };\n\n const handleDisabledFutureDate = (date: Dayjs): boolean => {\n return date && date > dayjs();\n };\n\n const handleDisabledTime = (date: Dayjs | null) => {\n if (!date) return;\n const curYear = date.year();\n const curMonth = date.month() + 1;\n const curDate = date.date();\n const curWeekday = date.isoWeekday();\n const curHour = date.hour();\n const curMinute = date.minute();\n const currentSecond = date.second();\n let disabledHours: number[] = [];\n let disabledMinutes: number[] = [];\n let disabledSeconds: number[] = [];\n let matchCurDate = false;\n crontab.forEach((cron) => {\n const { isAllTime, fields } = cron;\n //时分秒都没输入,则所有时间都可选\n if (isAllTime) return;\n const { hour, minute, second, year, month, weekday, date } = fields;\n const isMatchDate =\n isInFieldSetOrRanges(curYear, year) &&\n isInFieldSetOrRanges(curMonth, month) &&\n isInFieldSetOrRanges(curWeekday, weekday) &&\n isInFieldSetOrRanges(curDate, date);\n matchCurDate =\n matchCurDate ||\n (isMatchDate &&\n isInFieldSetOrRanges(curHour, hour) &&\n isInFieldSetOrRanges(curMinute, minute) &&\n isInFieldSetOrRanges(currentSecond, second));\n if (isMatchDate) {\n const hourFields = isEmptyFieldSetOrRanges(hour)\n ? [...Array(24).keys()]\n : getFieldsFromFieldSetAndRanges(hour);\n const minuteFields = isEmptyFieldSetOrRanges(minute)\n ? [...Array(60).keys()]\n : getFieldsFromFieldSetAndRanges(minute);\n const secondFields = isEmptyFieldSetOrRanges(second)\n ? [...Array(60).keys()]\n : getFieldsFromFieldSetAndRanges(second);\n // 当前在禁止小时里\n if (isInFieldSetOrRanges(curHour, hour)) {\n // 当前在禁止分钟里\n if (isInFieldSetOrRanges(curMinute, minute)) {\n disabledSeconds = disabledSeconds.concat([...secondFields]);\n }\n // 秒全禁用则对应分钟也禁用\n if (secondFields.length === 60) {\n disabledMinutes = disabledMinutes.concat([...minuteFields]);\n }\n }\n // 分全禁用则对应小时也禁用\n if (minuteFields.length === 60 && secondFields.length === 60) {\n disabledHours = disabledHours.concat([...hourFields]);\n }\n }\n });\n setConfirmDisabled(matchCurDate);\n return {\n disabledHours: () => disabledHours,\n disabledMinutes: () => disabledMinutes,\n disabledSeconds: () => disabledSeconds,\n };\n };\n\n const isDatePicker = picker === \"date\";\n const isQuarterPicker = picker === \"quarter\";\n\n const PickerBtn = useCallback(() => {\n const strMap: PickerModeMap = {\n date: [\n i18n.t(`${NS}:${K.LAST_DAY}`),\n i18n.t(`${NS}:${K.TODAY}`),\n i18n.t(`${NS}:${K.NEXT_DAY}`),\n ],\n week: [\n i18n.t(`${NS}:${K.LAST_WEEK}`),\n i18n.t(`${NS}:${K.THIS_WEEK}`),\n i18n.t(`${NS}:${K.NEXT_WEEK}`),\n ],\n month: [\n i18n.t(`${NS}:${K.LAST_MONTH}`),\n i18n.t(`${NS}:${K.THIS_MONTH}`),\n i18n.t(`${NS}:${K.NEXT_MONTH}`),\n ],\n quarter: [\n i18n.t(`${NS}:${K.LAST_QUARTER}`),\n i18n.t(`${NS}:${K.THIS_QUARTER}`),\n i18n.t(`${NS}:${K.NEXT_QUARTER}`),\n ],\n year: [\n i18n.t(`${NS}:${K.LAST_YEAR}`),\n i18n.t(`${NS}:${K.THIS_YEAR}`),\n i18n.t(`${NS}:${K.NEXT_YEAR}`),\n ],\n };\n const strs = strMap[picker as PickerMode];\n const currentDate = value || dayjs();\n const handlePreTime = () => {\n let preDate: Dayjs;\n switch (picker) {\n case \"date\":\n preDate = currentDate.clone().subtract(1, \"days\");\n break;\n case \"week\":\n preDate = currentDate.clone().subtract(1, \"weeks\");\n break;\n case \"month\":\n preDate = currentDate.clone().subtract(1, \"months\");\n break;\n case \"quarter\":\n preDate = currentDate.clone().subtract(1, \"quarters\");\n break;\n case \"year\":\n preDate = currentDate.clone().subtract(1, \"years\");\n break;\n default:\n preDate = currentDate;\n break;\n }\n onChange?.(preDate, dayjs(preDate).format(format));\n setValue(preDate);\n };\n const handleCurTime = () => {\n let curDate: Dayjs;\n switch (picker) {\n case \"date\":\n curDate = dayjs();\n break;\n case \"week\":\n curDate = dayjs().startOf(\"week\");\n break;\n case \"month\":\n curDate = dayjs();\n break;\n case \"quarter\":\n curDate = dayjs().startOf(\"quarter\");\n break;\n case \"year\":\n curDate = dayjs();\n break;\n default:\n curDate = currentDate;\n break;\n }\n onChange?.(curDate, dayjs(curDate).format(format));\n setValue(curDate);\n };\n const handleNextTime = () => {\n let nextDate: Dayjs;\n switch (picker) {\n case \"date\":\n nextDate = currentDate.clone().add(1, \"days\");\n break;\n case \"week\":\n nextDate = currentDate.clone().add(1, \"weeks\");\n break;\n case \"month\":\n nextDate = currentDate.clone().add(1, \"months\");\n break;\n case \"quarter\":\n nextDate = currentDate.clone().add(1, \"quarters\");\n break;\n case \"year\":\n nextDate = currentDate.clone().add(1, \"years\");\n break;\n default:\n nextDate = currentDate;\n break;\n }\n onChange?.(nextDate, dayjs(nextDate).format(format));\n setValue(nextDate);\n };\n\n return (\n <div\n className={classNames(\"pickerBtnWrap\", {\n disabledFastSelect: disabled,\n })}\n >\n <div className={classNames(\"pre\")} onClick={() => handlePreTime()}>\n <LeftOutlined rev=\"\" />\n <span>{strs[0]}</span>\n </div>\n <div className=\"current\" onClick={() => handleCurTime()}>\n {strs[1]}\n </div>\n <div\n className={classNames({\n next: true,\n nextDisabled:\n futureDateDisabled &&\n handleDisabledFutureDate(\n currentDate\n .clone()\n .add(1, picker === \"date\" ? \"days\" : (picker as any))\n ),\n })}\n onClick={() => handleNextTime()}\n >\n <span>{strs[2]}</span>\n <RightOutlined rev=\"\" />\n </div>\n </div>\n );\n }, [value, picker, futureDateDisabled]);\n\n const cellRender = useCallback(\n (\n current: string | number | Dayjs,\n info: { originNode: React.ReactElement }\n ) => {\n const quarterMap = {\n 1: i18n.t(`${NS}:${K.FISRT_QUARTER}`),\n 2: i18n.t(`${NS}:${K.SECOND_QUARTER}`),\n 3: i18n.t(`${NS}:${K.THIRD_QUARTER}`),\n 4: i18n.t(`${NS}:${K.FOURTH_QUARTER}`),\n };\n const selectedQuarter: number = dayjs(value).quarter();\n const currentQuarter: number = dayjs(current).quarter();\n return picker === \"quarter\" ? (\n <div\n className={classNames(\"quarterContent\", {\n selectedQuarter: selectedQuarter === currentQuarter,\n })}\n >\n {quarterMap[currentQuarter as keyof typeof quarterMap]}\n </div>\n ) : (\n info.originNode\n );\n },\n [value, picker]\n );\n\n return (\n <div\n className=\"pickerWrap\"\n onChange={(e) => {\n e.stopPropagation();\n }}\n >\n <DatePicker\n cellRender={(current, info: { originNode: React.ReactElement }) => {\n return cellRender(current, info);\n }}\n value={value}\n getPopupContainer={(trigger) => trigger}\n popupClassName={classNames({\n quarterPicker: isQuarterPicker,\n confirmDisabled: confirmDisabled,\n })}\n format={format}\n showTime={isDatePicker ? showTime : undefined}\n // Currently we don't support multiple pick mode\n onChange={onChange as any}\n style={inputStyle}\n placeholder={placeholder}\n onOk={onOk}\n suffixIcon={<WrappedIcon icon=\"calendar\" lib=\"easyops\" />}\n picker={picker}\n disabledDate={\n (futureDateDisabled && handleDisabledFutureDate) ||\n (disabledDate && handleDisabledDate)\n }\n disabledTime={disabledDate && (handleDisabledTime as any)}\n disabled={disabled}\n />\n {useFastSelectBtn && <PickerBtn />}\n </div>\n );\n}\n\nexport function EoDatePickerComponent(\n props: EoDatePickerProps\n): React.ReactElement {\n const { picker = \"date\", ...restProps } = props;\n\n const PickerFormatMap = {\n date: \"YYYY-MM-DD\",\n week: \"gggg-ww周\",\n month: \"YYYY-MM月\",\n quarter: \"YYYY-第Q季度\",\n year: \"YYYY\",\n };\n const currentTheme = useCurrentTheme();\n const locale =\n i18n.language && i18n.language.split(\"-\")[0] === \"en\" ? enUS : zhCN;\n const isDatePicker = picker === \"date\";\n const format = props.format || PickerFormatMap[picker];\n\n const handleChange = (_date: Dayjs | null, dateString: string): void => {\n props.onChange?.(dateString);\n };\n\n const handleOk = (date: Dayjs): void => {\n props.onOk?.(date?.format(props.format));\n };\n const cahce = useMemo(() => {\n return createCache();\n }, []);\n\n const value: Dayjs | undefined = useMemo(() => {\n const parseValue = props.value;\n if (parseValue) {\n if (!props.format && (picker === \"week\" || picker === \"quarter\")) {\n //dayjs目前不支持解析gggg-ww周、YYYY-第Q季度格式的输入\n return dayjs(moment(parseValue, format).format());\n } else {\n return dayjs(parseValue, format);\n }\n }\n }, [props.value, format]);\n\n return (\n <WrappedFormItem exportparts=\"message\" {...pickFormItemProps(props)}>\n <ConfigProvider\n locale={locale as any}\n theme={{\n algorithm:\n currentTheme === \"dark-v2\"\n ? theme.darkAlgorithm\n : theme.defaultAlgorithm,\n }}\n >\n <StyleProvider container={props.shadowRoot as ShadowRoot} cache={cahce}>\n <InternalStateDatePicker\n {...restProps}\n value={value}\n format={format}\n onChange={handleChange}\n onOk={isDatePicker ? handleOk : undefined}\n picker={picker}\n />\n </StyleProvider>\n </ConfigProvider>\n </WrappedFormItem>\n );\n}\n","export enum K {\n TODAY = \"TODAY\",\n THIS_WEEK = \"THIS_WEEK\",\n THIS_MONTH = \"THIS_MONTH\",\n THIS_QUARTER = \"THIS_QUARTER\",\n THIS_YEAR = \"THIS_YEAR\",\n START_TIME_END_TIME_CANNOT_EQUAL = \"START_TIME_END_TIME_CANNOT_EQUAL\",\n START_TIME_REQUIRED = \"START_TIME_REQUIRED\",\n END_TIME_REQUIRED = \"END_TIME_REQUIRED\",\n}\n// HELLO = \"HELLO\",\n\nconst en: Locale = {\n TODAY: \"Today\",\n THIS_WEEK: \"This Week\",\n THIS_MONTH: \"This Month\",\n THIS_QUARTER: \"This Quarter\",\n THIS_YEAR: \"This Year\",\n START_TIME_END_TIME_CANNOT_EQUAL: \"Start Time and End Time can NOT be equal\",\n START_TIME_REQUIRED: \"Start Time is required\",\n END_TIME_REQUIRED: \"End Time is required\",\n};\n\nconst zh: Locale = {\n TODAY: \"今天\",\n THIS_WEEK: \"本周\",\n THIS_MONTH: \"本月\",\n THIS_QUARTER: \"本季度\",\n THIS_YEAR: \"今年\",\n START_TIME_END_TIME_CANNOT_EQUAL: \"开始时间和结束时间不能相等\",\n START_TIME_REQUIRED: \"开始时间必填\",\n END_TIME_REQUIRED: \"结束时间必填\",\n};\n\nexport const NS = \"bricks/form/eo-time-range-picker\";\n\nexport const locales = { en, zh };\n\ntype Locale = { [k in K]: string } & {\n [k in K as `${k}_plural`]?: string;\n};\n","import React, {\n useEffect,\n useMemo,\n useState,\n useRef,\n CSSProperties,\n} from \"react\";\nimport { createDecorators, EventEmitter } from \"@next-core/element\";\nimport { wrapBrick } from \"@next-core/react-element\";\nimport { useCurrentTheme } from \"@next-core/react-runtime\";\nimport {\n FormItemElementBase,\n MessageBody,\n pickFormItemProps,\n} from \"@next-shared/form\";\nimport type { FormItem, FormItemProps } from \"../form-item/index.jsx\";\nimport { TimePicker, DatePicker, ConfigProvider, theme } from \"antd\";\nimport { StyleProvider, createCache } from \"@ant-design/cssinjs\";\nimport \"@next-core/theme\";\nimport type {\n GeneralIcon,\n GeneralIconProps,\n} from \"@next-bricks/icons/general-icon\";\nimport styleText from \"./styles.shadow.css\";\nimport fixStyleText from \"../time-picker/fix-style.shadow.css\";\nimport { i18n, initializeI18n } from \"@next-core/i18n\";\nimport { K, NS, locales } from \"./i18n.js\";\nimport { isEmpty, uniqueId, difference } from \"lodash\";\nimport dayjs from \"dayjs\";\nimport type { Dayjs } from \"dayjs\";\nimport customParseFormat from \"dayjs/plugin/customParseFormat.js\";\nimport isoWeek from \"dayjs/plugin/isoWeek.js\";\nimport advancedFormat from \"dayjs/plugin/advancedFormat.js\";\nimport quarterOfYear from \"dayjs/plugin/quarterOfYear.js\";\nimport enUS from \"antd/locale/en_US.js\";\nimport zhCN from \"antd/locale/zh_CN.js\";\nimport \"dayjs/locale/zh-cn.js\";\n\ninitializeI18n(NS, locales);\ndayjs.extend(customParseFormat);\ndayjs.extend(advancedFormat);\ndayjs.extend(isoWeek);\ndayjs.extend(quarterOfYear);\n\nconst { defineElement, property, event } = createDecorators();\nconst WrappedFormItem = wrapBrick<FormItem, FormItemProps>(\"eo-form-item\");\nconst WrappedIcon = wrapBrick<GeneralIcon, GeneralIconProps>(\"eo-icon\");\n\nconst INIT_TIME_RANGE: TimeRange = {\n startTime: \"00:00:00\",\n endTime: \"23:59:59\",\n};\n\nexport enum presetRangeType {\n Today = \"今天\",\n ThisWeek = \"本周\",\n ThisMonth = \"本月\",\n ThisQuarter = \"本季度\",\n ThisYear = \"今年\",\n}\nexport interface TimeRange {\n startTime: string;\n endTime: string;\n}\n\ntype PickerType = \"date\" | \"week\" | \"month\" | \"quarter\" | \"year\";\ntype OtherPickerType = \"dateTime\" | \"hmTime\" | \"time\";\nexport type RangeType = PickerType & OtherPickerType;\n\nexport interface EoTimeRangePickerProps extends FormItemProps {\n shadowRoot?: ShadowRoot | null;\n value?: TimeRange;\n format: string;\n rangeType?: RangeType;\n placeholder?: string | [string, string];\n inputStyle?: CSSProperties;\n onChange?: (range: TimeRange) => void;\n emitChangeOnInit?: boolean;\n selectNearDays?: number;\n presetRanges?: presetRangeType[];\n}\ntype RealTimeRangePickerProps = Omit<\n EoTimeRangePickerProps,\n keyof Omit<FormItemProps, \"formElement\">\n>;\n/**\n * 时间区间选择器\n * @author zhendonghuang\n * @category form-input-basic\n */\nexport\n@defineElement(\"eo-time-range-picker\", {\n styleTexts: [styleText, fixStyleText],\n})\nclass EoTimeRangePicker extends FormItemElementBase {\n /**\n * 时间段选择器字段名\n */\n @property() accessor name: string | undefined;\n\n /**\n * 时间段选择器说明\n */\n @property() accessor label: string | undefined;\n\n /**\n *时间段选择器的初始值\n * @default { \"startTime\": \"00:00:00\", \"endTime\": \"23:59:59\" }\n */\n @property({ attribute: false }) accessor value: TimeRange | undefined;\n\n /**\n * 是否必填\n */\n @property({ type: Boolean }) accessor required: boolean | undefined;\n\n /**\n * 时间段类型\n */\n @property({ attribute: false })\n accessor rangeType: RangeType | undefined;\n\n /**\n * 输入框提示文字,单时间段时为string,范围时间段时为[string, string]\n */\n @property({ attribute: false })\n accessor placeholder: string | [string, string] | undefined;\n\n /**\n * 输入框样式\n */\n @property({ attribute: false }) accessor inputStyle:\n | React.CSSProperties\n | undefined;\n\n /**\n * 只有rangeType在`date` 和 `dateTime`下, 才支持只选择最近n天(当前时间向前n天)\n */\n @property({ type: Number })\n accessor selectNearDays: number | undefined;\n\n /**\n * @default true\n * 是否在初始化完成后额外触发一次`time.range.change`, 这里因为历史原因之前默认行为就是在初始化后会触发该事件,这里为了兼容之前的行为,默认值只能设置为 true。\n */\n @property({ type: Boolean })\n accessor emitChangeOnInit: boolean | undefined = true;\n\n /**\n * @default []\n * 预设时间范围快捷选择;设置了属性selectNearDays时,属性presetRanges不生效;属性rangeType为week时,presetRanges的值只能为本周、本月、本季度、今年,属性rangeType为month、quarter、year时,以此类推\n */\n @property({ attribute: false })\n accessor presetRanges: presetRangeType[] | undefined;\n\n @property({\n attribute: false,\n })\n accessor validator: ((value: any) => MessageBody | string) | undefined;\n\n /**\n *时间段变化时触发\n */\n @event({ type: \"change\" })\n accessor #changeEvent!: EventEmitter<TimeRange>;\n\n handleChange = (value: TimeRange): void => {\n this.value = value;\n this.#changeEvent.emit(value);\n };\n // istanbul ignore next;\n unequal = (value: TimeRange): string => {\n if (value.startTime && value.endTime && value.startTime === value.endTime) {\n return i18n.t(`${NS}:${K.START_TIME_END_TIME_CANNOT_EQUAL}`);\n }\n return \"\";\n };\n // istanbul ignore next;\n startTimeRequired = (value: TimeRange): string => {\n if (!value.startTime && this.required) {\n return i18n.t(`${NS}:${K.START_TIME_REQUIRED}`);\n }\n return \"\";\n };\n // istanbul ignore next;\n endTimeRequired = (value: TimeRange): string => {\n if (!value.endTime && this.required) {\n return i18n.t(`${NS}:${K.END_TIME_REQUIRED}`);\n }\n return \"\";\n };\n\n #builtInvalidator: ((value: any) => MessageBody | string)[] = [\n this.unequal,\n this.startTimeRequired,\n this.endTimeRequired,\n ];\n\n #defaultFormat = \"HH:mm:ss\";\n render() {\n let format = this.#defaultFormat;\n switch (this.rangeType as RangeType) {\n case \"date\":\n format = \"YYYY-MM-DD\";\n break;\n case \"dateTime\":\n format = `YYYY-MM-DD ${this.#defaultFormat}`;\n break;\n case \"hmTime\":\n format = `HH:mm`;\n break;\n case \"week\": //week,month,quarter,year 不设置format,使用ant.design RangePicker的默认format\n format = \"\";\n break;\n case \"month\":\n format = \"\";\n break;\n case \"quarter\":\n format = \"\";\n break;\n case \"year\":\n format = \"\";\n break;\n }\n return (\n <EoTimeRangePickerComponent\n curElement={this}\n formElement={this.getFormElement()}\n name={this.name}\n label={this.label}\n value={this.value}\n notRender={this.notRender}\n labelBrick={this.labelBrick}\n helpBrick={this.helpBrick}\n selectNearDays={this.selectNearDays}\n emitChangeOnInit={this.emitChangeOnInit}\n rangeType={this.rangeType}\n required={this.required}\n format={format}\n placeholder={this.placeholder}\n inputStyle={this.inputStyle}\n validator={\n (this.validator\n ? this.#builtInvalidator.concat(this.validator)\n : this.#builtInvalidator) as any\n }\n presetRanges={this.presetRanges}\n onChange={this.handleChange}\n shadowRoot={this.shadowRoot}\n needValidate={true}\n trigger=\"handleChange\"\n />\n );\n }\n}\n\nconst rangeRules = {\n date: [] as presetRangeType[],\n dateTime: [] as presetRangeType[],\n week: [presetRangeType.Today],\n month: [presetRangeType.Today, presetRangeType.ThisWeek],\n quarter: [\n presetRangeType.Today,\n presetRangeType.ThisWeek,\n presetRangeType.ThisMonth,\n ],\n year: [\n presetRangeType.Today,\n presetRangeType.ThisWeek,\n presetRangeType.ThisMonth,\n presetRangeType.ThisQuarter,\n ],\n};\n\nexport function RealTimeRangePicker(\n props: RealTimeRangePickerProps\n): React.ReactElement {\n const {\n value,\n selectNearDays,\n format,\n emitChangeOnInit,\n presetRanges,\n onChange,\n formElement,\n placeholder,\n inputStyle,\n } = props;\n const times = [\"time\", \"hmTime\"];\n const rangeType = props.rangeType ?? \"time\";\n const today = times.includes(rangeType) ? \"\" : dayjs().format(\"YYYY-MM-DD\");\n const initRange = {\n startTime: today + (today ? \" \" : \"\") + INIT_TIME_RANGE.startTime,\n endTime: today + (today ? \" \" : \"\") + INIT_TIME_RANGE.endTime,\n };\n\n const initValue: TimeRange =\n !isEmpty(value?.startTime) || !isEmpty(value?.endTime)\n ? (value as TimeRange)\n : initRange;\n\n const [startTime, setStartTime] = useState(\n dayjs(initValue.startTime, format)\n );\n const [prevStartTime, setPrevStartTime] = useState(startTime?.clone());\n const [endTime, setEndTime] = useState(dayjs(initValue.endTime, format));\n const [prevEndTime, setPrevEndTime] = useState(endTime?.clone());\n\n const onStartTimeChange = (time: Dayjs | null, timeString: string) => {\n time && setStartTime(time);\n onChange?.({\n startTime: timeString,\n endTime: endTime?.format(format),\n });\n };\n\n const onEndTimeChange = (time: Dayjs | null, timeString: string) => {\n time && setEndTime(time);\n onChange?.({\n endTime: timeString,\n startTime: startTime?.format(format),\n });\n };\n\n useEffect(() => {\n if (emitChangeOnInit && !props.value && !formElement && onChange) {\n onChange(times.includes(rangeType) ? INIT_TIME_RANGE : initRange);\n }\n }, []);\n\n useEffect(() => {\n if (value?.startTime) {\n const start = dayjs(value.startTime, format || \"YYYY-MM-DD\");\n setStartTime(start);\n setPrevStartTime(start);\n }\n if (value?.endTime) {\n const end = dayjs(value.endTime, format || \"YYYY-MM-DD\");\n setEndTime(end);\n setPrevEndTime(end);\n }\n }, [value]);\n\n const timeRange = (\n <div className=\"timeRange\" style={inputStyle}>\n <TimePicker\n {...{ id: uniqueId(\"start-time-\") }}\n // Currently we don't support multiple pick mode\n onChange={onStartTimeChange as any}\n getPopupContainer={(trigger) => trigger}\n value={!isEmpty(value?.startTime) ? startTime : undefined}\n format={format}\n placeholder={placeholder as string | undefined}\n />\n <span className=\"timeRangeSplit\">~</span>\n <TimePicker\n {...{ id: uniqueId(\"end-time-\") }}\n // Currently we don't support multiple pick mode\n onChange={onEndTimeChange as any}\n getPopupContainer={(trigger) => trigger}\n value={!isEmpty(value?.endTime) ? endTime : undefined}\n format={format}\n placeholder={placeholder as string | undefined}\n />\n </div>\n );\n const presetRangeMap = {\n [presetRangeType.Today]: {\n [i18n.t(`${NS}:${K.TODAY}`)]: [dayjs().startOf(\"day\"), dayjs()],\n },\n [presetRangeType.ThisWeek]: {\n [i18n.t(`${NS}:${K.THIS_WEEK}`)]: [\n dayjs().startOf(\"week\"),\n dayjs().endOf(\"week\"),\n ],\n },\n [presetRangeType.ThisMonth]: {\n [i18n.t(`${NS}:${K.THIS_MONTH}`)]: [\n dayjs().startOf(\"month\"),\n dayjs().endOf(\"month\"),\n ],\n },\n [presetRangeType.ThisQuarter]: {\n [i18n.t(`${NS}:${K.THIS_QUARTER}`)]: [\n dayjs().startOf(\"quarter\"),\n dayjs().endOf(\"quarter\"),\n ],\n },\n [presetRangeType.ThisYear]: {\n [i18n.t(`${NS}:${K.THIS_YEAR}`)]: [\n dayjs().startOf(\"year\"),\n dayjs().endOf(\"year\"),\n ],\n },\n };\n\n const presetRange = useMemo(() => {\n const rangeResult = [];\n if (!selectNearDays && !times.includes(rangeType)) {\n const compliantRanges = difference(\n presetRanges,\n (rangeRules as any)[rangeType]\n );\n for (const i of compliantRanges) {\n const list = Object.entries(presetRangeMap[i])[0];\n rangeResult.push({ label: list[0], value: list[1] });\n }\n }\n return rangeResult;\n }, [rangeType, selectNearDays, presetRanges]);\n const rangeChange = (dates: any) => {\n setStartTime(dates?.[0]);\n setEndTime(dates?.[1]);\n onChange?.({\n startTime: dates?.[0].format(format || \"YYYY-MM-DD\"), //week,month,quarter,year 的format为\"\",比如rangeType为quarter,直接返回2022-Q3的这种格式的数据,目前看起来还不是平台通用的,还是先默认转换成\"YYYY-MM-DD\"\n endTime: dates?.[1].format(format || \"YYYY-MM-DD\"),\n });\n };\n\n const needConfirm = useRef(false);\n const onOpenChange = (open: boolean) => {\n if (!open && needConfirm.current) {\n setStartTime(prevStartTime);\n setEndTime(prevEndTime);\n } else {\n needConfirm.current = true;\n }\n };\n\n const rangeOk = (selectedTime: any) => {\n needConfirm.current = false;\n const dates = selectedTime as [Dayjs, Dayjs];\n setPrevStartTime(dates?.[0]?.clone());\n setPrevEndTime(dates?.[1]?.clone());\n };\n\n const disabledDate = (current: Dayjs) => {\n if (!selectNearDays) {\n return false;\n }\n const tooSelectNearDays =\n current <= dayjs().subtract(selectNearDays, \"days\") ||\n current > dayjs().endOf(\"day\");\n return !!tooSelectNearDays;\n };\n\n // Memoize the picker value\n const pickerValue = useMemo(() => {\n return (\n !isEmpty(value?.startTime) || !isEmpty(value?.endTime)\n ? [startTime, endTime]\n : []\n ) as any;\n }, [endTime, startTime, value?.endTime, value?.startTime]);\n\n const dateRange = (\n <DatePicker.RangePicker\n style={inputStyle}\n showTime={(rangeType as RangeType) === \"dateTime\"}\n picker={(rangeType as RangeType) === \"dateTime\" ? \"date\" : rangeType}\n value={pickerValue}\n presets={presetRange as any}\n format={format}\n onChange={rangeChange}\n onOpenChange={onOpenChange}\n onOk={rangeOk}\n disabledDate={disabledDate}\n placeholder={placeholder as [string, string] | undefined}\n separator={\"~\"}\n getPopupContainer={(trigger) => trigger}\n suffixIcon={<WrappedIcon icon=\"calendar\" lib=\"easyops\" />}\n />\n );\n const range = times.includes(rangeType) ? timeRange : dateRange;\n\n return <div>{range}</div>;\n}\n\nexport function EoTimeRangePickerComponent(props: EoTimeRangePickerProps) {\n const currentTheme = useCurrentTheme();\n const locale =\n i18n.language && i18n.language.split(\"-\")[0] === \"en\" ? enUS : zhCN;\n\n const cahce = useMemo(() => {\n return createCache();\n }, []);\n return (\n <WrappedFormItem exportparts=\"message\" {...pickFormItemProps(props)}>\n <ConfigProvider\n locale={locale as any}\n theme={{\n algorithm:\n currentTheme === \"dark-v2\"\n ? theme.darkAlgorithm\n : theme.defaultAlgorithm,\n }}\n >\n <StyleProvider container={props.shadowRoot as ShadowRoot} cache={cahce}>\n <div\n onChange={(e) => {\n e.stopPropagation();\n }}\n >\n <RealTimeRangePicker\n format={props.format}\n value={props.value}\n rangeType={props.rangeType}\n onChange={props.onChange}\n emitChangeOnInit={props.emitChangeOnInit}\n selectNearDays={props.selectNearDays}\n presetRanges={props.presetRanges}\n formElement={props.formElement}\n placeholder={props.placeholder}\n inputStyle={props.inputStyle}\n />\n </div>\n </StyleProvider>\n </ConfigProvider>\n </WrappedFormItem>\n );\n}\n","import React, { useMemo, useState } from \"react\";\nimport { createDecorators, EventEmitter } from \"@next-core/element\";\nimport { wrapBrick } from \"@next-core/react-element\";\nimport \"@next-core/theme\";\nimport { ColorPicker, theme, ConfigProvider } from \"antd\";\nimport type { ColorPickerProps, Color } from \"antd/es/color-picker\";\nimport { StyleProvider, createCache } from \"@ant-design/cssinjs\";\nimport { FormItemElementBase } from \"@next-shared/form\";\nimport type { FormItem, FormItemProps } from \"../form-item/index.js\";\nimport { useCurrentTheme } from \"@next-core/react-runtime\";\nimport styleText from \"./styles.shadow.css\";\nconst { defineElement, property, event } = createDecorators();\nconst WrappedFormItem = wrapBrick<FormItem, FormItemProps>(\"eo-form-item\");\n\nexport interface EoColorPickerProps\n extends Pick<\n ColorPickerProps,\n \"allowClear\" | \"disabled\" | \"showText\" | \"format\" | \"size\" | \"defaultValue\"\n > {\n shadowRoot: ShadowRoot | null;\n configProps?: Partial<ColorPickerProps>;\n onChange?: (value?: string) => void;\n value?: string;\n}\n\n/**\n * 构件 `eo-color-picker`\n * @author astrid\n */\nexport\n@defineElement(\"eo-color-picker\", {\n styleTexts: [styleText],\n})\nclass EoColorPicker extends FormItemElementBase implements EoColorPickerProps {\n /**\n * 字段名称\n */\n @property()\n accessor name: string | undefined;\n\n /**\n * 字段说明\n */\n @property()\n accessor label: string | undefined;\n /**\n * 值\n */\n @property()\n accessor value: string | undefined;\n\n /**\n * 颜色默认的值\n */\n @property()\n accessor defaultValue: string | Color | undefined;\n /**\n * 是否必填\n */\n @property({ type: Boolean })\n accessor required: boolean | undefined;\n /**\n * 允许清除选择的颜色\n */\n @property({ type: Boolean })\n accessor allowClear: boolean | undefined;\n /**\n * 设置触发器大小\n * @default middle\n */\n @property({ attribute: false })\n accessor size: \"small\" | \"middle\" | \"large\" | undefined;\n\n /**\n * 显示颜色文本\n */\n @property({ type: Boolean })\n accessor showText: boolean | undefined;\n /**\n * 是否禁用\n */\n @property({ type: Boolean })\n accessor disabled: boolean | undefined;\n\n /**\n * 颜色格式\n * @default hex\n */\n @property({ attribute: false })\n accessor format: \"rgb\" | \"hex\" | \"hsb\" | undefined;\n /**\n * 透传 antd ColorPicker 属性 [ColorPickerProps](https://ant.design/components/color-picker-cn#api)\n */\n @property({ attribute: false })\n accessor configProps: Partial<ColorPickerProps> | undefined;\n\n /**\n * 颜色变化事件, 返回值格式和`format`格式一致\n */\n @event({ type: \"change\" })\n accessor #changeEvent!: EventEmitter<string | undefined>;\n handleChange = (value?: string) => {\n this.value = value;\n this.#changeEvent.emit(value);\n };\n\n render() {\n return (\n <WrappedFormItem\n exportparts=\"message\"\n curElement={this as HTMLElement}\n formElement={this.getFormElement()}\n label={this.label}\n name={this.name}\n required={this.required}\n notRender={this.notRender}\n helpBrick={this.helpBrick}\n labelBrick={this.labelBrick}\n trigger=\"handleChange\"\n >\n <EoColorPickerComponent\n format={this.format}\n value={this.value}\n size={this.size}\n disabled={this.disabled}\n onChange={this.handleChange}\n shadowRoot={this.shadowRoot}\n configProps={this.configProps}\n showText={this.showText}\n allowClear={this.allowClear}\n defaultValue={this.defaultValue}\n />\n </WrappedFormItem>\n );\n }\n}\n\nexport function EoColorPickerComponent(\n props: EoColorPickerProps\n): React.ReactElement {\n const currentTheme = useCurrentTheme();\n const [format, setFormat] = useState<ColorPickerProps[\"format\"]>(\n props.format\n );\n const cache = useMemo(() => {\n return createCache();\n }, []);\n return (\n <ConfigProvider\n theme={{\n algorithm:\n currentTheme === \"dark-v2\"\n ? theme.darkAlgorithm\n : theme.defaultAlgorithm,\n }}\n >\n <StyleProvider container={props.shadowRoot as ShadowRoot} cache={cache}>\n <ColorPicker\n {...props.configProps}\n getPopupContainer={(trigger) => trigger.parentElement as HTMLElement}\n value={props.value}\n disabled={props.disabled}\n allowClear={props.allowClear}\n defaultValue={props.defaultValue}\n size={props.size}\n showText={props.showText}\n format={format}\n onFormatChange={setFormat}\n onChange={(value) => {\n let outputValue = value.toHexString();\n switch (props.format) {\n case \"rgb\":\n outputValue = value.toRgbString();\n break;\n case \"hsb\":\n outputValue = value.toHsbString();\n break;\n default:\n outputValue = value.toHexString();\n break;\n }\n props.onChange?.(outputValue);\n }}\n onClear={() => {\n props.onChange?.();\n }}\n />\n </StyleProvider>\n </ConfigProvider>\n );\n}\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `:host{display:inline-block}:host([hidden]){display:none}.complete-container{position:relative}.option-container{display:flex;flex-direction:column;margin:2px 4px;padding:5px 12px;cursor:pointer;border-radius:var(--medius-border-radius)}.option-container .label{line-height:22px}.option-container .caption{font-size:var(--auxiliary-font-size-small);color:var(--color-secondary-text);line-height:20px}.option-container:hover{background-color:var(--antd-select-item-active-bg)}.group-wrapper .option-container{padding-left:24px}.group-item{color:var(--antd-text-color-secondary);font-size:12px;margin:2px 4px;padding:5px 12px}.selected-option{background-color:var(--color-info-icon-bg)}.dropdown-wrapper{position:absolute;box-sizing:border-box;width:100%;background-color:var(--antd-select-dropdown-bg);box-shadow:var(--antd-box-shadow-base);z-index:1050;margin-top:5px;padding:4px 2px;border-radius:var(--small-border-radius)}.dropdown-list{max-height:256px;overflow:scroll}eo-input{width:100%}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `:host{display:block}:host([hidden]){display:none}eo-form-item{display:block}textarea{display:block;width:100%;padding:4px 11px;color:var(--antd-input-color);background:var(--antd-input-bg);box-sizing:border-box;border-radius:var(--antd-button-border-radius);border:1px solid var(--antd-input-border-color);font-size:14px;line-height:22px}textarea:not(:disabled):hover{border:1px solid var(--antd-input-hover-border-color)}textarea:not(:disabled):focus{border:1px solid var(--antd-input-focus-border-color);outline:0;box-shadow:0 0 0 2px rgb(0 113 235/20%)}textarea:disabled{cursor:not-allowed;color:var(--text-color-disabled);background:var(--antd-input-disabled-bg);resize:none}textarea::placeholder{color:var(--antd-input-placeholder-color)}textarea.error{border-color:var(--antd-error-color)}textarea.error:hover{border-color:var(--antd-error-color)}textarea.error:focus{border-color:var(--antd-error-color)}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n"],"names":["___CSS_LOADER_EXPORT___","push","module","id","toString","exports","styleElement","nonce","setAttribute","options","document","update","remove","insertStyleElement","obj","css","supports","concat","media","needLayer","layer","length","sourceMap","btoa","unescape","encodeURIComponent","JSON","stringify","styleTagTransform","apply","parentNode","removeChild","removeStyleElement","e","t","default","_","d","name","weekdays","split","weekdaysShort","weekdaysMin","months","monthsShort","ordinal","weekStart","yearStart","formats","LT","LTS","L","LL","LLL","LLLL","l","ll","lll","llll","relativeTime","future","past","s","m","mm","h","hh","dd","M","MM","y","yy","meridiem","locale","stylesInDOM","getIndexByIdentifier","identifier","result","i","modulesToDom","list","idCountMap","identifiers","item","base","count","indexByIdentifier","references","updater","addElementStyle","byIndex","splice","api","domAPI","newObj","lastIdentifiers","newList","index","newLastIdentifiers","_i","_index","element","createElement","setAttributes","attributes","insert","styleSheet","cssText","firstChild","appendChild","createTextNode","n","r","prototype","quarter","this","$utils","u","Math","ceil","month","add","Number","p","bind","startOf","o","endOf","memo","style","target","styleTarget","querySelector","window","HTMLIFrameElement","contentDocument","head","getTarget","Error","a","isoWeekday","isoWeekYear","year","isoWeek","$u","utc","diff","day","date","SIZING_STYLE","hiddenTextarea","modKey","test","navigator","platform","TextareaAutoResize","React","LegacyTextareaAutoResize","_ref","ref","autoResize","_autoResize","minRows","maxRows","borderSize","paddingSize","containerRef","value","propValue","submitWhen","onChange","onSubmit","onKeyDown","onCompositionStart","onCompositionEnd","props","setValue","useState","textareaRef","useRef","autoStyle","setAutoStyle","useImperativeHandle","focus","textarea","current","_textarea$value","valueLength","setSelectionRange","doAutoResize","useCallback","uiTextNode","body","uiTextNodeStyle","getComputedStyle","sizingStyle","map","getPropertyValue","join","minHeight","maxHeight","overflowY","placeholder","height","scrollHeight","singleRowHeight","parseFloat","max","min","resize","calculateAutoSizeStyle","flushSync","useEffect","compositionRef","handleCompositionStart","handleCompositionEnd","handleKeyDown","key","shiftKey","preventDefault","stopPropagation","container","previousInlineSize","observer","ResizeObserver","entries","entry","currentInlineSize","contentBoxSize","inlineSize","contentRect","width","undefined","isInitial","requestAnimationFrame","observe","disconnect","_extends","WrappedFormItem","wrapBrick","defineElement","property","event","method","createDecorators","_Textarea","_componentRef","WeakMap","_A","_B","_C","_D","_E","_F","_G","_H","_I","_J","_K","_L","_M","_N","_Textarea_brand","WeakSet","Textarea","FormItemElementBase","constructor","arguments","_classPrivateMethodInitSpec","_classPrivateFieldInitSpec","_initProto","createRef","_init_name","_init_extra_name","_init_label","_init_extra_label","_init_value","_init_extra_value","_init_placeholder","_init_extra_placeholder","_init_disabled","_init_extra_disabled","_init_minLength","_init_extra_minLength","_init_maxLength","_init_extra_maxLength","_init_autoSize","_init_extra_autoSize","_init_required","_init_extra_required","_init_max","_init_extra_max","_init_min","_init_extra_min","_init_message","_init_extra_message","_init_textareaStyle","_init_extra_textareaStyle","_init_InputChangeEvent","_defineProperty","_init_extra_InputChangeEvent","_classPrivateGetter","_get_InputChangeEvent","emit","_classPrivateFieldGet","v","_classPrivateFieldSet","label","disabled","minLength","maxLength","autoSize","required","message","textareaStyle","focusTextarea","_classPrivateFieldGet2","render","TextareaComponent","curElement","formElement","getFormElement","notRender","labelBrick","helpBrick","validateState","trigger","onInputChange","handleInputChange","_Textarea2","_set_InputChangeEvent","c","_initClass","_applyDecs","styleTexts","styleText","alias","type","Boolean","attribute","bound","has","_checkInRHS","forwardRef","_autoSize$minRows","formItemRef","handleChange","exportparts","pickFormItemProps","className","classNames","error","_topics","_subUid","PubSub","publish","topic","subscribers","len","func","subscribe","fn","_this$subUid","token","unsubscribe","uid","Field","detail","field","_fields","_options","_formData","_initData","_FormStore_brand","FormStore","getInstance","instance","get","set","super","Map","setField","getAllValues","allFields","_assertClassBrand","_getAllFields","call","Object","fromEntries","k","includes","filter","setInitValue","values","isEmitValuseChange","setFieldsValue","setFieldsValueByInitData","isNil","newFormData","_classPrivateFieldGet3","_classPrivateFieldGet4","forEach","_ref2","onValuesChanged","changedValues","allValues","resetFields","resetValidateState","getFieldsValue","removeField","delete","validateFields","callback","results","validateField","some","formData","_classPrivateFieldGet5","fieldDetail","validate","validateValue","messageBody","getName","valid","pattern","validator","isEmpty","stringValue","String","RegExp","checkMin","checkMax","numberValue","parsedValidator","Array","isArray","getValueFromEvent","checked","onWatch","_options$needValidate","realValue","needValidate","_options$needValidate2","keys","_detail","_Form","_values","_Form_brand","Form","ReactNextElement","_init_staticValues","_init_extra_staticValues","_init_layout","_init_extra_layout","_init_size","_init_extra_size","_init_labelCol","sm","span","md","lg","xl","xxl","_init_extra_labelCol","_init_wrapperCol","_init_extra_wrapperCol","_init_valuesChangeEvent","_init_extra_valuesChangeEvent","_get_valuesChangeEvent","_init_successEvent","_init_extra_successEvent","_init_errorEvent","_init_extra_errorEvent","_init_formStyle","_init_extra_formStyle","formStore","handleValuesChange","isFormElement","_setInitValue","staticValues","layout","size","labelCol","wrapperCol","err","_this$staticValues","_get_errorEvent","_get_successEvent","runInMicrotask","queueMicrotask","runInMacrotask","setTimeout","formStyle","FormComponent","defaultEmitValuesChange","computedStyle","useMemo","display","flexDirection","gap","_Form2","_set_valuesChangeEvent","_set_successEvent","_set_errorEvent","formatOptions","fields","uniqBy","op","locals","WrappedGeneralIcon","_Radio","_formatOptions","_Radio_brand","_handleOptionsChange","Radio","_init_options","_init_extra_options","_init_type","_init_extra_type","_init_ui","_init_extra_ui","_init_customStyle","_init_extra_customStyle","_init_useBrick","_init_extra_useBrick","_init_changeEvent","_init_extra_changeEvent","_init_optionsChange","_init_extra_optionsChange","_get_changeEvent","find","_get_optionsChange","ui","customStyle","useBrick","RadioComponent","optionsChange","setOptions","isEqual","option","_props$onChange","icon","iconStyle","isBoolean","isDisabled","htmlFor","onClick","fontSize","ReactUseBrick","data","title","marginRight","verticalAlign","_Radio2","_set_changeEvent","_set_optionsChange","xmlns","xmlnsXlink","x1","x2","y1","y2","offset","stopColor","x","filterUnits","dx","dy","in","stdDeviation","in2","operator","fill","fillRule","xlinkHref","stroke","strokeLinejoin","transform","opacity","WrappedSlPopup","WrappedTag","onCheck","onClose","WrappedIcon","applyArgs","args","query","arg","_Select","_O","_P","_Q","_R","_S","_T","_U","_Select_brand","_V","_W","_X","_handleSelectFocus","Select","_init_mode","_init_extra_mode","_init_tokenSeparators","_init_extra_tokenSeparators","_init_maxTagCount","_init_extra_maxTagCount","_init_groupBy","_init_extra_groupBy","_init_suffix","_init_extra_suffix","_init_clearable","_init_extra_clearable","_init_fields","_init_extra_fields","_init_useBackend","_init_extra_useBackend","_init_debounceSearchDelay","_init_extra_debounceSearchDelay","_init_inputStyle","_init_extra_inputStyle","_init_dropdownStyle","_init_extra_dropdownStyle","_init_dropdownHoist","_init_extra_dropdownHoist","_init_searchEvent","_init_extra_searchEvent","_init_focusEvent","_init_extra_focusEvent","Promise","resolve","then","_get_searchEvent","_get_focusEvent","mode","tokenSeparators","maxTagCount","groupBy","suffix","clearable","useBackend","debounceSearchDelay","inputStyle","dropdownStyle","dropdownHoist","SelectComponent","onSearch","handleSearch","onSelectFocus","_props$useBackend2","onValueChange","debouncedOnSearch","debounce","multiple","selectRef","inputSpanRef","shouldTriggerOnValueChangeArgs","inputValue","setInputValue","inputWidth","setInputWidth","requestStatus","setRequestStatus","isDropHidden","setIsDropHidden","isFocused","setIsFocused","selectedOptions","setSelectedOptions","renderOptions","setRenderOptions","focusOptionItem","setFocusOptionItem","inputRef","_props$options","handleSelectorClick","newValue","newOptions","handleMultipleItemClose","closeValue","handleSearchQuery","async","provider","isSearchable","onValueChangeArgs","actualArgs","fetchByProvider","actualData","handleHttpError","handleDebounceBackendSearch","computedOptions","selected","computedValue","_props$useBackend","matchToken","customValue","substring","handleKeydown","code","pop","findIndex","isEmptyValue","useLayoutEffect","toLocaleUpperCase","_inputSpanRef$current","_inputSpanRef$current2","offsetWidth","handleDocumentClick","path","composedPath","addEventListener","removeEventListener","renderSelector","tagList","ellipsisInfo","closable","slice","allOptions","reduce","pre","cur","renderLabel","_option$closable","color","checkable","_allOptions$find","closeable","Options","getSelectOption","_item$value","onMouseOver","onMouseLeave","caption","lib","theme","group","Empty","active","placement","strategy","distance","sync","flip","slot","position","handleClear","spinning","_Select2","_set_searchEvent","_set_focusEvent","WrappedButton","_SubmitButtons","_SubmitButtons_brand","SubmitButtons","_init_submitText","_init_extra_submitText","_init_cancelText","_init_extra_cancelText","_init_disableAfterClick","_init_extra_disableAfterClick","_init_submitDisabled","_init_extra_submitDisabled","_init_submitType","_init_extra_submitType","_init_cancelType","_init_extra_cancelType","_init_submitEvent","_init_extra_submitEvent","_init_cancelEvent","_init_extra_cancelEvent","_get_submitEvent","disableAfterClick","submitDisabled","_get_cancelEvent","submitText","cancelText","submitType","cancelType","ButtonsComponent","onCancelClick","_handleCancelClick","onSubmitClick","_handleSubmitClick","_SubmitButtons2","_set_submitEvent","_set_cancelEvent","AntdIcon","A","_Checkbox","_Checkbox_brand","Checkbox","_init_isCustom","_init_extra_isCustom","_init_isGroup","_init_extra_isGroup","_init_optionGroups","_init_extra_optionGroups","_init_checkboxChangeEvent","_init_extra_checkboxChangeEvent","currentSelectOption","optionGroups","before","after","_get_checkboxChangeEvent","_init_optionsChangeEvent","_init_extra_optionsChangeEvent","_get_optionsChangeEvent","isCustom","isGroup","CheckboxComponent","handleCheckboxChange","_props$value","setValues","collapseKeys","setCollapseKeys","setOptionGroups","_props$optionsChange","handleInputClick","IconCheckbox","disabledIconCheckbox","disabledIconCustomCheckbox","iconCheckbox","iconCustomCheckbox","inputBox","defaultChecked","content","text","CheckboxItem","_props$options2","alignItems","part","checkboxLabel","checkboxLabelDisabled","checkboxLabelCheck","checkboxColor","checkboxInputWrapper","checkboxInputWrapperDisabled","checkboxInputCheck","checkboxInput","checkboxInputDisabled","checkboxInner","background","borderColor","checkboxText","iconNode","mergedIcon","imgSrc","imgStyle","getIcon","CheckGroupItem","_optionGroups","newOptionsKeys","checkOptions","intersection","checkType","newKeys","CaretRightOutlined","rotate","rev","checkboxInputPartCheck","_props$onChange2","_props$onChange3","uniq","_Checkbox2","_set_checkboxChangeEvent","_set_optionsChangeEvent","K","NS","initializeReactI18n","en","UNIQUE","zh","WrappedForm","onValuesChange","onValidateSuccess","onValidateError","uniqueValidatorFN","properties","_props$curElement","fieldValue","_unique","_properties$message","_properties$label","Set","unique","getRealValue","_DynamicFormItem","_DynamicFormItem_brand","_handleAdd","_handleRemove","DynamicFormItem","_init_hideRemoveButton","_init_extra_hideRemoveButton","_init_disabledRemoveButton","_init_extra_disabledRemoveButton","_init_hideAddButton","_init_extra_hideAddButton","_init_disabledAddButton","_init_extra_disabledAddButton","_init_addEvent","_init_extra_addEvent","_init_removeEvent","_init_extra_removeEvent","_get_addEvent","_get_removeEvent","_this$getFormElement","hideRemoveButton","disabledRemoveButton","hideAddButton","disabledAddButton","DynamicFormItemComponent","handleDynamicFormChange","onAdd","onRemove","useTranslation","formWrapperRef","bricks","setBricks","bricksOfNoLabel","brick","omit","parsedUseBrick","flatten","handleRemoveItem","_props$onRemove","newValues","addButtonDisabled","addButtonHide","formWrapper","forms","querySelectorAll","every","hideRemoveBtn","removeBtnDisabled","ReactUseMultipleBricks","category","buttonStyle","handleAddItem","_props$onAdd","_DynamicFormItem2","_set_addEvent","_set_removeEvent","WrappedInput","_GeneralSearch","_GeneralSearch_brand","_handleChange","_handleDebouncedChange","_handleSearch","GeneralSearch","_init_autoFocus","_init_extra_autoFocus","_init_trim","_init_extra_trim","_init_debounceTime","_init_extra_debounceTime","_init_change","_init_extra_change","_get_change","trim","_init_search","_init_extra_search","_get_search","autoFocus","debounceTime","GeneralSearchComponent","onDebouncedChange","_onDebouncedChange","onMouseDown","_GeneralSearch2","_set_change","_set_search","Colors","COLORS_MAP","green","red","blue","orange","cyan","purple","geekblue","gray","getColor","_COLORS_MAP","ICON","COLOR","SELECT_ICON","SEARCH_PLACEHOLDER","getLibs","unwrapProvider","searchIcons","WrappedGeneralRadio","onOptionsChange","WrappedModal","onConfirm","onCancel","onOpen","WrappedSearch","_IconSelect","_IconSelect_brand","IconSelect","IconSelectComponent","_IconSelect2","emptyIcon","modalRef","iconLibs","setIconLibs","searchParams","setSearchParams","iconList","setIconList","libs","handleSearchIcons","params","q","page","pageSize","previewIcon","setPreviewIcon","previewColor","setPreviewColor","_props$value2","selectedIcon","setSelectedIcon","selectedColor","setSelectedColor","clearSelect","handleColorSelect","_modalRef$current2","open","backgroundColor","modalTitle","maskClosable","closeWhenConfirm","handleModalConfirm","_modalRef$current","close","handleModalClose","handleModalOpen","newSearchParams","iconInfo","locales","UPLOAD","FILE_UPLOADING","DRAG_UPLOAD_TEXT","EXCEEDED_FILE_SIZE_LIMIT","symbolForAbortController","Symbol","for","FileSizeUnit","sizeValidator","file","limitSize","unit","MB","reject","sizeConst","KB","GB","i18n","Upload","children","itemRender","autoUpload","uploadName","action","accept","maxCount","overMaxCountMode","beforeUploadValidators","beforeUploadUserDataProcessor","internalFileDataList","setInternalFileDataList","fileList","beforeLoadFilter","files","acceptValidator","accepts","validAccepts","lowerFileName","toLowerCase","mimeType","baseMimeType","startsWith","lowerType","affixList","affix","endsWith","handleFileUpload","originFiles","existsFilesSlice","filteredFiles","existsLength","allowCount","Infinity","validatedFiles","all","allSettled","_file","validatorResult","errors","status","reason","beforeLoadValidator","processedFileDataList","fileDataList","Date","userData","beforeLoadProcessor","newFileDataList","fileData","FormData","abortController","AbortController","append","req","http","request","signal","response","handleUploadSuccess","_fileData","catch","handleUploadError","_fileData$errors","uploadFile","hidden","upload","_inputRef$current","click","uploadFiles","actions","_fileData$symbolForAb","removedFileData","abort","handleRemove","getImage","revokeUrl","url","Blob","URL","createObjectURL","image","Image","src","onload","revokeObjectURL","onerror","userDataProcessor","naturalWidth","naturalHeight","pipes","unitFormat","WrappedImage","_UploadImage","_UploadImage_brand","UploadImage","_init_bucketName","_init_extra_bucketName","_init_maxCount","_init_extra_maxCount","_init_multiple","_init_extra_multiple","_init_limitSize","_init_extra_limitSize","imageList","bucketName","UploadImageComponent","_UploadImage2","defaultUploadIcon","deleteIcon","closeIcon","wrapBrickImageRef","curValue","_fileDataList","getBasePath","imageValidator","images","processedImages","_image$url","objectName","uploadActions","onlyPreview","imgList","_item$userData","_GeneralSwitch","_GeneralSwitch_brand","GeneralSwitch","_init_checkedText","_init_extra_checkedText","_init_unCheckedText","_init_extra_unCheckedText","_init_checkedIcon","_init_extra_checkedIcon","_init_unCheckedIcon","_init_extra_unCheckedIcon","_init_switchEvent","_init_extra_switchEvent","_get_switchEvent","checkedText","unCheckedText","checkedIcon","unCheckedIcon","GeneralSwitchComponent","onSwitch","handleSwitch","setChecked","handleSwitchChange","_GeneralSwitch2","_set_switchEvent","WrappedEasyopsIcon","WrappedTooltip","_EoUploadFile","_EoUploadFile_brand","EoUploadFile","_init_accept","_init_extra_accept","_init_buttonText","_init_extra_buttonText","_init_buttonType","_init_extra_buttonType","_init_buttonIcon","_init_extra_buttonIcon","_init_overMaxCountMode","_init_extra_overMaxCountMode","_init_uploadDraggable","_init_extra_uploadDraggable","_init_draggableUploadTip","_init_extra_draggableUploadTip","_init_autoUpload","_init_extra_autoUpload","_init_url","_init_extra_url","_init_method","_init_extra_method","_init_uploadName","_init_extra_uploadName","buttonText","buttonType","buttonIcon","uploadDraggable","draggableUploadTip","EoUploadFileComponent","_EoUploadFile2","fileTextIcon","loadingIcon","useCurrentTheme","isDragOver","setIsDragOver","isMaxQuantity","onDragEnter","onDragOver","onDragLeave","onDrop","_e$dataTransfer$files","dataTransfer","Trans","i18nKey","components","total","_AutoComplete","_AutoComplete_brand","AutoComplete","_init_filterByCaption","_init_extra_filterByCaption","_init_validator","_init_extra_validator","_init_pattern","_init_extra_pattern","filterByCaption","EoAutoCompleteComponent","filteredOptions","setFilteredOptions","setActive","originalOptions","walkOptions","containerElement","blur","onFocus","search","_option$options","_option$options2","toLower","cloneDeep","f","_f$options","_AutoComplete2","TimePicker","InternalTimePicker","RangePicker","InternalRangePicker","assign","picker","_a","addon","renderExtraFooter","variant","bordered","restProps","hasOwnProperty","indexOf","getOwnPropertySymbols","propertyIsEnumerable","__rest","mergedVariant","internalRenderExtraFooter","_InternalPanelDoNotUseOrYouWillBeFired","dayjs","customParseFormat","_EoTimePicker","_EoTimePicker_brand","_handleOpenChange","EoTimePicker","_init_configProps","_init_extra_configProps","_init_openEvent","_init_extra_openEvent","_init_closeEvent","_init_extra_closeEvent","flag","_get_openEvent","_get_closeEvent","configProps","EoTimePickerComponent","onOpenChange","shadowRoot","currentTheme","language","enUS","zhCN","format","cahce","createCache","ConfigProvider","algorithm","darkAlgorithm","defaultAlgorithm","StyleProvider","cache","getPopupContainer","_time","timeString","allowClear","_EoTimePicker2","_set_openEvent","_set_closeEvent","fixStyleText","initializeI18n","NEXT_DAY","TODAY","LAST_DAY","NEXT_WEEK","THIS_WEEK","LAST_WEEK","NEXT_MONTH","THIS_MONTH","LAST_MONTH","NEXT_QUARTER","THIS_QUARTER","LAST_QUARTER","NEXT_YEAR","THIS_YEAR","LAST_YEAR","FISRT_QUARTER","SECOND_QUARTER","THIRD_QUARTER","FOURTH_QUARTER","advancedFormat","quarterOfYear","_EoDatePicker","_EoDatePicker_brand","_handleOk","EoDatePicker","_init_showTime","_init_extra_showTime","_init_format","_init_extra_format","_init_picker","_init_extra_picker","_init_futureDateDisabled","_init_extra_futureDateDisabled","_init_disabledDate","_init_extra_disabledDate","_init_useFastSelectBtn","_init_extra_useFastSelectBtn","_init_okEvent","_init_extra_okEvent","_get_okEvent","showTime","futureDateDisabled","disabledDate","useFastSelectBtn","EoDatePickerComponent","onOk","_EoDatePicker2","_set_okEvent","getFieldSetAndRanges","expression","fieldSet","ranges","range","isNaN","isInFieldSetOrRanges","fieldSetAndRanges","isEmptyFieldSetOrRanges","getFieldsFromFieldSetAndRanges","InternalStateDatePicker","confirmDisabled","setConfirmDisabled","crontab","second","minute","hour","weekday","hourFieldSetAndRanges","minuteFieldSetAndRanges","secondFieldSetAndRanges","yearFieldSetAndRanges","monthFieldSetAndRanges","dateFieldSetAndRanges","weekFieldSetAndRanges","isAllDate","isAllTime","handleDisabledFutureDate","isDatePicker","isQuarterPicker","PickerBtn","strs","week","currentDate","disabledFastSelect","handlePreTime","preDate","clone","subtract","LeftOutlined","handleCurTime","curDate","next","nextDisabled","handleNextTime","nextDate","RightOutlined","cellRender","info","quarterMap","selectedQuarter","currentQuarter","originNode","DatePicker","popupClassName","quarterPicker","suffixIcon","curYear","curMonth","curWeekday","cron","disabledTime","curHour","curMinute","currentSecond","disabledHours","disabledMinutes","disabledSeconds","matchCurDate","isMatchDate","hourFields","minuteFields","secondFields","parseValue","moment","_date","dateString","_props$onOk","START_TIME_END_TIME_CANNOT_EQUAL","START_TIME_REQUIRED","END_TIME_REQUIRED","INIT_TIME_RANGE","startTime","endTime","_EoTimeRangePicker","presetRangeType","_EoTimeRangePicker_brand","_builtInvalidator","_defaultFormat","EoTimeRangePicker","_init_rangeType","_init_extra_rangeType","_init_selectNearDays","_init_extra_selectNearDays","_init_emitChangeOnInit","_init_extra_emitChangeOnInit","_init_presetRanges","_init_extra_presetRanges","unequal","startTimeRequired","endTimeRequired","rangeType","selectNearDays","emitChangeOnInit","presetRanges","EoTimeRangePickerComponent","_EoTimeRangePicker2","rangeRules","dateTime","Today","ThisWeek","ThisMonth","ThisQuarter","RealTimeRangePicker","_props$rangeType","times","today","initRange","initValue","setStartTime","prevStartTime","setPrevStartTime","setEndTime","prevEndTime","setPrevEndTime","start","end","timeRange","uniqueId","onStartTimeChange","time","onEndTimeChange","presetRangeMap","ThisYear","presetRange","rangeResult","compliantRanges","difference","needConfirm","pickerValue","dateRange","presets","dates","selectedTime","_dates$","_dates$2","separator","_EoColorPicker","_EoColorPicker_brand","EoColorPicker","_init_defaultValue","_init_extra_defaultValue","_init_allowClear","_init_extra_allowClear","_init_showText","_init_extra_showText","defaultValue","showText","EoColorPickerComponent","setFormat","ColorPicker","parentElement","onFormatChange","outputValue","toHexString","toRgbString","toHsbString","onClear","_EoColorPicker2"],"sourceRoot":""}