-
-
Notifications
You must be signed in to change notification settings - Fork 115
/
main.704b0f70.js.map
1 lines (1 loc) · 488 KB
/
main.704b0f70.js.map
1
{"version":3,"file":"static/js/main.704b0f70.js","mappings":"8EAaMA,GAVJ,gBAAKC,QAAQ,YAAYC,MAAM,KAAKC,OAAO,KAAKC,QAAQ,MAAxD,UACE,cAAGC,OAAO,OAAOC,YAAY,IAAIC,KAAK,OAAOC,SAAS,UAAtD,UACE,iBACEC,EAAE,kXACFF,KAAK,gBAQPG,GACJ,gBAAKT,QAAQ,YAAYG,QAAQ,MAAjC,UACE,cAAGC,OAAO,OAAOC,YAAY,IAAIC,KAAK,OAAOC,SAAS,UAAtD,UACE,iBACEC,EAAE,kXACFF,KAAK,gBAMb,KACEP,KAAAA,EACAU,MAAAA,I,iHC1Ba,SAASC,IACtB,OACE,4BACE,0DACA,wBACE,SAAC,KAAD,CAAMC,GAAG,IAAT,sC,eCLO,SAASC,IACtB,OACE,SAAC,KAAD,CAAQC,IAAI,aAAaC,WAAW,SAAC,KAAD,CAAMC,KAAK,UAAUC,MAAM,EAAMC,MAAO,CAAEC,cAAe,gB,eCHjG,KCQA,SAASC,IAAqC,IAA7BC,EAA4B,uDAApB,GACvB,OAAOC,EAAAA,EAAAA,UAAQ,kBAAM,SAAC,YAAD,CAAeC,MAAOF,EAAMjB,QAA5B,SAAsCiB,EAAMjB,YAA0B,CAACiB,EAAMjB,UAOpG,IAgCA,EAhCsB,WAAuC,IAAtCiB,EAAqC,uDAA7B,GAC7B,SAASG,EAASC,GAChB,IAAMrB,EAAUqB,EAAEC,OAAOH,MACnBI,EAAiC,MAA1BvB,EAAQwB,MAAM,KAAK,GAE9BC,OAAOC,SAASC,KADdJ,EACF,gCAAgDvB,EAAhD,oBAEA,qCAAqDA,EAArD,mBAKJ,IAAM4B,EAAiBC,EAAAA,GACjBC,EAAcb,EAAMc,KACpBC,EAAeF,EAAY,GAIjC,OAHIE,IAAiBJ,GACnBE,EAAYG,QAAQL,IAEfV,EAAAA,EAAAA,UACL,kBACE,gBAAKgB,UAAWC,EAAAA,IAAhB,UACE,SAAC,KAAD,CAAQC,aAAcN,EAAY,GAAIV,SAAUA,EAAhD,SACGU,EAAYO,KAAI,SAACrC,EAASsC,GACzB,OAAO,SAACtB,EAAD,CAAmBhB,QAASA,GAAdsC,YAK7B,CAACR,KC5CL,GAAgB,MAAQ,qBAAqB,YAAc,2BAA2B,QAAU,uBAAuB,WAAa,0BAA0B,YAAc,4B,sDCA5K,GAAgB,MAAQ,qBAAqB,KAAO,oBAAoB,QAAU,wB,WCClF,GACES,MACE,gBAAKzC,MAAM,KAAKC,OAAO,KAAKF,QAAQ,YAApC,UACE,iBACEM,KAAK,OACLE,EAAE,43DAIRmC,WACE,iBAAK3C,QAAQ,gBAAgBC,MAAM,KAAKC,OAAO,KAA/C,WACE,iBACEM,EAAE,o1BACFF,KAAK,aAEP,iBACEE,EAAE,6qBACFF,KAAK,eAIXsC,QACE,iBAAK5C,QAAQ,gBAAgBC,MAAM,KAAKC,OAAO,KAA/C,WACE,iBACEM,EAAE,w4CACFF,KAAK,aAEP,iBACEE,EAAE,4nDACFF,KAAK,eAIXuC,OACE,iBAAKR,UAAU,QAAQrC,QAAQ,gBAAgBC,MAAM,KAAKC,OAAO,KAAjE,WACE,iBACEM,EAAE,iUACFF,KAAK,aAEP,iBACEE,EAAE,2zBACFF,KAAK,eAIXwC,OACE,gBAAKT,UAAU,QAAQrC,QAAQ,gBAAgBC,MAAM,MAAMC,OAAO,MAAlE,UACE,iBACEM,EAAE,8nBACFF,KAAK,cAIXyC,QACE,iBAAK/C,QAAQ,gBAAgBC,MAAM,KAAKC,OAAO,KAA/C,WACE,iBAAMM,EAAE,qXACR,iBAAMA,EAAE,qJACR,iBAAMA,EAAE,qJACR,iBAAMA,EAAE,wJCtDC,SAASwC,IACtB,IAAMnB,GAAWoB,EAAAA,EAAAA,MACXf,EAAOgB,EAAKC,MAAK,SAACC,GAAD,OAAU,IAAIC,OAAJ,WAAeD,EAAKE,MAAQ,KAAMC,KAAK1B,EAAS2B,aAEjF,OAAI,OAACtB,QAAD,IAACA,GAAAA,EAAMuB,UAIT,iBAAKpB,UAAWC,EAAAA,OAAhB,WACE,gBAAID,UAAWC,EAAAA,MAAf,UACIoB,EAAYxB,EAAKyB,OACnB,0BAAOzB,EAAK0B,WAEd,gBAAKvB,UAAWC,EAAAA,KAAhB,SACGJ,EAAKuB,UACJvB,EAAKuB,SAASjB,KAAI,SAACY,EAAMX,GACvB,OAAIW,EAAKS,SAEL,gBAAexB,UAAWC,EAAAA,QAA1B,SACGc,EAAKQ,MADEnB,GAKV,mBAAmBc,KAAKH,EAAKE,MAAQ,KAErC,eAAaxB,KAAMsB,EAAKE,KAAM7B,OAAO,UAArC,UACG2B,EAAKQ,MACN,iBAAK5D,QAAQ,gBAAgBC,MAAO,GAApC,WACE,iBAAMO,EAAE,iUACR,iBAAMA,EAAE,mWAJJiC,IAUV,SAAC,KAAD,CAAmB9B,GAAIyC,EAAKE,MAAQ,GAAIQ,SAAO,EAA/C,SACGV,EAAKQ,MADMnB,WA9BjB,KCVX,OAAgB,KAAO,oBAAoB,IAAM,mBAAmB,IAAM,mBAAmB,OAAS,sBAAsB,IAAM,mBAAmB,OAAS,uBCKjJsB,EAA6B,CACxCC,OAAQ,OAGGC,EAAU,SAACC,EAAqBC,GAC3C,OAAO,kBACFD,GACAC,IASMC,EAAeC,EAAAA,cAA6B,CACvDH,MAAOH,EACPO,SAAU,kBAAM,Q,WCtBlB,GACEpB,MACE,gBAAKjD,MAAM,KAAKC,OAAO,KAAKF,QAAQ,YAApC,UACE,eAAGM,KAAK,OAAOC,SAAS,UAAxB,WACE,iBAAMN,MAAM,KAAKC,OAAO,KAAKI,KAAK,UAAUiE,GAAG,OAC/C,iBAAMtE,MAAM,IAAIC,OAAO,KAAKsE,EAAE,IAAIC,EAAE,IAAInE,KAAK,UAAUiE,GAAG,SAC1D,iBAAMtE,MAAM,KAAKC,OAAO,KAAKsE,EAAE,KAAKC,EAAE,IAAInE,KAAK,OAAOoE,YAAY,OAAOH,GAAG,WAIlFI,SACE,gBAAK1E,MAAM,KAAKC,OAAO,KAAKF,QAAQ,YAApC,UACE,eAAGM,KAAK,OAAOC,SAAS,UAAxB,WACE,iBAAMN,MAAM,KAAKC,OAAO,KAAKI,KAAK,UAAUiE,GAAG,OAC/C,iBAAMtE,MAAM,KAAKC,OAAO,IAAIsE,EAAE,IAAIC,EAAE,IAAInE,KAAK,UAAUiE,GAAG,SAC1D,iBAAMtE,MAAM,KAAKC,OAAO,KAAKsE,EAAE,IAAIC,EAAE,KAAKnE,KAAK,OAAOoE,YAAY,MAAMH,GAAG,WAIjFK,OACE,iBAAKvC,UAAU,OAAOpC,MAAM,KAAKC,OAAO,KAAKF,QAAQ,cAArD,WACE,2BACE,iBAAM6E,GAAG,IAAIvE,KAAK,UAAUE,EAAE,kCAEhC,iBAAMF,KAAK,UAAUE,EAAE,qBACvB,gBAAKP,MAAM,KAAKC,OAAO,KAAK4E,UAAU,gCAAgCC,UAAU,QAChF,gBAAK9E,MAAM,KAAKC,OAAO,KAAK4E,UAAU,wCAAwCC,UAAU,QACxF,gBAAK9E,MAAM,KAAKC,OAAO,KAAK4E,UAAU,oCAAoCC,UAAU,QACpF,gBAAK9E,MAAM,KAAKC,OAAO,KAAK4E,UAAU,wCAAwCC,UAAU,QACxF,gBAAK9E,MAAM,KAAKC,OAAO,KAAK4E,UAAU,yCAAyCC,UAAU,WCpBhF,SAASC,IACtB,OAA4BC,EAAAA,EAAAA,YAAWb,GAA/BF,EAAR,EAAQA,MAAOI,EAAf,EAAeA,SACf,OACE,UAAC,EAAAY,SAAD,YACE,gBAAK7C,UAAW,CAACC,EAAAA,KAA8B,SAAjB4B,EAAMF,OAAoB,KAAO1B,EAAAA,KAAY6C,OAAOC,SAASC,KAAK,KAAKC,OAArG,UACE,UAAC,KAAD,CAAM3E,GAAG,IAAT,UACG4E,EAAAA,EAAAA,KACiB,QAAjBrB,EAAMF,SACL,mCACK,yBAAMhC,EAAAA,cAKjB,gBAAKK,UAAW,CAACC,EAAAA,IAA6B,SAAjB4B,EAAMF,OAAoB,KAAO1B,EAAAA,QAAe6C,OAAOC,SAASC,KAAK,KAAKC,OAAvG,SACGpD,EAAAA,KAAS,WAAuBO,GAAS,IAA7Ba,EAA4B,EAA5BA,KAAMM,EAAsB,EAAtBA,KAAMD,EAAgB,EAAhBA,KAIvB,GAHI6B,OAAOC,KAAK/B,GAAKgC,SAAS/B,KAC5BA,EAAQD,EAAYC,IAElB,oBAAoBJ,KAAKD,GAC3B,MAAqB,QAAjBY,EAAMF,QAEN,eAAavC,OAAO,UAAUK,KAAMwB,EAAMjB,UAAWC,EAAAA,SAArD,UACGqB,EADH,KACS,0BAAOC,MADRnB,IAMV,SAAC,IAAD,CACEkD,WAAW,EAEXC,UAA4B,SAAjB1B,EAAMF,OAAoB,QAAU,SAC/C6B,SAAS,iBAAM5E,MAAO,CAAE6E,WAAY,UAA3B,SAAwClC,IAJnD,UAME,cAAGnC,OAAO,UAAUK,KAAMwB,EAAMjB,UAAWC,EAAAA,SAA3C,SACGqB,KALElB,GAUX,IAAIsD,EAAmC,CACrCC,MAAO,QAET,MAAqB,QAAjB9B,EAAMF,QAEN,UAAC,KAAD,CACErD,GAAI2C,EAGJrC,MAAO,qBAAGgF,SAA2BF,OAAcG,GAJrD,UAMGvC,EANH,KAMS,0BAAOC,MAJTnB,IAUT,SAAC,IAAD,CACEkD,WAAW,EAEXC,UAA4B,SAAjB1B,EAAMF,OAAoB,QAAU,SAC/C6B,SAAS,iBAAM5E,MAAO,CAAE6E,WAAY,UAA3B,SAAwClC,IAJnD,UAME,SAAC,KAAD,CACEjD,GAAI2C,EAEJrC,MAAO,qBAAGgF,SAA2BF,OAAcG,GAHrD,SAKGvC,KATElB,SAeb,iBAAKJ,UAAW,CAACC,EAAAA,IAA6B,SAAjB4B,EAAMF,OAAoB,KAAO1B,EAAAA,QAAe6C,OAAOC,SAASC,KAAK,KAAKC,OAAvG,WACE,SAAC,IAAD,CAASM,UAA4B,SAAjB1B,EAAMF,OAAoB,QAAU,SAAU6B,QAAQ,uCAA1E,UACE,cAAG/D,KAAK,sBAAsBqE,IAAI,sBAAsB1E,OAAO,SAA/D,SACGyB,EAAAA,WAGL,mBAAQkD,QAAS,kBAAM9B,EAAS,CAAEN,OAAyB,SAAjBE,EAAMF,OAAoB,MAAQ,UAA5E,SACoB,SAAjBE,EAAMF,OAAoBd,EAAAA,KAAYA,EAAAA,gBClFjD,IAAQmD,EAA2BC,EAAAA,GAAAA,OAAnBC,EAAmBD,EAAAA,GAAAA,MAAZE,EAAYF,EAAAA,GAAAA,QAKpB,SAASG,EAAWrF,GACjC,MAA6BA,EAArBsF,UAAAA,OAAR,SACQxC,GAAUe,EAAAA,EAAAA,YAAWb,GAArBF,MACR,OACE,SAAC,KAAD,CAAQ7B,UAAWC,EAAAA,OAAnB,SACoB,QAAjB4B,EAAMF,QACL,UAAC,EAAAkB,SAAD,YACE,SAAC,KAAD,CAAOyB,UAAW,EAAG1F,MAAO,CAAE2F,OAAQ,KAAtC,UACE,SAACP,EAAD,CAAQpF,MAAO,CAAE4F,QAAS,OAAQC,WAAY,UAA9C,UACE,SAAC9B,EAAD,SAGJ,UAAC,KAAD,CAAQ3C,UAAWC,EAAAA,WAAnB,WACE,SAACiE,EAAD,CAAOtG,MAAOyG,EAAY,IAAM,EAAGrE,UAAWC,EAAAA,YAA9C,UACE,gBAAKrB,MAAO,CAAEhB,MAAOyG,EAAY,IAAM,EAAGxG,OAAQ,sBAAlD,UACE,SAAC8C,EAAD,SAGJ,SAACwD,EAAD,CAASvF,MAAO,CAAE8F,QAAS,IAAM1E,UAAWC,EAAAA,cAA5C,UACE,SAAC,KAAD,aAKN,UAAC,EAAA4C,SAAD,YACE,SAACqB,EAAD,CAAOtG,MAAOyG,EAAY,IAAM,GAAhC,UACE,UAAC,KAAD,CAAQrE,UAAWC,EAAAA,MAAnB,WACE,SAACiE,EAAD,CAAOlE,UAAWC,EAAAA,YAAoBrC,MAAO,GAA7C,UACE,SAAC+E,EAAD,OAEF,SAAC,KAAD,CACE/D,MAAO,CACL+F,SAAU,QACV/G,MAAOyG,EAAY,IAAM,GACzBE,OAAQ,EACRK,KAAM,EACNC,IAAK,EACLC,OAAQ,EACRC,SAAU,QARd,UAWE,SAACZ,EAAD,CAASnE,UAAWC,EAAAA,QAAgBrB,MAAO,CAAEoG,YAAa,IAA1D,UACE,SAACrE,EAAD,cAKR,UAAC,KAAD,CAAQ/B,MAAO,CAAE+F,SAAU,YAA3B,WACE,SAACX,EAAD,CACEpF,MAAO,CACLf,OAAQ,UACRoH,WAAY,OACZN,SAAU,WACVD,QAAS,WACT9G,MAAO,OACP4G,QAAS,OACTU,cAAe,MACfC,eAAgB,WAChBC,gBAAiB,cACjBb,OAAQ,IAXZ,UAcE,SAAC,EAAD,CAAe1E,KAAM/B,OAEvB,SAACqG,EAAD,CAASvF,MAAO,CAAE8F,QAAS,IAAM1E,UAAWC,EAAAA,cAA5C,UACE,SAAC,KAAD,cC1Ed,IAAMoF,EAAW,SAACC,GAAD,OAAoB,SAACvG,GAAD,OAEjC,SAAC,EAAAwG,SAAD,CAAUC,UAAU,SAAC,EAAD,IAApB,UACE,SAACF,GAAD,UAAevG,QAIf0G,EAAOJ,GAASK,EAAAA,EAAAA,OAAK,kBAAM,oCAC3BC,EAAaN,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAEjCE,EAAkBP,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FACtCG,EAAcR,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAClCI,EAAsBT,GAASK,EAAAA,EAAAA,OAAK,kBAAM,wFAC1CK,EAAWV,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC/BM,EAAYX,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAChCO,EAAcZ,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAClCQ,EAAsBb,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAE1CS,EAAWd,GAASK,EAAAA,EAAAA,OAAK,kBAAM,oCAC/BU,EAASf,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC7BW,EAAQhB,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC5BY,EAAWjB,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC/Ba,EAAWlB,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC/Bc,EAASnB,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC7Be,EAAQpB,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC5BgB,EAAWrB,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC/BiB,EAAWtB,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC/BkB,EAAkBvB,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FACtCmB,GAAWxB,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC/BoB,GAAOzB,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC3BqB,GAAe1B,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FACnCsB,GAAS3B,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC7BuB,GAAO5B,GAASK,EAAAA,EAAAA,OAAK,kBAAM,yFAC3BwB,GAAU7B,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC9ByB,GAAS9B,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC7B0B,GAAa/B,GAASK,EAAAA,EAAAA,OAAK,kBAAM,yFACjC2B,GAAYhC,GAASK,EAAAA,EAAAA,OAAK,kBAAM,yFAChC4B,GAAWjC,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC/B6B,GAAQlC,GAASK,EAAAA,EAAAA,OAAK,kBAAM,yFAC5B8B,GAAWnC,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC/B+B,GAAapC,GAASK,EAAAA,EAAAA,OAAK,kBAAM,yFACjCgC,GAAUrC,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC9BiC,GAAQtC,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC5BkC,GAASvC,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC7BmC,GAAQxC,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC5BoC,GAASzC,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC7BqC,GAAe1C,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FACnCsC,GAAQ3C,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC5BuC,GAAS5C,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC7BwC,GAAS7C,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC7ByC,GAAO9C,GAASK,EAAAA,EAAAA,OAAK,kBAAM,yFAC3B0C,GAAO/C,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC3B2C,GAAYhD,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAChC4C,GAAajD,GAASK,EAAAA,EAAAA,OAAK,kBAAM,yFACjC6C,GAAOlD,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC3BzB,GAASoB,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC7B8C,GAASnD,GAASK,EAAAA,EAAAA,OAAK,kBAAM,yFAC7B+C,GAAOpD,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC3BgD,GAAcrD,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAClCiD,GAAatD,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FACjCkD,GAAMvD,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC1BmD,GAAOxD,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC3BoD,GAAUzD,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC9BqD,GAAQ1D,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC5BsD,GAAa3D,GAASK,EAAAA,EAAAA,OAAK,kBAAM,yFACjCuD,GAAO5D,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC3BwD,GAAU7D,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC9ByD,GAAU9D,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC9B0D,GAAS/D,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC7B2D,GAAiBhE,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FACrC4D,GAAUjE,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC9B6D,GAAUlE,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC9B8D,GAAcnE,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAClC+D,GAAWpE,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC/BgE,GAAQrE,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC5BiE,GAAYtE,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAChCkE,GAAQvE,GAASK,EAAAA,EAAAA,OAAK,kBAAM,0FAC5BmE,GAAOxE,GAASK,EAAAA,EAAAA,OAAK,kBAAM,yFAC3BoE,GAAQzE,GAASK,EAAAA,EAAAA,OAAK,kBAAM,yFAErBqE,GAAwB,CACnC,CACE9I,KAAM,cACN+I,SAAS,SAAC,EAAD,CAAY3F,WAAW,IAChCjD,SAAU,CACR,CAAE6I,OAAO,EAAMD,SAAS,SAACrE,EAAD,KACxB,CAAE1E,KAAM,IAAK+I,SAAS,SAAC3L,EAAD,OAG1B,CACE4C,KAAM,SACN+I,SAAS,SAAC,EAAD,IACT5I,SAAU,CACR,CAAE6I,OAAO,EAAMD,SAAS,SAACpE,EAAD,KACxB,CAAE3E,KAAM,qBAAsB+I,SAAS,SAACpE,EAAD,KACvC,CAAE3E,KAAM,gBAAiB+I,SAAS,SAACnE,EAAD,KAClC,CAAE5E,KAAM,0BAA2B+I,SAAS,SAAClE,EAAD,KAC5C,CAAE7E,KAAM,aAAc+I,SAAS,SAACjE,EAAD,KAC/B,CAAE9E,KAAM,gBAAiB+I,SAAS,SAAC/D,EAAD,KAClC,CAAEhF,KAAM,cAAe+I,SAAS,SAAChE,EAAD,KAChC,CAAE/E,KAAM,wBAAyB+I,SAAS,SAAC9D,EAAD,KAC1C,CAAEjF,KAAM,IAAK+I,SAAS,SAAC3L,EAAD,OAG1B,CACE4C,KAAM,cACN+I,SAAS,SAAC,EAAD,IACT5I,SAAU,CACR,CAAE6I,OAAO,EAAMD,SAAS,SAAC7D,EAAD,KACxB,CAAElF,KAAM,uBAAwB+I,SAAS,SAAC7D,EAAD,KACzC,CAAElF,KAAM,qBAAsB+I,SAAS,SAAC5D,EAAD,KACvC,CAAEnF,KAAM,wBAAyB+I,SAAS,SAACzD,EAAD,KAC1C,CAAEtF,KAAM,oBAAqB+I,SAAS,SAAC3D,EAAD,KACtC,CAAEpF,KAAM,wBAAyB+I,SAAS,SAAC1D,EAAD,KAC1C,CAAErF,KAAM,qBAAsB+I,SAAS,SAACxD,EAAD,KACvC,CAAEvF,KAAM,oBAAqB+I,SAAS,SAACvD,EAAD,KACtC,CAAExF,KAAM,uBAAwB+I,SAAS,SAACtD,EAAD,KACzC,CAAEzF,KAAM,uBAAwB+I,SAAS,SAACrD,EAAD,KACzC,CAAE1F,KAAM,gCAAiC+I,SAAS,SAACpD,EAAD,KAClD,CAAE3F,KAAM,uBAAwB+I,SAAS,SAACnD,GAAD,KACzC,CAAE5F,KAAM,mBAAoB+I,SAAS,SAAClD,GAAD,KACrC,CAAE7F,KAAM,2BAA4B+I,SAAS,SAACjD,GAAD,KAC7C,CAAE9F,KAAM,qBAAsB+I,SAAS,SAAChD,GAAD,KACvC,CAAE/F,KAAM,mBAAoB+I,SAAS,SAAC/C,GAAD,KACrC,CAAEhG,KAAM,sBAAuB+I,SAAS,SAAC9C,GAAD,KACxC,CAAEjG,KAAM,qBAAsB+I,SAAS,SAAC7C,GAAD,KACvC,CAAElG,KAAM,0BAA2B+I,SAAS,SAAC5C,GAAD,KAC5C,CAAEnG,KAAM,yBAA0B+I,SAAS,SAAC3C,GAAD,KAC3C,CAAEpG,KAAM,uBAAwB+I,SAAS,SAAC1C,GAAD,KACzC,CAAErG,KAAM,oBAAqB+I,SAAS,SAACzC,GAAD,KACtC,CAAEtG,KAAM,uBAAwB+I,SAAS,SAACxC,GAAD,KACzC,CAAEvG,KAAM,yBAA0B+I,SAAS,SAACvC,GAAD,KAC3C,CAAExG,KAAM,uBAAwB+I,SAAS,SAACtC,GAAD,KACzC,CAAEzG,KAAM,oBAAqB+I,SAAS,SAACrC,GAAD,KACtC,CAAE1G,KAAM,qBAAsB+I,SAAS,SAACpC,GAAD,KACvC,CAAE3G,KAAM,oBAAqB+I,SAAS,SAACnC,GAAD,KACtC,CAAE5G,KAAM,qBAAsB+I,SAAS,SAAClC,GAAD,KACvC,CAAE7G,KAAM,4BAA6B+I,SAAS,SAACjC,GAAD,KAC9C,CAAE9G,KAAM,oBAAqB+I,SAAS,SAAChC,GAAD,KACtC,CAAE/G,KAAM,qBAAsB+I,SAAS,SAAC/B,GAAD,KACvC,CAAEhH,KAAM,qBAAsB+I,SAAS,SAAC9B,GAAD,KACvC,CAAEjH,KAAM,mBAAoB+I,SAAS,SAAC7B,GAAD,KACrC,CAAElH,KAAM,mBAAoB+I,SAAS,SAAC5B,GAAD,KACrC,CAAEnH,KAAM,yBAA0B+I,SAAS,SAAC3B,GAAD,KAC3C,CAAEpH,KAAM,yBAA0B+I,SAAS,SAAC1B,GAAD,KAC3C,CAAErH,KAAM,mBAAoB+I,SAAS,SAACzB,GAAD,KACrC,CAAEtH,KAAM,qBAAsB+I,SAAS,SAAC/F,GAAD,KACvC,CAAEhD,KAAM,qBAAsB+I,SAAS,SAACxB,GAAD,KACvC,CAAEvH,KAAM,mBAAoB+I,SAAS,SAACvB,GAAD,KACrC,CAAExH,KAAM,2BAA4B+I,SAAS,SAACtB,GAAD,KAC7C,CAAEzH,KAAM,0BAA2B+I,SAAS,SAACrB,GAAD,KAC5C,CAAE1H,KAAM,kBAAmB+I,SAAS,SAACpB,GAAD,KACpC,CAAE3H,KAAM,mBAAoB+I,SAAS,SAACnB,GAAD,KACrC,CAAE5H,KAAM,sBAAuB+I,SAAS,SAAClB,GAAD,KACxC,CAAE7H,KAAM,oBAAqB+I,SAAS,SAACjB,GAAD,KACtC,CAAE9H,KAAM,0BAA2B+I,SAAS,SAAChB,GAAD,KAC5C,CAAE/H,KAAM,mBAAoB+I,SAAS,SAACf,GAAD,KACrC,CAAEhI,KAAM,sBAAuB+I,SAAS,SAACd,GAAD,KACxC,CAAEjI,KAAM,uBAAwB+I,SAAS,SAACb,GAAD,KACzC,CAAElI,KAAM,qBAAsB+I,SAAS,SAACZ,GAAD,KACvC,CAAEnI,KAAM,8BAA+B+I,SAAS,SAACX,GAAD,KAChD,CAAEpI,KAAM,sBAAuB+I,SAAS,SAACV,GAAD,KACxC,CAAErI,KAAM,sBAAuB+I,SAAS,SAACT,GAAD,KACxC,CAAEtI,KAAM,2BAA4B+I,SAAS,SAACR,GAAD,KAC7C,CAAEvI,KAAM,uBAAwB+I,SAAS,SAACP,GAAD,KACzC,CAAExI,KAAM,oBAAqB+I,SAAS,SAACN,GAAD,KACtC,CAAEzI,KAAM,wBAAyB+I,SAAS,SAACL,GAAD,KAC1C,CAAE1I,KAAM,oBAAqB+I,SAAS,SAACJ,GAAD,KACtC,CAAE3I,KAAM,mBAAoB+I,SAAS,SAACH,GAAD,KACrC,CAAE5I,KAAM,oBAAqB+I,SAAS,SAACF,GAAD,KACtC,CAAE7I,KAAM,IAAK+I,SAAS,SAAC3L,EAAD,OAG1B,CACE4C,KAAM,IACN+I,SAAS,SAACvE,EAAD,MC7KPyE,GAAM,kBAAMC,EAAAA,EAAAA,IAAUJ,KACfK,GAAW,SAAC,GAAiD,IAA/ChJ,EAA8C,EAA9CA,SACzB,GAA0BiJ,EAAAA,EAAAA,YAAWzI,EAASF,GAA9C,eAAOG,EAAP,KAAcI,EAAd,KACA,OAAO,SAACF,EAAaqI,SAAd,CAAuBnL,MAAO,CAAE4C,MAAAA,EAAOI,SAAAA,GAAvC,SAAoDb,KAG7DkJ,EAAAA,QACE,SAAC,KAAD,WACE,SAACF,GAAD,WACE,SAACF,GAAD,QAGJK,SAASC,eAAe,U,muDCpBnB,SAASC,KCQT,SAASC,EAAUtL,EAAqCyF,GAC7D,GAAsB,qBAAXtF,OACT,OAAO,EAGT,IACMoL,EAAS9F,EAAM,YAAc,aAC7B+F,EAAoBxL,IAAWG,OAEjCsL,EAAMD,EAAYxL,EAJTyF,EAAM,cAAgB,eAIczF,EAAuBuL,GAKxE,OAJIC,GAA2B,kBAARC,IACrBA,EAAMN,SAASO,gBAAgBH,IAG1BE,ECpBF,IAMME,EAAY,SAACf,EAAsB5K,GAC9C,IAAM4L,EAAWhB,EAAQiB,wBACnBC,EARsB9L,SAAAA,GAC5B,OAAOA,IAAWG,OACbH,EAAuB6L,wBACvB,CAAEpG,IAAK,EAAGD,KAAM,EAAGE,OAAQ,GAKbqG,CAAc/L,GAC3BgM,EAAYV,EAAUtL,GAAQ,GAC9BiM,EAAaX,EAAUtL,GAEvBkM,EAAU/L,OAAOgL,SAASgB,KAC1BC,EAAYF,EAAQE,WAAa,EACjCC,EAAaH,EAAQG,YAAc,EAEzC,MAAO,CACL5G,IAAKmG,EAASnG,IAAMqG,EAAWrG,IAAMuG,EAAYI,EACjD5G,KAAMoG,EAASpG,KAAOsG,EAAWtG,KAAOyG,EAAaI,EACrD7N,MAAOoN,EAASpN,MAChBC,OAAQmN,EAASnN,SAIR6N,EAAmB,iBAAyB,qBAAXnM,OAAyBA,OAAS,M,iGCD3DkH,EAAAA,SAAAA,I,6BAcnBkF,SAAAA,EAAY5M,GAAkC,6BAC5C,cAAMA,IAVD8C,MAAoB,CACzB+J,sBAAkB/H,EAClBgI,gBAAYhI,GAOgC,EALtCiI,SAKsC,IAJtC1M,YAIsC,IAH7B2M,OAAS,CAAC,SAAU,SAAU,aAAc,YAAa,WAAY,WAAY,QAGpD,EAFtCC,cAAqC,GAEC,EADtCC,aACsC,IAuF9CC,YAAeC,SAAAA,GACTA,IACF,EAAKL,IAAMK,IAvFb,EAAKC,eAAiB,EAAKA,eAAeC,MAApB,WAFsB,E,gDAI9CC,WAAoB,WACZlN,EAASmN,KAAKxN,MAAMK,QAAUsM,EAEpCa,KAAKN,QAAU1M,OAAOiN,YAAW,WAC/B,EAAKpN,OAASA,IACd,EAAKqN,+B,kCAGTC,WACEH,KAAKI,sBACLC,aAAaL,KAAKN,W,4BAEpBG,WACE,IAAM9H,EAAciI,KAAKxN,MAAnBuF,UACEuI,EAAiBN,KAAKxN,MAAtB8N,aACR,GAAKN,KAAKT,KAAQS,KAAKT,IAAIgB,aAA3B,CAIA,IAAMC,EAAW,CACfnP,MAAO2O,KAAKT,IAAIkB,YAChBnP,OAAQ0O,KAAKT,IAAImB,cAEbC,EAAa,CAAErI,KAAK,EAAMC,QAAQ,GACf,kBAAdR,GAAkD,kBAAjBuI,IAC1CK,EAAWrI,KAAM,EACjBP,EAAY,GAGc,kBAAjBuI,IACTK,EAAWrI,KAAM,EACjBqI,EAAWpI,QAAS,GAGtB,IAAMqI,EAAapC,EAAUwB,KAAKT,IAAKS,KAAKnN,QACtC0M,EAAMS,KAAKT,IAAIb,wBACfnG,EAASyF,SAASO,gBAAgBmC,aAAenB,EAAI1J,EAAI+K,EAAWtP,OAEtEqP,EAAWrI,KAAOiH,EAAI1J,EAAI,GAC5BmK,KAAKa,qBAAL,UAA8BL,IAC9BR,KAAKc,cAAc,CACjB1I,SAAU,QACVE,IAAKP,GAAa,EAClBM,KAAMuI,EAAWvI,KACjBhH,MAAOuP,EAAWvP,SAEXsP,EAAWpI,QAAUA,EAAS,GACvCyH,KAAKa,qBAAL,UAA8BL,IAC9BR,KAAKc,cAAc,CACjB1I,SAAU,QACVG,OAAQ+H,GAAgB,EACxBjI,KAAMuI,EAAWvI,KACjBhH,MAAOuP,EAAWvP,UAGpB2O,KAAKa,sBACLb,KAAKc,oB,2BAGTA,SAAcxB,GACZ,IAAQ3M,EAAaqN,KAAKxN,MAAlBG,SACFoO,IAAYf,KAAK1K,MAAMgK,WAC7BU,KAAKgB,SAAS,CAAE1B,WAAAA,IAAc,WAC5B3M,GAAYA,EAASoO,Q,iCAGzBF,SAAoBxB,GAClBW,KAAKgB,SAAS,CAAE3B,iBAAAA,M,qCAGlBa,WAA0B,WACxBF,KAAKI,sBACLJ,KAAKR,OAAOyB,SAASC,SAAAA,GACnB,EAAKzB,cAAcyB,GAAa,EAAKrB,eACrC,EAAKhN,QAAU,EAAKA,OAAOsO,iBAAiBD,EAAW,EAAKrB,gBAAgB,Q,iCAGhFO,WAAsB,WACpBJ,KAAKR,OAAOyB,SAASC,SAAAA,GACnB,IAAME,EAAU,EAAK3B,cAAcyB,GACnC,EAAKrO,QAAU,EAAKA,OAAOwO,oBAAoBH,EAAWE,GAAS,Q,oBAQhEE,WACL,MAAqGtB,KAAKxN,MAAlG+O,EAAR,EAAQA,UAAW9N,EAAnB,EAAmBA,UAAWoB,EAA9B,EAA8BA,SAAwD2M,GAAtF,YACMC,EAAM,CAAChO,EAAW8N,GAAWhL,OAAOC,SAASC,KAAK,KAAKC,OAC7D,OACEgL,EAAAA,EAAAA,KAAAA,OAAAA,EAAAA,EAAAA,GAAAA,GAASF,EAAT,CAAqBG,IAAK3B,KAAKL,YAAatN,OAAK,UAAO2N,KAAK1K,MAAM+J,iBAAqBW,KAAKxN,MAAMH,OAAnGwC,UACE6M,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAWgO,EAAKpP,MAAO2N,KAAK1K,MAAMgK,WAAvCzK,SACGA,W,EAhHUqF,CAAczE,EAAAA,WAAdyE,EACL0H,aAA2B,CACvCL,UAAW,UACX5O,SAAUuL,G,kECzBD2D,IAAiC,qBAAX7O,SAA0BA,OAAOgL,WAAYhL,OAAOgL,SAAS8D,eAkBjF,SAASjF,EAAOrK,GAC7B,IAAQuP,EAAcvP,EAAduP,UACFC,GAAcC,EAAAA,EAAAA,UACdC,GAAeD,EAAAA,EAAAA,QAAgCF,GAWrD,OATAI,EAAAA,EAAAA,YAAU,WACR,OAAO,WACDH,EAAYI,SAAWF,EAAaE,UACtCF,EAAaE,QAAQC,YAAYL,EAAYI,SAC7CJ,EAAYI,aAAU9K,MAGzB,IAEEuK,GAGAK,EAAaE,UAChBF,EAAaE,QAAUpE,SAASgB,MAE7BgD,EAAYI,UACfJ,EAAYI,QAAUpE,SAAS8D,cAAc,OAC7CI,EAAaE,QAAQE,YAAYN,EAAYI,UAExCrE,EAAAA,aAAsBvL,EAAMqC,SAAUmN,EAAYI,UAThD,K,oPCEI,SAASzF,EAAQnK,GAC9B,IACEiB,EAqBEjB,EArBFiB,UACApB,EAoBEG,EApBFH,MAFF,GAsBIG,EAnBF+P,OAmBE/P,EAlBF+O,WAAAA,OAJF,MAIc,YAJd,IAsBI/O,EAjBFuE,UAAAA,OALF,WAsBIvE,EAhBFgQ,aAAAA,OANF,WAsBIhQ,EAfFiQ,cAAAA,OAPF,MAOkB,GAPlB,IAsBIjQ,EAdFkQ,YAAAA,OARF,MAQgB,GARhB,IAsBIlQ,EAbFmQ,YAAAA,OATF,WAsBInQ,EAZFoQ,cAAAA,OAVF,WAsBIpQ,EAXFkN,QAAAA,OAXF,MAWY,IAXZ,IAsBIlN,EAVFqQ,eAAAA,OAZF,MAYmB,YAZnB,IAsBIrQ,EARFsQ,UAAAA,OAdF,MAcc5E,EAdd,IAsBI1L,EAPFuQ,SAAAA,OAfF,MAea7E,EAfb,IAsBI1L,EANFwQ,UAAAA,OAhBF,MAgBc9E,EAhBd,IAsBI1L,EALFyQ,SAAAA,OAjBF,MAiBa/E,EAjBb,IAsBI1L,EAJF0Q,QAAAA,OAlBF,MAkBYhF,EAlBZ,EAmBErJ,EAGErC,EAHFqC,SAnBF,EAsBIrC,EAFF2Q,YAAAA,OApBF,MAoBgB,GApBhB,EAqBKC,GArBL,OAsBI5Q,EAtBJ,GAwBA,GAA4B6Q,EAAAA,EAAAA,UAAS7Q,EAAM+P,SAAU,GAArD,eAAOA,EAAP,KAAee,EAAf,KACA,GAA8BD,EAAAA,EAAAA,WAAS,GAAvC,eAAOE,EAAP,KAAgBC,EAAhB,KACMzB,GAAYE,EAAAA,EAAAA,QAAuB,MACnCwB,GAAUxB,EAAAA,EAAAA,QAAuB,OACvCE,EAAAA,EAAAA,YAAU,WACJI,IAAW/P,EAAM+P,QAAU/P,EAAM+P,QACnCiB,GAAW,GAETjB,IAAW/P,EAAM+P,QAAW/P,EAAM+P,SACpCmB,KACAJ,GAAU,MAEX,CAAC9Q,EAAM+P,UAEVJ,EAAAA,EAAAA,YAAU,WACJoB,IAsCAZ,GAAe5L,GACjBiH,SAASgB,KAAK2E,UAAUC,IAAOrC,EAA/B,SArCA+B,GAAU,MAEX,CAACC,IAEJ,IAAMM,GACgB,kBAAbhP,GACLiP,EAAAA,EAAAA,cAAajP,GAAD,UACPsO,EADO,CAEV9Q,OAAO,UAAKwC,EAASrC,MAAMH,MAAU8Q,EAAY9Q,OACjDoB,UAAW,CAACoB,EAASrC,MAAMiB,UAAc8N,EAA9B,YAAmDhL,OAAOC,SAASC,KAAK,KAAKC,OACxFqN,SAAU,MAGZrC,EAAAA,EAAAA,KAAAA,QAAAA,EAAAA,EAAAA,GAAAA,GAAUyB,EAAV,CAAuB1P,UAAc8N,EAAL,WAAhC1M,SACGA,KASP,SAASmP,GAAwBpR,GAC3BA,EAAEC,SAAWkP,EAAUK,SAAWrL,IAGlCyL,GAAgBG,IAClBe,KACAJ,GAAU,GACVJ,GAAWA,EAAQtQ,IAErB6P,GAAiBA,EAAcwB,aAAexB,EAAcwB,YAAYrR,IAS1E,SAAS8Q,KACHf,GAAe5L,GACjBiH,SAASgB,KAAK2E,UAAUO,OAAU3C,EAAlC,SAOJ,IAAM4C,IACJzC,EAAAA,EAAAA,KAAC0C,EAAAA,GAAD,QACEC,WAAYxB,EACZD,cAAeA,EACflD,QAASA,EACT4E,GAAI/B,EACJgC,WAAYzB,EACZ0B,UAAWzB,EACX0B,UAAWzB,EACX0B,SAzCJ,SAAsB9E,GACpB4D,GAAW,GACXP,GAAYA,EAASrD,KAwCfwD,EATN,CAAAvO,SAWI8P,SAAAA,GACA,OACEC,EAAAA,EAAAA,MAAAA,MAAAA,CACEvS,MAAOA,EACPsP,IAAK8B,EACLhQ,UAAW,CACT8N,EACA9N,EACCsD,EAAoC,KAArBwK,EAAhB,UACAgB,EAAYhB,EAAN,cAA+B,MAEpChL,OAAOC,SACPC,KAAK,KACLC,OAXL7B,SAAAA,CAaG8N,IACCmB,EAAAA,EAAAA,eAAapC,EAAAA,EAAAA,KAAAA,MAAAA,KAAD,UACPe,EADO,CAEVwB,YAAaD,GACbvQ,UAAW,CAAI8N,EAAJ,YAA0BkB,EAAchP,WAAW8C,OAAOC,SAASC,KAAK,KAAKC,OACxFqN,SAAUvB,EAAe,EAAI,QAEhCzL,GACC2K,EAAAA,EAAAA,KAAAA,MAAAA,CAAKC,IAAKI,EAAWkC,YAAaD,GAAyBvQ,UAAc8N,EAAL,aAApE1M,UACGiP,EAAAA,EAAAA,cAAaD,GAAgB,CAAE,cAAec,OAGjDb,EAAAA,EAAAA,cAAaD,GAAgB,CAAE,cAAec,WAO1D,OAAIpB,GAAWxM,GACN2K,EAAAA,EAAAA,KAAC7E,GAAD,qBAAiB6F,GAAjB,CAAA7N,SAAiCsP,MAEjCA,G,2FC7JI,SAASzJ,EAAmClI,GACzD,IACEiB,EAQEjB,EARFiB,UADF,EASIjB,EAPF+O,UAAAA,OAFF,MAEc,SAFd,IASI/O,EANFF,cAAAA,OAHF,MAGkB,SAHlB,IASIE,EALFqS,QAASC,OAJX,MAIqB,OAJrB,EAKE1N,EAIE5E,EAJF4E,MACAjF,EAGEK,EAHFL,KANF,EASIK,EAFFJ,KAAAA,OAPF,SAQK2S,GARL,OASIvS,EATJ,GAWIwS,EAAM,KACV,GAAoB,kBAAT7S,EACT6S,GACEtD,EAAAA,EAAAA,KAAAA,MAAAA,CAAKhQ,KAAM0F,EAAOhG,QAAQ,YAA1ByD,UACIoQ,EAAS9S,IAAS,IAAIyB,KAAI,SAAChC,EAAGsT,GAAJ,OAC1BxD,EAAAA,EAAAA,KAAAA,OAAAA,CAAc9P,EAAGA,EAAGD,SAAS,WAAlBuT,YAIZ,KAAIzP,EAAAA,eAAqBtD,GAK9B,OAAO,KAJP6S,EAAMvP,EAAAA,aAAmBtD,EAAM,CAC7BT,KAAM0F,IAKV2N,EAAO1S,OAAP0S,EAAAA,EAAAA,GAAAA,CAAiBrT,KAAM,gBAAmBqT,EAAO1S,OACjD,IAAM8S,GAAS,UACVJ,EADO,CAEVtR,UAAW,CACT8N,EACA9N,EACA8N,GAAajP,EAAmBiP,EAAhC,IAA6CjP,EAAkB,KAC/DF,GAAQmP,EAAeA,EAAvB,QAA0C,MAEzChL,OAAOC,SACPC,KAAK,KACLC,SAGL,OAAOjB,EAAAA,cAAoBqP,GAApBrP,EAAAA,EAAAA,GAAAA,GAAkC0P,GAAiBH,G,yHC3C5D,EAAevP,EAAAA,YAAiD,SAACjD,EAAOmP,GACtE,MAcInP,EAbF+O,UAAAA,OADF,MACc,QADd,IAcI/O,EAZF4S,SAAAA,OAFF,WAcI5S,EAXF6S,OAAAA,OAHF,WAcI7S,EAVF8S,QAAAA,OAJF,WAcI9S,EATF+S,MAAAA,OALF,WAcI/S,EARFgT,MAAAA,OANF,WAcIhT,EAPFiT,SAAAA,OAPF,MAOa,SAPb,IAcIjT,EANFL,KAAAA,OARF,MAQS,QART,IAcIK,EALFkT,KAAAA,OATF,MASS,UATT,EAUE3Q,EAIEvC,EAJFuC,KACAtB,EAGEjB,EAHFiB,UACAoB,EAEErC,EAFFqC,SACGkQ,GAbL,OAcIvS,EAdJ,GAeMiP,EAAM,CACVhO,EACA8N,EACAmE,EAAUnE,EAAN,SAAwBmE,EAAS,KACrCvT,EAAUoP,EAAN,IAAmBpP,EAAS,KAChCqT,EAAWjE,EAAN,SAA0B,KAC/B+D,EAAa/D,EAAN,WAA4B,KACnC6D,GAAYE,EAAU,WAAa,KACnCD,EAAS,SAAW,KACpBE,EAAQ,QAAU,MAEjBhP,OAAOC,SACPC,KAAK,KACLC,OAEH,OACEkO,EAAAA,EAAAA,MAAAA,UAAAA,EAAAA,EAAAA,GAAAA,GAAYG,EAAZ,CAAoBpD,IAAKA,EAAKxP,KAAMsT,EAAUL,SAAUA,GAAYE,EAAS7R,UAAWgO,EAAxF5M,SAAAA,CACGE,IAAQ2M,EAAAA,EAAAA,KAAChH,EAAD,CAAMvI,KAAM4C,IACpBF,GACCY,EAAAA,SAAAA,IAAmBZ,GAAW8Q,SAAAA,GAC5B,OAAKA,EACDlQ,EAAAA,eAAqBkQ,GAAeA,GACjCjE,EAAAA,EAAAA,KAAAA,OAAAA,CAAA7M,SAAO8Q,IAFKA,Y,8QC5B7B,EAAelQ,EAAAA,YAA2C,SAACjD,EAAOmP,GAChE,MAwBInP,EAvBF+O,UAAAA,OADF,MACc,UADd,EAEE9N,EAsBEjB,EAtBFiB,UACAoB,EAqBErC,EArBFqC,SAHF,EAwBIrC,EApBFoT,UAAAA,OAJF,WAwBIpT,EAnBFuE,UAAAA,OALF,WAwBIvE,EAlBFqT,UAAAA,OANF,SAQEC,GAgBEtT,EAjBF+P,OAiBE/P,EAhBFsT,OACAC,EAeEvT,EAfFuT,WACAC,EAcExT,EAdFwT,kBACAC,EAaEzT,EAbFyT,mBACAhP,EAYEzE,EAZFyE,QAZF,EAwBIzE,EAXF0T,YAAAA,OAbF,MAagB,eAbhB,IAwBI1T,EAVFL,KAAAA,OAdF,MAcS,QAdT,EAeE4C,EASEvC,EATFuC,KAfF,EAwBIvC,EARF2T,SAAAA,OAhBF,MAgBa,IAhBb,IAwBI3T,EAPF4T,SAAAA,OAjBF,MAiBa,IAjBb,EAkBE/U,EAMEmB,EANFnB,MAlBF,EAwBImB,EALF6T,mBAAAA,OAnBF,WAwBI7T,EAJF8T,SAAAA,OApBF,MAoBapI,EApBb,IAwBI1L,EAHF+T,UAAAA,OArBF,MAqBcrI,EArBd,EAsBEsI,EAEEhU,EAFFgU,UACGC,GAvBL,OAwBIjU,EAxBJ,GAyBA,GAA4B6Q,EAAAA,EAAAA,UAAS7Q,EAAM+P,QAA3C,eAAOA,EAAP,KAAee,EAAf,MACAnB,EAAAA,EAAAA,YAAU,WACJ3P,EAAM+P,SAAWA,GACnBe,EAAU9Q,EAAM+P,UAEjB,CAAC/P,EAAM+P,SAEV,OAA8Bc,EAAAA,EAAAA,WAAS,GAAvC,eAAOiC,EAAP,KAAgBoB,GAAhB,KACMjF,GAAM,CAACF,EAAW9N,EAAWtB,EAAO,GAAGA,EAAS,MAAMoE,OAAOC,SAASC,KAAK,KAAKC,OAlCd,SAsCzDiQ,GAtCyD,wDAAAC,IAAAA,EAAAA,EAAAA,GAAAA,IAAAA,MAsCxE,WAA4BhU,GAA5B,oEACE8T,IAAW,GADb,cAGIJ,GAHJ,qBAGY,OAHZ,SAGuBA,EAAS1T,GAHhC,+DAKE0Q,GAAU,GACVoD,IAAW,GANb,0DAtCwE,2CAAAG,IAAAA,EAAAA,EAAAA,GAAAA,IAAAA,MA8CxE,WAA6BjU,GAA7B,oEACE8T,IAAW,GADb,cAGIH,GAHJ,qBAGa,OAHb,SAGwBA,EAAU3T,GAHlC,+DAKE0Q,GAAU,GACVoD,IAAW,GANb,0DA9CwE,sBAsDxE,OACEhF,EAAAA,EAAAA,KAAC/E,GAAD,QAAS5F,UAAWA,EAAWwL,OAAQA,GAAYkE,EAAnD,CAA0DvD,QApB5D,WACEI,GAAU,IAmBkE7P,UAAWgO,GAAvF5M,UACE6M,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,aAAd1M,UACE+P,EAAAA,EAAAA,MAAAA,MAAAA,CACEnR,UAAW,CACN8N,EADM,SAETuE,EAAWvE,EAAN,eAAgC,KACrCxM,EAAUwM,EAAN,cAA+B,MAElChL,OAAOC,SACPC,KAAK,KACLC,OACHrE,MAAO,CAAE8T,SAAAA,EAAUC,SAAAA,EAAU/U,MAAAA,GAT/BwD,SAAAA,EAWIiR,GAAS/Q,KACT6P,EAAAA,EAAAA,MAAAA,MAAAA,CAAKnR,UAAc8N,EAAL,UAAd1M,SAAAA,CACGE,IAAQ2M,EAAAA,EAAAA,KAAChH,EAAD,CAAMvI,KAAM4C,IACpB+Q,IAASpE,EAAAA,EAAAA,KAAAA,KAAAA,CAAA7M,SAAKiR,IACdO,IAAsB3E,EAAAA,EAAAA,KAACrG,EAAD,CAAQmK,OAAK,EAAChO,QAAU5E,SAAAA,GAAD,OAAO+T,GAAa/T,IAAImC,KAAK,QAAQ5C,KAAK,cAG5FuP,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,QAAuBlP,MAAOmU,EAA5C3R,SACGA,GAAYoC,IAEd2O,IACChB,EAAAA,EAAAA,MAAAA,MAAAA,CAAKnR,UAAc8N,EAAL,UAAd1M,SAAAA,EACE6M,EAAAA,EAAAA,KAACrG,GAAD,QACEwK,UAAWA,EACX1T,KAAMA,EACNmT,QAASA,EACTF,SAAUE,GACNW,EALN,CAMEzO,QAAU5E,SAAAA,GAAD,OAtFiD,4CAsF1CkU,CAAclU,IANhCiC,SAQGqR,KAEFH,IACCrE,EAAAA,EAAAA,KAACrG,GAAD,UAAY2K,EAAZ,CAA+BxO,QAAU5E,SAAAA,GAAD,OAAO+T,GAAa/T,IAA5DiC,SACGkR,mB,oCChHnB,WAAgBvT,QAA2B,IAA3BA,IAAAA,EAAoB,IAClC,MAAoEA,EAApE,IAAQ+O,UAAAA,OAAR,MAAoB,UAApB,EAA+B9N,EAA/B,EAA+BA,UAA/B,IAA0CpC,MAAAA,OAA1C,MAAkD,IAAlD,EAA0DoV,GAA1D,OAAoEjU,EAApE,GACMiP,EAAM,CAACF,EAAW9N,GAAW8C,OAAOC,SAASC,KAAK,KAAKC,OAC7D,OACEgL,EAAAA,EAAAA,KAACvE,GAAD,UAAWsJ,EAAX,CAAkBpV,MAAOA,EAAOoC,UAAWgO,EAA3C5M,SACGrC,EAAMqC,a,WCZPkS,EACJ,mOAMF,WAAgBvU,QAA8B,IAA9BA,IAAAA,EAAuB,IACrC,MAAgCA,EAAxBwU,KAAAA,OAAR,MAAe,GAAf,EAAsBP,GAAtB,OAAgCjU,EAAhC,GACA,OACEkP,EAAAA,EAAAA,KAACpL,EAAAA,SAAD,CAAAzB,SACGmS,EAAKjU,MAAMgU,GAAWnT,KAAI,SAACqT,EAAMpT,GAChC,IAAMqT,EAAQD,EAAKC,MAAMH,GACzB,GAAIG,GAASA,EAAM,GAAI,CACrB,IAAMC,EAAMD,EAAM,GAClB,OACEE,EAAAA,EAAAA,eAAAA,KAAAA,EAAAA,EAAAA,GAAAA,GAAOX,EAAP,CAAcY,IAAKxT,EAAKX,KAAMiU,EAAIG,WAAW,QAAUH,EAAzBA,UAAyCA,IACpEA,GAIP,OAAOzF,EAAAA,EAAAA,KAACpL,EAAAA,SAAD,CAAAzB,SAAqBoS,GAANpT,S,wECJ9B,EAAe4B,EAAAA,YAA+C,SAACjD,EAAOmP,GACpE,MAUInP,EATF+O,UAAAA,OADF,MACc,WADd,IAUI/O,EARF+U,MAAAA,OAFF,MAEU,SAFV,IAUI/U,EAPFkT,KAAAA,OAHF,MAGS,UAHT,EAIEjS,EAMEjB,EANFiB,UACA+T,EAKEhV,EALFgV,IACAC,EAIEjV,EAJFiV,IACA1S,EAGEvC,EAHFuC,KAPF,EAUIvC,EAFFkV,QAAAA,OARF,MAQYxJ,EARZ,EASKsD,GATL,OAUIhP,EAVJ,GAWIqC,EAAWrC,EAAMqC,SACrB,GAAoCwO,EAAAA,EAAAA,WAAS,GAA7C,eAAOsE,EAAP,KAAmBC,EAAnB,KACMnG,EAAM,CACVF,EACA9N,EACAiS,EAAUnE,EAAN,IAAmBmE,EAAS,KAChC6B,EAAWhG,EAAN,IAAmBgG,EAAU,KAClCC,EAASjG,EAAN,SAA0B,MAE5BhL,OAAOC,SACPC,KAAK,KACLC,OAwBH,OAtBAyL,EAAAA,EAAAA,YAAU,WACRyF,GAAc,KACb,CAACpV,EAAMgV,MAENG,GAAcH,EAChB3S,GACE6M,EAAAA,EAAAA,KAAAA,MAAAA,CACE8F,IAAKA,EACLC,IAAKA,EACLC,QAAUG,SAAAA,IAEU,KADAH,EAAUA,EAAQG,QAAOvQ,IAEzCsQ,GAAc,MAKb7S,GAAwB,kBAATA,EACxBF,GAAW6M,EAAAA,EAAAA,KAAChH,EAAD,CAAMvI,KAAM4C,IACdA,GAAQU,EAAAA,eAAqBV,KACtCF,EAAWE,IAGX2M,EAAAA,EAAAA,KAAAA,QAAAA,EAAAA,EAAAA,GAAAA,GAAUF,EAAV,CAAsB/N,UAAWgO,EAAKE,IAAKA,EAA3C9M,SACGA,QCjEA,SAASiT,IACd,IAAIjJ,EAAY,EAMhB,OALIb,UAAYA,SAASO,iBAAmBP,SAASO,gBAAgBM,UACnEA,EAAYb,SAASO,gBAAgBM,UAC5Bb,SAASgB,OAClBH,EAAYb,SAASgB,KAAKH,WAErBA,E,yGCYT,EAAepJ,EAAAA,YAA+C,SAACjD,EAAOmP,GACpE,MAWInP,EAVF+O,UAAAA,OADF,MACc,aADd,EAEE9N,EASEjB,EATFiB,UACAwD,EAQEzE,EARFyE,QACApC,EAOErC,EAPFqC,SAJF,EAWIrC,EANFuF,UAAAA,OALF,MAKc,EALd,IAWIvF,EALFuV,MAAAA,OANF,WAWIvV,EAJFwV,MAAAA,OAPF,MAOU,IAPV,IAWIxV,EAHFyV,UAAAA,OARF,MAQc,EARd,IAWIzV,EAFF0V,UAAAA,OATF,SAUKzB,GAVL,OAWIjU,EAXJ,GAYM2V,EAAgBJ,GAAYE,GAAJ,EAC9B,GAA8B5E,EAAAA,EAAAA,UAAS,GAAvC,eAAO+E,EAAP,KAAgBC,EAAhB,KACA,GAA8BhF,EAAAA,EAAAA,UAAS,GAAvC,eAAOjB,EAAP,KAAgBkG,EAAhB,KACM/E,EAAU6E,GAAWD,EACrB1G,EAAM,CACVF,EACA9N,EACCsU,EAAqB,KAAb,WACTxE,EAAahC,EAAN,QAAyB,KAC/BgC,EAAgC,KAAnBhC,EAAd,SAEChL,OAAOC,SACPC,KAAK,KACLC,OAOH,SAAS6R,IACPF,EDnBG,SAA0BtQ,QAAuB,IAAvBA,IAAAA,EAAoB,GACnD,IAAIqQ,EAAU,EAMd,OALIrQ,EAAY+P,MACdM,EAAUI,KAAKC,OACXX,IAAiB/P,IAAciG,SAASgB,KAAK0J,aAAe3Q,EAAY/E,OAAO2V,aAAgB,MAG9FP,EAAU,IAAM,IAAMA,ECYhBQ,CAAiB7Q,IAC5BuQ,EAAWR,KAEb,SAASe,IACkB,kBAAd9Q,GAA2C,kBAAViQ,GAAyC,kBAAZ5F,GDzCtE,SAAyBhK,EAAsB0Q,EAAoB1G,QAAqB,IAA/DhK,IAAAA,EAAmB,QAA4C,IAAzC0Q,IAAAA,EAAe,UAA0B,IAArB1G,IAAAA,EAAkB,GAC1F,IAAI2G,EAAQ,EACNC,EAAQC,aAAY,WACpB7G,EAAU2G,GAAS3Q,EAEjBgK,GADJ2G,GAASD,IACc1Q,EACrBpF,OAAOkW,SAAS,EAAG9G,EAAU2G,GAE7B/V,OAAOkW,SAAS,EAAG9Q,GAGrB+Q,cAAcH,KAEf,GC6BCI,CAAgBrR,EAAWiQ,EAAO5F,GAGtC,OAfAD,EAAAA,EAAAA,YAAU,WAER,OADAnP,QAAUA,OAAOmO,iBAAiB,SAAUoH,GACrC,WACLvV,QAAUA,OAAOqO,oBAAoB,SAAUkH,QAajD3D,EAAAA,EAAAA,MAAAA,OAAAA,EAAAA,EAAAA,GAAAA,CAAKpN,QAAS,kBAAM0Q,GAAaW,KAAepV,UAAWgO,GAASgF,EAApE,CAA2E9E,IAAKA,EAAhF9M,SAAAA,CACGoC,EACoB,oBAAbpC,EAA0BA,EAAWA,EAAS,CAAEuT,QAAAA,EAAShG,QAAAA,EAASyG,YAAaA,W,wFCvD7F,EAAepT,EAAAA,YAA8C,SAACjD,EAAOmP,GACnE,MAWInP,EAVF+O,UAAAA,OADF,MACc,UADd,EAEE9N,EASEjB,EATFiB,UAFF,EAWIjB,EARFH,MAAAA,OAHF,MAGU,GAHV,EAIE+E,EAOE5E,EAPF4E,MAJF,EAWI5E,EANF6W,IAAAA,OALF,MAKQ,GALR,IAWI7W,EALF8W,IAAAA,OANF,WAWI9W,EAJF+W,WAAAA,OAPF,SAQEC,EAGEhX,EAHFgX,MACA3U,EAEErC,EAFFqC,SACG4R,GAVL,OAWIjU,EAXJ,GAYMiX,EAAW,CACfhW,UAAW,CAAE6V,EAA6B,KAApB/H,EAAV,SAAoC+H,EAAM,MAAQ,MAAM/S,OAAOC,SAASC,KAAK,KAAKC,OAC9FrE,MAAO,IAEHoP,EAAM,CACVhO,EACA8N,EACC1M,EAAsB,KAAX,SACXA,EAAmC,KAArB0M,EAAf,UACAgI,EAAgBhI,EAAN,cAA+B,MAExChL,OAAOC,SACPC,KAAK,KACLC,OAEGgT,EAA8B,GAMpC,OALIF,GAAmB,IAAVA,EACXC,EAASpX,OAAToX,EAAAA,EAAAA,GAAAA,CAAmB5Q,gBAAiBzB,GAAU/E,GAE9CqX,EAAarX,MAAQA,GAAS,IAG9BuS,EAAAA,EAAAA,MAAAA,QAAAA,EAAAA,EAAAA,GAAAA,CAAMnR,UAAWgO,GAASgF,EAAWiD,EAArC,CAAmD/H,IAAKA,EAAxD9M,SAAAA,CACGuC,IAASsK,EAAAA,EAAAA,KAAAA,OAAAA,CAAMjO,UAAc8N,EAAL,OAAsBlP,MAAO,CAAEwG,gBAAiBzB,KACxEvC,EACU,IAAV2U,IAAgBpS,IAASsK,EAAAA,EAAAA,KAAAA,OAAAA,EAAAA,EAAAA,GAAAA,GAAS+H,EAAT,CAAA5U,UAAqByU,GAAOE,GAASH,GAAOG,EAAQH,EAASA,EAAzC,IAAkDG,Y,2DCLtG,EA9BuB/T,EAAAA,YAAkD,SAACjD,EAAOmP,GAC/E,MAA0GnP,EAAlG+O,UAAAA,OAAR,MAAoB,eAApB,EAAoC9N,EAAsEjB,EAAtEiB,UAApC,EAA0GjB,EAA3DqS,QAASC,OAAxD,MAAkE,OAAlE,EAA0EO,EAAgC7S,EAAhC6S,OAAQsE,EAAwBnX,EAAxBmX,UAAclD,GAAhG,OAA0GjU,EAA1G,GACMoX,EAAQnU,EAAAA,eAAqBkU,GAC7BlI,EAAM,CACPF,EADO,QAEV9N,EACA4R,EAAS,SAAW,KACnBsE,EAA6B,KAAjB,eACbC,EAAQ,YAAc,MAErBrT,OAAOC,SACPC,KAAK,KACLC,OACG0M,GAAa,QAAE3P,UAAWgO,GAAQgF,GAIxC,OAHKmD,IACHxG,EAAW,kBAAoBuG,GAE1BlU,EAAAA,cACLqP,GADKrP,EAAAA,EAAAA,GAAAA,GAGA2N,EAHA,CAIHzB,IAAAA,KAEFiD,EAAAA,EAAAA,MAACtO,EAAAA,SAAD,CAAAzB,SAAAA,CACG+U,IAASlI,EAAAA,EAAAA,KAAAA,OAAAA,CAAMjO,UAAc8N,EAAL,aAAf1M,SAA4C8U,IACrDnX,EAAMqC,gB,wCC5BPkH,EAAatG,EAAAA,YAAkD,SAACjD,EAAOmP,GAC3E,MAA6EnP,EAArE+O,UAAAA,OAAR,MAAoB,eAApB,EAAoC9N,EAAyCjB,EAAzCiB,UAApC,EAA6EjB,EAA9BmX,UAAAA,OAA/C,MAA2D,IAA3D,EAAmElD,GAAnE,OAA6EjU,EAA7E,GACMiP,EAAM,CAACF,EAAW9N,GAAW8C,OAAOC,SAASC,KAAK,KAAKC,OAC7D,OACEgL,EAAAA,EAAAA,KAAAA,OAAAA,EAAAA,EAAAA,GAAAA,IAAAA,EAAAA,EAAAA,GAAAA,CAAWjO,UAAWgO,GAAQgF,GAA9B,CAAuC9E,IAAKA,EAA5C9M,SACGY,EAAAA,SAAAA,IAAmBjD,EAAMqC,UAAW4I,SAAAA,GACnC,OAAOhI,EAAAA,aAAmBgI,EAAS7G,OAAOiT,OAAO,CAAEF,UAAAA,GAAalM,EAAQjL,MAAO,cAStFuJ,EAA0B+N,KAAOA,EAElC,ICxBA,EDwBA,E,kDErBA,EAAerU,EAAAA,YAAmD,SAACjD,EAAOmP,GACxE,MAA4FnP,EAApF+O,UAAAA,OAAR,MAAoB,cAApB,IAA4F/O,EAAzDuX,SAAAA,OAAnC,SAAqDlV,EAAuCrC,EAAvCqC,SAAUpB,EAA6BjB,EAA7BiB,UAAc+N,GAA7E,OAA4FhP,EAA5F,GAEMiP,EAAM,CAACF,EAAW9N,EAAWsW,GAAexI,EAAP,aAA6BhL,OAAOC,SAASC,KAAK,KAAKC,OAElG,OACEgL,EAAAA,EAAAA,KAAAA,OAAAA,EAAAA,EAAAA,GAAAA,CAAKjO,UAAWgO,GAASD,EAAzB,CAAqCG,IAAKA,EAA1C9M,SACGA,Q,wBCbP,SAASoE,GAAS+Q,EAAsBpK,GACtC,GAAIA,EACF,GACE,GAAIA,IAASoK,EAAS,OAAO,QACrBpK,EAAOA,EAAKqK,YAGxB,OAAO,EAGT,SAASC,GAAM1V,GACb,MAA8B,oBAAhB2V,YACV3V,aAAgB2V,YAChB3V,GAAwB,kBAATA,GAAuC,IAAlBA,EAAK4V,UAA2C,kBAAlB5V,EAAK6V,SAG7E,IAgBA,KAlCuC,qBAAXrX,SAA0BA,OAAOgL,WAAYhL,OAAOgL,SAAS8D,eAsBnF,SAAUkI,EAAsBpK,GAC9B,OAAIoK,GAAWA,EAAQM,UAAwC,oBAArBN,EAAQM,UAA2BJ,GAAMtK,GAC1EoK,EAAQM,SAAS1K,GAEtBoK,GAAWA,EAAQO,yBAA2BL,GAAMtK,GAC/CoK,IAAYpK,KAAWoK,EAAQO,wBAAwB3K,GAEzD3G,GAAS+Q,EAASpK,IAE3B3G,GCjBS,SAASuR,GAAe9W,EAAqB+W,GAC1D,IAAMC,EAAyB,MAATD,EAAe,OAAS,MACxCE,EAA0B,SAAVD,EAAmB,QAAU,SACnD,OAAOE,WAAWlX,EAAO,SAASgX,EAAV,UAA2BE,WAAWlX,EAAO,SAASiX,EAAV,UCjBtE,OAAiC,qBAAX3X,QAA8C,qBAAbgL,SCUjD6M,GAASC,OAAiB9X,OAAkB+X,uBAAyB/M,SAAsBgN,cAC3FC,GAASH,IAAa,UAAUnW,KAAKuW,UAAUC,WAStC,SAASC,GAAK7Z,GAC3B,OAAgB,KAAZA,EACKsZ,GAEO,KAAZtZ,EACK0Z,GAEFJ,IAAUI,GCbnB,SAASI,GAAQZ,EAA0BzL,EAAmBsM,EAAoBC,GAChF,OAAO/C,KAAKa,IACVrK,EAAK,SAASyL,GACdzL,EAAK,SAASyL,GACda,EAAK,SAASb,GACda,EAAK,SAASb,GACda,EAAK,SAASb,GACdW,GAAK,IACDI,SAASF,EAAK,SAASb,GAAS,IAC9Be,SAASD,EAAc,UAAkB,WAATd,EAAoB,MAAQ,SAAW,IACvEe,SAASD,EAAc,UAAkB,WAATd,EAAoB,SAAW,UAAY,IAC7E,GCAO,SAAS/L,GAAsBjB,GAC5C,IAAIgO,EAAO,GAKX,IACE,GAAIL,GAAK,IAAK,CACZK,EAAOhO,EAAQiB,wBACf,IAAMG,EAAYV,EAAUV,GAAS,GAC/BqB,EAAaX,EAAUV,GAC7BgO,EAAKnT,KAAOuG,EACZ4M,EAAKpT,MAAQyG,EACb2M,EAAKlT,QAAUsG,EACf4M,EAAKC,OAAS5M,OAEd2M,EAAOhO,EAAQiB,wBAGjB,MAAO9L,IAET,ICvCoC+Y,EDuC9BC,EAAS,CACbvT,KAAMoT,EAAKpT,KACXC,IAAKmT,EAAKnT,IACVjH,MAAOoa,EAAKC,MAAQD,EAAKpT,KACzB/G,OAAQma,EAAKlT,OAASkT,EAAKnT,KAIvBuT,EAAyC,SAArBpO,EAAQ4M,SDvBrB,SAAwBrM,GACrC,IAAMgB,EAAOhB,EAASgB,KAChBsM,EAAOtN,EAASO,gBAChBgN,EAAgBO,iBAAiBR,GAEvC,MAAO,CACLha,OAAQ+Z,GAAQ,SAAUrM,EAAMsM,EAAMC,GACtCla,MAAOga,GAAQ,QAASrM,EAAMsM,EAAMC,ICgBkBQ,CAAetO,EAAQuO,eAAkB,GAC3F3a,EAAQwa,EAAMxa,OAASoM,EAAQgD,aAAemL,EAAOF,MAAQE,EAAOvT,KACpE/G,EAASua,EAAMva,QAAUmM,EAAQiD,cAAgBkL,EAAOrT,OAASqT,EAAOtT,IAE1E2T,EAAiBxO,EAAQyO,YAAc7a,EACvC8a,EAAgB1O,EAAQ2O,aAAe9a,EAO3C,GALAsa,EAAOS,WAAa5O,EAAQ4O,YAAc5O,EAAQqB,YAAc,EAChE8M,EAAO7T,UAAY0F,EAAQ1F,WAAa0F,EAAQ1F,WAAa,EAIzDkU,GAAkBE,EAAe,CACnC,IAAMzY,EE5DK,SACb+J,EACA6O,GAEA,GAAyB,IAArB7O,EAAQ2M,SACV,MAAO,GAGT,IACMmC,EADS9O,EAAQuO,cAAeQ,YACcV,iBAAiBrO,EAAS,MAC9E,OAAO6O,EAAWC,EAAID,GAAYC,EFkDjBE,CAAyBhP,GACxCwO,GAAkBzB,GAAe9W,EAAQ,KACzCyY,GAAiB3B,GAAe9W,EAAQ,KAExCkY,EAAOva,OAAS4a,EAChBL,EAAOta,QAAU6a,EAGnB,OCpEoCR,EDoEfC,GCnErB,UACKD,EADL,CAEED,MAAOC,EAAQtT,KAAOsT,EAAQta,MAC9BkH,OAAQoT,EAAQrT,IAAMqT,EAAQra,SECnB,SAASob,GAAcjP,GACpC,IAAIgO,EAAOhO,EAAQiB,wBASnB,MAJsB,CACpBrN,MAAOoM,EAAQyO,aAAezO,EAAQkP,aAAelB,EAAKpa,OAAS,EACnEC,OAAQmM,EAAQ2O,cAAgB3O,EAAQiL,cAAgB+C,EAAKna,QAAU,GCPpE,SAASsb,GAASC,GACvB,MAAyFA,GAAW,GAArFC,EAAf,EAAMC,QAA4BC,EAAlC,EAA2BC,MAAiBjW,EAA5C,EAA4CA,UAAWD,EAAvD,EAAuDA,UAAWmW,EAAlE,EAAkEA,mBAC5DC,EAAM,CACV9U,KAAM,EACNC,IAAK,EACLtB,UAAAA,GAGF,IAAK8V,IAAeE,IAAahP,SAC/B,OAAOmP,EAGT,IAAMC,EAAgB5E,KAAKa,IAAIrL,SAASO,gBAAgBmC,aAAc1N,OAAO2V,aAAe,GACtF0E,EAAe7E,KAAKa,IAAIrL,SAASO,gBAAgBkC,YAAazN,OAAOsa,YAAc,GAEzFH,EAAInW,UAAYA,EAChB,IAAM6H,EAAYV,EAAW2O,EAA2Bd,cAAezN,iBAAiB,GAClFO,EAAaX,EAAW2O,EAA2Bd,cAAezN,iBAClEwO,GAAU,UACXrO,GAAsBoO,GACtBJ,GAAcI,IAEbG,GAAQ,UACTvO,GAAsBsO,GACtBN,GAAcM,IAGbzU,EAAS6U,EAAgBL,EAAQxU,OACjCmT,EAAQ2B,EAAeN,EAAQ1U,KAAO0U,EAAQ1b,MAsBpD,OApBA8b,EAAI7U,IAAMyU,EAAQzU,IAAMuG,EACxBsO,EAAI9U,KAAO0U,EAAQ1U,KAEdtB,IACHoW,EAAI7U,IAAMyU,EAAQhV,UAClBoV,EAAI9U,KAAO0U,EAAQV,YAGjBrV,GAAa,SAASrC,KAAKqC,KAC7BmW,EAAI7U,KAAO2U,EAAM3b,QAEf0F,GAAa,WAAWrC,KAAKqC,KAC/BmW,EAAI9U,MAAQ0U,EAAQ1b,OAElB2F,GAAa,YAAYrC,KAAKqC,KAChCmW,EAAI7U,KAAOyU,EAAQzb,QAEjB0F,GAAa,UAAUrC,KAAKqC,KAC9BmW,EAAI9U,MAAQ4U,EAAM5b,OAEZ8b,EAAInW,WACV,IAAK,aACL,IAAK,UAWL,IAAK,WACL,IAAK,UAWL,QACE,MAtBF,IAAK,SAEL,IAAK,MACHmW,EAAI9U,KAAO8U,EAAI9U,MAAQ4U,EAAM5b,MAAQ0b,EAAQ1b,OAAS,EACtD,MACF,IAAK,cACL,IAAK,WACH8b,EAAI9U,KAAO8U,EAAI9U,KAAOyG,EAAaiO,EAAQ1b,MAAQ4b,EAAM5b,MACzD,MAIF,IAAK,QAEL,IAAK,OACH8b,EAAI7U,IAAM6U,EAAI7U,KAAO2U,EAAM3b,OAASyb,EAAQzb,QAAU,EACtD,MACF,IAAK,cACL,IAAK,aACH6b,EAAI7U,IAAM6U,EAAI7U,IAAM2U,EAAM3b,OAASyb,EAAQzb,OAmF/C,OA9EI4b,IACElW,GAAa,SAASrC,KAAKqC,IAAc+V,EAAQzU,IAAM2U,EAAM3b,QAAUiH,EAAS0U,EAAM3b,SACxF6b,EAAInW,UAAYA,EAAU9B,QAAQ,OAAQ,UAC1CiY,EAAI7U,IAAM6U,EAAI7U,IAAM2U,EAAM3b,OAASyb,EAAQzb,QAEzC0F,GAAa,YAAYrC,KAAKqC,IAAcuB,EAAS0U,EAAM3b,QAAUyb,EAAQzU,IAAM2U,EAAM3b,SAC3F6b,EAAInW,UAAYA,EAAU9B,QAAQ,UAAW,OAC7CiY,EAAI7U,IAAM6U,EAAI7U,IAAM2U,EAAM3b,OAASyb,EAAQzb,QAEzC0F,GAAa,WAAWrC,KAAKqC,IAAc0U,EAAQuB,EAAM5b,QAC3D8b,EAAInW,UAAYA,EAAU9B,QAAQ,SAAU,QAC5CiY,EAAI9U,KAAO8U,EAAI9U,KAAO0U,EAAQ1b,MAAQ4b,EAAM5b,OAE1C2F,GAAa,UAAUrC,KAAKqC,IAAc+V,EAAQ1U,KAAO4U,EAAM5b,QACjE8b,EAAInW,UAAYA,EAAU9B,QAAQ,QAAS,SAC3CiY,EAAI9U,KAAO8U,EAAI9U,KAAO0U,EAAQ1b,MAAQ4b,EAAM5b,OAG1C2F,GAAa,gBAAgBrC,KAAKqC,IAAcD,GAG/C,SAASpC,KAAKqC,IAAc+V,EAAQzU,IAAM,GAC1C,gBAAgB3D,KAAKqC,IAAc+V,EAAQzU,IAAMyU,EAAQzb,OAAS,EAAI2b,EAAM3b,OAAS,GACrF,YAAYqD,KAAKqC,IAAc+V,EAAQzU,IAAMyU,EAAQzb,OAAS2b,EAAM3b,UAErE6b,EAAI7U,IAAMuG,IAIR7H,GAAa,SAASrC,KAAKqC,IAAc+V,EAAQzU,IAAM,IACzD6U,EAAI7U,KAAOyU,EAAQzU,KAEjBtB,GAAa,YAAYrC,KAAKqC,IAAc+V,EAAQxU,OAAS0U,EAAM3b,SAErE6b,EAAI7U,IAAM6U,EAAI7U,KAAO2U,EAAM3b,OAASyb,EAAQxU,SAE1CvB,GAAa,gBAAgBrC,KAAKqC,IAAc+V,EAAQxU,OAASwU,EAAQzb,OAAS,EAAI2b,EAAM3b,OAAS,IACvG6b,EAAI7U,IAAM6U,EAAI7U,IAAM2U,EAAM3b,OAAS,GAAKyb,EAAQxU,OAASwU,EAAQzb,OAAS,KAI1E0F,GAAa,gBAAgBrC,KAAKqC,KAChC,SAASrC,KAAKqC,IAAcuB,EAASwU,EAAQzb,OAAS2b,EAAM3b,SAC9D6b,EAAI7U,IAAM6U,EAAI7U,KAAO2U,EAAM3b,OAASiH,EAASwU,EAAQzb,SAEnD,gBAAgBqD,KAAKqC,IAAcuB,EAASwU,EAAQzb,OAAS,EAAI2b,EAAM3b,OAAS,IAClF6b,EAAI7U,IAAM6U,EAAI7U,KAAO2U,EAAM3b,OAAS,EAAIiH,EAASwU,EAAQzb,OAAS,IAEhE,YAAYqD,KAAKqC,IAAcuB,EAAS,IAC1C4U,EAAI7U,IAAM6U,EAAI7U,IAAMC,IAIpBvB,GAAa,gBAAgBrC,KAAKqC,IAAcD,IAG/C,UAAUpC,KAAKqC,IAAc+V,EAAQ1U,KAAO,GAC5C,gBAAgB1D,KAAKqC,IAAc+V,EAAQ1U,KAAO0U,EAAQ1b,MAAQ,EAAI4b,EAAM5b,MAAQ,GACpF,WAAWsD,KAAKqC,IAAc+V,EAAQ1U,KAAO0U,EAAQ1b,MAAQ4b,EAAM5b,SAEpE8b,EAAI9U,KAAOyG,GAGT,gBAAgBnK,KAAKqC,IAAc0U,EAAQqB,EAAQ1b,MAAQ,EAAI4b,EAAM5b,MAAQ,IAC/E8b,EAAI9U,KAAO0U,EAAQ1U,KAAO0U,EAAQ1b,MAAQqa,EAAQuB,EAAM5b,QAEjD2F,GAAa,gBAAgBrC,KAAKqC,IAAc0U,EAAQqB,EAAQ1b,MAAQ,EAAI4b,EAAM5b,MAAQ,IACnG8b,EAAI9U,KAAO8U,EAAI9U,MAAQqT,EAAQqB,EAAQ1b,MAAQ,EAAI4b,EAAM5b,MAAQ,IAE/D2F,GAAa,gBAAgBrC,KAAKqC,KAChC,UAAUrC,KAAKqC,IAAc+V,EAAQ1b,MAAQqa,EAAQuB,EAAM5b,QAC7D8b,EAAI9U,KAAO8U,EAAI9U,MAAQ4U,EAAM5b,MAAQ0b,EAAQ1b,MAAQqa,IAEnD,WAAW/W,KAAKqC,IAAc0U,EAAQ,IACxCyB,EAAI9U,KAAO8U,EAAI9U,KAAOqT,KAIrByB,E,2MCpGHI,GAAkBC,SAAAA,GAAD,OAAoBA,GAA0B,kBAAVA,EAAqBA,EAAQ,CAAEC,KAAMD,EAAOE,KAAMF,IAO7G,GAAe/X,EAAAA,YAAyD,SAACjD,EAAOmP,GAC9E,IACElO,EAmBEjB,EAnBFiB,UADF,EAoBIjB,EAjBF+O,UAAAA,OAHF,MAGc,oBAHd,IAoBI/O,EAhBFuE,UAAAA,OAJF,YAoBIvE,EAfFmb,UAeEnb,EAdFob,gBAAAA,OANF,WAoBIpb,EAbF4S,SAAAA,OAPF,YAoBI5S,EAZF+P,OAYE/P,EAXFua,SAAAA,OATF,MASY,QATZ,IAoBIva,EAVFwE,UAAAA,OAVF,MAUc,MAVd,EAYEkW,EAQE1a,EARF0a,mBACArK,EAOErQ,EAPFqQ,eAEAhO,EAKErC,EALFqC,SACA4O,EAIEjR,EAJFiR,QAhBF,EAoBIjR,EAHFqb,gBAAAA,OAjBF,MAiBoB3P,EAjBpB,IAoBI1L,EAFFsb,QAAAA,OAlBF,MAkBY5P,EAlBZ,EAmBKuI,GAnBL,OAoBIjU,EApBJ,IAsBMwF,GAASiK,EAAAA,EAAAA,QAAe,KACxB8L,GAAa9L,EAAAA,EAAAA,UACb+L,GAAW/L,EAAAA,EAAAA,UACXgM,GAAahM,EAAAA,EAAAA,QAAiB,IAC9BiM,GAAgBjM,EAAAA,EAAAA,QAA+B,MACrD,GAA4BoB,EAAAA,EAAAA,YAAW7Q,EAAM+P,QAA7C,eAAOA,EAAP,KAAee,EAAf,KACA,GAAsCD,EAAAA,EAAAA,UAAsB,CAC1DrM,UAAAA,EACAsB,IAAK,EACLC,OAAQ,EACRF,KAAM,EACNqT,MAAO,EACP1T,OAAQA,EAAOoK,UANjB,eAAO+L,EAAP,KAAoBC,EAApB,MAQAC,EAAAA,EAAAA,qBAAoB1M,GAAK,iBAAO,CAC9B+L,KAAM,kBAAMA,KACZD,KAAM,kBAAMA,UAGd,IAAM9H,EAAalQ,EAAAA,SAAAA,KAAoBZ,GACjCyZ,GAA6B,UAC9B7H,EAD2B,CAE9BzP,UAAAA,EACAuL,OAAAA,EACAY,YAAa,KAEToL,EAA8B,IASpCpM,EAAAA,EAAAA,YAAU,WAKR,OAJIyL,IACF5P,UAAYA,SAASmD,iBAAiB,YAAaqN,GACnDxb,OAAOmO,iBAAiB,SAAUsN,IAE7B,WACLzQ,UAAY4P,GAAkB5P,SAASqD,oBAAoB,YAAamN,GACxExb,OAAOqO,oBAAoB,SAAUoN,MAEtC,KAEHtM,EAAAA,EAAAA,YAAU,WACJ3P,EAAM+P,SAAWA,GACnBe,IAAY9Q,EAAM+P,UAEnB,CAAC/P,EAAM+P,UAEVJ,EAAAA,EAAAA,YAAU,WACR,IAAMuM,EAAQ9B,GAAS,CACrB5V,UAAWmX,EAAYnX,WAAaA,EACpC+V,QAASgB,EAAW3L,QACpB6K,MAAOe,EAAS5L,QAChBrL,UAAAA,EACAmW,mBAAAA,IAEFkB,GAAe,UAAKM,EAAN,CAAa1W,OAAQA,EAAOoK,WAC1CyL,EAAgBtL,KACf,CAACA,IAEJ,IAAMkM,EAAe,WACnBzW,EAAOoK,SAAW,EAClBkB,GAAU,GACVuK,GAAmBA,GAAgB,IAG/BW,EAAsB5b,SAAAA,GAC1B,IAAM+b,EAAUX,EAAS5L,QACnBwM,EAAYb,EAAW3L,QAE3BuM,GACAC,GACAhc,EAAEC,SACDyX,GAASqE,EAAS/b,EAAEC,UACpByX,GAASsE,EAAWhc,EAAEC,UAEvBmF,EAAOoK,SAAW,EAClBkB,GAAU,GACVuK,GAAmBA,GAAgB,KAIvC,SAASgB,IACP,GAAIZ,EAAW7L,QAAQ0M,OAAS,EAAG,kBACTb,EAAW7L,SADF,IACjC,2BAA4C,KAAjC2M,EAAiC,QAC1C/b,OAAOqN,aAAa0O,IAFW,8BAIjCd,EAAW7L,QAAU,IAGzB,SAAS4M,IACPH,IACAX,EAAc9L,QAAU,OAExB,IAAMoL,EAAQD,GAAe/a,EAAMgb,OAEnC,GAAKA,EAAMC,KAAX,CAIA,IAAMwB,EAASjc,OAAOiN,YAAW,WACD,SAA1BiO,EAAc9L,SAAoBqL,OACrCD,EAAMC,MACTQ,EAAW7L,QAAQ8M,KAAKD,QANtBxB,KASJ,SAAS0B,EAAWxB,GAElB,GADAkB,IACKlB,IAAanb,EAAMmb,UAAxB,CACAO,EAAc9L,QAAU,OAExB,IAAMoL,EAAQD,GAAe/a,EAAMgb,OAEnC,GAAKA,EAAME,KAAX,CAKA,IAAMuB,EAASjc,OAAOiN,YAAW,WACD,SAA1BiO,EAAc9L,SAAoBsL,MACrCF,EAAME,MAETO,EAAW7L,QAAQ8M,KAAKD,QARtBvB,KAeJ,SAAS0B,EAAmBhO,EAAmBxO,EAAqByc,GAClE,IAAMxc,EAASD,EAAE0c,cACXC,EAAW3c,EAAE4c,eAAkB5c,EAAE6c,YAAoBJ,GACvD1B,GAAY,GAEbK,EAAS5L,SAAWkI,GAAS0D,EAAS5L,QAASmN,IAC/CxB,EAAW3L,SAAWkI,GAASyD,EAAW3L,QAASmN,MAEpD5B,GAAY,GAER4B,GAAWA,IAAY1c,GAAYyX,GAASzX,EAAQ0c,IACxDnO,EAAQuM,EAAW/a,GAIvB,SAAS8a,IACFnL,IACLvK,EAAOoK,SAAW,EAClBkB,GAAU,IAGZ,SAASmK,KACHlL,IACJvK,EAAOoK,SAAW,EAClBkB,GAAU,IAwCZ,MAzBgB,UAAZyJ,GAAwB3H,IAC1BmJ,EAAa/W,QAAW5E,SAAAA,GACtB,IAAQ4E,GAjJNmO,GAASlQ,EAAAA,eAAqBkQ,GACzBA,EAAMnT,MAER,IA8IGgF,QACR+K,EAASmL,IAASD,KACdjW,GAASA,EAAQ5E,GAAI2P,KAGb,UAAZwK,GAAwB3H,IAC1BmJ,EAAamB,QAAU,kBAAMV,MAGf,UAAZjC,GAAwB3H,IAC1BmJ,EAAaoB,YAAcpB,EAAaqB,aAAgBhd,SAAAA,GACtDwc,EAAmBJ,EAAYpc,EAAG,gBAEpC2b,EAAasB,WAAatB,EAAauB,aAAgBld,SAAAA,GACrDwc,EAAmBD,EAAYvc,EAAG,cAEhC0b,EAAanL,cACfmL,EAAanL,YAAa2M,aAAgBld,SAAAA,GACxCwc,EAAmBD,EAAYvc,EAAG,gBAIxC0b,EAAajc,OAAbic,EAAAA,EAAAA,GAAAA,GAA0BA,EAAajc,MAAU8b,IAE/CvJ,EAAAA,EAAAA,MAACnP,EAAAA,SAAD,CAAAZ,SAAAA,EACGiP,EAAAA,EAAAA,cACC6B,EACA/O,OAAOiT,OAAO,GAAIlE,EAAMnT,OAAxBoE,EAAAA,EAAAA,GAAAA,GACK2X,EADL,CAEE5M,IAAKoM,EACLta,UAAW,CAACkS,EAAMnT,MAAMiB,UAAW2R,EAAc7D,EAAN,YAA6B,MACrEhL,OAAOC,SACPC,KAAK,KACLC,YAGPgL,EAAAA,EAAAA,KAAC/E,GAAD,UACM2R,EADN,CAEEjc,OAAK,UAAOic,EAAajc,MAAU8b,GACnCL,QArDN,SAAqBlO,EAAmBmQ,GACtCjC,GAAWA,EAAQlO,EAAMmQ,GACzB,IAAMrB,EAAQ9B,GAAS,CACrB5V,UAAWmX,EAAYnX,WAAaA,EACpC+V,QAASgB,EAAW3L,QACpB6K,MAAOe,EAAS5L,QAChBrL,UAAAA,EACAmW,mBAAAA,IAEFkB,GAAe,UAAKM,EAAN,CAAa1W,OAAQA,EAAOoK,YA6CtC3O,UAAW,CAAC8N,EAAW9N,EAAW0a,EAAYnX,WAAWT,OAAOC,SAASC,KAAK,KAAKC,OACnFK,UAAWA,EACX8L,eAAgBA,EAChBN,OAAQA,EACRI,aAAa,EARf9N,UAUGiP,EAAAA,EAAAA,cACCL,EACA7M,OAAOiT,QAAPjT,EAAAA,EAAAA,GAAAA,GACK6M,EAAQjR,MADb,CAEEmP,IAAKqM,EACLva,UAAW,CAACgQ,EAAQjR,OAASiR,EAAQjR,MAAMiB,UAAWuD,GAAWT,OAAOC,SAASC,KAAK,KAAKC,oB,sDC3TlFqG,GAAAA,SAAAA,I,6BAA8C,qEAQjEiT,YAAc,WACZ,IAAQzO,EAAc,EAAK/O,MAAnB+O,UACR,OACEG,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,SAAd1M,UACE+P,EAAAA,EAAAA,MAAAA,MAAAA,CAAKxT,QAAQ,YAAbyD,SAAAA,EACE6M,EAAAA,EAAAA,KAAAA,OAAAA,CACE5L,YAAY,MACZlE,EAAE,4IAEJ8P,EAAAA,EAAAA,KAAAA,OAAAA,CACEhQ,KAAK,OACLE,EAAE,iJAnBqD,E,qCAyBjE0P,WACE,MAAkEtB,KAAKxN,MAA/D+O,EAAR,EAAQA,UAAW9N,EAAnB,EAAmBA,UAAoBwc,EAAvC,EAAuCA,aAAiBxJ,GAAxD,aACMhF,EAAM,CAACF,EAAW9N,EAAYwc,EAA4B,KAAb,YAAmB1Z,OAAOC,SAASC,KAAK,KAAKC,OAChG,OACEgL,EAAAA,EAAAA,KAAC5E,IAAD,UACM2J,EADN,CAEEhD,SACEmB,EAAAA,EAAAA,MAAAA,MAAAA,CAAKnR,UAAWgO,EAAhB5M,SAAAA,CACGob,GAAgBjQ,KAAKgQ,eACtBtO,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,SAAd1M,SAAuCmL,KAAKxN,MAAMyE,aALxDpC,SASkC,kBAAxBmL,KAAKxN,MAAMqC,SAAwBmL,KAAKxN,MAAMqC,UAAW6M,EAAAA,EAAAA,KAAAA,OAAAA,CAAA7M,SAAOmL,KAAKxN,MAAMqC,kB,EAtCtEkI,CAAgBtH,EAAAA,WAAhBsH,GACL6E,aAA6B,CACzCL,UAAW,YACXvK,UAAW,MACXD,WAAW,EACXwL,QAAQ,EACR0N,cAAc,G,8ECJlB,GAAexa,EAAAA,YAA+C,SAACjD,EAAOmP,GACpE,MASInP,EARF+O,UAAAA,OADF,MACc,UADd,EAEE9N,EAOEjB,EAPFiB,UACApB,EAMEG,EANFH,MAHF,EASIG,EALFkT,KAAAA,OAJF,MAIS,UAJT,IASIlT,EAJFL,KAAAA,OALF,MAKS,OALT,IASIK,EAHF0d,QAAAA,OANF,MAMY,KANZ,EAOEC,EAEE3d,EAFF2d,WACG/M,GARL,OASI5Q,EATJ,IAUM4d,EAAW3a,EAAAA,OAA+B,MAC1C4a,EAAW5a,EAAAA,OAA8B,OAC/C4Y,EAAAA,EAAAA,qBAAsE1M,GAAK,kBAAMyO,EAAShO,WAC1F,IAAMX,EAAM,CACVF,EACA9N,EACAiS,EAAUnE,EAAN,IAAmBmE,EAAS,KAChCyK,EAAgB5O,EAAN,SAA0B,KACpC/O,EAAM4S,SAAW,WAAa,MAE7B7O,OAAOC,SACPC,KAAK,KACLC,OAcH,OAZAyL,EAAAA,EAAAA,YAAU,YAIV,WACE,GAAIkO,EAASjO,SAAWgO,EAAShO,QAAS,CACxC,IAAMkO,EAAQtd,QAAUA,OAAO8Y,iBAAiBuE,EAASjO,QAAS,MAClEgO,EAAShO,QAAQ/P,MAAMke,aACrBF,EAASjO,QAAQ3B,YAAoD,EAAtC+K,SAAS8E,EAAM5E,MAAiB,IADjE,MANF8E,OAYA5L,EAAAA,EAAAA,MAAAA,MAAAA,CAAKnR,UAAWgO,EAAKpP,MAAOA,EAA5BwC,SAAAA,EACE6M,EAAAA,EAAAA,KAAChH,EAAD,CAAMvI,KAAM+d,KACZxO,EAAAA,EAAAA,KAAAA,SAAAA,EAAAA,EAAAA,GAAAA,CAAOC,IAAKyO,EAAUje,KAAMA,EAAMse,aAAa,OAAUrN,EAAzD,CAAqE3P,UAAc8N,EAAL,YAC7E4O,IACCzO,EAAAA,EAAAA,KAAAA,OAAAA,CAAMjO,UAAc8N,EAAL,eAA8BI,IAAK0O,EAAlDxb,SACGsb,U,6ICtBI,SAASO,GAAgBle,GACtC,MAYIA,EAXF+O,UAAAA,OADF,MACc,eADd,IAYI/O,EATFgX,MAAAA,OAHF,MAGU,GAHV,EAIEmH,EAQEne,EARFme,KAJF,EAYIne,EAPFL,KAAAA,OALF,MAKS,QALT,EASEye,EAGEpe,EAHFoe,aACAC,EAEEre,EAFFqe,WACGpK,GAXL,OAYIjU,EAZJ,IAaMse,GAAY7O,EAAAA,EAAAA,QAAiB,IAanC,SAAS8O,EAAgBC,GACvB,IAAM5L,EAAW5S,EAAM,WAAWL,GAClC,QAAIiT,GACKA,EAAS4L,EAAK7e,EAAM,IAAI8e,KAAKN,IAYxC,IAAMrd,GAAOb,EAAAA,EAAAA,UAAQ,WACnB,OAAO,QAAIye,MAAM1H,IACd5V,KAAI,SAACud,EAAGtd,GAGP,OAFiBkd,EAAgBld,IACnBid,EAAU1O,QAAQ8M,KAAKrb,GAC9B,CACL2V,MAAO3V,EACPuR,SAAU2L,EAAgBld,OAG7B0C,QAAQ/B,SAAAA,GAAD,OAAWoc,IAAgBpc,EAAK4Q,cACzC,CAACwL,IAEJ,OACElP,EAAAA,EAAAA,KAAAA,OAAAA,EAAAA,EAAAA,GAAAA,CAAKjO,UAAc8N,EAAL,YAA8BkF,EAA5C,CAAA5R,UACE6M,EAAAA,EAAAA,KAAAA,KAAAA,CAAA7M,SACGvB,EAAKM,KAAI,SAACY,EAAMX,GACf,IAAMud,EAAU,GACX5c,EAAK4Q,WACRgM,EAAQ5Z,QAAW5E,SAAAA,GAAD,OAxC5B,SAAqBoe,EAAape,GAChC,GAAK+d,EAAL,CACA,IAAMU,EAAc,IAAIJ,KAAKN,GAC7BU,EAAY,MAAMlf,GAAoD6e,GACtEH,GAAcA,EAAW1e,EAAM6e,EAAKF,EAAU1O,QAASiP,IAoCtBC,CAAY9c,EAAKgV,SAE5C,IAAM+H,EA/CRZ,GAAQxe,EACH,IAAI8e,KAAKN,GAAT,MAAqBxe,KAEvB,EA6CD,OACEuP,EAAAA,EAAAA,KAAAA,MAAAA,EAAAA,EAAAA,GAAAA,CAEE,aAAY6P,IAAiB/c,EAAKgV,MAAQ3V,OAAMyD,EAChDqK,IAAM6P,SAAAA,GAAD,OAASA,GAlC1B,SAAyBA,GACvB,GAAIA,GAAOA,EAAIvH,YAAcuH,EAAIC,QAAJD,MAAsB,CACjD,IAAMzZ,EAAY2Z,OAAOF,EAAIC,QAAJD,OAAwBA,EAAI9Q,aACjD8Q,EAAIvH,WAAWA,aAChBuH,EAAIvH,WAAWA,WAA8BpL,UAAY9G,IA8B/B4Z,CAAgBH,KACjCJ,EAJN,CAKE3d,UAAW,CACTe,EAAK4Q,SAAW,WAAa,KAC7BmM,IAAiB/c,EAAKgV,MAAQ,WAAa,KAC3CoH,GAAgBpc,EAAK4Q,SAAW,OAAS,MAExC7O,OAAOC,SACPC,KAAK,KACLC,OAZL7B,SAcGL,EAAKgV,MAAQ,GAAbhV,IAAsBA,EAAKgV,MAAUhV,EAAKgV,QAbtC3V,W,6CCvFZ,SAAS+d,GAAepf,GAC7B,MAAkFA,EAA1E+O,UAAAA,OAAR,MAAoB,eAApB,EAAoC9N,EAA8CjB,EAA9CiB,UAApC,EAAkFjB,EAAnCqf,UAAAA,OAA/C,MAA2D,SAA3D,EAAwEpL,GAAxE,OAAkFjU,EAAlF,IACA,OACEoS,EAAAA,EAAAA,MAAAA,MAAAA,CAAKnR,UAAW,CAAC8N,EAAW9N,GAAW8C,OAAOC,SAASC,KAAK,KAAKC,OAAjE7B,SAAAA,CACG,yBAAyBF,KAAKkd,KAA2BnQ,EAAAA,EAAAA,KAACoQ,IAAD,QAAW3f,KAAK,QAAQqX,MAAO,IAAQ/C,IAChG,oBAAoB9R,KAAKkd,KAA2BnQ,EAAAA,EAAAA,KAACoQ,IAAD,QAAW3f,KAAK,UAAUqX,MAAO,IAAQ/C,IAC7F,aAAa9R,KAAKkd,KAA2BnQ,EAAAA,EAAAA,KAACoQ,IAAD,QAAW3f,KAAK,UAAUqX,MAAO,IAAQ/C,O,mLCe9E,SAAShK,GAAWjK,GACjC,MAeIA,EAdF+O,UAAAA,OADF,MACc,eADd,EAEE9N,EAaEjB,EAbFiB,UACA2R,EAYE5S,EAZF4S,SAHF,EAeI5S,EAVFuf,OAAAA,OALF,MAKW,WALX,EAMEC,EASExf,EATFwf,aANF,EAeIxf,EARFyf,WAAAA,OAPF,SAQEtf,EAOEH,EAPFG,SACAuf,EAME1f,EANF0f,cACAC,EAKE3f,EALF2f,gBACAC,EAIE5f,EAJF4f,gBACAxB,EAGEpe,EAHFoe,aACAiB,EAEErf,EAFFqf,UACGQ,GAdL,OAeI7f,EAfJ,IAgBA,GAAwB6Q,EAAAA,EAAAA,UAAS7Q,EAAME,OAAvC,eAAOie,EAAP,KAAa2B,EAAb,MACAnQ,EAAAA,EAAAA,YAAU,kBAAMmQ,EAAQ9f,EAAME,SAAQ,CAACF,EAAME,QAC7C,IAAM6f,EAAY,CAChBL,cAAAA,EACAC,gBAAAA,EACAC,gBAAAA,EACAxB,aAAAA,EACAiB,UAAAA,GAEIW,EAAa7B,GAAO8B,EAAAA,GAAAA,GAAUV,EAAQ,IAAId,KAAKN,IAAS,GACxD+B,EAAiB/B,GAAQ,IAAIM,KAC7B0B,GAAqB,UAAKN,EAAR,CAAoB3f,MAAO8f,IAiBnD,OAhBIP,GAA6B,KAAfO,GAAuBA,IACvCG,EAAOxC,YACLzO,EAAAA,EAAAA,KAACrG,EAAD,CACE5H,UAAc8N,EAAL,aACTxM,KAAK,QACLqQ,SAAU5S,EAAM4S,SAChB5N,QAAS,WACP8a,OAAQhb,GACR3E,GAAYA,KAEd+S,KAAMlT,EAAMkT,KACZF,OAAK,EACLrT,KAAK,YAKTuP,EAAAA,EAAAA,KAAC3E,IAAD,QACEgQ,QAAQ,QACR/V,UAAU,aACVkW,oBAAkB,EAClB+C,cAAc,GACV+B,EALN,CAME/a,SACEyK,EAAAA,EAAAA,KAACkQ,IAAD,QACEne,UAAc8N,EAAL,YACLgR,EAFN,CAGE5B,KAAM+B,EACN7B,WAAY,SAAC1e,EAAM6e,EAAKF,EAAWO,GACjCiB,EAAQ,IAAIrB,KAAKI,IACjB,IAAMuB,EAAUvB,GAAcoB,EAAAA,GAAAA,GAAUV,EAAQV,GAAe,GAC/D1e,GAAYA,EAASigB,EAASvB,EAAalf,EAAM6e,EAAKF,OAd9Djc,UAmBE6M,EAAAA,EAAAA,KAACtG,IAAD,QACEyX,YAAY,iCACZC,UAAQ,EACR1N,SAAUA,GACNuN,EAJN,CAKElf,UAAW,CAAI8N,EAAJ,SAAuB9N,GAAW8C,OAAOC,SAASC,KAAK,KAAKC,a,wNCxF/E,SAASqc,GAAWC,GAClB,OAAOpc,OAAOC,KAAKmc,GAAO,IACvBpf,KAAKqf,SAAAA,GAAD,OAAcD,EAAIC,GAAWA,EAAU,QAC3C1c,OAAOC,SACPC,KAAK,KACLC,OAgDE,SAASwc,GAAQ1gB,GACtB,IACQ2gB,EAUJ3gB,EAVFme,KAEAyC,EAQE5gB,EARF4gB,IACA1V,EAOElL,EAPFkL,MACA2V,EAME7gB,EANF6gB,MACAC,EAKE9gB,EALF8gB,UACAC,EAIE/gB,EAJF+gB,aACAC,EAGEhhB,EAHFghB,UACAC,EAEEjhB,EAFFihB,YACGhN,GAVL,OAWIjU,EAXJ,IAYMiP,EAA4C,CAChDiS,IAAa,IAARN,GAAqB,IAARA,EAClBO,MAAM,EACNN,OAAO,EACPO,UAAU,EACVC,MAAM,EACNzO,UAAU,GAERuL,EAAO2C,EACN3C,GArFP,SAAqBA,GACnB,OAAOA,aAAgBM,OAAS6C,MAAMnD,EAAKoD,WAoF7BC,CAAYrD,KAAOA,EAAO,IAAIM,MAC5C,IAAMgD,EAAOtD,EAAKuD,cACZC,EAAQxD,EAAKyD,WACbC,GAAO5hB,EAAAA,EAAAA,UAAQ,kBAAM,IAAIwe,KAAK,IAAIA,KAAKN,GAAO2B,QAAQ,IAAIgC,WAAU,CAAC3D,EAAK4D,iBAC1EC,GAAU/hB,EAAAA,EAAAA,UAAQ,kBAAM,IAAIwe,KAAKgD,EAAgB,IAAVE,EAAc,GAAKA,EAAQ,EAAG,GAAGM,YAAW,CAAC9D,EAAK4D,iBAC3FG,EAAMhX,EACNiT,KACF+D,EAAMA,EAAML,EAAO,GACT,IACR5S,EAAIkS,MAAO,GAETe,EAAMF,IACR/S,EAAIoS,MAAO,IAGf,IAAIc,GAAWliB,EAAAA,EAAAA,UAAQ,kBAAM,IAAIwe,KAAK,IAAIA,KAAKN,GAAO2B,QAAQoC,MAAO,CAACA,IAClErB,GAASA,EAAMkB,iBAAmBI,EAASJ,iBAC7C9S,EAAI4R,OAAQ,GAEVF,GAAgBA,EAAaoB,iBAAmBI,EAASJ,iBAC3D9S,EAAImS,UAAW,GAEjB,IAAMgB,EAAiD,CACrDpd,QAAS,WACP,IAAMqd,EAAYF,EAASP,WAC3BX,GACEA,EAAakB,EAAU,CACrBV,KAAMU,EAAST,cACfC,MAAqB,IAAdU,EAAkB,GAAKA,EAAY,EAC1CH,IAAKC,EAASF,cAQtB,OAJIlB,GAAgBA,EAAaoB,GAAD,UAAgBniB,EAAUiP,MACxDA,EAAI2D,UAAW,SACRwP,EAASpd,UAGhBkK,EAAAA,EAAAA,KAAAA,OAAAA,EAAAA,EAAAA,GAAAA,CAAKjO,UAAWsf,GAAWtR,IAAUgF,EAAWmO,EAAhD,CAAA/f,SACG2e,EACCA,EAAUmB,EAASF,WAAV,UAA0BjiB,EAAUiP,EAApC,CAAyCkP,KAAMgE,MAExDjT,EAAAA,EAAAA,KAAAA,MAAAA,CAAA7M,SAAM8f,EAASF,eAMvB,IAAMK,GAAY,CAAC,qBAAO,qBAAO,qBAAO,qBAAO,qBAAO,qBAAO,sBACvDC,GAAU,CAAC,SAAK,SAAK,SAAK,SAAK,SAAK,SAAK,UAExC,SAASC,GAAcxiB,GAC5B,MAYIA,EAXF+O,UAAAA,OADF,MACc,eADd,EAEE9N,EAUEjB,EAVFiB,UAFF,EAYIjB,EATFyiB,QAAAA,OAHF,MAGYF,GAHZ,IAYIviB,EARF0iB,UAAAA,OAJF,MAIcJ,GAJd,EAKEnE,EAOEne,EAPFme,KACA0C,EAME7gB,EANF6gB,MACAC,EAKE9gB,EALF8gB,UACAC,EAIE/gB,EAJF+gB,aACAC,EAGEhhB,EAHFghB,UACAC,EAEEjhB,EAFFihB,YACGhN,GAXL,OAYIjU,EAZJ,IAcM2iB,GAAe1iB,EAAAA,EAAAA,UACnB,kBACEiP,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,WAAd1M,UACIogB,GAAW,IAAIrhB,KAAI,SAACygB,EAAMxgB,GAAP,OACnB6N,EAAAA,EAAAA,KAAAA,MAAAA,CAAejO,UAAWsf,GAAW,CAAEW,IAAa,IAAR7f,GAAqB,IAARA,IAAciS,MAAOoP,GAAaA,EAAUrhB,GAArGgB,SACGwf,GADOxgB,UAMhB,CAAC0N,EAAW0T,EAASC,IAGvB,OACEtQ,EAAAA,EAAAA,MAAAA,OAAAA,EAAAA,EAAAA,GAAAA,GAAS6B,EAAT,CAAgBhT,UAAW,CAAC8N,EAAeA,EAAN,QAAyB,KAAM9N,GAAW8C,OAAOC,SAASC,KAAK,KAAKC,OAAzG7B,SAAAA,CACGsgB,GACDzT,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAW,CAAC8N,EAAeA,EAAN,YAA6B,MAAMhL,OAAOC,SAASC,KAAK,KAAKC,OAAvF7B,UACG,QAAIqc,MAAM,IAAItd,KAAI,SAACud,EAAGtd,GAAJ,OACjB6N,EAAAA,EAAAA,KAAAA,MAAAA,CAAejO,UAAc8N,EAAL,QAAxB1M,UACG,QAAIqc,MAAM,IAAItd,KAAI,SAACud,EAAGiC,GAAJ,OACjB1R,EAAAA,EAAAA,KAACwR,GAAD,CACEvC,KAAMA,EACN0C,MAAOA,EACPE,aAAcA,EACdC,UAAWA,EACXF,UAAWA,EAEXF,IAAKA,EACLgC,IAAKvhB,EACL4f,YAAa,SAAC4B,EAAS/hB,GACrBmgB,GAAeA,EAAY4B,EAAS/hB,IAEtCoK,MAAa,EAAN7J,EAAUuf,GANZA,OARDvf,Y,uECnKb,SAASyhB,GAAgB9iB,GAC9B,MAOIA,EANF+O,UAAAA,OADF,MACc,eADd,EAEE9N,EAKEjB,EALFiB,UAFF,EAOIjB,EAJF8gB,UAAAA,OAHF,MAGc,IAAIrC,KAHlB,EAIEsE,EAGE/iB,EAHF+iB,WAJF,EAOI/iB,EAFFqe,WAAAA,OALF,MAKe3S,EALf,EAMKuI,GANL,OAOIjU,EAPJ,IAQA,OACEkP,EAAAA,EAAAA,KAAAA,OAAAA,EAAAA,EAAAA,GAAAA,CAAKjO,UAAW,CAAC8N,EAAeA,EAAN,SAA0B,KAAM9N,GAAW8C,OAAOC,SAASC,KAAK,KAAKC,QAAY+P,EAA3G,CAAA5R,UACG,QAAIqc,MAAM,KAAKtd,KAAI,SAACud,EAAGtd,GACtB,IAAM2hB,EAAgBlC,EAAWc,WACjC,OACE1S,EAAAA,EAAAA,KAAAA,MAAAA,CAAejO,UAAW,CAAC+hB,IAAkB3hB,EAAM,WAAa,MAAM0C,OAAOC,SAASC,KAAK,KAAKC,OAAhG7B,UACE6M,EAAAA,EAAAA,KAAAA,OAAAA,CAAMlK,QAAS,kBAAMqZ,EAAWhd,GAAK,IAArCgB,SAA+C0gB,GAAcA,EAAW1hB,IAASA,KADzEA,S,qECdb,SAAS4hB,GAAejjB,GAC7B,MAOIA,EANF+O,UAAAA,OADF,MACc,eADd,IAOI/O,EALFkjB,SAAAA,OAFF,MAEa,EAAE,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,IAFxE,EAGEjiB,EAIEjB,EAJFiB,UAHF,EAOIjB,EAFFqe,WAAAA,OALF,MAKe3S,EALf,EAMKuI,GANL,OAOIjU,EAPJ,IAQA,GAAoC6Q,EAAAA,EAAAA,UAAS7Q,EAAM8gB,WAAnD,eAAOqC,EAAP,KAAmBC,EAAnB,KAWA,OACElU,EAAAA,EAAAA,KAAAA,OAAAA,EAAAA,EAAAA,GAAAA,CAAKjO,UAAW,CAAC8N,EAAeA,EAAN,QAAyB,KAAM9N,GAAW8C,OAAOC,SAASC,KAAK,KAAKC,QAAY+P,EAA1G,CAAA5R,SACG6gB,GACCA,EAAS9hB,KAAI,SAACud,EAAGtd,GACf,IAAMgiB,EAAeF,EAAYzB,cAC3BD,EAAO4B,EAAeH,EAAS7hB,GACrC,OACE6N,EAAAA,EAAAA,KAAAA,MAAAA,CAEEjO,UAAW,CACToiB,IAAiB5B,EAAO,WAAa,KAC7B,IAARpgB,GAAaA,IAAQ6hB,EAAS5G,OAAS,EAAI,SAAW,MAErDvY,OAAOC,SACPC,KAAK,KACLC,OARL7B,UAUE6M,EAAAA,EAAAA,KAAAA,OAAAA,CAAMlK,QAAS,kBA3B3B,SAAwByc,EAAcpgB,GACpC,GAAY,IAARA,GAAaA,IAAQ6hB,EAAU5G,OAAS,EAAG,CAC7C,IAAM6B,EAAO,IAAIM,KAAK0E,GACtBhF,EAAKmF,YAAY7B,GACjB2B,EAAcjF,GACdE,EAAYoD,GAAM,QAElBpD,EAAYoD,GAoBiB8B,CAAe9B,EAAMpgB,IAA1CgB,SAAiDof,KAT5CpgB,S,qFClCnB,SAASkf,KAAkD,2BAApCiD,EAAoC,yBAApCA,EAAoC,GAAAC,UAAAA,GACzD,MAAO,UAAID,GAAKzf,OAAOC,SAASC,KAAK,KAAKC,OAYrC,SAASwf,GAAkB1jB,GAChC,MAQIA,EAPF+O,UAAAA,OADF,MACc,eADd,EAEE9N,EAMEjB,EANFiB,UAFF,EAQIjB,EALF8gB,UAAAA,OAHF,MAGc,IAAIrC,KAHlB,EAIEsE,EAIE/iB,EAJF+iB,WAJF,EAQI/iB,EAHFqe,WAAAA,OALF,MAKe3S,EALf,EAMEiY,EAEE3jB,EAFF2jB,YACG1P,GAPL,OAQIjU,EARJ,IAUM4jB,GAAc3jB,EAAAA,EAAAA,UAAQ,WAC1B,IAAM0hB,EAAQb,EAAUc,WACxB,OAAQmB,GAAcA,EAAWpB,IAAWA,EAAQ,IACnD,CAACb,EAAUiB,eAAgBgB,IAC9B,OACE3Q,EAAAA,EAAAA,MAAAA,OAAAA,EAAAA,EAAAA,GAAAA,CAAKnR,UAAWsf,GAAWxR,EAAeA,EAAN,WAA4B,KAAM9N,IAAgBgT,EAAtF,CAAA5R,SAAAA,EACE6M,EAAAA,EAAAA,KAAAA,MAAAA,CACEjO,UAAWsf,GAAWxR,EAAeA,EAAN,gBAAiC,KAAM,QACtE/J,QAAS,kBAAMqZ,EAAW,YAE5BnP,EAAAA,EAAAA,KAAAA,MAAAA,CACEjO,UAAWsf,GAAWxR,EAAeA,EAAN,gBAAiC,KAAM,SACtE/J,QAAS,kBAAMqZ,EAAW,UAF5Bhc,SAIGuhB,KAEH1U,EAAAA,EAAAA,KAAAA,MAAAA,CACEjO,UAAWsf,GAAWxR,EAAeA,EAAN,gBAAiC,KAAM,QACtE/J,QAAS,kBAAMqZ,EAAW,SAF5Bhc,SAIGye,EAAWY,gBAEbiC,IACCzU,EAAAA,EAAAA,KAAAA,MAAAA,CACEjO,UAAWsf,GAAWxR,EAAeA,EAAN,iBAAkC,MACjE/J,QAAS,kBAAMqZ,EAAW,UAC1B/K,MAAOqQ,KAGXzU,EAAAA,EAAAA,KAAAA,MAAAA,CACEjO,UAAWsf,GAAWxR,EAAeA,EAAN,gBAAiC,KAAM,QACtE/J,QAAS,kBAAMqZ,EAAW,e,8KC5C5BwF,GAAc,CAClB,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,qBACA,sBA0Ba,SAASxb,GAAWrI,GACjC,MAgBIA,EAfF+O,UAAAA,OADF,MACc,eADd,EAEE9N,EAcEjB,EAdFiB,UACAwhB,EAaEziB,EAbFyiB,QACAC,EAYE1iB,EAZF0iB,UAJF,EAgBI1iB,EAXF+iB,WAAAA,OALF,MAKec,GALf,EAME1F,EAUEne,EAVFme,KANF,EAgBIne,EATF6gB,MAAAA,OAPF,MAOU,IAAIpC,KAPd,EAQEkF,EAQE3jB,EARF2jB,YARF,EAgBI3jB,EAPF8gB,UAAAA,OATF,MASc,IAAIrC,KATlB,EAUEsC,EAME/gB,EANF+gB,aACAC,EAKEhhB,EALFghB,UAXF,EAgBIhhB,EAJFG,SAAAA,OAZF,MAYauL,EAZb,IAgBI1L,EAHF8jB,cAAAA,OAbF,MAakBpY,EAblB,EAcEqY,EAEE/jB,EAFF+jB,SACG9P,GAfL,OAgBIjU,EAhBJ,IAiBA,GAAwB6Q,EAAAA,EAAAA,UAAkC,OAA1D,eAAOlR,EAAP,KAAaqkB,EAAb,KACA,GAAoCnT,EAAAA,EAAAA,UAASsN,GAA7C,eAAO8F,EAAP,KAAmBC,EAAnB,KACA,GAA8CrT,EAAAA,EAAAA,UAASiQ,GAAvD,eAAOqD,EAAP,KAAwBC,EAAxB,MAEAzU,EAAAA,EAAAA,YAAU,WACJwO,IACF+F,EAAc/F,GACdiG,EAAmBjG,MAEpB,CAACA,IAEJ,IAAMoB,GAAStf,EAAAA,EAAAA,UACb,kBACE8jB,GAAaA,EAAqCxE,OAC7CwE,EAAqCxE,OACtC,aACN,CAACwE,IAEH,SAASR,EAAec,GACtB,GAAIA,GAAW,sBAAsBliB,KAAKkiB,GAC3B,SAAT1kB,IACF0kB,EAAU,OAEZL,EAAQK,OACH,CACL,IAAIxF,EAAc,IAAIJ,KAAKwF,GAAcE,GACrCxC,EAAQ9C,EAAY+C,WACR,SAAZyC,IACF1C,GAAS,GAEK,SAAZ0C,IACF1C,GAAS,GAEX9C,EAAYyF,SAAS3C,GACL,SAAZ0C,GAAkC,SAAZA,GACxBP,GAAiBA,EAAc,IAAIrF,KAAKI,GAAcwF,GAExDD,EAA+B,UAAZC,EAAsBxD,EAAQhC,GACjDqF,EAA0B,UAAZG,EAAsBxD,EAAQhC,GAE5CmF,EAAQ,QAUZ,SAASO,EAAe5kB,EAAkCgiB,EAAe6C,IACtEL,GAAmB,IAAI1F,MAAQ9e,GAAMgiB,GACtCyC,EAAmB,IAAI3F,KAAK0F,IAC5BH,EAAQ,OACR7jB,GAAYA,EAAS,IAAIse,KAAK0F,IAEhC,OACE/R,EAAAA,EAAAA,MAAAA,OAAAA,EAAAA,EAAAA,GAAAA,CAAKnR,UAAW,CAAC8N,EAAW9N,GAAW8C,OAAOC,SAASC,KAAK,KAAKC,QAAY+P,EAA7E,CAAA5R,SAAAA,EACE6M,EAAAA,EAAAA,KAACwU,GAAD,CACEC,YAAaA,EACb7C,UAAWqD,EACXpB,WAAYA,EACZ1E,WAAYkF,IAEJ,QAAT5jB,IACCuP,EAAAA,EAAAA,KAACsT,GAAD,CACEzT,UAAWA,EACXgS,aAAcA,EACdE,YAAa,SAACN,EAAc8D,GAC1BL,EAAmBzD,GACnBxgB,EAASwgB,EAAc8D,IAEzBzD,UAAWA,EACX7C,KAAM8F,EACNpD,MAAOA,GAAS,IAAIpC,KACpBqC,UAAWqD,EACX1B,QAASA,EACTC,UAAWA,IAGL,UAAT/iB,IACCuP,EAAAA,EAAAA,KAAC4T,GAAD,CACEhC,UAAWqD,EACXpB,WAAYA,EACZhU,UAAWA,EACXsP,WAAaG,SAAAA,GAAD,OAAS+F,EAAe,WAAY/F,MAG1C,SAAT7e,IACCuP,EAAAA,EAAAA,KAAC+T,GAAD,CACElU,UAAWA,EACX+R,UAAWmD,GAAcE,EACzB9F,WAAaG,SAAAA,GAAD,OAAS+F,EAAe,cAAe/F,MAG7C,SAAT7e,IACCuP,EAAAA,EAAAA,KAACkQ,IAAD,QACEjB,KAAMgG,GACFJ,EAFN,CAGE9iB,UAAc8N,EAAL,cACTsP,WAxDR,SAAwB1e,EAAoC6e,IACzD2F,GAAmB,IAAI1F,MAAxB,MAAsC9e,GAAsB6e,GAC5D4F,EAAmB,IAAI3F,KAAK0F,IAC5BhkB,GAAYA,EAAS,IAAIse,KAAK0F,QAwD3BJ,GAAYxE,IACXrQ,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,YAA2B/J,QAAS,kBAAMue,EAAe,SAAvElhB,UACG4d,EAAAA,GAAAA,GAAUV,EAAS0E,GAAcE,S,wBCtK7B,SAASO,GAAU1kB,GAChC,IAAQ+O,EAAsC/O,EAAtC+O,UAAWmT,EAA2BliB,EAA3BkiB,IAAKphB,EAAsBd,EAAtBc,KAAM+d,EAAgB7e,EAAhB6e,YAExB8F,GAAU1kB,EAAAA,EAAAA,UACd,kBACGa,GAAQ,IAAIiD,QAAQ/B,SAAAA,GACnB,IAAI4iB,GAAkB5iB,EAAKmc,MAAQnc,EAAKmc,KAAK5d,MAAM,MAAS,IAAIa,KAAKod,SAAAA,GAAD,OAASU,OAAOV,MACpF,OAAmB,IAAfoG,EAAItI,OACC4F,IAAQ0C,EAAI,GAEjB/F,GAA8B,IAAf+F,EAAItI,OACduC,EAAY+C,WAAa,IAAMgD,EAAI,IAAM1C,IAAQ0C,EAAI,MAE1D/F,GAA8B,IAAf+F,EAAItI,UACduC,EAAY6C,gBAAkBkD,EAAI,IAAM/F,EAAY+C,WAAa,IAAMgD,EAAI,IAAM1C,IAAQ0C,EAAI,SAI1G,CAAC/F,EAAaqD,EAAKphB,IAGrB,OAAOb,EAAAA,EAAAA,UACL,kBACEmS,EAAAA,EAAAA,MAAAA,MAAAA,CAAKnR,UAAc8N,EAAL,SAAd1M,SAAAA,EACE6M,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,OAAd1M,SAAqC6f,KACrChT,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,SAAd1M,SACGsiB,GACCA,EAAQrI,OAAS,GACjBqI,EAAQvjB,KAAI,SAACY,EAAMX,GACX,IAAQwjB,EAAoB7iB,EAApB6iB,MAAU5Q,GAAxB6Q,EAAAA,EAAAA,GAAkC9iB,EAAlC,IACA,OACEkN,EAAAA,EAAAA,KAAAA,OAAAA,EAAAA,EAAAA,GAAAA,GAAmB+E,EAAnB,CAAA5R,SACGwiB,IADOxjB,aAQtB,CAACsjB,EAASzC,I,4ICiBC,SAASva,GAAS3H,GAC/B,MAcIA,EAbF+O,UAAAA,OADF,MACc,aADd,EAEE9N,EAYEjB,EAZFiB,UACApB,EAWEG,EAXFH,MAHF,EAcIG,EAVF6gB,MAAAA,OAJF,MAIU,IAAIpC,KAJd,EAKEN,EASEne,EATFme,KACArd,EAQEd,EARFc,KANF,GAcId,EAPF+iB,WAOE/iB,EANF+kB,aAAAA,OARF,MAQgB,UARhB,IAcI/kB,EALFglB,WAAAA,OATF,MASe,eATf,EAWEC,EAGEjlB,EAHFilB,SACAhE,EAEEjhB,EAFFihB,YACGrQ,GAbL,OAcI5Q,EAdJ,IAeMiP,EAAM,CAACF,EAAW9N,GAAW8C,OAAOC,SAASC,KAAK,KAAKC,OAC7D,GAAkC2M,EAAAA,EAAAA,UAAe7Q,EAAM8gB,WAAa,IAAIrC,MAAxE,eAAOqC,EAAP,KAAkBoE,EAAlB,KAQA,SAASC,EAAaxlB,GACpB,IAAIkf,EAAc,IAAIJ,KACtB,GAAa,UAAT9e,EACFkf,EAAcgC,GAAS,IAAIpC,SACtB,CACL,IAAMkD,EAAQb,EAAUc,WACpBd,GAAsB,SAATnhB,GACfmhB,EAAUwD,SAAS3C,EAAQ,GAEzBb,GAAsB,SAATnhB,GACfmhB,EAAUwD,SAAS3C,EAAQ,GAE7B9C,EAAciC,EAEhBoE,EAAa,IAAIzG,KAAKI,IACtBoG,GAAYA,EAAStlB,EAAMkf,EAAa+C,WAAa,EAAG/C,IArB1DlP,EAAAA,EAAAA,YAAU,WACJ3P,EAAM8gB,YAAcA,GACtBoE,EAAapE,KAEd,CAAC9gB,EAAM8gB,YAoBV,IAAMsE,GAAanlB,EAAAA,EAAAA,UACjB,kBAAMiP,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,SAAd1M,UAAuC4d,EAAAA,GAAAA,GAAU8E,EAAajE,OACpE,CAAC/R,EAAWgW,EAAajE,IAGrBuE,GAAWplB,EAAAA,EAAAA,UACf,kBACEmS,EAAAA,EAAAA,MAAAA,MAAAA,CAAKnR,UAAc8N,EAAL,aAAd1M,SAAAA,EACE6M,EAAAA,EAAAA,KAAChH,EAAD,CAAMvI,KAAK,OAAOqF,QAAS,kBAAMmgB,EAAa,YAC9CjW,EAAAA,EAAAA,KAAAA,OAAAA,CAAMjO,UAAc8N,EAAL,OAAsB/J,QAAS,kBAAMmgB,EAAa,UAAjE9iB,SACG2iB,KAEH9V,EAAAA,EAAAA,KAAChH,EAAD,CAAMvI,KAAK,OAAOqF,QAAS,kBAAMmgB,EAAa,gBAGlD,CAACpW,EAAWiW,IAGd,OACE5S,EAAAA,EAAAA,MAAAA,MAAAA,CAAKnR,UAAWgO,EAAKpP,MAAOA,EAA5BwC,SAAAA,EACE+P,EAAAA,EAAAA,MAAAA,MAAAA,CAAKnR,UAAc8N,EAAL,WAAd1M,SAAAA,CACG+iB,EACAC,MAEHnW,EAAAA,EAAAA,KAACsT,IAAD,QACEvB,YAAa,SAACpC,EAAa4F,GACzBS,EAAarG,GACboC,GAAeA,EAAYpC,EAAa4F,IAE1CzD,UAAW,SAACkB,EAAKoD,GAAN,OACTpW,EAAAA,EAAAA,KAACwV,GAAD,CAAW3V,UAAWA,EAAWmT,IAAKA,EAAKphB,KAAMA,EAAM+d,YAAayG,EAAUnH,QAEhFA,KAAMA,EACN0C,MAAOA,EACPC,UAAWA,GAAa,IAAIrC,MACxB7N,O,+HCjIZ,GAAe3N,EAAAA,YAA4C,SAACjD,EAAOmP,GACjE,MAaInP,EAZF+O,UAAAA,OADF,MACc,SADd,EAEE9N,EAWEjB,EAXFiB,UACAqS,EAUEtT,EAVFsT,MACAiS,EASEvlB,EATFulB,MACAC,EAQExlB,EARFwlB,OALF,EAaIxlB,EAPFylB,SAAAA,OANF,WAaIzlB,EANF0lB,QAAAA,OAPF,WAaI1lB,EALF6S,OAAAA,OARF,SASEmB,EAIEhU,EAJFgU,UACA2R,EAGE3lB,EAHF2lB,cACAtjB,EAEErC,EAFFqC,SACG2M,GAZL,OAaIhP,EAbJ,IAcMiP,GAAMhP,EAAAA,EAAAA,UACV,iBACE,CACE8O,EACA9N,EACAwkB,EAAc1W,EAAN,YAA6B,KACrC2W,EAAa3W,EAAN,YAA6B,KACpC8D,EAAS,SAAW,MAEnB9O,OAAOC,SACPC,KAAK,KACLC,SACL,CAAC6K,EAAW9N,EAAWwkB,EAAUC,IAGnC,OACEtT,EAAAA,EAAAA,MAAAA,OAAAA,EAAAA,EAAAA,GAAAA,GAASpD,EAAT,CAAqB/N,UAAWgO,EAAKE,IAAKA,EAA1C9M,SAAAA,EACIiR,GAASiS,KACTnT,EAAAA,EAAAA,MAAAA,MAAAA,CAAKnR,UAAc8N,EAAL,QAAd1M,SAAAA,CACGiR,IAASpE,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,cAAd1M,SAA4CiR,IACrDiS,IAASrW,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,SAAd1M,SAAuCkjB,OAGpDljB,IACC6M,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAW,CAAI8N,EAAJ,QAAsB4W,GAAe5hB,OAAOC,SAASC,KAAK,KAAKC,OAAQrE,MAAOmU,EAA9F3R,SACGA,IAGJmjB,IAAUtW,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,UAAd1M,SAAwCmjB,W,sGC5C5CI,GAAgB3iB,EAAAA,YAAuD,SAACjD,EAAOmP,GAC1F,MAYInP,EAXF+O,UAAAA,OADF,MACc,UADd,IAYI/O,EAVFL,KAAAA,OAFF,MAES,QAFT,IAYIK,EATF4S,SAAAA,OAHF,WAYI5S,EARFE,MAAAA,OAJF,MAIU,GAJV,EAKEe,EAOEjB,EAPFiB,UACApB,EAMEG,EANFH,MACAwC,EAKErC,EALFqC,SACA6Q,EAIElT,EAJFkT,KARF,EAYIlT,EAHF6lB,QAASC,OATX,SAUE3lB,EAEEH,EAFFG,SACG8T,GAXL,OAYIjU,EAZJ,IAcA,GAA8B6Q,EAAAA,EAAAA,UAASiV,GAAvC,eAAOD,EAAP,KAAgBE,EAAhB,KACA,GAAsClV,EAAAA,EAAAA,YAAtC,eAAOmV,EAAP,KAAoBC,EAApB,KACIH,IAAcE,GAChBC,EAAeH,IAEjB7lB,EAAAA,EAAAA,UAAQ,WACF6lB,IAAcE,GAChBD,EAAWD,KAEZ,CAACE,IAEJ,IAAM/W,EAAM,CAACF,EAAW9N,EAAW2R,EAAW,WAAa,KAAMM,EAAUnE,EAAN,IAAmBmE,EAAS,MAC9FnP,OAAOC,SACPC,KAAK,KACLC,QACHjE,EAAAA,EAAAA,UAAQ,WACF4lB,IAAY7lB,EAAM6lB,SACpBE,IAAa/lB,EAAM6lB,WAEpB,CAAC7lB,EAAM6lB,UAQV,IAAMhB,EAAQxiB,GAAYnC,EAC1B,OACEkS,EAAAA,EAAAA,MAAAA,QAAAA,CAAanR,UAAWgO,EAAKpP,MAAAA,EAA7BwC,SAAAA,EACE6M,EAAAA,EAAAA,KAAAA,SAAAA,EAAAA,EAAAA,GAAAA,IAAAA,EAAAA,EAAAA,GAAAA,GAAgB+E,EAAhB,CAAuBtU,KAAAA,EAAMiT,SAAAA,EAAU1S,MAAAA,IAAvC,CAAgD2lB,QAASA,EAAS1lB,SATtE,SAAsBC,GACpBA,EAAE8lB,UACFH,EAAW3lB,EAAEC,OAAOwlB,SACpB1lB,GAAYA,EAASC,IAMuE+O,IAAKA,KAC9F0V,IAAS3V,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,QAAd1M,SAAsCwiB,UCtDtD,GAAe5hB,EAAAA,YAA+C,SAACjD,EAAOmP,GACpE,OAAOD,EAAAA,EAAAA,KAAC0W,IAAD,QAAezW,IAAKA,GAASnP,O,kECItC,GAAeiD,EAAAA,YAAkD,SAACjD,EAAOmP,GACvE,MAA8FnP,EAAtF+O,UAAAA,OAAR,MAAoB,gBAApB,EAAqC9N,EAAyDjB,EAAzDiB,UAAWuB,EAA8CxC,EAA9CwC,KAAMtC,EAAwCF,EAAxCE,MAAOC,EAAiCH,EAAjCG,SAAUkC,EAAuBrC,EAAvBqC,SAAa4R,GAApF,OAA8FjU,EAA9F,IACA,OACEkP,EAAAA,EAAAA,KAAAA,OAAAA,EAAAA,EAAAA,GAAAA,GAAS+E,EAAT,CAAgB9E,IAAKA,EAAKlO,UAAW,CAAC8N,EAAW9N,GAAW8C,OAAOC,SAASC,KAAK,KAAKC,OAAtF7B,SACGY,EAAAA,SAAAA,QAAuBZ,GAAUjB,KAAK+R,SAAAA,GACrC,GAAKA,EACL,OAAKlQ,EAAAA,eAAqBkQ,GACnBlQ,EAAAA,aAAmBkQ,GAAnBlQ,EAAAA,EAAAA,GAAAA,GACDkQ,EAAMnT,OAAS,GAChB,CACD6lB,QAAS1S,EAAMnT,MAAME,QAAUA,EAC/BsC,KAAAA,EACArC,SAAAA,KANqCgT,W,uDCNpCgT,GAAgBljB,EAAAA,YAAqD,SAACjD,EAAOmP,GACxF,MAAuFnP,EAA/E+O,UAAAA,OAAR,MAAoB,mBAApB,EAAwC9N,EAA+CjB,EAA/CiB,UAAWuB,EAAoCxC,EAApCwC,KAAMtC,EAA8BF,EAA9BE,MAAOC,EAAuBH,EAAvBG,SAAa8T,GAA7E,OAAuFjU,EAAvF,IACMomB,GAAW3W,EAAAA,EAAAA,QAAgB,IAC3BR,EAAM,CAACF,EAAW9N,GAAW8C,OAAOC,SAASC,KAAK,KAAKC,OACvDmiB,EAASpjB,EAAAA,SAAAA,QAAuBjD,EAAMqC,UAE5C,OADApC,EAAAA,EAAAA,UAAQ,kBAAOmmB,EAASxW,QAAU1P,GAAS,KAAK,CAACA,KAE/CgP,EAAAA,EAAAA,KAAAA,OAAAA,EAAAA,EAAAA,GAAAA,GAAS+E,EAAT,CAAgBhT,UAAWgO,EAAKE,IAAKA,EAArC9M,SACGY,EAAAA,SAAAA,IAAmBojB,GAASpb,SAAAA,GAC3B,GAAKhI,EAAAA,eAAqBgI,GAY1B,OAVEyT,MAAM4H,QAAQpmB,IACd+K,GACAA,EAAQjL,OACRiL,EAAQjL,MAAME,OACdA,EAAMoE,SAAS2G,EAAQjL,MAAME,SAExBkmB,EAASxW,QAAQtL,SAAS2G,EAAQjL,MAAME,QAC3CkmB,EAASxW,QAAQ8M,KAAKzR,EAAQjL,MAAME,QAGjC+C,EAAAA,aACLgI,EACA7G,OAAOiT,OAAO,GAAIpM,EAAQjL,MAAO,CAC/BwC,KAAAA,EACAqjB,QAASO,EAASxW,QAAQtL,SAAS2G,EAAQjL,MAAME,OACjDC,SAAWC,SAAAA,GACT,IAAIA,EAAEC,OAAOV,MAA0B,aAAlBS,EAAEC,OAAOV,KAA9B,CACA,IAAMkmB,EAAUzlB,EAAEC,OAAOwlB,QACnBU,EAAUH,EAASxW,QAAQtL,SAAS2G,EAAQjL,MAAME,QACnDqmB,GAAWV,EACdO,EAASxW,QAAQ8M,KAAKzR,EAAQjL,MAAME,OAC3BqmB,IAAYV,IACrBO,EAASxW,QAAUwW,EAASxW,QAAQ7L,QAAQyiB,SAAAA,GAAD,OAASA,IAAQvb,EAAQjL,MAAME,UAE5EC,GAAYA,EAASC,EAAGgmB,EAASxW,uB,uECrC/C,SAAS6W,GAAiBzmB,EAAsBmP,GAC9C,IACElO,EAOEjB,EAPFiB,UADF,EAQIjB,EANF+O,UAAAA,OAFF,MAEc,aAFd,IAQI/O,EALFL,KAAAA,OAHF,MAGS,WAHT,IAQIK,EAJF0mB,cAAAA,OAJF,WAQI1mB,EAHF4S,SAAAA,OALF,WAQI5S,EAFFE,MAAAA,OANF,MAMU,GANV,EAOK+T,GAPL,OAQIjU,EARJ,IAUMiP,EAAM,CAAChO,EAAWylB,GAAiB,iBAAiB3iB,OAAOC,SAASC,KAAK,KAAKC,OACpF,OACEgL,EAAAA,EAAAA,KAAC0W,IAAD,QACEzW,IAAKA,GACD8E,EAFN,CAGEtU,KAAMA,EACNoP,UAAWA,EACX6D,SAAUA,EACV1S,MAAOA,EACPe,UAAWgO,KAKjB,IAAMrH,GAAW3E,EAAAA,WAAkDwjB,IAKlE7e,GAAsB+e,MAAQR,GAE/B,ICrCA,GDqCA,G,sNExBA,SAASS,GAAQC,GACf,IAAIC,EAAmBD,EAIvB,OAHKnI,MAAM4H,QAAQQ,KACjBA,EAAmBA,EAAmB,CAACA,GAAoB,IAEtDA,EAGT,SAASC,GAAiB/mB,EAAsBmP,GAC9C,MAUInP,EATF+O,UAAAA,OADF,MACc,aADd,EAEE9N,EAQEjB,EARFiB,UACAoB,EAOErC,EAPFqC,SAHF,EAUIrC,EANFgnB,UAAAA,OAJF,SAKEvB,EAKEzlB,EALFylB,SALF,EAUIzlB,EAJFinB,UAAAA,OANF,SAOaC,EAGTlnB,EAHF6mB,UACA1mB,EAEEH,EAFFG,SACG6O,GATL,OAUIhP,EAVJ,IAWA,GAAkC6Q,EAAAA,EAAAA,UAAS+V,GAAQM,IAAnD,eAAOL,EAAP,KAAkBM,EAAlB,KACMlY,EAAM,CAACF,EAAW9N,EAAWwkB,EAAW,aAAe,MAAM1hB,OAAOC,SAASC,KAAK,KAAKC,OA2B7F,OAVAjE,EAAAA,EAAAA,UAAQ,WACFinB,IAAmBL,GACrBM,EAAaP,GAAQM,MAEtB,CAACA,KACJjnB,EAAAA,EAAAA,UAAQ,WACFinB,IAAmBL,GACrB1mB,GAAYA,EAAS0mB,KAEtB,CAACA,EAAWK,KAEbhY,EAAAA,EAAAA,KAAAA,OAAAA,EAAAA,EAAAA,GAAAA,CAAKjO,UAAWgO,GAASD,EAAzB,CAAqCG,IAAKA,EAA1C9M,SACGY,EAAAA,SAAAA,IAAmBZ,GAAU,SAAC8Q,EAAYjI,GAEzC,IAAM2J,EAAM1B,EAAM0B,KAAOuS,OAAOlc,GACxB0H,EAAaO,EAAMnT,MAAnB4S,SACJ/N,GAAW,EAGbA,EAFEmiB,EAESH,EAAU,KAAOhS,EAEjBgS,EAAUQ,QAAQxS,IAAQ,EAEvC,IAAMyS,GAAa,QACjBvY,UAAAA,EACAlK,SAAAA,EACA+N,SAAAA,EACAqU,UAAAA,EACAM,YAAa3U,EAAW,aAAW,kBA5C3C,SAAqBiC,GACnB,IAAIxQ,EAAOwiB,EACX,GAAIG,EACF3iB,EAAOA,EAAK,KAAOwQ,EAAM,GAAK,CAACA,OAC1B,CAEL,IAAM3J,GADN7G,GAAO,QAAIA,IACQgjB,QAAQxS,GACV3J,GAAS,EAExB7G,EAAKmjB,OAAOtc,EAAO,GAEnB7G,EAAKqY,KAAK7H,GAGdsS,EAAa9iB,GA8BkCkjB,CAAY1S,KAClD1B,EAAMnT,OAEX,OAAOiD,EAAAA,aAAmBkQ,EAAOmU,SAMzC,IAAMxf,GAAW7E,EAAAA,WAAgD8jB,IAKhEjf,GAAsB2f,MCjFR,SAAeznB,GAC5B,MAYIA,EAXF+O,UAAAA,OADF,MACc,aADd,EAEE9N,EAUEjB,EAVFiB,UAFF,EAYIjB,EATFuC,KAAAA,OAHF,MAGS,OAHT,EAIEF,EAQErC,EARFqC,SACAwC,EAOE7E,EAPF6E,SACA0iB,EAMEvnB,EANFunB,YANF,EAYIvnB,EALF4S,SAAAA,OAPF,SAQEqU,EAIEjnB,EAJFinB,UACAS,EAGE1nB,EAHF0nB,OACAnC,EAEEvlB,EAFFulB,MACGvW,GAXL,OAYIhP,EAZJ,IAaMiP,EAAM,CACVF,EAAeA,EAAN,QAAyB,KAClC9N,EACA4D,EAAckK,EAAN,UAA2B,KACnC6D,EAAc7D,EAAN,YAA6B,MAEpChL,OAAOC,SACPC,KAAK,KACLC,OACGyjB,EAA6B,kBAATplB,GAAoB2M,EAAAA,EAAAA,KAAChH,EAAD,CAAMvI,KAAM4C,IAAWA,EAkBrE,OACE6P,EAAAA,EAAAA,MAAAA,OAAAA,EAAAA,EAAAA,GAAAA,CAAKnR,UAAWgO,GAASD,EAAzB,CAAA3M,SAAAA,EACE+P,EAAAA,EAAAA,MAAAA,MAAAA,CAAKnR,UAAc8N,EAAL,UAAyB/J,QAASuiB,EAAhDllB,SAAAA,CACG4kB,GAAaU,GACdzY,EAAAA,EAAAA,KAAAA,OAAAA,CAAMjO,UAAc8N,EAAL,SAAf1M,SAAwCqlB,IACvCnC,IAASrW,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,SAAd1M,SAAuCkjB,QAEnDrW,EAAAA,EAAAA,KAAC0C,EAAAA,EAAD,CAAeE,GAAIjN,EAAUuL,eAAe,EAAOlD,QAAS,IAAK2E,WAAe9C,EAAL,SAA3E1M,SACI8P,SAAAA,GAAD,OACClP,EAAAA,cAAmBiM,EAAAA,EAAAA,KAAAA,MAAAA,CAAA7M,SAAMA,IAAiB,CACxCpB,UAAc8N,EAAL,SACTlP,OA3BUsT,EA2BQ9Q,EA1BnB+B,OAAOiT,OAAO,GAAIlE,GAASA,EAAMnT,MAAQmT,EAAMnT,MAAMH,MAAQ,GAAI,CACtE+nB,mBAAoB,WA0BdzY,IAAM/O,SAAAA,GAAD,OAvBf,SAAqB+R,EAA0B0V,GACxCA,IAGU,WAAX1V,GAAkC,YAAXA,IACzB0V,EAAShoB,MAAMf,OAAS,OAEX,YAAXqT,GAAmC,aAAXA,IAC1B0V,EAAShoB,MAAMf,OAAY+oB,EAAS3R,aAApC,OAeuB/I,CAAYgF,EAAQ/R,MA5B3B+S,IAAAA,UD0DtB,IE9FA,GF8FA,G,gFGzFe,SAAStL,GAAmB7H,GACzC,MAOIA,EANF+O,UAAAA,OADF,MACc,sBADd,EAEE9N,EAKEjB,EALFiB,UAFF,EAOIjB,EAJFwU,KAAAA,OAHF,MAGS,GAHT,EAIEnS,EAGErC,EAHFqC,SAJF,EAOIrC,EAFFgF,QAAAA,OALF,MAKY,kBAAM,MALlB,EAMKgK,GANL,OAOIhP,EAPJ,IAgBA,IAAM4Q,GAAa,UACd5B,EADW,CAEd/N,UAAW,CAAC8N,EAAW9N,GAAW8C,OAAOC,SAASC,KAAK,KAAKC,OAC5Dc,QAXF,SAAqB5E,GACnB,IAAKoU,EACH,OAAOxP,EAAQ,IAAI,EAAO5E,GAE5B0nB,IAAAA,CAAKtT,GAAOuT,SAAAA,GACV/iB,EAAQwP,EAAMuT,EAAQ3nB,SAQ1B,OACEgS,EAAAA,EAAAA,MAAAA,QAAAA,EAAAA,EAAAA,GAAAA,GAAUxB,EAAV,CAAAvO,SAAAA,EACE6M,EAAAA,EAAAA,KAAAA,OAAAA,CAAMjO,UAAc8N,EAAL,UAAf1M,SAAyCmS,IACxCnS,M,uHChBA,SAAS2lB,GAAwChoB,GACtD,MAWIA,EAVF+O,UAAAA,OADF,MACc,mBADd,IAWI/O,EATFgU,UAAAA,OAFF,WAEclP,EAFd,EAGE7D,EAQEjB,EARFiB,UACAue,EAOExf,EAPFwf,aACAyI,EAMEjoB,EANFioB,gBALF,EAWIjoB,EALFyf,WAAAA,OANF,WAWIzf,EAJFuf,OAAAA,OAPF,MAOW,aAPX,EAQEpf,EAGEH,EAHFG,SACAD,EAEEF,EAFFE,MACG2f,GAVL,OAWI7f,EAXJ,IAaA,GAAkC6Q,EAAAA,EAAAA,UAAkC,IAApE,eAAOqX,EAAP,KAAkBC,EAAlB,KAYA,SAASC,EAAaC,EAAyBhnB,GAC7C,IAAMinB,GAAc,QAAIJ,GACxBI,EAAYjnB,GAAQgnB,EACpBF,EAAaG,GACbnoB,GAAYA,EAASkoB,EAAOC,GAG9B,OAlBA3Y,EAAAA,EAAAA,YAAU,WACR,IAAI4Y,EAAyB,GACvBC,EAAatoB,EACfwe,MAAM4H,QAAQkC,IAAgB,MAACA,GAAAA,EAAYlM,QAC7CkM,EAAW/Z,SAAQ,SAAC0P,EAAMjT,GACxBqd,EAAUrd,GAAsC,kBAAtBsd,EAAWtd,GAAsB,IAAIuT,KAAKN,GAASA,KAGjFgK,EAAaI,KACZ,CAACE,KAAKC,UAAUxoB,MAUjBkS,EAAAA,EAAAA,MAAAA,MAAAA,CACEnR,UAAW,CAAI8N,EAAJ,YAA6BA,EAA7B,UAAgDhL,OAAOC,SAASC,KAAK,KAAKC,OACrFrE,OAAK,QAAIhB,MAAO,KAAQmV,GAF1B3R,SAAAA,EAIE6M,EAAAA,EAAAA,KAAC3E,IAAD,QACEgQ,QAAQ,QACR/V,UAAU,aACVkW,oBAAkB,GACd8E,EAJN,CAKE/a,SACEyK,EAAAA,EAAAA,KAAC7G,IAAD,QACE8V,KAAM+J,EAAU,GAChBjnB,UAAc8N,EAAL,YACLkZ,EAHN,CAIE9nB,SAAWwgB,SAAAA,GAAD,OAAkByH,EAAazH,EAAc,OAV7Dte,UAcE6M,EAAAA,EAAAA,KAACtG,IAAD,QACEyX,YAAY,iCACZC,UAAQ,GACHT,EAHP,CAKE3f,MAAOgoB,EAAU,IAAKjI,EAAAA,GAAAA,GAAUV,EAAQ2I,EAAU,IAAM,GACxDjnB,UAAW,CAAC8N,EAAW9N,GAAW8C,OAAOC,SAASC,KAAK,KAAKC,cAIhEgL,EAAAA,EAAAA,KAAChH,EAAD,CAAMvI,KAAK,aAAaG,cAAc,WAAWD,MAAO,CAAE8oB,SAAU,GAAI7iB,KAAM,EAAG8iB,OAAQ,sBAEzF1Z,EAAAA,EAAAA,KAAC3E,IAAD,QACEgQ,QAAQ,QACR/V,UAAU,aACVkW,oBAAkB,GACd8E,EAJN,CAKE/a,SACEyK,EAAAA,EAAAA,KAAC7G,IAAD,QACE8V,KAAM+J,EAAU,GAChBjnB,UAAc8N,EAAL,YACLkZ,EAHN,CAIE9nB,SAAWwgB,SAAAA,GAAD,OAAkByH,EAAazH,EAAc,OAV7Dte,UAcE6M,EAAAA,EAAAA,KAACtG,IAAD,QACEyX,YAAY,iCACZC,UAAQ,GACHT,EAHP,CAIE3f,MAAOgoB,EAAU,IAAKjI,EAAAA,GAAAA,GAAUV,EAAQ2I,EAAU,IAAM,GAExDjnB,UAAW,CAAC8N,EAAW9N,GAAW8C,OAAOC,SAASC,KAAK,KAAKC,aAG/Dub,GAAcyI,EAAU5L,OAAS,IAChCpN,EAAAA,EAAAA,KAAChH,EAAD,CAAMjH,UAAc8N,EAAL,aAA4BnK,MAAM,OAAOI,QAAS,kBAAMmjB,EAAa,KAAKxoB,KAAK,a,mGCxFvF,SAAS2I,GAAUtI,GAChC,MASIA,EARF+O,UAAAA,OADF,MACc,cADd,EAEE9N,EAOEjB,EAPFiB,UACAue,EAMExf,EANFwf,aACAyI,EAKEjoB,EALFioB,gBAJF,EASIjoB,EAJFyf,WAAAA,OALF,WASIzf,EAHFuf,OAAAA,OANF,MAMW,aANX,EAOEpf,EAEEH,EAFFG,SACG0f,GARL,OASI7f,EATJ,IAUA,GAAwB6Q,EAAAA,EAAAA,UAAS7Q,EAAME,OAAvC,eAAOie,EAAP,KAAa2B,EAAb,KAEM5f,EAAQie,GAAQ,GAStB,SAASiK,EAAaC,GACpBvI,EAAQuI,GACRloB,GAAYA,EAASkoB,GAOvB,OAjBAxI,EAAW3f,MAAyB,kBAAVA,EAAqBA,GAAQ+f,EAAAA,GAAAA,GAAUV,EAAQrf,IAEzEyP,EAAAA,EAAAA,YAAU,WACJ3P,EAAME,QAAUie,GAClB2B,EAAQ9f,EAAME,SAEf,CAACF,EAAME,QAMNuf,GAAcI,EAAW3f,QAC3B2f,EAAWlC,YACTzO,EAAAA,EAAAA,KAAChH,EAAD,CAAMjH,UAAc8N,EAAL,aAA4B/J,QAAS,kBAAMojB,OAAatjB,IAAYnF,KAAK,YAI1FuP,EAAAA,EAAAA,KAAC3E,IAAD,QACEgQ,QAAQ,QACR/V,UAAU,aACVkW,oBAAkB,GACd8E,EAJN,CAKE/a,SACEyK,EAAAA,EAAAA,KAAC7G,IAAD,QACE8V,KAAOje,GAAS,IAAIue,KAAKve,SAAW4E,EACpC7D,UAAc8N,EAAL,YACLkZ,EAHN,CAIE9nB,SAAWwgB,SAAAA,GAAD,OAAkByH,EAAazH,OAV/Cte,UAcE6M,EAAAA,EAAAA,KAACtG,IAAD,QACEyX,YAAY,iCACZC,UAAQ,GACHT,EAHP,CAIE5e,UAAW,CAAC8N,EAAW9N,GAAW8C,OAAOC,SAASC,KAAK,KAAKC,aC5DpE,IAEA,GAF0D,SAAC,GAAD,SAAG7B,U,mHCiE7D,OAxDA,SAAcrC,QAAuB,IAAvBA,IAAAA,EAAmB,IAC/B,MAaIA,EAZF+O,EADF,EACEA,UACA9N,EAFF,EAEEA,UAFF,IAGEoR,QAASC,OAHX,MAGqB,KAHrB,EAIE1P,EAJF,EAIEA,OACA6iB,EALF,EAKEA,SACAZ,EANF,EAMEA,MAEAgE,EARF,EAQEA,MACAC,EATF,EASEA,KACAzmB,EAVF,EAUEA,SAEG4R,GAZL,OAaIjU,EAbJ,IAeM+oB,EAAoD,CACxD9nB,UAAW,CACT8N,EAAeA,EAAN,cAA+B,KACxC9N,EACA4nB,EAAW9Z,EAAN,cAA+B,KACnC8V,EAAuC,KAA5B9V,EAAZ,kBAEChL,OAAOC,SACPC,KAAK,KACLC,QAEL,MAAe,eAAXtB,EACG6iB,GASHrT,EAAAA,EAAAA,MAACtO,EAAAA,SAAD,CAAAzB,SAAAA,EACE6M,EAAAA,EAAAA,KAAAA,MAAAA,EAAAA,EAAAA,GAAAA,GAAQ6Z,EAAR,CAAA1mB,SAAqBwiB,MACrB3V,EAAAA,EAAAA,KAACoD,GAAD,UACM2B,EADN,CAEE+U,QAASF,EAAc,EAAPA,EAAW,EAAIA,EAC/B7nB,UAAW8N,EAAeA,EAAN,gBAAiC,GAHvD1M,SAKGA,SAdH+P,EAAAA,EAAAA,MAACE,GAAD,UAAa2B,EAAb,CAAoB+U,QAASF,EAA7BzmB,SAAAA,EACE6M,EAAAA,EAAAA,KAAAA,QAAAA,EAAAA,EAAAA,GAAAA,GAAU6Z,EAAV,CAAA1mB,SAAuBwiB,MACvB3V,EAAAA,EAAAA,KAAAA,OAAAA,CAAMjO,UAAW8N,EAAeA,EAAN,gBAAiC,GAA3D1M,SAAgEA,SAkBtE6M,EAAAA,EAAAA,KAACoD,EAAD,CAAS0W,QAASF,EAAM7nB,UAAc8N,EAAL,UAAmC,OAAZuD,EAAmB,UAAY,SAAvFjQ,SACGA,KCxDQ,SAAS4mB,GAAIjpB,QAAsB,IAAtBA,IAAAA,EAAkB,IAC5C,MAAsEA,EAA9D+O,EAAR,EAAQA,UAAWnM,EAAnB,EAAmBA,OAAQ6iB,EAA3B,EAA2BA,SAAUyD,EAArC,EAAqCA,OAAQL,EAA7C,EAA6CA,MAA7C,IAAoDxmB,SAAAA,OAApD,MAA+D,GAA/D,EACA,SAAS8mB,EAAWC,GAClB,OAAO/mB,EAASjB,KAAI,SAAC+R,EAAOjI,GAAR,OAClB0J,EAAAA,EAAAA,eAACyU,IAAD,UACMlW,EAAMnT,MADZ,CAEE+O,UAAWA,EACX8F,IAAK3J,EACLge,OAAQA,EACR7W,QAAS+W,EAAS,KAAO,KACzBE,WAAYjnB,EAASia,OAAS,IAAMpR,EACpCtI,OAAQA,EACRimB,MAAOA,EACPpD,SAAUA,IAET2D,EAASjW,EAAMnT,MAAM6kB,MAAQ1R,EAAMnT,MAAMqC,aAIhD,IAAM4M,EAAMF,EAAeA,EAAN,OAAwB,GAC7C,OACEqD,EAAAA,EAAAA,MAACtO,EAAAA,SAAD,CAAAzB,SAAAA,CACc,aAAXO,IAAyBsM,EAAAA,EAAAA,KAAAA,KAAAA,CAAIjO,UAAWgO,EAAf5M,SAAqB8mB,GAAW,MAC1Dja,EAAAA,EAAAA,KAAAA,KAAAA,CAAIjO,UAAWgO,EAAf5M,SAAqB8mB,S,gGCmB3B,SAASI,GAAqBvpB,EAA0BmP,GACtD,MAWInP,EAVF+O,UAAAA,OADF,MACc,iBADd,EAEE9N,EASEjB,EATFiB,UACAqS,EAQEtT,EARFsT,MACAmS,EAOEzlB,EAPFylB,SAJF,EAWIzlB,EANFkpB,OAAAA,OALF,MAKW,EALX,EAMEhW,EAKElT,EALFkT,KANF,EAWIlT,EAJF6oB,MAAAA,OAPF,SAQExmB,EAGErC,EAHFqC,SARF,EAWIrC,EAFF4C,OAAAA,OATF,MASW,aATX,EAUKqR,GAVL,OAWIjU,EAXJ,IAYMiP,EAAM,CACVF,EACA9N,EACA8N,GAAanM,EAAYmM,EAAzB,IAAsCnM,EAAW,KACjD6iB,EAAc1W,EAAN,YAA6B,KACrCmE,EAAUnE,EAAN,IAAmBmE,EAAS,MAE/BnP,OAAOC,SACPC,KAAK,KACLC,OAGGmiB,EA9DqB,SAC3BhkB,EACA6mB,GAEA,IAEIM,EAFEC,EAAsD,GACxDC,EAA8D,KA6BlE,OA1BArnB,EAASoM,SAAQ,SAACrB,EAAiDlC,GACjE,IAAIye,EAAWvc,EAEVsc,IACHF,EAAYN,EACZQ,EAAU,GACVD,EAAK/M,KAAKgN,IAIKxe,IAAU7I,EAASia,OAAS,IAE3CqN,EAAW1mB,EAAAA,aAAmB0mB,EAAU,CACtCb,KAAMU,KAIV,MAAqBG,EAAS3pB,MAAtB8oB,KAAAA,OAAR,MAAe,EAAf,EACAY,EAAQhN,KAAKiN,IACbH,GAAaV,IAEI,IACfY,EAAU,SAIPD,EA4B4DG,CAD7C3mB,EAAAA,SAAAA,QAAuBZ,GAC0D6mB,GAEvG,OACEha,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAWgO,EAAKE,IAAKA,EAA1B9M,UACE+P,EAAAA,EAAAA,MAAAA,SAAAA,EAAAA,EAAAA,GAAAA,GAAW6B,EAAX,CAAA5R,SAAAA,CACGiR,IAASpE,EAAAA,EAAAA,KAAAA,UAAAA,CAASjO,UAAc8N,EAAL,SAAlB1M,SAA2CiR,KACrDpE,EAAAA,EAAAA,KAAAA,QAAAA,CAAA7M,SACGgkB,EAAOjlB,KAAI,SAAC+R,EAAOjI,GAAR,OACVgE,EAAAA,EAAAA,KAAC+Z,GAAD,CAAiBla,UAAWA,EAAW0W,SAAUA,EAAUoD,MAAOA,EAAOK,OAAQA,EAAQtmB,OAAQA,EAAjGP,SACG8Q,GADOjI,cAUtB,IAAMlD,GAAe/E,EAAAA,WAAoDsmB,IAKxEvhB,GAA8BsP,KAAOuS,GAEtC,U,gEC/FA,GAAe5mB,EAAAA,YAA+C,SAACjD,EAAOmP,GACpE,MAQInP,EAPF+O,UAAAA,OADF,MACc,YADd,EAEE9N,EAMEjB,EANFiB,UACAoB,EAKErC,EALFqC,SAHF,EAQIrC,EAJF8pB,OAAAA,OAJF,WAQI9pB,EAHFL,KAAAA,OALF,MAKS,aALT,IAQIK,EAFF+pB,MAAAA,OANF,MAMU,SANV,EAOKC,GAPL,OAQIhqB,EARJ,IASMiP,EAAM,CACVhO,EACA8N,EACAA,GAAapP,EAAUoP,EAAvB,IAAoCpP,EAAS,KAC7CoP,GAAagb,EAAWhb,EAAxB,IAAqCgb,EAAU,KAC/C1nB,EAAc0M,EAAN,aAA8B,KACpC+a,EAAY/a,EAAd,UAAmC,MAElChL,OAAOC,SACPC,KAAK,KACLC,OACH,OACEgL,EAAAA,EAAAA,KAAAA,OAAAA,EAAAA,EAAAA,GAAAA,CAAKjO,UAAWgO,GAAS+a,EAAzB,CAAoC7a,IAAKA,EAAzC9M,SACGA,IAAY6M,EAAAA,EAAAA,KAAAA,OAAAA,CAAMjO,UAAc8N,EAAL,cAAf1M,SAA6CA,U,+JCfhE,YAAgBrC,QAA4B,IAA5BA,IAAAA,EAAqB,IACnC,MAeIA,EAfJ,IACE+O,UAAAA,OADF,MACc,WADd,EAEE9N,EAFF,EAEEA,UACApB,EAHF,EAGEA,MAHF,IAIE2E,UAAAA,OAJF,MAIc,QAJd,MAKE0O,KAAAA,OALF,MAKS,IALT,EAMEI,EANF,EAMEA,MACAkS,EAPF,EAOEA,OACAjjB,EARF,EAQEA,KARF,IASEsR,mBAAAA,OATF,SAUEoW,EAVF,EAUEA,UAVF,IAWE/c,QAAAA,OAXF,MAWY,IAXZ,MAYE6C,OAAAA,OAZF,aAaEC,aAAAA,OAbF,SAcK8L,GAdL,OAeI9b,EAfJ,IAgBMiP,EAAM,CAAChO,EAAW8N,EAAWvK,GAAWT,OAAOC,SAASC,KAAK,KAAKC,OAClEgmB,EAAU,CAACD,EAAYA,EAAUhpB,UAAY,KAAM8N,EAAeA,EAAN,cAA+B,MAC9FhL,OAAOC,SACPC,KAAK,KACLC,OACGimB,GAAO,UACRtqB,GADK,WAEP,iBAAiBsC,KAAKqC,GAAc,SAAW,QAAU0O,IAEtDkX,GAAanqB,EAAAA,EAAAA,UAAQ,kBAAOulB,GAAStW,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,UAAd1M,SAAwCmjB,IAAgB,OAAO,CAACA,IACrG6E,GAAWpqB,EAAAA,EAAAA,UAAQ,kBAAOsC,GAAO2M,EAAAA,EAAAA,KAAChH,EAAD,CAAMvI,KAAM4C,IAAW,OAAO,CAACA,IAChE+nB,GAAYrqB,EAAAA,EAAAA,UAAQ,kBAAOqT,GAAQpE,EAAAA,EAAAA,KAAAA,KAAAA,CAAA7M,SAAKiR,IAAc,OAAO,CAACA,IACpE,OACEpE,EAAAA,EAAAA,KAAC/E,GAAD,QAASlJ,UAAWgO,EAAK/B,QAASA,EAAS6C,OAAQA,EAAQC,aAAcA,GAAkB8L,EAA3F,CAAAzZ,UACE+P,EAAAA,EAAAA,MAAAA,MAAAA,CAAKnR,UAAc8N,EAAL,WAA0BlP,MAAOsqB,EAA/C9nB,SAAAA,EACIiR,GAAS/Q,KACT6P,EAAAA,EAAAA,MAAAA,MAAAA,CAAKnR,UAAc8N,EAAL,UAAd1M,SAAAA,CACGgoB,EACAC,EACAhX,GAASO,IAAsB3E,EAAAA,EAAAA,KAACrG,EAAD,CAAQmK,OAAK,EAAChO,QAAShF,EAAM0Q,QAASnO,KAAK,QAAQ5C,KAAK,cAG5FuP,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,QAAd1M,UACE6M,EAAAA,EAAAA,KAAAA,OAAAA,EAAAA,EAAAA,GAAAA,GAAS+a,EAAT,CAAoBhpB,UAAWipB,EAA/B7nB,SACGrC,EAAMqC,cAGV+nB,S,sECrDM,SAAS7hB,GAASvI,GAC/B,MAA8GA,EAAtG+O,UAAAA,OAAR,MAAoB,aAApB,IAA8G/O,EAA5EwE,UAAAA,OAAlC,MAA8C,aAA9C,EAA4DvD,EAAkDjB,EAAlDiB,UAAWa,EAAuC9B,EAAvC8B,KAAMO,EAAiCrC,EAAjCqC,SAAUuQ,EAAuB5S,EAAvB4S,SAAaqB,GAApG,OAA8GjU,EAA9G,IAEMiP,GAAMhP,EAAAA,EAAAA,UAAQ,iBAAM,CAAC8O,EAAW9N,GAAW8C,OAAOC,SAASC,KAAK,KAAKC,SAAQ,CAAC6K,EAAW9N,IAE/F,OACEiO,EAAAA,EAAAA,KAAC5E,IAAD,QACE6Q,WAAS,EACTT,oBAAkB,EAClBzZ,UAAWgO,EACX2D,SAAUA,EACVpO,UAAWA,GACPyP,EANN,CAOEhD,QAASnP,EAPXO,SASGY,EAAAA,aAAmBZ,EAAU+B,OAAOiT,OAAO,GAAIhV,EAASrC,W,oFC+B/D,GA3CeA,SAAAA,GACb,MASIA,EARF+O,UAAAA,OADF,MACc,UADd,EAEE9N,EAOEjB,EAPFiB,UACAsB,EAMEvC,EANFuC,KACAgoB,EAKEvqB,EALFuqB,UAJF,EASIvqB,EAJFkT,KAAAA,OALF,MAKS,GALT,IASIlT,EAHFwqB,YAAAA,OANF,MAMgB,2BANhB,EAOEnoB,EAEErC,EAFFqC,SACG4R,GARL,OASIjU,EATJ,IAWMiP,EAAM,CAACF,EAAW9N,GAAW8C,OAAOC,SAASC,KAAK,KAAKC,OAC7D,OACEkO,EAAAA,EAAAA,MAAAA,OAAAA,EAAAA,EAAAA,GAAAA,CAAKnR,UAAWgO,GAASgF,EAAzB,CAAA5R,SAAAA,EACE6M,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,QAAd1M,SACGE,IAGC6P,EAAAA,EAAAA,MAAAA,OAAAA,EAAAA,EAAAA,GAAAA,CAAKxT,QAAQ,gBAAgBC,MAAOqU,EAAMpU,OAAQoU,GAAUqX,EAA5D,CAAAloB,SAAAA,EACE6M,EAAAA,EAAAA,KAAAA,OAAAA,CAAM9P,EAAE,yEAAyEF,KAAK,aACtFgQ,EAAAA,EAAAA,KAAAA,OAAAA,CAAM9P,EAAE,wDAAwDF,KAAK,aACrEgQ,EAAAA,EAAAA,KAAAA,OAAAA,CACE9P,EAAE,oKACFF,KAAK,aAEPgQ,EAAAA,EAAAA,KAAAA,OAAAA,CACE9P,EAAE,uUACFF,KAAK,aAEPgQ,EAAAA,EAAAA,KAAAA,OAAAA,CACE9P,EAAE,4YACFF,KAAK,kBAKZsrB,IAAetb,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,eAAd1M,SAA6CmoB,IAC5DnoB,IAAY6M,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,UAAd1M,SAAwCA,S,yCC5C3D,GAAeY,EAAAA,YAAqD,SAACjD,EAAOmP,GAC1E,IAAQlO,EAAyEjB,EAAzEiB,UAAR,EAAiFjB,EAA9DyqB,UAAAA,OAAnB,MAA+B,SAA/B,IAAiFzqB,EAAxC+O,UAAAA,OAAzC,MAAqD,cAArD,EAAuEkF,GAAvE,OAAiFjU,EAAjF,IACMiP,EAAM,CAACF,EAAW9N,GAAW8C,OAAOC,SAASC,KAAK,KAAKC,OAC7D,OAAOgL,EAAAA,EAAAA,KAACtG,IAAD,QAAOuG,IAAKA,EAAK,aAAYsb,EAAWxpB,UAAWgO,GAASgF,EAA5D,CAAmEtU,KAAK,aCwDjF,GA5DiBK,SAAAA,GACf,IACEiB,EAeEjB,EAfFiB,UADF,EAgBIjB,EAdF+O,UAAAA,OAFF,MAEc,mBAFd,IAgBI/O,EAbF0qB,SAAAA,OAHF,MAGa,GAHb,EAIEC,EAYE3qB,EAZF2qB,WAJF,EAgBI3qB,EAXFkT,KAAAA,OALF,MAKS,SALT,IAgBIlT,EAVF+U,MAAAA,OANF,MAMU,QANV,EAOE6V,EASE5qB,EATF4qB,SACAvoB,EAQErC,EARFqC,SARF,EAgBIrC,EAPF6qB,aAAAA,OATF,MASiB,CACbC,iBAAiB,EACjBC,gBAAgB,GAXpB,EAaEC,EAGEhrB,EAHFgrB,UACAC,EAEEjrB,EAFFirB,MACAC,EACElrB,EADFkrB,SAGIjc,EAAM,CAACF,EAAcA,EAAf,SAAiCmE,EAAWnE,EAA5C,UAA+DgG,EAAS9T,GACjF8C,OAAOC,SACPC,KAAK,KACLC,OAEH,OACEkO,EAAAA,EAAAA,MAAAA,MAAAA,CAAKnR,UAAWgO,EAAhB5M,SAAAA,CACGA,IACEuoB,GACD3nB,EAAAA,eAAqBZ,IACrBY,EAAAA,aAAmBZ,EAAU,CAC3B2C,QAASimB,KAEb/b,EAAAA,EAAAA,KAAAA,MAAAA,CAAA7M,SACGqoB,EAAStpB,KAAI,SAACY,EAAMkJ,GAAP,OACZkH,EAAAA,EAAAA,MAAAA,MAAAA,CAAKnR,UAAc8N,EAAL,IAAkB4b,EAAhCtoB,SAAAA,CACkB,YAAfsoB,IACCvY,EAAAA,EAAAA,MAAAA,MAAAA,CAAKnR,UAAc8N,EAAL,SAAuBA,EAAvB,IAAoC4b,EAApC,QAAdtoB,SAAAA,EACE6M,EAAAA,EAAAA,KAAAA,MAAAA,CAAK8F,IAAKhT,EAAI,QAAaiT,IAAI,MAClB,MAAZ4V,OAAAA,EAAAA,EAAcC,mBACb5b,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,WAAd1M,UACE6M,EAAAA,EAAAA,KAAAA,OAAAA,CAAMjO,UAAc8N,EAAL,kBAAiC/J,QAAS,wBAAMgmB,OAAN,EAAMA,EAAYhpB,IAA3EK,UACE6M,EAAAA,EAAAA,KAAChH,EAAD,CAAMvI,KAAK,SAASE,MAAO,CAAE+E,MAAO,OAAQ+jB,SAAU,cAMhEzZ,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,IAAkB4b,EAAlB,QAAdtoB,SAAoDL,EAAKQ,QAC5C,MAAZqoB,OAAAA,EAAAA,EAAcE,kBACb7b,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,IAAkB4b,EAAlB,QAAqC3lB,QAAS,wBAAMkmB,OAAN,EAAMA,EAAWhgB,IAA7E7I,UACE6M,EAAAA,EAAAA,KAAChH,EAAD,CAAMvI,KAAK,SAASE,MAAO,CAAE+E,MAAO,cAhBSsG,YCsB7D,GAxDclL,SAAAA,GACZ,IACEiB,EAeEjB,EAfFiB,UADF,EAgBIjB,EAdF+O,UAAAA,OAFF,MAEc,mBAFd,IAgBI/O,EAbF0qB,SAAAA,OAHF,MAGa,GAHb,IAgBI1qB,EAZFmrB,UAAAA,OAJF,MAIc,EAJd,IAgBInrB,EAXF+U,MAAAA,OALF,MAKU,QALV,IAgBI/U,EAVFkT,KAAAA,OANF,MAMS,SANT,EAOE0X,EASE5qB,EATF4qB,SACAvoB,EAQErC,EARFqC,SARF,EAgBIrC,EAPF6qB,aAAAA,OATF,MASiB,CACbC,iBAAiB,EACjBC,gBAAgB,GAXpB,EAaEE,EAGEjrB,EAHFirB,MACAD,EAEEhrB,EAFFgrB,UACAE,EACElrB,EADFkrB,SAEIjc,EAAM,CAACF,EAAcA,EAAf,SAAiCmE,EAAWnE,EAA5C,UAA+DgG,EAAS9T,GACjF8C,OAAOC,SACPC,KAAK,KACLC,OAEGknB,KAAWP,EAAaC,kBAAmBD,EAAaE,gBAE9D,OACE3Y,EAAAA,EAAAA,MAAAA,MAAAA,CAAKnR,UAAWgO,EAAhB5M,SAAAA,CACGqoB,EAAStpB,KAAI,SAACY,EAAMkJ,GAAP,OACZkH,EAAAA,EAAAA,MAAAA,MAAAA,CAAKnR,UAAc8N,EAAL,OAAd1M,SAAAA,EACE6M,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,YAAd1M,UACE6M,EAAAA,EAAAA,KAAAA,MAAAA,CAAK8F,IAAKhT,EAAI,QAAaiT,IAAI,QAGjC7C,EAAAA,EAAAA,MAAAA,MAAAA,CAAKnR,UAAWmqB,EAAcrc,EAAN,WAA4B,GAApD1M,SAAAA,EACe,MAAZwoB,OAAAA,EAAAA,EAAcC,mBACb5b,EAAAA,EAAAA,KAAAA,OAAAA,CAAMjO,UAAc8N,EAAL,kBAAiC/J,QAAS,wBAAMgmB,OAAN,EAAMA,EAAYhpB,IAA3EK,UACE6M,EAAAA,EAAAA,KAAChH,EAAD,CAAMvI,KAAK,SAASE,MAAO,CAAE+E,MAAO,OAAQ+jB,SAAU,SAG7C,MAAZkC,OAAAA,EAAAA,EAAcE,kBACb7b,EAAAA,EAAAA,KAAAA,OAAAA,CAAMjO,UAAc8N,EAAL,kBAAiC/J,QAAS,wBAAMkmB,OAAN,EAAMA,EAAWhgB,IAA1E7I,UACE6M,EAAAA,EAAAA,KAAChH,EAAD,CAAMvI,KAAK,SAASE,MAAO,CAAE+E,MAAO,OAAQ+jB,SAAU,aAbrBzd,MAmB1CigB,EAAYT,EAASpO,SAAWsO,IAC/B1b,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,QAAsBA,EAAtB,OAAuC/J,QAASimB,EAA9D5oB,SACGA,QC5CEgpB,GAAaC,SAAAA,GACxB,IAAMC,EAAS,IAAIC,WACnB,OAAO,IAAIC,SAASC,SAAAA,GAClBH,EAAO5c,iBAAiB,QAAQ,kBAAM+c,EAAQtE,OAAOmE,EAAOnS,YAC5DmS,EAAOI,cAAcL,OAIZM,GAAe,SAACC,EAAiBC,GAE5C,IADA,IAAMC,EAAuC,GACpCrZ,EAAI,EAAGA,EAAImZ,EAAMvP,OAAQ5J,GAAK,EACrCqZ,EAAarP,KAAK2O,GAAUQ,EAAMnZ,KAEpC,OAAO+Y,QAAQO,IAAID,GAAcE,MAAMC,SAAAA,GAMrC,OALmCA,EAAe9qB,KAAI,SAAC+qB,EAAQjhB,GAAT,6BACnD4gB,EAAaK,IADsC,iBAE9CN,EAAM3gB,KAFwC,iBAG9C2gB,EAAM3gB,GAAO1I,MAHiC,SCsC1D,GAvDyBxC,SAAAA,GACvB,IAAQ2qB,EAAsE3qB,EAAtE2qB,WAAR,EAA8E3qB,EAA1DE,MAAAA,OAApB,MAA4B,GAA5B,IAA8EF,EAA9CosB,SAAAA,OAAhC,WAA8EpsB,EAA5BmrB,UAAAA,OAAlD,MAA8D,EAA9D,EAAiEhrB,EAAaH,EAAbG,SAC3Dyd,GAAWnO,EAAAA,EAAAA,QAAyB,MACpC4c,EAA4BnsB,GAAS,GAC3C,GAAgC2Q,EAAAA,EAAAA,UAA2B,IAA3D,eAAOyb,EAAP,KAAiBC,EAAjB,MAEA5c,EAAAA,EAAAA,YAAU,WACR4c,EAAYF,KACX,IAEH,IA0BIG,EA1BEC,GAAmBC,EAAAA,EAAAA,cAAY,kBDfR9O,SAAAA,GACzBA,EAAShO,SAASgO,EAAShO,QAAQ+c,QCcIC,CAAehP,KAAW,CAACA,IAEhEiP,GAAeH,EAAAA,EAAAA,cAAY,WAC3B9O,EAAShO,UAASgO,EAAShO,QAAQ1P,MAAQ,IAC/CusB,MACC,CAACA,IAEEK,EAAa,mCAAG,WAAO1sB,GAAP,8EACdyrB,EAAQzrB,EAAEC,OAAOwrB,MADH,iDAGC,OAHD,SAGUD,GAAaC,EAAO,WAH9B,OAGdkB,EAHc,OAIhBC,EAJgB,mBAIEV,IAJF,QAIeS,IAC/B5B,EAAY6B,EAAY1Q,SAC1B0Q,EAAcA,EAAYC,MAAM,EAAG9B,IAErCoB,EAAYS,GACJ,MAAR7sB,GAAAA,EAAW6sB,GATS,4CAAH,sDA4BnB,MAPmB,SAAfrC,IACF6B,EAAOzkB,IAEU,YAAf4iB,GAA2C,SAAfA,IAC9B6B,EAAOhjB,KAIP4I,EAAAA,EAAAA,MAACnP,EAAAA,SAAD,CAAAZ,SAAAA,EACE6M,EAAAA,EAAAA,KAAAA,QAAAA,CAAOvP,KAAK,OAAOwP,IAAKyO,EAAUwO,SAAUA,EAAUvsB,MAAO,CAAE4F,QAAS,QAAUtF,SAAU2sB,IAC3FN,IACCtd,EAAAA,EAAAA,KAACsd,GAAD,UAAUxsB,EAAV,CAAiBmrB,UAAWA,GAAa,EAAGT,SAAU4B,EAAUrB,MAAO4B,EAAc3B,SApBzEhgB,SAAAA,GAChB,IAAM8hB,GAAc,QAAIV,GACxBU,EAAYxF,OAAOtc,EAAO,GAC1BqhB,EAAYS,GACJ,MAAR7sB,GAAAA,EAAW6sB,WCGf,OAbA,SAAgBhtB,GACd,MAAiCA,EAAzB2qB,WAAAA,OAAR,MAAqB,QAArB,EAEA,MAAmB,UAAfA,GACKzb,EAAAA,EAAAA,KAACtG,IAAD,UAAW5I,IFAb,CAAC,UAAW,OAAQ,QAAQsE,SEGlBqmB,IACRzb,EAAAA,EAAAA,KAACge,IAAD,UAAcltB,IAEhB,M,2DC7BF,SAASmtB,GAAIntB,QAAsB,IAAtBA,IAAAA,EAAkB,IACpC,MAA+EA,EAA/E,IAAQ+O,UAAAA,OAAR,MAAoB,QAApB,EAA6B9N,EAA7B,EAA6BA,UAAWsU,EAAxC,EAAwCA,MAAOuT,EAA/C,EAA+CA,KAAMsE,EAArD,EAAqDA,KAAMrD,EAA3D,EAA2DA,MAAU9V,GAArE,OAA+EjU,EAA/E,IACMiP,EAAM,CACVF,EACA9N,EACA6nB,EAAU/Z,EAAN,IAAmB+Z,EAAS,KAChCvT,EAAWxG,EAAN,SAA0B,KAC/Bgb,EAAWhb,EAAN,UAAyBgb,EAAU,KACxCxU,EAAWxG,EAAN,SAAwBqe,EAAS,MAErCrpB,OAAOC,SACPC,KAAK,KACLC,OACH,OACEgL,EAAAA,EAAAA,KAAAA,OAAAA,EAAAA,EAAAA,GAAAA,CAAKjO,UAAWgO,GAASgF,EAAzB,CAAA5R,SACGrC,EAAMqC,Y,4DCfN,SAAS4mB,GAAIjpB,QAAsB,IAAtBA,IAAAA,EAAkB,IACpC,MAAiFA,EAAjF,IAAQ+O,UAAAA,OAAR,MAAoB,QAApB,EAA6B9N,EAA7B,EAA6BA,UAA7B,IAAwCosB,OAAAA,OAAxC,MAAiD,EAAjD,EAAoDC,EAApD,EAAoDA,QAASvD,EAA7D,EAA6DA,MAAU9V,GAAvE,OAAiFjU,EAAjF,IACMiP,EAAM,CACVF,EACA9N,EACA8oB,EAAWhb,EAAN,UAAyBgb,EAAU,KACxCuD,EAAave,EAAN,YAA2Bue,EAAY,MAE7CvpB,OAAOC,SACPC,KAAK,KACLC,OACGqpB,EAAcF,EAAc,CAAEpnB,YAAaonB,EAAS,EAAGtP,aAAcsP,EAAS,GAAvD,GAC7B,OACEne,EAAAA,EAAAA,KAAAA,OAAAA,EAAAA,EAAAA,GAAAA,GAAS+E,EAAT,CAAgBhT,UAAWgO,EAA3B5M,SACGY,EAAAA,SAAAA,QAAuBjD,EAAMqC,UAAUjB,KAAK+R,SAAAA,GAC3C,OAAKlQ,EAAAA,eAAqBkQ,GACnBlQ,EAAAA,aACLkQ,EACA/O,OAAOiT,OAAO,GAAIlE,EAAMnT,MAAO,CAC7BH,OAAO,UAAKsT,EAAMnT,MAAMH,MAAU0tB,MAJGpa,Q,2JCP5Bqa,GAAAA,SAAAA,I,6HAInB1e,WACE,MAeItB,KAAKxN,MAdP+O,EADF,EACEA,UACA9N,EAFF,EAEEA,UACAwsB,EAHF,EAGEA,SACA5tB,EAJF,EAIEA,MACAglB,EALF,EAKEA,MACA6I,EANF,EAMEA,SACAC,EAPF,EAOEA,eACAC,EARF,EAQEA,WACAC,EATF,EASEA,KACAC,EAVF,EAUEA,OAGAC,EAbF,EAaEA,SACGnd,GAdL,aAiBM3B,EAAM,CAACF,EAAW9N,EAAW8sB,EAAchf,EAAN,SAA0B,MAAMhL,OAAOC,SAASC,KAAK,KAAKC,OAC/F8pB,EAAW,CAAC,eAAgBL,GAAgB5pB,OAAOC,SAASC,KAAK,KAAKC,OAC5E,OAAI4pB,GAEA1b,EAAAA,EAAAA,MAAAA,OAAAA,EAAAA,EAAAA,GAAAA,CAAKnR,UAAWgO,EAAKpP,MAAOA,GAAW+Q,EAAvC,CAAAvO,SAAAA,EACE+P,EAAAA,EAAAA,MAAC6W,GAAD,CAAA5mB,SAAAA,EACE+P,EAAAA,EAAAA,MAAC+a,GAAD,CAAK5X,OAAK,EAACtU,UAAW+sB,EAAtB3rB,SAAAA,CACGorB,IAAYve,EAAAA,EAAAA,KAAAA,QAAAA,CAAOrP,MAAO,CAAE+E,MAAO,OAAvBvC,SAAAA,OACb6M,EAAAA,EAAAA,KAAAA,QAAAA,CAAOrP,MAAO+tB,EAAYK,QAASP,EAAnCrrB,SACGwiB,QAGL3V,EAAAA,EAAAA,KAACie,GAAD,CAAKlsB,UAAU,aAAfoB,SAA6BmL,KAAKxN,MAAMqC,cAEzCwrB,IACC3e,EAAAA,EAAAA,KAAC+Z,GAAD,CAAA5mB,UACE6M,EAAAA,EAAAA,KAACie,GAAD,CAAKlsB,UAAU,cAAfoB,SAA8BwrB,WAOtCzb,EAAAA,EAAAA,MAAAA,OAAAA,EAAAA,EAAAA,GAAAA,CAAKnR,UAAWgO,EAAKpP,MAAOA,GAAW+Q,EAAvC,CAAAvO,SAAAA,CACGwiB,IACCzS,EAAAA,EAAAA,MAACnP,EAAAA,SAAD,CAAAZ,SAAAA,CACGorB,IAAYve,EAAAA,EAAAA,KAAAA,QAAAA,CAAOrP,MAAO,CAAE+E,MAAO,OAAvBvC,SAAAA,OACb6M,EAAAA,EAAAA,KAAAA,QAAAA,CAAOjO,UAAW+sB,EAAUnuB,MAAO+tB,EAAYK,QAASP,EAAxDrrB,SACGwiB,QAIP3V,EAAAA,EAAAA,KAACie,GAAD,CAAKlsB,UAAU,aAAfoB,SAA6BmL,KAAKxN,MAAMqC,WACvCwrB,IAAQ3e,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAU,cAAfoB,SAA8BwrB,Y,EAvD1BL,CAAoBvqB,EAAAA,eAApBuqB,GACLpe,aAAe,CAC3BL,UAAW,e,4OCuEf,SAAS1F,GAAT,EAaE8F,GACA,QAZEJ,UAAAA,OAYF,MAZc,SAYd,EAXE9N,EAWF,EAXEA,UACAitB,EAUF,EAVEA,OACA7rB,EASF,EATEA,SACA8rB,EAQF,EAREA,cACAC,EAOF,EAPEA,cACAjuB,EAMF,EANEA,SACAkuB,EAKF,EALEA,SACAC,EAIF,EAJEA,YACG/b,GAGL,aACMgc,GAAWtuB,EAAAA,EAAAA,UACf,kBA7CJ,SACEiuB,EACAM,GAKA,IAAM1rB,EAAmB,CACvB2rB,QAAS,GACT7e,QAAS,GACT8e,YAAY,EACZC,OAAQ,IAEV,IAAK,IAAMnsB,KAAQ0rB,EAAQ,CACzB,IAAMluB,EAAQkuB,EAAO1rB,GACrB,GAAKxC,EAAL,CACA,MAAuCwuB,GAAG,UAAKxuB,EAAN,CAAawC,KAAAA,KAA9CosB,EAAR,EAAQA,aAAcC,EAAtB,EAAsBA,aACtB/rB,EAAM2rB,QAAQjsB,GAAQkc,MAAM4H,QAAQsI,IAAdlQ,EAAAA,GAAAA,GAAkCkQ,GAAgBA,EACxE9rB,EAAM8M,QAAQpN,GAAQqsB,GAExB,OAAO/rB,EA0BHgsB,CAAaZ,GAAQ,YAAsB,IAvBrBhuB,EAuBE0uB,EAAmB,EAAnBA,aAEtB,MAAO,CAAEA,aADTA,EAvBW,QADS1uB,EAwBW0uB,SAvBF9pB,IAAV5E,EAAsB,GAAKA,EAwBvB2uB,aAAcD,QAEzC,IAEF,GAAwB/d,EAAAA,EAAAA,UAAoB0d,GAA5C,eAAOztB,EAAP,KAAaiuB,EAAb,MAEAlT,EAAAA,EAAAA,qBACE1M,GACA,iBAAO,CACLkf,SAAUW,EACVC,UAAWC,EACXC,eAAgB,kBAAMruB,EAAK8O,SAC3Bwf,SAAU,kBAAMtuB,EAAK6tB,QACrBU,UAAWA,EACXC,cAAeA,KAEjB,CAACxuB,IAGH,IAAMyuB,EAAyC,GAC/C,IAAK,IAAM/sB,KAAQ0rB,EAAQ,CACzB,IAAMluB,EAAQkuB,EAAO1rB,GACrB,GAAKxC,EAAL,CACA,IAAMwvB,EAAQ1uB,EAAK6tB,OAAOnsB,GACQ,mBAAvBxC,EAAM4uB,eACf5uB,EAAM6lB,QAAU7lB,EAAM4uB,cAExB,IAAMa,EAAiCC,GAAa,UAC/C1vB,EAD8C,CAEjDwC,KAAAA,KAEIqrB,EAAO2B,GAASxvB,EAAM6tB,KACtBH,EAAW1tB,EAAM0tB,SACvB6B,EAAU/sB,IACR0M,EAAAA,EAAAA,KAACse,IAAD,qBAEOxtB,EAFP,CAGI6U,IAAKrS,EACLH,SAAUotB,EACV5B,KAAAA,EACAH,SAAAA,EACA5qB,MAAOhC,EACP0B,KAAAA,EACAurB,WAAYyB,OAMpB,SAASH,EAAUnB,GACjB,IAAMyB,GAAW,UAAK7uB,EAAR,CAAc8O,QAASse,IACrCa,EAAQY,GAGV,SAASL,EAAiBM,EAAmB1vB,GAC3C,IAAMyvB,GAAW,UAAK7uB,EAAR,CAAc8O,SAAS,UAAK9O,EAAK8O,SAAZ,WAAsBggB,EAAY1vB,MACrE6uB,EAAQY,GAGV,SAASvH,EACP5lB,EACAqtB,EACA5kB,EACAujB,GAEA,OAAO,SAACsB,EAAiDC,GACvD,IAAI7vB,EAAQ4vB,GAAOA,EAAIzvB,QAAU,UAAWyvB,EAAIzvB,OAASyvB,EAAIzvB,OAAOH,MAAQ4vB,EAE5E5vB,EAAQ6vB,GAAQ7vB,GAEX6vB,GAAQ9kB,GAAW6kB,GAAOA,EAAIzvB,QAAU,UAAU8B,KAAK2tB,EAAIzvB,OAAOV,QAErEO,EAAQ4vB,EAAIzvB,OAAOH,MAAQ4vB,EAAIzvB,OAAOH,MAAQ4vB,EAAIzvB,OAAOwlB,UAEtDkK,GAAQ9kB,GAAW6kB,GAAOA,EAAIzvB,QAAU,aAAa8B,KAAK2tB,EAAIzvB,OAAOV,QAExEO,EAAQ4vB,EAAIzvB,OAAOwlB,SAErB,IAAMmK,EAAY,CAChBpgB,SAAS,UAAK9O,EAAK8O,SAAZ,WAAsBpN,EAAOtC,KAExB2vB,GAAaA,EAAU3vB,KAEnC8vB,EAAUrB,QAAVqB,EAAAA,EAAAA,GAAAA,GAAwBlvB,EAAK6tB,eACtBqB,EAAUrB,OAAOnsB,IAEtBstB,GAAOA,EAAI5J,SAAkC,oBAAhB4J,EAAI5J,SAAwB4J,EAAI5J,UACjE6I,GAAQ,UAAKjuB,EAASkvB,IAClBxB,GACFA,EAAGsB,GAEL3vB,GAAYA,GAAS,UAAKW,EAASkvB,KAIvC,SAAShB,EAAa5uB,GACpBA,GAAKA,EAAE6vB,iBACP,IAAQxB,EAAqB3tB,EAArB2tB,QAAS7e,EAAY9O,EAAZ8O,QACjBmf,GAAQ,UAAKjuB,EAAN,CAAY4tB,YAAY,KAC/B,IAxHewB,EAwHTF,EAAY,CAAEtB,YAAY,GAC1BxZ,EAAWG,SAAAA,GAAD,OACd0Z,GAAQ,UACHjuB,EACAkvB,EAFE,CAGLrB,OAASP,GAAiBA,EAAc/Y,IAAS,OAE/C8a,EAAaC,SAAAA,GACbjC,IACF6B,EAAUpgB,QAAU6e,GAEtBM,GAAQ,UAAKjuB,EAASkvB,EAAf,CAA0BrB,OAAQ,MACzCL,GAAeA,EAAY,CAAExrB,MAAOhC,EAAMsvB,SAAAA,EAAUC,MAAOnB,KAE7D,IACE,IAAMoB,EAAqBjC,EAAWA,EAAS,CAAEI,QAAAA,EAAS7e,QAAAA,GAAWxP,QAAK0E,EAC1E,OAAIwrB,KAxISJ,EAwIuBI,IAxIsC,oBAAjBJ,EAAQjE,MAyIxDqE,EAAmBrE,KAAKkE,GAAWI,MAAMrb,GAEzCib,EAAUG,GAEnB,MAAOjb,GACPH,EAAQG,IAIZ,SAASmb,IACP,IAAQ9B,EAA6B5tB,EAA7B4tB,WAAR,EAAqC5tB,EAAjB8O,QAAAA,OAApB,MAA8B,GAA9B,EACI6gB,GAAmB,EACvB,IAAK,IAAMjuB,KAAQ0rB,EACjB,GAAI9pB,OAAOssB,UAAUC,eAAeC,KAAK1C,EAAQ1rB,GAAO,CACtD,IAAMxC,EAA4BkuB,EAAO1rB,GACzC,IAAKxC,EAAO,SACZ,GAAIA,EAAM6vB,WAAa7vB,EAAM6vB,UAAUjgB,EAAQpN,IAAQ,CACrDiuB,GAAmB,EACnB,OAIN,OAAQ/B,GAAc+B,EAGxB,SAASvB,IACP,IAAMT,EAAY3tB,EAAZ2tB,QACAoC,GAAW,UAAKpC,GACtBrqB,OAAO0sB,QAAQD,GAAUzvB,KAAI,YAAkB,mBAAhByT,EAAgB,KAAX3U,EAAW,KACzCwe,MAAM4H,QAAQpmB,KAChB2wB,EAAShc,IAATgc,EAAAA,GAAAA,GAAoB3wB,OAGxB6uB,GAAQ,UAAKjuB,EAAN,CAAY2tB,QAAAA,EAAS7e,QAASihB,EAAUlC,OAAQ,MAGzD,SAASe,EAAT,GAYuB,IAXrBrtB,EAWqB,EAXrBA,SACAwtB,EAUqB,EAVrBA,UACArtB,EASqB,EATrBA,KAQGyR,GACkB,aACfhJ,EACgB,oBAAb5I,EACHA,EACAA,EAAS,CACPlC,SAAUioB,EAAa5lB,EAAOqtB,GAC9BxB,SAAUW,EACVwB,UAAWA,IAEnB,IAAKvlB,GAA6C,IAAlChI,EAAAA,SAAAA,MAAqBgI,KAAmBzI,EAAM,OAAOyI,EACrE,IAAMjL,GAAQ,QACZwC,KAAMyI,EAAQjL,MAAMwC,MAAQA,GACzByR,GAEC8c,EAAkB3sB,OAAOssB,UAAUC,eAAeC,KAAK9vB,EAAK8O,QAASpN,GAC3ExC,EAAMyD,GAAKwH,EAAQjL,MAAMyD,GACzBzD,EAAME,MAAQ6wB,EAAkBjwB,EAAK8O,SAAW9O,EAAK8O,QAAQpN,GAAQxC,EAAME,MAG3E,IAAMP,EAAOsL,EAAQjL,MAAML,KAO3B,MALa,aAATA,GAAgC,WAATA,GAA4C,mBAAhBK,EAAME,QAC3DF,EAAM6lB,UAAY7lB,EAAME,aACjBF,EAAME,OAEfF,EAAMG,SAAWioB,EAAa5lB,EAAMqtB,EAAW5kB,EAASA,EAAQjL,MAAMG,UAC/D8C,EAAAA,aAAmBgI,EAASjL,GAGrC,OACEkP,EAAAA,EAAAA,KAAAA,QAAAA,EAAAA,EAAAA,GAAAA,IAAAA,EAAAA,EAAAA,GAAAA,GAEOqD,EAFP,CAGItR,UAAW,CAAC8N,EAAW9N,GAAW8C,OAAOC,SAASC,KAAK,KAAKC,OAC5DmqB,SAAUW,IAJd,CAAA3sB,UAOE6M,EAAAA,EAAAA,KAAAA,WAAAA,CAAgB0D,SAAU9R,EAAK4tB,WAA/BrsB,SACuB,oBAAbA,EACJA,EAAS,CACP6rB,OAAQqB,EACRzsB,MAAOhC,EACPmuB,UAAWC,EACXsB,UAAWA,IAEbnuB,OAMZ,IChUA,GDgUeY,EAAAA,WAAyDoG,I,mEEzT3D2nB,GAAW/tB,EAAAA,YACtB,SAA8BjD,EAA2BmP,GACvD,MAQInP,EAPF+O,UAAAA,OADF,MACc,cADd,EAEE9N,EAMEjB,EANFiB,UACAoB,EAKErC,EALFqC,SACAkjB,EAIEvlB,EAJFulB,MAJF,EAQIvlB,EAHFqS,QAAAA,OALF,MAKY,MALZ,IAQIrS,EAFF6S,OAAAA,OANF,SAOK7D,GAPL,OAQIhP,EARJ,IASMiP,EAAM,CAACF,EAAW9N,EAAWjB,EAAM4S,SAAW,aAAe,KAAMC,EAAS,WAAa,MAC5F9O,OAAOC,SACPC,KAAK,KACLC,OACGoO,EAAUtS,EAAMU,MAA2B,kBAAZ2R,EAAuB,IAAMA,EAClE,OAAOpP,EAAAA,cACLqP,GADKrP,EAAAA,EAAAA,GAAAA,GAGA+L,EAHA,CAIH/N,UAAWgO,EACXE,IAAAA,KAEDoW,GAASvW,EAAWtO,KACnB2B,GAEA+P,EAAAA,EAAAA,MAACtO,EAAAA,SAAD,CAAAzB,SAAAA,EACE6M,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,QAAd1M,SAAsCA,KACtC6M,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,SAAd1M,SAAuCkjB,WAOjDyL,GAASC,YAAc,Y,uIC7BvB,SAASC,GAAgBlxB,EAAqBmP,GAC5C,IAeIgiB,EAfJ,EAcInxB,EAbF+O,UAAAA,OADF,MACc,SADd,IAcI/O,EAZFylB,SAAAA,OAFF,WAcIzlB,EAXFoxB,QAAAA,OAHF,WAcIpxB,EAVF0lB,QAAAA,OAJF,WAcI1lB,EATF6S,OAAAA,OALF,WAcI7S,EARFkT,KAAAA,OANF,MAMS,UANT,IAcIlT,EAPFqxB,WAAAA,OAPF,MAOe3lB,EAPf,EAQEzK,EAMEjB,EANFiB,UACAoB,EAKErC,EALFqC,SACAqlB,EAIE1nB,EAJF0nB,OACAlC,EAGExlB,EAHFwlB,OAXF,EAcIxlB,EAFFsxB,WAAAA,OAZF,MAYe,GAZf,EAaKtiB,GAbL,OAcIhP,EAdJ,IAiBEmxB,EADEG,GAAcA,EAAWhV,OAAS,EAC5BgV,EAAWlwB,KAAI,SAACY,EAAWkJ,GAAZ,OAA8BmmB,EAAYrvB,EAAMkJ,MAE/D7I,EAEV,IAAIkvB,EAAetuB,EAAAA,SAAAA,IACjBkuB,GACA,SAAChe,EAAwBjI,GAAzB,OACE,iBAAqBiI,IACrBlQ,EAAAA,aAAmBkQ,EAAO,CACxB0B,IAAK3J,OAGLsmB,EAAc,CAClBziB,EACA9N,EACAmwB,EAAariB,EAAN,WAA4B,KACnC2W,EAAa3W,EAAN,YAA6B,KACpC8D,EAAY9D,EAAN,UAA2B,KACjC0W,EAAc1W,EAAN,YAA6B,KACrCmE,GAAiB,YAATA,EAAwBnE,EAAhC,SAAkDmE,EAAS,MAE1DnP,OAAOC,SACPC,KAAK,KACLC,OACH,OACEkO,EAAAA,EAAAA,MAAAA,OAAAA,EAAAA,EAAAA,GAAAA,CAAKnR,UAAWuwB,GAAiBxiB,EAAjC,CAA6CG,IAAKA,EAAlD9M,SAAAA,CACGqlB,IAAUxY,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,UAAd1M,SAAwCqlB,IAClD6J,EACA/L,IAAUtW,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,UAAd1M,SAAwCmjB,QAKzD,IAAMhc,GAAOvG,EAAAA,WAAiDiuB,IAK7D1nB,GAAc8N,KAAO0Z,GAEtB,U,iIC7DA,YAAgBhxB,QAA4B,IAA5BA,IAAAA,EAAqB,IACnC,MAaIA,EAbJ,IACE+O,UAAAA,OADF,MACc,WADd,EAEE9N,EAFF,EAEEA,UAFF,IAGEiS,KAAAA,OAHF,MAGS,UAHT,MAIEJ,QAAAA,OAJF,SAKErT,EALF,EAKEA,IACA8X,EANF,EAMEA,SACA3S,EAPF,EAOEA,MACA6sB,EARF,EAQEA,QACApvB,EATF,EASEA,SACA3C,EAVF,EAUEA,UAVF,IAWEgyB,WAAAA,OAXF,SAYK9gB,GAZL,OAaI5Q,EAbJ,IAcMiP,EAAM,CAACF,EAAW9N,EAAWiS,EAAUnE,EAAN,IAAmBmE,EAAS,MAAMnP,OAAOC,SAASC,KAAK,KAAKC,OAE7FytB,GAAgB1xB,EAAAA,EAAAA,UACpB,kBACEiP,EAAAA,EAAAA,KAAAA,MAAAA,CAAKtQ,QAAQ,cAAbyD,UACE6M,EAAAA,EAAAA,KAAAA,SAAAA,CAAQ0iB,GAAG,KAAKC,GAAG,KAAKC,EAAE,KAAK5yB,KAAK,OAAOD,YAAY,IAAI8yB,iBAAiB,WAGhF,IAGIC,GAAW/xB,EAAAA,EAAAA,UACf,kBACEiP,EAAAA,EAAAA,KAAAA,MAAAA,CACEjO,UAAW,CAAI8N,EAAJ,QAAsB2iB,EAAgB3iB,EAAN,cAA+B,MACvEhL,OAAOC,SACPC,KAAK,KACLC,OACHrE,MAAO,CAAE+E,MAAAA,EAAOyB,gBAAiBorB,GALnCpvB,UAOE+P,EAAAA,EAAAA,MAAAA,MAAAA,CAAKnR,UAAc8N,EAAL,eAAd1M,SAAAA,CACG3C,GAAaiyB,EACblyB,IACCyP,EAAAA,EAAAA,KAAAA,MAAAA,CACEjO,UAAW,CAAI8N,EAAJ,QAAsBwI,EAAcxI,EAAN,YAA6B,MACnEhL,OAAOC,SACPC,KAAK,KACLC,OAJL7B,SAMG5C,WAMX,CAACiyB,EAAYD,EAAS1iB,EAAWwI,EAAU9X,IAG7C,OACE2S,EAAAA,EAAAA,MAAAA,OAAAA,EAAAA,EAAAA,GAAAA,CAAKnR,UAAWgO,GAAS2B,EAAzB,CAAAvO,SAAAA,EACIyQ,GAAW4e,IAAeM,EAC3B3vB,GACCY,EAAAA,aACEZ,EACA+B,OAAOiT,OAAO,GAAIhV,EAASrC,MAAO,CAChCiB,UAAW,CAAI8N,EAAJ,QAAsB+D,EAAa/D,EAAN,QAAyB,MAAMhL,OAAOC,SAASC,KAAK,KAAKC,e,6HCvEvG+tB,GAAgB,CACpBvxB,UAAMoE,EACNE,aAASF,EACT2M,iBAAa3M,EACbsY,kBAActY,EACdwY,kBAAcxY,EACdyM,UAAW,GAiBb,SAAS2gB,GAAoClyB,EAA2BmP,GACtE,MAaInP,EAZF+O,UAAAA,OADF,MACc,cADd,EAEE9N,EAWEjB,EAXFiB,UAFF,EAaIjB,EAVFqS,QAASC,OAHX,MAGqB,IAHrB,IAaItS,EARF4S,SAAAA,OALF,WAaI5S,EAPFmyB,UAAAA,OANF,SAOE5vB,EAMEvC,EANFuC,KACAiS,EAKExU,EALFwU,KARF,EAaIxU,EAJF6S,OAAAA,OATF,SAUE8K,EAGE3d,EAHF2d,WACAyU,EAEEpyB,EAFFoyB,cACGC,GAZL,OAaIryB,EAbJ,IAcMsyB,EAAY,CAACvjB,EAAW8D,EAAS,SAAW,KAAMD,EAAW,aAAe,KAAM3R,GACrF8C,OAAOC,SACPC,KAAK,KACLC,OAEGquB,EAAUtvB,EAAAA,cACdqP,GADcrP,EAAAA,EAAAA,GAAAA,GAGTovB,EACCzf,EAAWqf,GAAgB,GAJnB,CAKZhxB,UAAWqxB,EACXnjB,IAAAA,KAEFiD,EAAAA,EAAAA,MAACtO,EAAAA,SAAD,CAAAzB,SAAAA,EACE6M,EAAAA,EAAAA,KAAChH,EAAD,CAAMjH,UAAc8N,EAAL,QAAuBpP,KAAM4C,KAC5C2M,EAAAA,EAAAA,KAAAA,MAAAA,CACEjO,UAAW,CAAC8N,GAAgBA,EAAP,SAA0BojB,GAAgBpjB,EAAjB,cAC3ChL,OAAOC,SACPC,KAAK,KACLC,OAJL7B,SAMGmS,IAEFmJ,MAGL,OAAIyU,EACKG,GAEFngB,EAAAA,EAAAA,MAAAA,KAAAA,CAAA/P,SAAAA,CAAAA,IAAMkwB,EAAN,OAGF,IAAMC,GAAWvvB,EAAAA,WAAiBivB,IAEzCM,GAASvB,YAAc,e,yCCtEVwB,GAAcxvB,EAAAA,YAAkD,SAACjD,EAAOmP,GACnF,MAAyEnP,EAAjE+O,UAAAA,OAAR,MAAoB,iBAApB,EAAsC9N,EAAmCjB,EAAnCiB,UAAWqS,EAAwBtT,EAAxBsT,MAAU+e,GAA3D,OAAyEryB,EAAzE,IACMiP,EAAM,CAACF,EAAW9N,GAAW8C,OAAOC,SAASC,KAAK,KAAKC,OAC7D,OAAKoP,GAIHpE,EAAAA,EAAAA,KAAAA,MAAAA,EAAAA,EAAAA,GAAAA,GAAQmjB,EAAR,CAAmBljB,IAAKA,EAAKlO,UAAWgO,EAAK,YAAU,UAAvD5M,UACE6M,EAAAA,EAAAA,KAAAA,SAAAA,CAAA7M,SAASiR,QAJJpE,EAAAA,EAAAA,KAAAA,MAAAA,EAAAA,EAAAA,GAAAA,GAAQmjB,EAAR,CAAmBljB,IAAKA,EAAKlO,UAAWgO,QASnDwjB,GAAYxB,YAAc,kB,kHCa1B,SAASyB,GAAT,GAAgH,IAA5F3jB,EAA4F,EAA5FA,UAAW4jB,EAAiF,EAAjFA,SAAU5iB,EAAuE,EAAvEA,OACvC,OAAO9P,EAAAA,EAAAA,UACL,kBACEiP,EAAAA,EAAAA,KAAChH,EAAD,CACEvI,KAAK,cACLsB,UAAW,CACT8N,EAAeA,EAAN,iBAAkC,MAC1C4jB,GAAY5iB,EAAS,SAAW,KAChC4iB,GAAa5iB,EAAqB,KAAZ,WAEtBhM,OAAOC,SACPC,KAAK,KACLC,WAGP,CAAC6K,EAAW4jB,EAAU5iB,IAGnB,IAAM6iB,GAAU3vB,EAAAA,YAAiB,SACtCjD,EACAmP,GAEA,MAUInP,EATF+O,UAAAA,OADF,MACc,iBADd,EAEE9N,EAQEjB,EARFiB,UACA2R,EAOE5S,EAPF4S,SAHF,EAUI5S,EANF8b,aAAAA,OAJF,MAIiB,GAJjB,EAKEzZ,EAKErC,EALFqC,SALF,EAUIrC,EAJF2yB,SAAAA,OANF,SAOEE,EAGE7yB,EAHF6yB,aAEG5e,GATL,OAUIjU,EAVJ,IAWM8yB,EAAsB,GACtBC,EAAuB,CAC3BtN,UAAU,EACVpjB,SAAAA,EACAwwB,aAAAA,EACA5xB,UAAW,CAAC8N,EAAeA,EAAN,WAA4B,MAAMhL,OAAOC,SAASC,KAAK,KAAKC,QAE7EsX,EAAWvY,EAAAA,OAAgC,MACjD,GAA4B4N,EAAAA,EAAAA,WAAS,GAArC,eAAOd,EAAP,KAAee,EAAf,KAsDA,OArDA7Q,EAAAA,EAAAA,UAAQ,WACN6Q,GAAU,KACT,CAAC6hB,IA8BCA,GAgBHG,EAAoB7xB,UAAe8N,EAAnC,SACA+jB,EAAoBvY,QAAU,QAC9BuY,EAAoBvuB,WAAY,EAChCwuB,EAAU/tB,QA/CZ,SAAiB5E,GACf,IAAMC,EAASD,EAAE0c,cACXC,EAAW3c,EAAE4c,eAAiB5c,EAAE6c,YAAY5c,OAC9CA,EAAOgC,SAASia,OAAS,GAjEjC,SAAyBlP,GACvB,IAAI4lB,GAAU,EACd,GAAI5lB,EAEF,GACOA,EAAK6R,QAAQnd,OAChBkxB,GAAU,GAER5lB,EAAK6R,QAAQnd,MAAQ,sBAAsBK,KAAKiL,EAAK6R,QAAQnd,QAC/DkxB,GAAU,UAEJ5lB,EAAK6R,QAAQnd,OAASsL,EAAOA,EAAKqK,aAE9C,OAAOub,EAqDDC,CAAgBlW,IACdvB,EAAS5L,SACX4L,EAAS5L,QAASsL,iBAuBf6X,EAAU/tB,QACjB+tB,EAAUtN,UAAW,EACrBqN,EAAoB7xB,UAAe8N,EAAnC,YACA+jB,EAAoBI,QAAS,EAC7BJ,EAAoB3X,WAAY,EAChC2X,EAAoB1X,gBAAiB,EACrC0X,EAAoB1iB,eAAgB,EACpC0iB,EAAoBvY,QAAU,QAC9BuY,EAAoBziB,eAApByiB,GAAwC/jB,EACxC+jB,EAAoBK,OA5BtB,SAAgB/lB,GACdA,EAAKvN,MAAMf,OAAYsO,EAAK8I,aAA5B,KACApF,GAAU,IA2BVgiB,EAAoB7gB,UAzBtB,SAAmB7E,GACjBA,EAAKvN,MAAMf,OAAS,OAyBpBg0B,EAAoBxX,QAvBtB,SAAiBlO,GACfA,EAAKvN,MAAMf,OAAS,MACpBgS,GAAU,IAsBVgiB,EAAoB9gB,UAjBtB,SAAmB5E,GACjBA,EAAKvN,MAAMf,OAAS,WAiBpBg0B,EAAoB/gB,WArBtB,SAAoB3E,GAClBA,EAAKvN,MAAMf,OAAYsO,EAAK8I,aAA5B,QA4BAhH,EAAAA,EAAAA,KAAAA,KAAAA,CAAI,YAAU,UAAUC,IAAKA,EAA7B9M,UACE6M,EAAAA,EAAAA,KAAC5E,IAAD,QACE9F,UAAU,WACVkW,oBAAkB,EAClB9H,SAAUA,EACV7C,OAAQA,EACRxL,WAAW,EACX4W,WAAS,GACL2X,EACAhX,EARN,CASE3M,IAAKqM,EACLvK,SAAS/B,EAAAA,EAAAA,KAACpE,IAAD,UAAUioB,EAAV,CAAqBlzB,MAAQ8yB,EAA2C,GAAhC,CAAE1sB,YAAa4sB,MAVlExwB,UAYE6M,EAAAA,EAAAA,KAACsjB,IAAD,UACMve,EADN,CAEE9E,IAAK,KACLyD,SAAUA,EACVwf,eAAa,EACbzU,YAAYzO,EAAAA,EAAAA,KAACwjB,GAAD,CAAUC,SAAUA,EAAU5jB,UAAWA,EAAWgB,OAAQA,IACxE9O,UAAW,CACT8N,EAAeA,EAAN,SAA0B,KAClC4jB,EAA2C,KAA7B5jB,EAAf,kBACA9N,GAEC8C,OAAOC,SACPC,KAAK,KACLC,kBAOb0uB,GAAQ3B,YAAc,c,gGC5IhBnmB,GAAO7H,EAAAA,YAA8C,SAACjD,EAAOmP,GACjE,MASInP,EARF+O,UAAAA,OADF,MACc,SADd,EAEE9N,EAOEjB,EAPFiB,UACAoB,EAMErC,EANFqC,SACAojB,EAKEzlB,EALFylB,SAJF,EASIzlB,EAJFozB,MAAAA,OALF,MAKU,QALV,IASIpzB,EAHF6yB,aAAAA,OANF,MAMiB,GANjB,EAOEQ,EAEErzB,EAFFqzB,gBACGhB,GARL,OASIryB,EATJ,IAUMiP,GAAMhP,EAAAA,EAAAA,UACV,iBACE,CACE8O,EACA0W,EAAW,aAAe,KAC1B4N,EAAqBtkB,EAAN,oBAAqC,KACpDqkB,EAAWrkB,EAAN,IAAmBqkB,EAAU,KAClCnyB,GAEC8C,OAAOC,SACPC,KAAK,KACLC,SACL,CAAC6K,EAAW0W,EAAU4N,EAAiBD,EAAOnyB,IAGhD,OACEiO,EAAAA,EAAAA,KAAAA,MAAAA,EAAAA,EAAAA,GAAAA,GAAQmjB,EAAR,CAAmBljB,IAAKA,EAAKlO,UAAWgO,EAAK,YAAU,OAAvD5M,SACGY,EAAAA,SAAAA,IAAmBZ,GAAU,SAAC8Q,EAAwB0B,GACrD,IAAK5R,EAAAA,eAAqBkQ,GAAQ,OAAOA,EACzC,IAAMnT,EAA8D,GAKpE,OAHImT,EAAMnT,MAAMqC,UAAY8Q,EAAMxT,OAAUizB,KAC1C5yB,EAAM6yB,aAAeA,GAEhB5vB,EAAAA,aAAmBkQ,EAAO/O,OAAOiT,QAAPjT,EAAAA,EAAAA,GAAAA,GAAmBpE,GAASmT,EAAMnT,MAAO,CAAE6U,IAAK,GAAGA,cAM5F/J,GAAKmmB,YAAc,WAQlBnmB,GAAcwM,KAAOkb,GACrB1nB,GAAc8nB,QAAUA,GACxB9nB,GAAc3C,QAAUsqB,GAEzB,UCpEA,M,2GCeqBjoB,GAAAA,SAAAA,I,6BAMnBoC,SAAAA,EAAY5M,GAAqB,6BAC/B,cAAMA,IAKRszB,aAAgBlzB,SAAAA,GACd,IAAQsQ,EAAY,EAAK1Q,MAAjB0Q,QACR,EAAKlC,SAAS,CAAEuB,QAAQ,IACxBW,GAAWA,EAAQtQ,IATY,EAWjCmzB,WAAa,WACX,MAA2B,EAAKvzB,MAAxBL,EAAR,EAAQA,KAAM6zB,EAAd,EAAcA,SACVjxB,EAAO,EAAKvC,MAAMuC,KACtB,IAAKA,GAAQixB,EACX,OAAQ7zB,GACN,IAAK,UACH4C,EAAO,eACP,MACF,IAAK,UACHA,EAAO,UACP,MACF,IAAK,OACHA,EAAO,cACP,MACF,IAAK,QACHA,EAAO,eAMb,OAAOA,GA9BP,EAAKO,MAAQ,CACXiN,QAAQ,GAHqB,E,qCAkCjCjB,WACE,MAWItB,KAAKxN,MAVP+O,EADF,EACEA,UACA9N,EAFF,EAEEA,UACAtB,EAHF,EAGEA,KACA2T,EAJF,EAIEA,MACAkX,EALF,EAKEA,YACAgJ,EANF,EAMEA,SAEAC,EARF,EAQEA,QACA5f,EATF,EASEA,mBACG6f,GAVL,aAYMrxB,EAAWmoB,GAAehd,KAAKxN,MAAMqC,SACrC4M,EAAM,CACVF,EACA9N,EACG8N,EAHO,IAGMpP,EAChB8zB,EAAa1kB,EAAN,WAA4B,KACnCykB,EAAczkB,EAAN,QAAyB,KACjCykB,EAAczkB,GAAYuE,EAAQ,SAAW,KAAKjR,EAAW,eAAiB,IAAO,MAEpF0B,OAAOC,SACPC,KAAK,KACLC,OACGyvB,GACJvhB,EAAAA,EAAAA,MAAAA,OAAAA,EAAAA,EAAAA,GAAAA,CAAKnR,UAAWgO,GAASykB,EAAzB,CAAArxB,SAAAA,CACGwR,IAAsB3E,EAAAA,EAAAA,KAACrG,EAAD,CAAQmK,OAAK,EAAChO,QAASwI,KAAK8lB,aAAc/wB,KAAK,QAAQ5C,KAAK,UAClF6zB,IAAYtkB,EAAAA,EAAAA,KAAChH,EAAD,CAAMvI,KAAM6N,KAAK+lB,gBAC9BrkB,EAAAA,EAAAA,KAAAA,OAAAA,CAAMjO,UAAc8N,EAAL,SAAf1M,SAAwCiR,KACxCpE,EAAAA,EAAAA,KAAAA,OAAAA,CAAMjO,UAAc8N,EAAL,eAAf1M,SAA8CA,QAGlD,OAAKwR,GAIH3E,EAAAA,EAAAA,KAAC0C,EAAAA,EAAD,CAAeE,GAAItE,KAAK1K,MAAMiN,OAAQK,eAAa,EAAClD,QAAS,IAAK2E,WAAY9C,EAA9E1M,SACGsxB,IAJIA,M,EA1EQnpB,CAAgBvH,EAAAA,WAAhBuH,GACL4E,aAA6B,CACzCL,UAAW,YACX0kB,SAAS,EACT5f,oBAAoB,G,mHCPlBgQ,GAAc,CAClB,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,qBACA,sBAGa,SAASpZ,GAAYzK,GAClC,MAUIA,EATF+O,UAAAA,OADF,MACc,gBADd,IAUI/O,EARFuf,OAAAA,OAFF,MAEW,UAFX,IAUIvf,EAPFG,SAAAA,OAHF,MAGa,aAHb,EAIEc,EAMEjB,EANFiB,UACAue,EAKExf,EALFwf,aALF,EAUIxf,EAJF4zB,mBAAAA,OANF,MAMuB,GANvB,IAUI5zB,EAHFyf,WAAAA,OAPF,WAUIzf,EAFF+iB,WAAAA,OARF,MAQec,GARf,EASKhE,GATL,OAUI7f,EAVJ,IAYA,GAA4B6Q,EAAAA,EAAAA,WAAS,GAArC,eAAOd,EAAP,KAAee,EAAf,KACA,GAAkCD,EAAAA,EAAAA,UAAS,IAAI4N,MAA/C,eAAOqC,EAAP,KAAkBoE,EAAlB,KACA,GAAwBrU,EAAAA,EAAAA,UAAS,SAAjC,eAAOlR,EAAP,KAAaqkB,EAAb,KACA,GAAwBnT,EAAAA,EAAAA,UAAS7Q,EAAME,OAAvC,eAAOie,EAAP,KAAa2B,EAAb,KAyBA,SAAS+T,EAAmBl0B,EAAkC6e,EAAagG,GACzE,IAAMsP,EAAe,IAAIrV,KAAK,IAAIA,KAAKqC,GAAWnhB,GAAM6e,IACnDgG,GACHR,EAAQ,SAEV,IAAMnB,GAAU5C,EAAAA,GAAAA,GAAUV,EAAQ,IAAId,KAAKqV,IAC3ChU,EAAQ+C,GACRqC,EAAa4O,GACb3zB,GAAYA,EAAS2zB,EAAcjR,GACtB,aAATljB,GACFmR,GAAU,GAId,OArCAnB,EAAAA,EAAAA,YAAU,kBAAMmQ,EAAQ9f,EAAME,SAAQ,CAACF,EAAME,QAE7C2f,EAAW3f,OAAQD,EAAAA,EAAAA,UACjB,iBAAuB,kBAATke,EAAoBA,EAAOA,GAAO8B,EAAAA,GAAAA,GAAUV,EAAQpB,GAAQ,KAC1E,CAACoB,EAAQpB,IAGPsB,GAAcI,EAAW3f,QAC3B2f,EAAWlC,YACTzO,EAAAA,EAAAA,KAACrG,EAAD,CACE5H,UAAc8N,EAAL,aACTxM,KAAK,QACLyC,QAAS,WACP8a,EAAQ,IACR3f,GAAYA,KAEd+S,KAAM2M,EAAW3M,KACjBF,OAAK,EACLrT,KAAK,YAoBTuP,EAAAA,EAAAA,KAAC3E,IAAD,QACEgQ,QAAQ,QACR/V,UAAU,aACVkW,oBAAkB,EAClB3K,OAAQA,GACJyP,EALN,CAMEnE,gBAAkB0Y,SAAAA,GAAD,OAAUjjB,EAAUijB,IACrCtvB,SACE2N,EAAAA,EAAAA,MAAAA,MAAAA,CAAKnR,UAAc8N,EAAL,WAAd1M,SAAAA,EACE6M,EAAAA,EAAAA,KAACwU,IAAD,QACE5C,UAAWA,EACXiC,WAAYA,GACR6Q,EAHN,CAIEvV,WAAa2V,SAAAA,GACX,GAAI,iBAAiB7xB,KAAK6xB,GACxBhQ,EAAQgQ,OACH,CACL,IAAMvS,EAAO,IAAIhD,KAAKqC,GAAWY,cAC3BoS,EAAe,IAAIrV,KAAK,IAAIA,KAAKqC,GAAWwC,YAAqB,SAAT3jB,EAAkB8hB,EAAO,EAAIA,EAAO,IAClGyD,EAAa4O,QAIT,UAATn0B,IACCuP,EAAAA,EAAAA,KAAC4T,GAAD,CACEhC,UAAWA,EACXiC,WAAYA,EACZ1E,WAAY,SAACsD,EAAO6C,GAAR,OAAmBqP,EAAmB,WAAYlS,EAAO6C,MAG/D,SAAT7kB,IACCuP,EAAAA,EAAAA,KAAC+T,GAAD,CACEnC,UAAWA,EACXzC,WAAY,SAACoD,EAAM+C,GAAP,OAAkBqP,EAAmB,cAAepS,EAAM+C,SAjChFniB,UAuCE6M,EAAAA,EAAAA,KAACtG,IAAD,QACEyX,YAAY,iCACZC,UAAQ,GACHT,EAHP,CAIE5e,UAAW,CAAC8N,EAAW9N,GAAW8C,OAAOC,SAASC,KAAK,KAAKC,a,gCChH9D+vB,GAA4B,GAC5Bzd,GAAgC,GAEjB0d,GAAAA,SAAAA,I,6BAAkE,qEAK9EpxB,MAAwB,CAC7BmxB,QAAS,IAN0E,E,qCAQ9EE,SAAOn0B,GAAgC,WACpCwE,EAAmBxE,EAAnBwE,UAAWqQ,EAAQ7U,EAAR6U,IACdof,GAAQzvB,KACXyvB,GAAQzvB,GAA0B,IAEpCxE,EAAM+P,QAAS,EACfkkB,GAAQzvB,GAAwBqQ,GAAiB7U,EAC7CA,EAAMo0B,WACR5d,GAAM3B,GAAiBpH,YAAW,WAChC,EAAK4mB,OAAOxf,EAAerQ,KAC1BxE,EAAMo0B,WAEX5mB,KAAKgB,SACH,CACEylB,QAAAA,GACAzvB,UAAAA,IAEF,WACEyvB,GAAQzvB,GAAwBqQ,GAAe9E,QAAS,EACxD,EAAKvB,SAAS,CAAEylB,QAAAA,U,oBAIfI,SAAOxf,EAAarQ,GACzB,GAAKqQ,GAAQrQ,GAAcyvB,GAAQzvB,GAAWqQ,GAA9C,CAGAof,GAAQzvB,GAAWqQ,GAAK9E,QAAS,EACjC,IAAM/P,EAAiCi0B,GAAQzvB,GAAWqQ,GAC1DrH,KAAKgB,SAAS,CAAEylB,QAAAA,KAAW,WACzBpmB,aAAa2I,GAAM3B,WACZ2B,GAAM3B,UACNof,GAAQzvB,GAAWqQ,GACtB7U,GAASA,EAAMs0B,aACjBt0B,EAAMs0B,YAAYt0B,EAAOi0B,U,oBAI/BnlB,WAAS,WACCC,EAAcvB,KAAKxN,MAAnB+O,UACAvK,EAAcgJ,KAAK1K,MAAnB0B,UACR,OACE0K,EAAAA,EAAAA,KAACjM,EAAAA,SAAD,CAAAZ,SACGmC,GACCJ,OAAOC,KAAKmJ,KAAK1K,MAAMmxB,QAAQzvB,IAAYpD,KAAKyT,SAAAA,GAC9C,MAA+C,EAAK/R,MAAMmxB,QAAQzvB,GAAWqQ,GAArE2V,EAAR,EAAQA,YAAaza,EAArB,EAAqBA,OAAWwkB,GAAhC,aAIA,MAHwB,SAApBA,EAAW50B,aACN40B,EAAW50B,MAGlBuP,EAAAA,EAAAA,KAAC5H,GAAD,QACErG,UAAW8N,EAEXqE,WAAW,EACXvU,MAAO,KACF01B,EALP,CAMEhwB,WAAW,EACX4L,aAAa,EACbJ,OAAQA,EACRtL,QAAS+lB,IAPJ3V,Y,EA5DAqf,CAAkBjxB,EAAAA,WAAlBixB,GACL9kB,aAA+B,CAC3CL,UAAW,WACXvK,UAAW,YCRf,IAAMyvB,GAAmB,GACnBO,GAAyB,GAO/B,SAASC,GAAmBz0B,EAAgCL,GAK1D,QAL0G,IAAhDA,IAAAA,EAAwC,QAC7FK,EAAMwE,YACTxE,EAAMwE,UAAY,YAEpBxE,EAAML,KAAOA,GACRK,EAAMuC,MAAuB,OAAfvC,EAAMuC,KACvB,OAAQvC,EAAML,MACZ,IAAK,UACHK,EAAMuC,KAAO,eACb,MACF,IAAK,UACHvC,EAAMuC,KAAO,UACb,MACF,IAAK,OACHvC,EAAMuC,KAAO,cACb,MACF,IAAK,QACHvC,EAAMuC,KAAO,eAMnB,OAAQvC,EAAML,MACZ,IAAK,OACHK,EAAML,KAAO,UACb,MACF,IAAK,QACHK,EAAML,KAAO,SAMjB,GAAIK,EAAMwE,YAAcyvB,GAAQj0B,EAAMwE,WAAY,CAChD,IAAMkwB,EAAMlpB,SAAS8D,cAAc,OACnC9D,SAASgB,KAAKsD,YAAY4kB,GAC1BA,EAAIzzB,UAAY,CAAC,mBAAoBjB,EAAMwE,WAAWT,OAAOC,SAASC,KAAK,KAAKC,OAChFswB,GAAWx0B,EAAMwE,WAAakwB,EAC9BT,GAAQj0B,EAAMwE,WAAa+G,EAAAA,QAAgB2D,EAAAA,EAAAA,KAACglB,GAAD,IAAeQ,GAGrC,OAAnB10B,EAAMo0B,WACRp0B,EAAMo0B,SAAqC,KAAzBp0B,EAAMo0B,UAAY,MAGlCH,GAAQj0B,EAAMwE,YAChByvB,GAAQj0B,EAAMwE,WAAW2vB,QAAzBF,EAAAA,EAAAA,GAAAA,GACKj0B,EADL,CAEEo0B,SAAUp0B,EAAMo0B,SAChBvf,ICzEGmE,SAASoO,OAAuB,KAAhBpR,KAAK2e,UAAkB,IAAIC,SAAS,ID0EvDN,YAJF,SAIcO,EAAaC,GAClBD,IACLA,EAAOnkB,SAAWmkB,EAAOnkB,UAEL,IADPtM,OAAOC,KAAKywB,EAAa90B,EAAMwE,YACnC8X,QAAgB2X,GAAQj0B,EAAMwE,oBAC9ByvB,GAAQj0B,EAAMwE,WACjBgwB,GAAWx0B,EAAMwE,YACnBgH,SAASgB,KAAKqD,YAAY2kB,GAAWx0B,EAAMwE,kBAQvD,CAAC,OAAQ,UAAW,UAAW,OAAQ,SAASiK,SAAS9O,SAAAA,GACtD80B,GAAyC90B,GAAQ,SAAC0a,GACjD,YAD2F,IAA1CA,IAAAA,EAAmC,IAC7Eoa,GAAmBpa,EAAS1a,OAYvC,UEzGA,GAAesD,EAAAA,YAAkF,SAACjD,EAAOmP,GAAR,OAC/FD,EAAAA,EAAAA,KAAAA,UAAAA,EAAAA,EAAAA,GAAAA,GAAYlP,EAAZ,CAAmBmP,IAAKA,QCD1B,GAAelM,EAAAA,YAAsF,SAACjD,EAAOmP,GAAR,OACnGD,EAAAA,EAAAA,KAAAA,YAAAA,EAAAA,EAAAA,GAAAA,GAAclP,EAAd,CAAqBmP,IAAKA,Q,oCCOtBpG,GAAS9F,EAAAA,YAAiD,SAACjD,EAAOmP,GACtE,MAA0EnP,EAAlE+O,UAAAA,OAAR,MAAoB,WAApB,EAAgC9N,EAA0CjB,EAA1CiB,UAAhC,EAA0EjB,EAA/BkT,KAAAA,OAA3C,MAAkD,UAAlD,EAAgEe,GAAhE,OAA0EjU,EAA1E,IACA,OACEkP,EAAAA,EAAAA,KAAAA,UAAAA,EAAAA,EAAAA,GAAAA,GACM+E,EADN,CAEE9E,IAAKA,EACLlO,UAAW,CAAC8N,EAAW9N,EAAWiS,EAAUnE,EAAN,IAAmBmE,EAAS,MAAMnP,OAAOC,SAASC,KAAK,KAAKC,aAUvG6E,GAAkBgsB,OAASA,GAC3BhsB,GAAkB4d,MAAQA,GAE3B,U,+ICCe,SAASje,GAAW1I,GACjC,IACEiB,EAaEjB,EAbFiB,UACApB,EAYEG,EAZFH,MAFF,EAcIG,EAXF+O,UAAAA,OAHF,MAGc,eAHd,IAcI/O,EAVFg1B,UAAAA,OAJF,MAIc,OAJd,IAcIh1B,EATFkT,KAAAA,OALF,MAKS,UALT,IAcIlT,EARFi1B,MAAAA,OANF,MAMU,EANV,IAcIj1B,EAPFk1B,SAAAA,OAPF,MAOa,GAPb,IAcIl1B,EANFm1B,gBAAAA,OARF,MAQoB,GARpB,IAcIn1B,EALF4P,QAASwlB,OATX,MAS2B,EAT3B,IAcIp1B,EAJFG,SAAAA,OAVF,MAUa,kBAAM,MAVnB,EAWEk1B,EAGEr1B,EAHFq1B,iBACA5yB,EAEEzC,EAFFyC,QACGwR,GAbL,OAcIjU,EAdJ,IAgBA,GAA8B6Q,EAAAA,EAAAA,UAASukB,GAAvC,eAAOxlB,EAAP,KAAgBkG,EAAhB,MACAnG,EAAAA,EAAAA,YAAU,kBAAMmG,EAAWsf,KAAgB,CAACA,IAE5C,IAAMnmB,EAAM,CAACF,EAAW9N,EAAWwB,EAAU,UAAY,KAAMyQ,GAAMnP,OAAOC,SAASC,KAAK,KAAKC,OAEzFoxB,GAAgBr1B,EAAAA,EAAAA,UAAQ,WAC5B,IAAMa,EAAmC,CAAC,CAAEnB,KAAM,OAAQiT,SAAsB,IAAZhD,IAC9DoH,EAAQhB,KAAKuf,KAAKN,EAAQC,GAC1BM,EAAYxe,GAAS,EAAIA,EAAQ,EACnCwH,EAAM,EACNxL,EAAQ,EAOZ,IANIpD,EAAU,GAAKoH,EAAQ,GACzBlW,EAAK4b,KAAK,CAAEmI,MAAO,IAEjBjV,EAAU,GAAKoH,EAAQ,GACzBlW,EAAK4b,KAAK,CAAE/c,KAAM,WAAYklB,MAAO,qBAAO4Q,KAAM,IAE7CjX,EAAMgX,GAAW,CAElB5lB,EAAU,GAAKoH,EAAQ,IACzBhE,EAAQpD,EAAU,GAEpB,IAAIiV,GAJJrG,GAAO,GAIWxL,EACdgE,EAAQpH,IAAY,GAAKoH,EAAQ,IACnC6N,GAAS,GAEP7N,EAAQpH,IAAY,GAAKoH,EAAQ,IACnC6N,GAAS,GAEPA,GAAS7N,GACXlW,EAAK4b,KAAK,CAAEmI,MAAAA,EAAOhS,OAAQjD,IAAYiV,IAU3C,OAPIjV,EAAU,EAAIoH,GAASA,EAAQ,GACjClW,EAAK4b,KAAK,CAAE/c,KAAM,WAAYklB,MAAO,qBAAO4Q,KAAM,IAEhD7lB,EAAU,EAAIoH,GAASA,EAAQ,GACjClW,EAAK4b,KAAK,CAAEmI,MAAO7N,IAErBlW,EAAK4b,KAAK,CAAE/c,KAAM,OAAQiT,SAAUhD,IAAYoH,IACzClW,IAWN,CAAC8O,EAASqlB,EAAOC,IAsCpB,OACE9iB,EAAAA,EAAAA,MAAAA,MAAAA,EAAAA,EAAAA,GAAAA,CAAInR,UAAWgO,EAAKpP,OAAK,UAAOA,EAAP,CAAc61B,UAAWV,KAAiB/gB,EAAnE,CAAA5R,SAAAA,CACGizB,EAAcl0B,KAAI,SAACY,EAAgCX,GAElD,IAAIwjB,GAAQ3V,EAAAA,EAAAA,KAAAA,IAAAA,CAAA7M,SAAIL,EAAK6iB,QAKrB,MAJI,gBAAgB1iB,KAAKH,EAAKrC,QAE5BklB,GAAQ3V,EAAAA,EAAAA,KAAAA,IAAAA,CAAGjO,UAAS,SAAWe,EAAKrC,SAGpCuP,EAAAA,EAAAA,KAAAA,KAAAA,CACEjO,UAAW,CAACe,EAAK6Q,OAAS,SAAW,KAAM7Q,EAAK4Q,SAAW,WAAa,MACrE7O,OAAOC,SACPC,KAAK,KACLC,OACHc,QAAS,kBAnDnB,SAAqBhD,GACnB,IAAIA,EAAK6Q,SAAU7Q,EAAK4Q,SAAxB,CAGA,IAAMoE,EAAQhB,KAAKuf,KAAKN,EAAQC,GAC1BpyB,EAAQ,GACVd,EAAK6iB,QACP/hB,EAAM8M,QAAU5N,EAAK6iB,OAEL,SAAd7iB,EAAKrC,OACPmD,EAAM8M,QAAUA,EAAU,EAAI,EAAIA,EAAU,EAAI,GAEhC,SAAd5N,EAAKrC,OACPmD,EAAM8M,QAAUA,EAAU,GAAKoH,EAAQpH,EAAU,EAAIoH,GAEnD,uBAAuB7U,KAAKH,EAAKrC,OAAmBqC,EAAKyzB,OAC3D3yB,EAAM8M,QAAwB,aAAd5N,EAAKrC,KAAsBiQ,EAAU5N,EAAKyzB,KAAO7lB,EAAU5N,EAAKyzB,KAC5E3yB,EAAM8M,QAAUoH,IAClBlU,EAAM8M,QAAUoH,GAEdlU,EAAM8M,QAAU,IAClB9M,EAAM8M,QAAU,IAIpBkG,EAAWhT,EAAM8M,SACjBzP,GAAYA,EAAS2C,EAAM8M,QAASqlB,EAAiBC,IAyB9BpW,CAAY9c,IAL7BK,SAQGwiB,GAFIxjB,MAMV8zB,EAAgB7Y,OAAS,IACxBpN,EAAAA,EAAAA,KAAAA,KAAAA,CAAIjO,UAAc8N,EAAL,WAAb1M,UACE6M,EAAAA,EAAAA,KAACnG,GAAD,CAAQmK,KAAMA,EAAM/R,aAAc+zB,EAAU/0B,SA/BeC,SAAAA,GACjE,IAAMu1B,EAAoBzW,OAAO9e,EAAEC,OAAOH,OACpC8W,EAAQhB,KAAKuf,KAAKN,EAAQU,GAEhCN,GAAoBA,EADOzlB,EAAUoH,EAAQA,EAAQpH,EACJ+lB,IA2B3CtzB,SACG8yB,EAAgB/zB,KAAI,SAACY,EAAckJ,GAAf,OACnBkH,EAAAA,EAAAA,MAACrJ,GAAAA,OAAD,CAAe7I,MAAO8B,EAAtBK,SAAAA,CACGL,EADH,kBAAiCkJ,c,2HClJ/C,SAAS0qB,GAAgB51B,EAA0BmP,QAAyC,IAAnEnP,IAAAA,EAAsB,IAC7C,MAaIA,EAbJ,IACE+O,UAAAA,OADF,MACc,aADd,MAEEsR,YAAAA,OAFF,MAEgB,SAFhB,MAGEngB,MAAAA,OAHF,MAGU,GAHV,EAIEmT,EAJF,EAIEA,UACApS,EALF,EAKEA,UALF,IAMEiS,KAAAA,OANF,MAMS,UANT,EAOErT,EAPF,EAOEA,MACA+S,EARF,EAQEA,SARF,IASEzS,SAAAA,OATF,MASauL,EATb,MAUEmqB,OAAAA,OAVF,MAUWnqB,EAVX,MAWEwR,QAAAA,OAXF,MAWYxR,EAXZ,EAYKkF,GAZL,OAaI5Q,EAbJ,IAcA,GAAgB6Q,EAAAA,EAAAA,UAEb,IAFIiN,GAAP,eAGA,GAAkCjN,EAAAA,EAAAA,UAASwP,GAA3C,eAAOyV,EAAP,KAAkBC,EAAlB,KACA,GAA4BllB,EAAAA,EAAAA,UAAS3Q,GAArC,eAAO81B,EAAP,KAAeC,EAAf,KACMhnB,EAAM,CAACF,EAAW9N,EAAWiS,EAAUnE,EAAN,IAAmBmE,EAAS,KAAMN,EAAW,WAAa,MAC9F7O,OAAOC,SACPC,KAAK,KACLC,OA+BH,SAASgyB,EAAWC,GAClBJ,EAAa1V,GACbwV,EAAOM,GAET,SAASC,EAAYD,GACnBJ,EAAa,IACb7Y,EAAQiZ,GAGV,OAfAxmB,EAAAA,EAAAA,YAAU,WACJqmB,IAAW91B,GACbC,EAAS61B,KAEV,CAACA,KAYF9mB,EAAAA,EAAAA,KAAAA,OAAAA,EAAAA,EAAAA,GAAAA,CAAKjO,UAAWgO,EAAKpP,MAAOA,GAAW+Q,EAAvC,CAAmDzB,IAAKA,EAAxD9M,UACG,QAAI2zB,GAAQ50B,KAAI,SAAColB,EAAK3R,GACrB,IAAMwhB,EAAuB,CAC3BC,IAAK,EACL32B,KAAM,OACN42B,UAAW,UACXtY,aAAc,MACd/d,MAAOsmB,EACPrmB,SAAWC,SAAAA,GAAD,OA/ClB,SAAsBA,EAAwCiB,GAC5D,IAAImlB,EAAMpmB,EAAEC,OAAOH,MACnBsmB,EAAMA,EAAIgQ,OAAOhQ,EAAIlK,OAAS,GAC9B,IAAMsI,GAAM,QAAIoR,GACZ9W,OAAOsH,IAAQ,GAAKA,GACtBpmB,EAAE0c,cAAc5c,MAAQsmB,EACxB5B,EAAIvjB,GAAOmlB,EACP1I,EAAMzc,EAAM,IACdyc,EAAMzc,EAAM,GAAGo1B,QAEjBR,EAAUrR,IACA4B,IACV5B,EAAIvjB,GAAO,GACX40B,EAAUrR,IAkCWwD,CAAahoB,EAAGyU,IACjC6hB,UAAYt2B,SAAAA,GAAD,OAhCnB,SAAuBA,EAA0CiB,GAC/D,IAAImlB,EAAMpmB,EAAE0c,cAAc5c,MACpB2U,EAAMzU,EAAEyU,IAAI8hB,qBACbnQ,GAAO1I,EAAMzc,EAAM,IAAM,qBAAqBc,KAAK0S,IACtDiJ,EAAMzc,EAAM,GAAGo1B,QA4BOG,CAAcx2B,EAAGyU,IACnCghB,OAASz1B,SAAAA,GAAD,OAAO81B,EAAW91B,IAC1B8c,QAAU9c,SAAAA,GAAD,OAAOg2B,EAAYh2B,IAC5Ba,UAAc8N,EAAL,SACTsR,YAAayV,EACbljB,SAAAA,EACAM,KAAAA,GAgBF,OAdIG,GAAqB,IAARwB,IACfwhB,EAAShjB,WAAY,IAGrBuB,EAAAA,EAAAA,eAAChM,IAAD,QACEuG,IAAM0Y,SAAAA,GACAA,IACF/J,EAAMjJ,GAAOgT,KAGbwO,EANN,CAOExhB,IAAKA,WASjB,OAAe5R,EAAAA,WAA+C2yB,IClHvD,SAASiB,GAAgB72B,GAC9B,OAAOkP,EAAAA,EAAAA,KAAChH,EAAD,CAAMvI,KAAMK,EAAML,O,6GCcNm3B,GAAAA,SAAAA,I,0IAQnBC,SAAoBp3B,EAAkCq3B,GACpD,MAAiCxpB,KAAKxN,MAA9Bf,EAAR,EAAQA,YAAa2W,EAArB,EAAqBA,QACrB,GAAIohB,GAAOA,EAAIvf,WAAY,CACzB,IACMwf,GAA0Bh4B,EADb+3B,EAAIvf,WAA2BvL,wBAA1CrN,MAC0D,KAAKq4B,QAAQ,GACzEC,EAASne,UAAU,GAAKZ,WAAW6e,GAAgB,GAAGrC,WAAY,IAQxE,GAPAoC,EAAII,aAAa,eAAgBH,GACjCD,EAAII,aACF,IADFJ,gBAEkBG,EAFlB,MAE8BA,EAF9B,IAEwCA,EAFxC,YAEmE,EAATA,EAF1D,MAE0EA,EAF1E,IAEoFA,EAFpF,aAGa,EAATA,GAGS,UAATx3B,EAAkB,CAEpB,IAAM03B,EAAY,EAAIrhB,KAAKshB,GAAKH,EAChCH,EAAII,aACF,QADFJ,oBAEsBK,EAFtB,MAEqCA,EAFrC,yBAGK,EAAKzhB,EAAqB,KAAOyhB,EAHtC,wE,oBASNvoB,WACE,IAaIyoB,EAbJ,EACE/pB,KAAKxN,MADC+O,EAAR,EAAQA,UAAWlP,EAAnB,EAAmBA,MAAaoB,EAAhC,EAAgCA,UAAWu2B,EAA3C,EAA2CA,SAAU5hB,EAArD,EAAqDA,QAAS2J,EAA9D,EAA8DA,OAAqB1gB,EAAnF,EAAmFA,MAAOsT,EAA1F,EAA0FA,OAAWnD,GAArG,aAEMC,EAAM,CACVF,EACA9N,EACG8N,EAHO,UAIVyoB,EAAczoB,EAAN,aAA8B,KACtCoD,EAAYpD,EAAN,WAA0BoD,EAAW,KAC3C6G,SAAUpD,EAAmBgf,WAAY,KAAO,IAAS7lB,EAAzD,kBAAsF,MAErFhL,OAAOC,SACPC,KAAK,KACLC,OAEGuzB,EACJze,SAAUpD,EAAmBgf,WAAY,KAAO,OAAS,WAAYpnB,KAAKxN,OAAS,UAAYmS,EACjG,GAAIqlB,EAAU,CACZ,IAAIE,EAAkC9hB,EAAN,IACT,cAAnB6hB,EACFC,GAAcxoB,EAAAA,EAAAA,KAAC2nB,GAAD,CAAcl3B,KAAK,UACL,YAAnB83B,IACTC,GAAcxoB,EAAAA,EAAAA,KAAC2nB,GAAD,CAAcl3B,KAAK,WAEnC43B,GACEroB,EAAAA,EAAAA,KAAAA,OAAAA,CAAMjO,UAAc8N,EAAL,QAAuBlP,MAAO,CAAE8oB,SAA8B,IAAnB9pB,EAA0B,GAApFwD,SACGkd,EAASA,EAAO3J,GAAqB8hB,IAI5C,OACEtlB,EAAAA,EAAAA,MAAAA,OAAAA,EAAAA,EAAAA,GAAAA,CAAKnR,UAAWgO,EAAKpP,MAAOA,GAAWmP,EAAvC,CAAA3M,SAAAA,EACE+P,EAAAA,EAAAA,MAAAA,MAAAA,CAAKxT,QAAQ,cAAcC,MAAK,GAAKA,EAArCwD,SAAAA,EACE6M,EAAAA,EAAAA,KAAAA,OAAAA,CAAMC,IAAK3B,KAAKupB,oBAAoBzpB,KAAKE,KAAM,MAAOvM,UAAc8N,EAAL,SAAwB7P,KAAK,UAC5FgQ,EAAAA,EAAAA,KAAAA,OAAAA,CACEC,IAAK3B,KAAKupB,oBAAoBzpB,KAAKE,KAAM,SACzCmqB,cAAc,QACd12B,UAAc8N,EAAL,UACT7P,KAAK,YAGRq4B,U,EA1EYT,CAAkB7zB,EAAAA,WAAlB6zB,GACL1nB,aAAwC,CACpDL,UAAW,aACXyoB,UAAU,EACV5hB,QAAS,EACT/W,MAAO,IACPI,YAAa,G,sGChBI24B,GAAAA,SAAAA,I,6HAQnB9oB,WACE,IAaIyoB,EAbJ,EACE/pB,KAAKxN,MADC+O,EAAR,EAAQA,UAAWlP,EAAnB,EAAmBA,MAAOoB,EAA1B,EAA0BA,UAAWu2B,EAArC,EAAqCA,SAAU5hB,EAA/C,EAA+CA,QAAS2J,EAAxD,EAAwDA,OAAQtgB,EAAhE,EAAgEA,YAAoBkT,EAApF,EAAoFA,OAAWnD,GAA/F,aAEMC,EAAM,CACVF,EACA9N,EACG8N,EAHO,QAIVyoB,EAAczoB,EAAN,aAA8B,KACtCoD,EAAYpD,EAAN,WAA0BoD,EAAW,KAC3C6G,SAAUpD,EAAmBgf,WAAY,KAAO,IAAS7lB,EAAzD,kBAAsF,MAErFhL,OAAOC,SACPC,KAAK,KACLC,OAEH,GAAIszB,EAAU,CACZ,IAAMC,EACJze,SAAUpD,EAAmBgf,WAAY,KAAO,OAAS,WAAYpnB,KAAKxN,OAAS,UAAYmS,EAC7FulB,EAAkC9hB,EAAN,IACT,cAAnB6hB,EACFC,GAAcxoB,EAAAA,EAAAA,KAAC2nB,GAAD,CAAcl3B,KAAK,iBACL,YAAnB83B,IACTC,GAAcxoB,EAAAA,EAAAA,KAAC2nB,GAAD,CAAcl3B,KAAK,kBAEnC43B,GAAeroB,EAAAA,EAAAA,KAAAA,OAAAA,CAAMjO,UAAc8N,EAAL,QAAf1M,SAAuCkd,EAASA,EAAO3J,GAAqB8hB,IAE7F,IAAMG,EAAe,CACnBh5B,MAAU+W,EAAL,IACL9W,OAAQG,GAEV,OACEmT,EAAAA,EAAAA,MAAAA,OAAAA,EAAAA,EAAAA,GAAAA,CAAKnR,UAAWgO,EAAKpP,MAAOA,GAAWmP,EAAvC,CAAA3M,SAAAA,EACE6M,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,OAAd1M,UACE6M,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,SAAd1M,UACE6M,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,MAAqBlP,MAAOg4B,QAG7CN,U,EA7CYK,CAAgB30B,EAAAA,WAAhB20B,GACLxoB,aAAqC,CACjDL,UAAW,aACXyoB,UAAU,EACV5hB,QAAS,EACT/W,MAAO,IACPI,YAAa,GCRjB,QACE24B,KAAAA,GACAd,OAAAA,I,8HCQa,SAAS5sB,GAAKlK,QAAuB,IAAvBA,IAAAA,EAAmB,IAC9C,MAaIA,EAbJ,IACE+O,UAAAA,OADF,MACc,SADd,MAEEiI,MAAAA,OAFF,MAEU,EAFV,MAGE9W,MAAO43B,OAHT,MAGoB,EAHpB,EAIE72B,EAJF,EAIEA,UACA82B,EALF,EAKEA,UALF,IAMEC,UAAAA,OANF,MAMc,SANd,MAOE1X,SAAAA,OAPF,SAQE1N,EARF,EAQEA,SARF,IASEzS,SAAAA,OATF,MASauL,EATb,MAUEusB,cAAAA,OAVF,MAUkBvsB,EAVlB,EAWE9G,EAXF,EAWEA,MACGqP,GAZL,OAaIjU,EAbJ,IAcA,GAA0B6Q,EAAAA,EAAAA,UAASinB,GAAnC,eAAO53B,EAAP,KAAcg4B,EAAd,KACA,GAAoCrnB,EAAAA,EAAAA,WAAU,GAA9C,eAAOsnB,EAAP,KAAmBC,EAAnB,KACMnpB,EAAM,CAACF,EAAW9N,EAAW2R,EAAW,WAAa,MAAM7O,OAAOC,SAASC,KAAK,KAAKC,OAC3F,GAAkC2M,EAAAA,EAAAA,YAAlC,eAAOwnB,EAAP,KAAkBC,EAAlB,KAeA,SAASC,EAASn4B,EAAkCyU,GAClDzU,EAAE8lB,UACF,IAAI2I,EAAeha,EACb2jB,EACJp4B,EAAEq4B,QAAUr4B,EAAE0c,cAAc5Q,wBAAwBrG,MAAQzF,EAAE0c,cAAc5Q,wBAAwBrN,MAAQ,EAO9G,OANIk5B,GACF33B,EAAE8lB,UACF2I,EAAe2J,EAAS3jB,EAAM,GAAMA,EAAM,GAE1Cga,EAAeha,EAAM,EAEhBga,EAgBT,OAzCIiJ,IAAaO,GACfC,EAAaR,IAGf73B,EAAAA,EAAAA,UAAQ,WACFC,IAAUm4B,GACZH,EAASJ,KAEV,CAACO,KAkCFnpB,EAAAA,EAAAA,KAAAA,OAAAA,EAAAA,EAAAA,GAAAA,GAAS+E,EAAT,CAAgBhT,UAAWgO,EAAKqO,aAAc,WA/B9C8a,GAAe,IA+Bf/1B,UACG,QAAIqc,MAAM1H,IAAQ5V,KAAI,SAACud,EAAGtd,GACzB,IAAMq3B,EACHx4B,GAASmB,EAAM,IAAO2U,KAAKuf,KAAKr1B,GAAS,IAAMmB,IAAuB,IAAhB82B,GAAsBA,IAAe92B,EAAM,GAC9Fs3B,EAAY,CACb5pB,EADa,SAEhB1N,EAAM,GAAKnB,IAAyB,IAAhBi4B,EAAoB,UAAY,KACpD92B,EAAM,GAAK82B,EAAa,WAAa,KACrCO,EAAS,UAAY,MAEpB30B,OAAOC,SACPC,KAAK,KACLC,OACGlE,EAAuB,GAK7B,OAJKsgB,IACHtgB,EAAMgF,QAAW5E,SAAAA,GAAD,OAtBxB,SAAiBA,EAAkCyU,GACjD,IAAIyL,EAAJ,CACA,IAAMuO,EAAe0J,EAASn4B,EAAGyU,GACjCqjB,EAASrJ,GACT1uB,EAAS0uB,IAkBoB7pB,CAAQ5E,EAAGiB,IAClCrB,EAAM44B,YAAex4B,SAAAA,GAAD,OA9B5B,SAAqBA,EAAkCyU,GACrD,IAAMga,EAAe0J,EAASn4B,EAAGyU,GAC7BsjB,IAAetJ,IACjBuJ,EAAcvJ,GACdoJ,EAAcpJ,IA0BiB+J,CAAYx4B,EAAGiB,MAG1C+Q,EAAAA,EAAAA,MAAAA,QAAAA,EAAAA,EAAAA,GAAAA,GAAoBpS,EAApB,CAAAqC,SAAAA,EACE6M,EAAAA,EAAAA,KAAAA,OAAAA,CAAMrP,MAAO,CAAE+E,MAAAA,GAAS3D,UAAW03B,EAAnCt2B,SACG21B,KAEH9oB,EAAAA,EAAAA,KAAAA,OAAAA,CAAMjO,UAAc8N,EAAL,MAAf1M,SAAqC21B,OAJ5B32B,S,iICjFrB,YAAgBrB,QAAyB,IAAzBA,IAAAA,EAAkB,IAChC,MAcIA,EAdJ,IACE+O,UAAAA,OADF,MACc,QADd,EAEE9N,EAFF,EAEEA,UACApB,EAHF,EAGEA,MAHF,IAIEyT,MAAAA,OAJF,MAIU,GAJV,EAKEjR,EALF,EAKEA,SALF,IAME0O,QAAAA,OANF,aAOEnM,MAAAA,OAPF,MAOU,UAPV,MAQEgO,SAAAA,OARF,aASE6S,SAAAA,OATF,SAUEoT,EAVF,EAUEA,SAVF,IAWEx5B,MAAAA,OAXF,SAYEqR,EAZF,EAYEA,QACGuD,GAbL,OAcIjU,EAdJ,IAeMiP,EAAM,CAACF,EAAW9N,EAAW5B,EAAW0P,EAAN,SAA0B,KAAM6D,EAAW,WAAa,MAC7F7O,OAAOC,SACPC,KAAK,KACLC,OACGimB,GAA4B,UAAKtqB,GAWvC,OAVKR,GAIH8qB,EAAKvlB,MAAQA,EACbulB,EAAK2O,YAAcl0B,EACf6gB,GAAYpmB,IACd8qB,EAAK4O,UAAL5O,mBAAoCvlB,KANtCulB,EAAKvlB,MAAQ,OACbulB,EAAK9jB,gBAAkBzB,GAQpBmM,GAKHqB,EAAAA,EAAAA,MAAAA,QAAAA,EAAAA,EAAAA,GAAAA,CAAMnR,UAAWgO,EAAKpP,MAAOsqB,GAAUlW,EAAvC,CAAA5R,SAAAA,CACGiR,GAASjR,EACTw2B,GACC3pB,EAAAA,EAAAA,KAAAA,MAAAA,CAAKlK,QAAS0L,EAASzP,UAAc8N,EAAL,SAAwBlQ,MAAM,KAAKC,OAAO,KAAKF,QAAQ,YAAvFyD,UACE6M,EAAAA,EAAAA,KAAAA,OAAAA,CAAM9P,EAAE,wPAER,SAVC,M,kOCXI,SAAS4J,GAAahJ,GACnC,MAsBIA,EArBFyf,WAAAA,OADF,WAsBIzf,EApBF4S,SAAAA,OAFF,WAsBI5S,EAnBFkT,KAAAA,OAHF,MAGS,UAHT,EAIE8lB,EAkBEh5B,EAlBFg5B,YAJF,EAsBIh5B,EAjBFi5B,OAAAA,OALF,MAKW,GALX,IAsBIj5B,EAhBF8S,QAAAA,OANF,WAsBI9S,EAfFk5B,aAAAA,OAPF,WAsBIl5B,EAdF+O,UAAAA,OARF,MAQc,kBARd,EASE9N,EAaEjB,EAbFiB,UATF,EAsBIjB,EAZFm5B,KAAAA,OAVF,MAUS,SAVT,EAWEt5B,EAWEG,EAXFH,MAEAK,EASEF,EATFE,MACAiB,EAQEnB,EARFmB,aACAi4B,EAOEp5B,EAPFo5B,WAfF,EAsBIp5B,EANFq5B,SAAAA,OAhBF,MAgBa,GAhBb,EAiBEhZ,EAKErgB,EALFqgB,YACAiZ,EAIEt5B,EAJFs5B,SACAn5B,EAGEH,EAHFG,SACAo5B,EAEEv5B,EAFFu5B,SACGhnB,GArBL,OAsBIvS,EAtBJ,IAwBMiP,EAAM,CAACF,EAAW9N,GAAW8C,OAAOC,SAASC,KAAK,KAAKC,OACvDs1B,GAAav5B,EAAAA,EAAAA,UAAQ,iBAAe,aAATk5B,IAAqB,CAACA,IACvD,GAAsCtoB,EAAAA,EAAAA,WAAS,GAA/C,eAAO4oB,EAAP,KAAoBC,EAApB,KACA,GAA0C7oB,EAAAA,EAAAA,UAAwC,IAAlF,eAAO8oB,EAAP,KAAsBC,EAAtB,KACA,GAA0C/oB,EAAAA,EAAAA,UAAS,IAAnD,eAAOgpB,EAAP,KAAsBC,EAAtB,KACA,GAA4CjpB,EAAAA,EAAAA,UAAS,IAArD,eAAOkpB,EAAP,KAAuBC,EAAvB,KACMC,IAAeh6B,EAAAA,EAAAA,UACnB,kBAAO+4B,GAAeW,EAAcrd,OAAS0c,EAAcW,EAAcrd,OAAS0c,EAAc,IAChG,CAACW,EAAcrd,SAEX4d,IAASzqB,EAAAA,EAAAA,QAAuB,MAEhC2W,IAAW3W,EAAAA,EAAAA,UACjB2W,GAASxW,SAAU3P,EAAAA,EAAAA,UAAQ,kBAAM05B,IAAe,CAACA,KAEjDhqB,EAAAA,EAAAA,YAAU,gBACM7K,IAAV5E,QAAwC4E,IAAjB3D,GACzBg5B,GAAoBh5B,KAErB,KAEHwO,EAAAA,EAAAA,YAAU,gBACM7K,IAAV5E,GACFi6B,GAAoBj6B,KAErB,CAACuoB,KAAKC,UAAUxoB,KAEnB,IAAMk6B,GAAkB,SAACnB,EAAuC/4B,GAC9D,IAAMm6B,EAAapB,EAAOl3B,MAAMC,SAAAA,GAAD,OAAUA,EAAK9B,QAAUA,KACxD,OAAOm6B,GAGT,SAASF,GACP7R,GAEA,IAAIgS,EAAsC,GAE1C,GAAIpB,EACExa,MAAM4H,QAAQgC,GAChBgS,EAAOhS,EAEPgS,EAAK5d,KAAK4L,QAGZ,GAAI5J,MAAM4H,QAAQgC,GAChBgS,EAAOhS,EAAYlnB,KAAKm5B,SAAAA,GAAD,OAAOH,GAAgBnB,EAAQsB,MAAkBx2B,QAAQy2B,SAAAA,GAAD,QAASA,SACnF,CACL,IAAMH,EAAaD,GAAgBnB,EAAQ3Q,GACvC+R,IACFP,EAAiBO,EAAWxV,OAC5ByV,EAAK5d,KAAK2d,IAIhBT,EAAiBU,GAkBnB,SAASG,GAAiBvvB,EAAelJ,GACvC,IAAIg0B,GAA8C,IAAX9qB,EAhBzC,SAA0BA,GACxB,IAAMyuB,EAAgBvT,GAASxW,QAG/B,OAFA+pB,EAAcnS,OAAOtc,EAAO,IACb,QAAIyuB,GAamCe,CAAiBxvB,GAAhCA,GAAAA,QAAAA,EAAAA,GAAAA,GAA6CyuB,GAA7CzuB,CAA4DlJ,IAC7F24B,EAAc3E,EAAO50B,KAAKY,SAAAA,GAAD,OAAUA,EAAK9B,SAC9CkoB,GAAauS,EAAa3E,GAG5B,SAAS5N,GAAauS,EAA2C3E,GAC/DuD,GAAYA,EAASoB,GACrBC,GAAmBD,EAAa3E,QAEtBlxB,IAAV5E,GAAuB05B,EAAiB5D,GAI1C,SAAS6E,GAAiBl7B,GACxB,IAAIo6B,EACS,UAATp6B,GAAoB8f,GAAcka,GACpCmB,QAAQC,IAAI,KACZhB,EAAiB,SAEjBA,EAAiB,GAEnBC,EAAkBD,GAGpB,SAASiB,GAAkB56B,GACzB,IAAMF,EAAQE,EAAEC,OAAOH,MACvBw5B,IAAiBx5B,GACjB45B,EAAiB55B,GACjB85B,EAAkBZ,GAAcl5B,EAAQ,UAAY,IACpDk5B,GAAcE,GAAYA,EAASp5B,GAIrC,SAAS+6B,KACPvB,GAAe,GACfE,EAAiB,IACjBE,EAAiB,IACjBE,EAAkB,IAClBY,GAAmB,GAAI,IAEzB,SAASA,GAAmB16B,EAAqCma,GAC1Dla,GAELA,EAAS+4B,EAAe7e,EAAUna,GASpC,OACEgP,EAAAA,EAAAA,KAAC3G,IAAD,QACEtH,UAAWgO,EACXsL,QAAQ,QACR1a,MAAO,CAAEq7B,UAAW,GACpBtoB,WAAUqmB,GAAUA,EAAO3c,OAAS,IAChC/J,EALN,CAME8I,gBAAkB0Y,SAAAA,IACXA,GAAQyF,GAAYM,EAAiB,IAC1CJ,EAAe3F,IAEjBhkB,OAAQ0pB,EACR33B,MACEoN,EAAAA,EAAAA,KAACpE,GAAD,CACE2a,UAAQ,EACR5lB,MAAO,CACLs7B,UAAW,GACXC,UAAW,IACXxnB,SAAU,IACVynB,UAAW,SACXx8B,MAAOq7B,GAAOtqB,QAAUsqB,GAAOtqB,QAAQ8J,YAAc,QAPzDrX,SAUI42B,GAA4B,IAAlBA,EAAO3c,OAGjB2c,EAAO73B,KAAKY,SAAAA,GACV,IAAMkJ,EAAQyuB,EAAc2B,WAAWC,SAAAA,GAAD,OAAWA,EAAMr7B,QAAU8B,EAAK9B,SACtE,OACEgP,EAAAA,EAAAA,KAACpE,GAAAA,KAAD,CACE+H,QAAmB,IAAX3H,EAERsJ,KAAMxS,EAAK6iB,MACX7f,QAAS,kBAAOw0B,EAAaiB,GAAiBvvB,EAAOlJ,GA9FrE,SAAyBA,GACvB03B,GAAe,GACf,IAAM1D,EAAS,CAACh0B,GAChB83B,EAAiB93B,EAAK6iB,OAEtBuD,GADoBpmB,EAAK9B,MACC81B,GAyFiDwF,CAAgBx5B,KAFxEkJ,OAPXgE,EAAAA,EAAAA,KAAAA,MAAAA,CAAKrP,MAAO,CAAE+E,MAAO,UAAW+jB,SAAU,IAA1CtmB,SAAiDyQ,EAAU,0CAAc,+BAvBjFzQ,UAwCE6M,EAAAA,EAAAA,KAAAA,MAAAA,CACEC,IAAK+qB,GACL/c,YAAa,kBAAM0d,GAAiB,UACpCvd,aAAc,kBAAMud,GAAiB,UACrCh7B,OAAK,QAAIhB,MAAO,OAAQ8U,SAAU,QAAW9T,GAJ/CwC,SAMGm3B,GACCpnB,EAAAA,EAAAA,MAAAA,MAAAA,CAAKnR,UAAc8N,EAAL,SAAd1M,SAAAA,EACE+P,EAAAA,EAAAA,MAAAA,MAAAA,CAAKvS,MAAO,CAAE4F,QAAS,OAAQg2B,SAAU,QAAzCp5B,SAAAA,CACGm3B,GACCG,EAAc1M,MAAM,EAAG+L,GAAa53B,KAAI,SAACY,EAAMkJ,GAC7C,OACEgE,EAAAA,EAAAA,KAACrF,IAAD,QACEhK,OAAK,QAAIf,OAAQ,GAAI8pB,OAAQ,EAAGnjB,QAAS,OAAQC,WAAY,UAAa2zB,EAASx5B,OACnFoB,UAAc8N,EAAL,OAETnK,MAAM,WACFy0B,EALN,CAMER,UAAQ,EACRnoB,QAAS,kBAAM+pB,GAAiBvvB,EAAOlJ,IAPzCK,SASGL,EAAK6iB,QAND3Z,QAUV+uB,KACD7nB,EAAAA,EAAAA,MAACvI,GAAD,CAAKhK,MAAO,CAAEf,OAAQ,GAAI8pB,OAAQ,EAAGnjB,QAAS,OAAQC,WAAY,UAAYkN,UAAU,EAAxFvQ,SAAAA,CAAAA,IACI43B,GADJ,UACoB,QAGtB/qB,EAAAA,EAAAA,KAACtG,GAAD,CACE/I,MAAO,CAAE67B,KAAM,GACfz6B,UAAc8N,EAAL,kBACTuR,UAAW8Y,EACXlmB,KAAMA,EACNN,SAAUA,EACV8jB,UAnFd,SAAsBt2B,GAChBo5B,GAAcG,EAAcrd,OAAS,IAAMud,GAA+B,IAAdz5B,EAAEu7B,SAChElB,GAAiBd,EAAcrd,OAAS,IAkF9Bnc,SAAU66B,GACV96B,MAAO25B,EACPxZ,YAAasZ,EAAcrd,OAAS,GAAK+D,QAGxB,UAAnB0Z,GAAkD,YAAnBA,GAAgCjnB,KAC/D5D,EAAAA,EAAAA,KAAChH,EAAD,CAAMvI,KAAMo6B,EAAgBn6B,KAAMkT,GAA8B,YAAnBinB,EAA8B/0B,QAASi2B,SAIxF/rB,EAAAA,EAAAA,KAACtG,GAAD,CACE0X,UAAW8Y,EACXlmB,KAAMA,EACNN,SAAUA,EACVzS,SAAU66B,GACV96B,MAAO25B,EACPxZ,YAAaA,EACb1C,YACsB,UAAnBoc,GAAkD,YAAnBA,GAAgCjnB,KAC9D5D,EAAAA,EAAAA,KAAChH,EAAD,CACEvI,KAAMo6B,EACNn6B,KAAMkT,GAA8B,YAAnBinB,EACjB/0B,QAASi2B,Y,sPChR3B,SAASW,GAAiB57B,GACxB,MAUIA,EATF+O,UAAAA,OADF,MACc,UADd,IAUI/O,EARFH,MAAAA,OAFF,MAEU,GAFV,EAIEwC,EAMErC,EANFqC,SACAuN,EAKE5P,EALF4P,QALF,EAUI5P,EAJFmS,OAAAA,OANF,MAMW,UANX,IAUInS,EAHF67B,YAAAA,OAPF,WAUI77B,EAFF87B,UAAAA,OARF,MAQc,aARd,EASK9sB,GATL,OAUIhP,EAVJ,IAYM+7B,GAAUtsB,EAAAA,EAAAA,QAAuB,MACvC,GAAsDoB,EAAAA,EAAAA,UAAS,GAA/D,eAAOmrB,EAAP,KAA4BC,EAA5B,KACMC,EAAmBj5B,EAAAA,SAAAA,QAAuBZ,GAAU0B,QAAQo4B,SAAAA,GAAD,QAASA,KACpEC,EAAYF,EAAiB5f,OAAS,EACtCkV,EAAc,CAACziB,EAAcA,EAAf,IAA4B+sB,EAAeD,EAAiB9sB,EAAnB,OAAqC,MAC/FhL,OAAOC,SACPC,KAAK,KACLC,OAgBH,OAdAyL,EAAAA,EAAAA,YAAU,kBAGV,WACE,IAAM0sB,EAAUN,EAAQnsB,QACxB,GAAIysB,GAAWA,EAAQC,UAAW,CAChC,IAAMz9B,GAAUw9B,EAAQC,UAA0B5iB,aAAe,GAAK,EACtE,GAAI7a,IAAUm9B,GAAuBhmB,KAAKumB,IAAI19B,EAAQm9B,IAAwB,EAC5E,OAEFC,EAAuBp9B,IAVX29B,OAedttB,EAAAA,EAAAA,KAAAA,OAAAA,EAAAA,EAAAA,GAAAA,CAAKjO,UAAWuwB,EAAa3xB,MAAOA,GAAWmP,EAA/C,CAA2DG,IAAK4sB,EAAhE15B,SACGY,EAAAA,SAAAA,IAAmBZ,GAAU,SAAC8Q,EAAYjI,GACzC,IAAMoc,GAAa,QACjBmV,WAAY,IAAGvxB,EAAQ,GACvB6D,UAAAA,EACA8sB,YAAAA,GACG1oB,EAAMnT,OAwBX,OAtBIkL,IAAUkxB,GAA2B,aAAdN,IACzBxU,EAAWoV,UAAe,IAAMN,EAAhC,IACA9U,EAAWqV,mBAAqB3mB,KAAKC,MAAM+lB,EAAsBI,EAAY,IAG3EP,GAA6B,aAAdC,IACjBxU,EAAWoV,UAAe,IAAMR,EAAiB5f,OAAjD,IACAgL,EAAWqV,kBAAoB,GAGlB,UAAXxqB,GAAsBjH,IAAW0E,EAAqB,IACxD0X,EAAWrmB,UAAe8N,EAA1B,eAEGoE,EAAMnT,MAAMmS,SAEbmV,EAAWnV,OADTjH,IAAU0E,EACQuC,EACXjH,EAAS0E,EACE,SAEA,QAGjB3M,EAAAA,aAAmBkQ,EAAOmU,SAUxCsU,GAAwBgB,KC3EV,SAAc58B,GAC3B,MAaIA,EAZF+O,UAAAA,OADF,MACc,UADd,EAEE9N,EAWEjB,EAXFiB,UACApB,EAUEG,EAVFH,MACAsS,EASEnS,EATFmS,OACAuqB,EAQE18B,EARF08B,UACAn6B,EAOEvC,EAPFuC,KACAo6B,EAME38B,EANF28B,kBACAF,EAKEz8B,EALFy8B,WACAnpB,EAIEtT,EAJFsT,MACAkX,EAGExqB,EAHFwqB,YACAqR,EAEE77B,EAFF67B,YACG7R,GAZL,OAaIhqB,EAbJ,IAcMwxB,EAAc,CACfziB,EADe,QAEfA,EAFe,SAEGoD,EACrBlR,EACAsB,EAAUwM,EAAN,UAA2B,MAE9BhL,OAAOC,SACPC,KAAK,KACLC,OACG24B,GAA+B,UAAKh9B,GACpCi9B,EAAkC,GACpCJ,IACFG,EAAch+B,MAAQ69B,GAEpBC,IACFE,EAAcE,YAAcJ,EACxBd,IACFiB,EAAiB/e,aAAe/H,KAAKumB,IAAII,KAG7C,IAAIK,EAAW,KAuBf,OArBEA,EADEnB,GACS3sB,EAAAA,EAAAA,KAAAA,OAAAA,CAAMjO,UAAc8N,EAAL,SACjBxM,GAAwB,kBAATA,GACb2M,EAAAA,EAAAA,KAAAA,OAAAA,CAAMjO,UAAc8N,EAAL,QAAf1M,SAAuCE,IACxCA,GAAwB,kBAATA,GAAiC,WAAX4P,GAAkC,UAAXA,GAEpEjD,EAAAA,EAAAA,KAAChH,EAAD,CACEvI,KACE,CACE4C,GAAwB,kBAATA,EAAfA,GAAsCA,EAAS,KAC9CA,GAAmB,WAAX4P,EAAgC,KAAV,QAC9B5P,GAAmB,UAAX4P,EAA+B,KAAV,SAE7BpO,OAAOC,SACPC,KAAK,KACLC,UAKEgL,EAAAA,EAAAA,KAAAA,OAAAA,CAAMjO,UAAc8N,EAAL,QAAf1M,SAAuCo6B,KAGlDrqB,EAAAA,EAAAA,MAAAA,OAAAA,EAAAA,EAAAA,GAAAA,GAAS4X,EAAT,CAAoB/oB,UAAWuwB,EAAa3xB,MAAOg9B,EAAnDx6B,SAAAA,EACE6M,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,aAA4BlP,MAAOi9B,EAAjDz6B,UACE6M,EAAAA,EAAAA,KAAAA,IAAAA,CAAGrP,MAAO,CAAEke,aAAc,aAE5B7O,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,aAAd1M,UACE6M,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAW,CAAI8N,EAAJ,gBAA8BxM,GAAQ,WAAWwB,OAAOC,SAASC,KAAK,KAAKC,OAA3F7B,SACG26B,OAGL5qB,EAAAA,EAAAA,MAAAA,MAAAA,CAAKnR,UAAc8N,EAAL,aAAd1M,SAAAA,EACE6M,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,cAAd1M,SAA4CiR,IAC3CkX,IAAetb,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,oBAAd1M,SAAkDmoB,YDO1E,IExFA,GFwFA,GG/Ee,SAASyS,GAAKj9B,GAC3B,IAAQ+O,EAA4D/O,EAA5D+O,UAAWjO,EAAiDd,EAAjDc,KAAMwV,EAA2CtW,EAA3CsW,KAAMggB,EAAqCt2B,EAArCs2B,IAAK/e,EAAgCvX,EAAhCuX,SAAU2lB,EAAsBl9B,EAAtBk9B,MAAOC,EAAen9B,EAAfm9B,WACrD,OACEjuB,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,QAAd1M,SACGvB,EAAKM,KAAI,SAAColB,EAAKnlB,GACd,IAAM+7B,EAAY/7B,EAAMiV,EAAOggB,EAC/B,OACElkB,EAAAA,EAAAA,MAAAA,MAAAA,CAEEvS,OAAK,WACF0X,EAAW,MAAQ,OAAYiP,EAAhC,KAEFvlB,UAAW,CAAI8N,EAAJ,QAAsBmuB,IAAmB,IAAVA,IAAmBA,EAAME,GAAa,WAAa,MAC1Fr5B,OAAOC,SACPC,KAAK,KACLC,OARL7B,SAAAA,EAUa,IAAV66B,GAAkBC,GAAcA,EAAWC,IACjC,IAAVF,GAAkBA,GAASA,EAAME,IAAcD,GAAcA,EAAWC,EAAWF,EAAME,MAVrF/7B,Q,+ICKF,SAAS8H,GAAOnJ,GAAoB,MACjD,EAgBIA,EAfF+O,UAAAA,OADF,MACc,WADd,IAgBI/O,EAdFE,MAAAA,OAFF,MAEU,EAFV,IAgBIF,EAbFs2B,IAAAA,OAHF,MAGQ,EAHR,IAgBIt2B,EAZF6W,IAAAA,OAJF,MAIQ,IAJR,IAgBI7W,EAXFq9B,KAAAA,OALF,WAgBIr9B,EAVFsW,KAAAA,OANF,MAMS,EANT,IAgBItW,EATF4S,SAAAA,OAPF,WAgBI5S,EARFs9B,SAAAA,OARF,WAgBIt9B,EAPFu9B,QAAAA,OATF,SAUEt8B,EAMEjB,EANFiB,UACAi8B,EAKEl9B,EALFk9B,MACAM,EAIEx9B,EAJFw9B,YACAjmB,EAGEvX,EAHFuX,SACApX,EAEEH,EAFFG,SACG8T,GAfL,OAgBIjU,EAhBJ,IAkBMy9B,EAAMx6B,EAAAA,OAA6B,MACnCy6B,EAASz6B,EAAAA,OAA6B,MACtC06B,EAAW16B,EAAAA,SACX26B,EAAS36B,EAAAA,SACT46B,EAAW56B,EAAAA,SACX66B,EAAW76B,EAAAA,SACX86B,EAAgB96B,EAAAA,SAChB+6B,EAAO/6B,EAAAA,SACb,GAAgC4N,EAAAA,EAAAA,UAAS6N,MAAM4H,QAAQpmB,GAASA,EAAQ,CAACA,IAAzE,eAAO+9B,EAAP,KAAiBC,EAAjB,KAiDA,SAAS9V,EAAa5B,GACpB0X,GAAY,QAAI1X,IAChBrmB,GAAYA,EAA6B,IAApB89B,EAAS3hB,OAAekK,EAAI,GAAKA,GAGxD,SAAS2X,EAAgBt/B,GACvB,IAAMu/B,GAASvnB,EAAMyf,GAAOhgB,EACxBV,EAAU,EACV8nB,EAAO9tB,UACTgG,EAAW/W,EAAQ6+B,EAAO9tB,QAAQ2H,EAAW,eAAiB,eAAkB,KAG9E3B,GAAW,IACbA,EAAU,GAERA,GAAW,MACbA,EAAU,KAGZ,IAAM4I,EAAM4f,GAASxoB,EAAU,KAAO,GAGtC,OAFiBI,KAAKqoB,MAAM7f,GACJlI,EAAOggB,EAyBjC,SAASgI,EAAWxO,GAClB,GAAKkO,EAAKpuB,QAAV,CAGA,IAAM2uB,GAAO,QAAIN,GACXO,EAAeL,EAAgBrO,EAAIvY,EAAW,UAAY,WAAaqmB,EAAOhuB,QAAWkuB,EAASluB,SACxG,GAAI4uB,IAAiBX,EAASjuB,QAAS,CACrC2uB,EAAKZ,EAAS/tB,SAAY4uB,EAC1B,IAAMC,EAAUrkB,EAASmkB,GACrBd,EAAI7tB,UACN6tB,EAAI7tB,QAAQ/P,MAAM0X,EAAW,MAAQ,QAAUknB,EAAQ54B,KACvD43B,EAAI7tB,QAAQ/P,MAAM0X,EAAW,SAAW,SAAWknB,EAAQvlB,OAE7DkP,EAAamW,GACbV,EAASjuB,QAAU4uB,IAGvB,SAASE,IACPV,EAAKpuB,aAAU9K,EACftE,OAAOqO,oBAAoB,YAAayvB,GAAY,GACpD99B,OAAOqO,oBAAoB,UAAW6vB,GAAW,IAjHnD/uB,EAAAA,EAAAA,YAAU,kBAAMuuB,EAAYxf,MAAM4H,QAAQpmB,GAASA,EAAQ,CAACA,MAAS,CAACA,IAEtE+T,EAAMjP,QAAWqQ,SAAAA,GACf,QAAqBvQ,IAAjBk5B,EAAKpuB,QAAT,CAGA,IAAM+uB,EAAajB,EAAO9tB,QAAS1D,wBAGnCkc,EAGF,SAAuB5B,GACrB,IAAK9H,MAAM4H,QAAQpmB,GACjB,OAAOwe,MAAM4H,QAAQE,GAAOA,EAAM,CAACA,GAErC,IAAMoY,GAAU,QAAIX,GACdY,EAAOD,EAAQ,GACfE,EAAOF,EAAQ,IAChBC,EAAOC,GAAQD,EAAOrY,GAASqY,EAAOC,GAAQD,EAAOrY,KACxDoY,EAAQ,GAAKpY,IAEVqY,EAAOC,GAAQA,EAAOtY,GAASqY,EAAOC,GAAQA,EAAOtY,KACxDoY,EAAQ,GAAKpY,GAGf,GAAIqY,EAAOrY,GAAOsY,EAAOtY,EAAK,CAC5B,IAAMuY,EAAOD,GAAQD,EAAOC,GAAQ,EAChCC,GAAQvY,IACVoY,EAAQ,GAAKpY,GAEXuY,EAAOvY,IACToY,EAAQ,GAAKpY,GAGjB,GAAIsY,EAAOtY,GAAOqY,EAAOrY,EAAK,CAC5B,IAAMuY,EAAOF,GAAQC,EAAOD,GAAQ,EAChCE,GAAQvY,IACVoY,EAAQ,GAAKpY,GAEXuY,EAAOvY,IACToY,EAAQ,GAAKpY,GAGjB,OAAOoY,EApCMI,CADAb,EAAgB9oB,EAAIkC,EAAW,UAAY,WAAaonB,EAAWpnB,EAAW,IAAM,UAuHnG,SAAS0nB,EAAkBV,GACzB,OAAuB,KAAdA,EAAOjI,IAAezf,EAAMyf,GAGvC,SAASlc,EAASoM,GAChBA,EAAMA,GAAOyX,EACb,IAAMQ,EAAU,CAAE54B,KAAM,KAAMqT,MAAO,QACrC,GAAKwF,MAAM4H,QAAQpmB,GAEZ,CACL,IAAMg/B,EAAY1Y,EAAI,GAAKA,EAAI,GAAKA,EAAI,GAAKA,EAAI,GAC3C2Y,EAAa3Y,EAAI,GAAKA,EAAI,GAAKA,EAAI,GAAKA,EAAI,GAClDiY,EAAQ54B,KAAUo5B,EAAkBC,GAApC,IACAT,EAAQvlB,MAAW,IAAM+lB,EAAkBE,GAA3C,SALAV,EAAQvlB,MAAW,IAAM+lB,EAAkBzY,EAAI,IAA/C,IAOF,OAAOiY,EAGT,SAASW,EAAc5Y,GACrB,OAAI0W,IAAmB,IAAVA,GAAkBA,EAAM1W,IAAQ0W,EAAM1W,GAAK3B,MAC/CqY,EAAM1W,GAAK3B,MACTqY,IAAmB,IAAVA,GAAkBA,EAAM1W,IAA8B,kBAAf0W,EAAM1W,GACxD0W,EAAM1W,GACJgX,GAAsC,oBAAhBA,GAA8BA,EAAYhX,GAClEgX,EAAYhX,GAEdA,EAGT,IAAMiY,EAAUrkB,IAIhB,OAHIxH,UACKqB,EAAMjP,SAGboN,EAAAA,EAAAA,MAAAA,OAAAA,EAAAA,EAAAA,GAAAA,CACEjD,IAAKuuB,EACLz8B,UAAW,CACT8N,EACA9N,EACA2R,EAAW,WAAa,KACxBsqB,EAAWnuB,EAAN,cAA+B,KACpCwI,EAAcxI,EAAN,YAA6B,MAEpChL,OAAOC,SACPC,KAAK,KACLC,QACC+P,EAZN,CAAA5R,SAAAA,EAcE6M,EAAAA,EAAAA,KAAAA,MAAAA,CACEC,IAAKsuB,EACLx8B,UAAc8N,EAAL,OACTlP,OAAK,wBACF0X,EAAW,MAAQ,OAASknB,EAAQ54B,OADlC,UAEF0R,EAAW,SAAW,QAAUknB,EAAQvlB,OAFtC,IAGc,IAAbokB,EAAoB,CAAEj3B,gBAAiBi3B,GAAY,WAAc,OAGxE,QAAIW,GAAU78B,KAAI,SAACY,EAAMX,GACxB,IAAMg+B,EAAeJ,EAAkBj9B,GACvC,OACEkN,EAAAA,EAAAA,KAAAA,MAAAA,CAEEjO,UAAc8N,EAAL,UACT0C,YAAc4D,SAAAA,GAAD,OArHvB,SAAyBhU,EAAayuB,GACpC,IAAIld,EAAJ,CAGA+qB,EAAS/tB,QAAUvO,EACnB28B,EAAKpuB,SAAU,EACfguB,EAAOhuB,QAAUkgB,EAAIvY,EAAW,UAAY,WACxCkmB,EAAI7tB,UACNkuB,EAASluB,QAAU6tB,EAAI7tB,QAAQ2H,EAAW,eAAiB,eAC3DwmB,EAAcnuB,QAAU6tB,EAAI7tB,QAAQ2H,EAAW,YAAc,eAE/D,IAAMgnB,GAAO,QAAIN,GACbvf,MAAM4H,QAAQpmB,KAChB49B,EAASluB,QACe,IAArB+tB,EAAS/tB,SAAiB2uB,EAAK,GAAKA,EAAK,IAA6B,IAArBZ,EAAS/tB,SAAiB2uB,EAAK,GAAKA,EAAK,GACvFT,EAASluB,QAAWmuB,EAAcnuB,QAClCmuB,EAAcnuB,SAEtBpP,OAAOmO,iBAAiB,YAAa2vB,GACrC99B,OAAOmO,iBAAiB,UAAW+vB,IAkGLY,CAAgBj+B,EAAKgU,IAC3CxV,OAAK,WAAK0X,EAAW,MAAQ,OAAY8nB,EAAhC,KAJXh9B,UAMIk7B,IAAuB,IAAZA,KACXruB,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAW,CAAI8N,EAAJ,WAAyBwuB,EAAU,OAAS,MAAMx5B,OAAOC,SAASC,KAAK,KAAKC,OAA5F7B,SACG+8B,EAAcp9B,MAPdX,MAaVg8B,IACCnuB,EAAAA,EAAAA,KAAC+tB,GAAD,CACEluB,UAAWA,EACXunB,IAAKA,EACLhgB,KAAMA,EACN4mB,MAAOA,EACP3lB,WAAYA,EACZzW,KA3FU,WAIhB,IAHA,IAAMs9B,GAASvnB,EAAMyf,GAAOhgB,EACtBipB,EAAa,IAAMjpB,GAASO,EAAMyf,GAClCld,EAAS,CAAC,GACP1G,EAAI,EAAGA,EAAI0rB,EAAO1rB,GAAK,EAC9B0G,EAAOsD,KAAKhK,EAAI6sB,GAGlB,OADAnmB,EAAOsD,KAAK,KACLtD,EAmFKomB,GACNrC,WAAY,SAACC,EAAWqC,GACtB,QADoC,IAAdA,IAAAA,EAAO,KACxBA,EACH,OAAOrtB,EAAAA,EAAAA,MAAAA,MAAAA,CAAA/P,SAAAA,CAAAA,IAAO+8B,EAAchC,GAArB,OAET,IAAMnpB,EAAwB,kBAATwrB,EAAoBA,EAAO,GAEhD,cADOxrB,EAAM4Q,OACNzS,EAAAA,EAAAA,MAAAA,OAAAA,EAAAA,EAAAA,GAAAA,GAAS6B,EAAT,CAAA5R,SAAAA,CAAAA,IAAkB+8B,EAAchC,GAAhC,e,qBCxQnB,GAAen6B,EAAAA,YAAgD,SAACjD,EAAOmP,GACrE,MAA6CnP,EAArC+O,UAAAA,OAAR,MAAoB,WAApB,EAAmCkF,GAAnC,OAA6CjU,EAA7C,IACA,OAAOkP,EAAAA,EAAAA,KAAC0W,IAAD,QAAe7W,UAAWA,IAA1B,UAA8CkF,EAA9C,CAAqDtU,KAAM,aAA3D,CAAyEwP,IAAKA,Q,mGCEvF,YAAgBnP,QAA2E,IAA3EA,IAAAA,EAAoE,IAClF,MAAqFA,EAArF,IAAQ+O,UAAAA,OAAR,MAAoB,UAApB,EAA+B9N,EAA/B,EAA+BA,UAA/B,IAA0CH,KAAAA,OAA1C,MAAiD,GAAjD,MAAqD4+B,WAAAA,OAArD,MAAkEh0B,EAAlE,EAA2EuI,GAA3E,OAAqFjU,EAArF,IACA,OACEkP,EAAAA,EAAAA,KAAAA,SAAAA,EAAAA,EAAAA,GAAAA,CAAOjO,UAAW,CAAC8N,EAAW9N,GAAW8C,OAAOC,SAASC,KAAK,KAAKC,QAAY+P,EAA/E,CAAA5R,SACGvB,GACCA,EAAKwb,OAAS,GACdxb,EAAKM,KAAI,SAACu+B,EAAsBC,GAAvB,OACP1wB,EAAAA,EAAAA,KAAAA,KAAAA,CAAA7M,UACIs9B,GAAO,IAAIv+B,KAAI,SAACY,EAAM69B,GACtB,IAAQvsB,EAAuDtR,EAAvDsR,MAA8BwsB,EAAyB99B,EAAzB89B,SAAaC,GAAnD,OAA+D/9B,EAA/D,IACMg+B,EACa,oBAAV1sB,EAAuBA,EAAMtR,EAAM69B,EAAQD,GAAWtsB,EAC/D,OAAwB,IAApBysB,EAAQ/W,QACH,MAEL8W,IACFC,EAAQ9+B,WAAe8+B,EAAQ9+B,WAAa,IAA5C,IAAkD8N,EAAlD,cAGAG,EAAAA,EAAAA,KAAAA,MAAAA,EAAAA,EAAAA,GAAAA,CAAiBlK,QAAUqQ,SAAAA,GAAD,OAASqqB,EAAW19B,EAAM69B,EAAQD,EAASvqB,KAAU0qB,EAA/E,CAAA19B,SACG29B,IADMH,QAZND,UCXnB,SAASK,GAAcn/B,EAA2B0d,QAAS,IAApC1d,IAAAA,EAAuB,SAAa,IAAT0d,IAAAA,EAAM,GAEtD,IADA,IAAI6H,EAAyB,GACpB3T,EAAI,EAAGA,EAAI5R,EAAKwb,OAAQ5J,GAAK,EAChC5R,EAAK4R,GAAGrQ,WACVgkB,EAASA,EAAO6Z,OAAOp/B,EAAK4R,GAAGrQ,UAAY,KAM/C,OAHIgkB,GAAUA,EAAO/J,OAAS,IAC5BkC,EAAMyhB,GAAc5Z,EAAQ7H,EAAM,IAE7BA,EAOT,SAAS2hB,GAAcr/B,EAA2BqS,QAAY,IAAvCrS,IAAAA,EAAuB,SAAgB,IAAZqS,IAAAA,EAAQ,IAExD,IADA,IAAIkT,EAAyB,GACpB3T,EAAI,EAAGA,EAAI5R,EAAKwb,OAAQ5J,GAAK,EAC/B5R,EAAK4R,GAAGrQ,SAEFvB,EAAK4R,GAAGrQ,UAAYvB,EAAK4R,GAAGrQ,SAAUia,OAAS,IACxD+J,EAASA,EAAO6Z,OAAOC,GAAcr/B,EAAK4R,GAAGrQ,SAAU8Q,KAFvDkT,EAAO3J,KAAK5b,EAAK4R,IAKrB,OAAO2T,EAeF,IAAM+Z,GAAgB,SAAhBA,EAAiBt/B,EAAsBsY,GAC7CA,IACHA,EAAS,CAAEsO,OAAQ,GAAI5Y,OAAQ,KAE7BsK,IAAWA,EAAOsO,SACpBtO,EAAOsO,OAAS,IAEdtO,IAAWA,EAAOtK,SACpBsK,EAAOtK,OAAS,IAIlB,IAFA,IAAIqE,EAAwB,GACtBktB,EAA2B,GACxB3tB,EAAI,EAAGA,EAAI5R,EAAKwb,OAAQ5J,GAAK,EAChC5R,EAAK4R,GAAG5D,QAAUhO,EAAK4R,GAAGmC,MAC5BuE,EAAOtK,OAAOhO,EAAK4R,GAAGmC,KAAiB/T,EAAK4R,GAAG5D,QAE7ChO,EAAK4R,GAAGotB,UAAYh/B,EAAK4R,GAAGmC,MACzBuE,EAAO0mB,WAAU1mB,EAAO0mB,SAAW,IACxC1mB,EAAO0mB,SAASh/B,EAAK4R,GAAGmC,MAAQ,GAEL,IAAzBuE,EAAOsO,OAAOpL,SAEZxb,EAAK4R,GAAGrQ,UAAYvB,EAAK4R,GAAGrQ,UAAYvB,EAAK4R,GAAGrQ,SAAUia,OAAS,IACrExb,EAAK4R,GAAGsW,QAAUmX,GAAcr/B,EAAK4R,GAAGrQ,UAA4Bia,QAEtE+jB,EAAS3jB,KAAK5b,EAAK4R,KAEjB5R,EAAK4R,IAAM5R,EAAK4R,GAAGrQ,WACrB8Q,EAAQA,EAAM+sB,OACZp/B,EAAK4R,GAAGrQ,SAAUjB,KAAKY,SAAAA,GAKrB,OAHIA,EAAKK,UAAYL,EAAKK,SAASia,OAAS,IAC1Cta,EAAKgnB,QAAUmX,GAAcn+B,EAAKK,UAAUia,QAEvCta,OAMf,GAA6B,IAAzBoX,EAAOsO,OAAOpL,OAAc,CAC9B,IAAMkC,EAAMyhB,GAAcI,GAC1BjnB,EAAOsO,OAAOhL,KACZ2jB,EAASj/B,KAAKY,SAAAA,GACZ,OAAY,IAARwc,KACCxc,EAAKK,UAAaL,EAAKK,UAAqC,IAAzBL,EAAKK,SAASia,UACpDta,EAAKs+B,QAAU9hB,GAFKxc,MAQ5B,GAAImR,GAASA,EAAMmJ,OAAS,EAAG,CAC7B,IAAMkC,EAAMyhB,GAAc9sB,GAC1BiG,EAAOsO,OAAOhL,KACZvJ,EAAM/R,KAAKY,SAAAA,GACT,OAAY,IAARwc,KACCxc,EAAKK,UAAaL,EAAKK,UAAqC,IAAzBL,EAAKK,SAASia,UACpDta,EAAKs+B,QAAU9hB,GAFKxc,MAO1BoX,EAASgnB,EAAcjtB,EAAOiG,GAEhC,OAAOA,GAOImnB,GAAoB,SAApBA,EAAqBz/B,EAAsBuD,QAA+B,IAA/BA,IAAAA,EAAc,IACpE,IAAK,IAAIqO,EAAI,EAAGA,EAAI5R,EAAKwb,OAAQ5J,GAAK,EAChC5R,EAAK4R,GAAGrQ,SACVgC,EAAOA,EAAK67B,OAAOK,EAAkBz/B,EAAK4R,GAAGrQ,UAAY,KAChDvB,EAAK4R,GAAGmC,KACjBxQ,EAAKqY,KAAK5b,EAAK4R,GAAGmC,KAGtB,OAAOxQ,G,mHC5ET,YAAgBrE,QAA2B,IAA3BA,IAAAA,EAAoB,IAClC,MAaIA,EAbJ,IACE+O,UAAAA,OADF,MACc,UADd,EAEE9N,EAFF,EAEEA,UAFF,IAGEyoB,QAAAA,OAHF,MAGY,GAHZ,MAIE5oB,KAAAA,OAJF,MAIS,GAJT,EAKEwS,EALF,EAKEA,MACAkS,EANF,EAMEA,OACAC,EAPF,EAOEA,SAPF,IAQE+a,OAAAA,OARF,MAQW90B,EARX,MASEg0B,WAAAA,OATF,MASeh0B,EATf,EAUE+0B,EAVF,EAUEA,MAEGxsB,GAZL,OAaIjU,EAbJ,IAeMiP,EAAM,CAACF,EAAW9N,EAAWwkB,EAAc1W,EAAN,YAA6B,MAAMhL,OAAOC,SAASC,KAAK,KAAKC,OACxG,EAAqCk8B,GAAc1W,GAA3ChC,EAAR,EAAQA,OAAQ5Y,EAAhB,EAAgBA,OAAQgxB,EAAxB,EAAwBA,SAClBz7B,EAAOk8B,GAAkB7W,GAC/B,OACEtX,EAAAA,EAAAA,MAAAA,OAAAA,EAAAA,EAAAA,GAAAA,CAAKnR,UAAWgO,GAASgF,EAAzB,CAAA5R,SAAAA,EACE+P,EAAAA,EAAAA,MAAAA,QAAAA,CAAOvS,MAAOigC,EAAW,CAAEY,YAAa,SAAY,GAApDr+B,SAAAA,CACGiR,IAASpE,EAAAA,EAAAA,KAAAA,UAAAA,CAAA7M,SAAUiR,IACnBoW,GAAWA,EAAQpN,OAAS,IAAKpN,EAAAA,EAAAA,KAACyxB,GAAD,CAAOjB,WAAYA,EAAY5+B,KAAM4mB,IACtE5mB,GAAQA,EAAKwb,OAAS,IACrBpN,EAAAA,EAAAA,KAAAA,QAAAA,CAAA7M,SACGvB,EAAKM,KAAI,SAACw/B,EAAQhB,GAAT,OACR1wB,EAAAA,EAAAA,KAAAA,KAAAA,CAAA7M,SACGgC,EAAKjD,KAAI,SAACqf,EAASof,GAClB,IAAIgB,EAAyD,CAC3Dx+B,SAAUu+B,EAAOngB,IAEnB,GAAI3R,EAAO2R,GAAU,CACnB,IAAMtN,EAAQrE,EAAO2R,GAASmgB,EAAOngB,GAAUA,EAASmgB,EAAQhB,EAAQC,GACxE,GAAI58B,EAAAA,eAAqBkQ,GACvB0tB,EAAKx+B,SAAW8Q,MACX,CACL,GAAIA,EAAMnT,QACR6gC,GAAO,UAAK1tB,EAAMnT,MAAd,CAAqBqC,SAAUw+B,EAAKx+B,WACZ,IAAxB8Q,EAAMnT,MAAMsgC,SAAyC,IAAxBntB,EAAMnT,MAAMgpB,SAAe,OAAO,KAEjE7V,EAAM9Q,WACRw+B,EAAKx+B,SAAW8Q,EAAM9Q,WAO5B,OAHIy9B,GAAYA,EAASrf,KACvBogB,EAAK5/B,UAAe8N,EAApB,cAGA6F,EAAAA,EAAAA,eAAAA,MAAAA,EAAAA,EAAAA,GAAAA,GAAQisB,EAAR,CAAchsB,IAAKgrB,EAAQ76B,QAAUqQ,SAAAA,GAAD,OAASmrB,EAAOI,EAAQ,CAAEhB,OAAAA,EAAQC,OAAAA,EAAQpf,QAAAA,GAAWpL,WAvBtFuqB,QA8Bd9+B,GAAwB,IAAhBA,EAAKwb,QAAgBmkB,IAC5BvxB,EAAAA,EAAAA,KAAAA,QAAAA,CAAA7M,UACE6M,EAAAA,EAAAA,KAAAA,KAAAA,CAAA7M,UACE6M,EAAAA,EAAAA,KAAAA,KAAAA,CAAI8Z,QAASU,EAAQpN,OAAQzc,MAAO,CAAE+F,SAAU,WAAYC,KAAM,GAAlExD,SACGo+B,QAKRzgC,EAAMqC,YAERmjB,IAAUtW,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,UAAd1M,SAAwCmjB,S,6GCtG1C,SAAS1b,GAAK9J,GAC3B,MAQIA,EAPF+O,UAAAA,OADF,MACc,SADd,EAEE9N,EAMEjB,EANFiB,UACAoB,EAKErC,EALFqC,SAHF,EAQIrC,EAJFL,KAAAA,OAJF,MAIS,UAJT,EAMEmhC,EAEE9gC,EAFF8gC,WACGpN,GAPL,OAQI1zB,EARJ,IASA,GAAkC6Q,EAAAA,EAAAA,UAAS7Q,EAAM6mB,WAAjD,eAAOA,EAAP,KAAkBM,EAAlB,KACA,GAAoCtW,EAAAA,EAAAA,UAAS,CAAEhS,MAAO,EAAGgH,KAAM,IAA/D,eAAOk7B,EAAP,KAAmBC,EAAnB,KACMC,GAAaxxB,EAAAA,EAAAA,UACbR,EAAM,CAACF,EAAW9N,EAAWtB,EAAUoP,EAAN,IAAmBpP,EAAS,MAAMoE,OAAOC,SAASC,KAAK,KAAKC,OAKnG,SAASg9B,IACHD,EAAWrxB,SAAoB,SAATjQ,GACxBqhC,EAAc,CACZniC,MAAOoiC,EAAWrxB,QAAQ3B,YAC1BpI,KAAMo7B,EAAWrxB,QAAQiK,aAK/B,OAZAlK,EAAAA,EAAAA,YAAU,kBAAMwX,EAAannB,EAAM6mB,aAAY,CAAC7mB,EAAM6mB,aACtDlX,EAAAA,EAAAA,YAAU,kBAAMuxB,MAAkB,CAACra,KAYjCzU,EAAAA,EAAAA,MAAAA,OAAAA,EAAAA,EAAAA,GAAAA,CAAKnR,UAAWgO,GAASykB,EAAzB,CAAArxB,SAAAA,EACE+P,EAAAA,EAAAA,MAAAA,MAAAA,CAAKnR,UAAc8N,EAAL,OAAd1M,SAAAA,EACE6M,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,OAAd1M,SACGY,EAAAA,SAAAA,IAAmBZ,GAAkC,SAACL,EAA0B6S,GAC/E,IAAK7S,EACH,OAAO,KAET,IAAMogB,EAAyB,CAC7BnhB,UAAW,CACN8N,EADM,QAET/M,EAAK6S,MAAQgS,EAAY,SAAW,KACpC7kB,EAAKhC,MAAM4S,SAAW,WAAa,MAElC7O,OAAOC,SACPC,KAAK,KACLC,OACH7B,SAAUL,EAAKhC,MAAM6kB,OASvB,OAPK7iB,EAAKhC,MAAM4S,WACdwP,EAASpd,QAAW5E,SAAAA,GAClB+mB,EAAanlB,EAAK6S,KAClBisB,GAAcA,EAAW9+B,EAAK6S,IAAe7S,EAAM5B,GACnD8gC,OAIFhyB,EAAAA,EAAAA,KAAAA,OAAAA,EAAAA,EAAAA,GAAAA,CAEEC,IAAM/B,SAAAA,GACAA,GAAQpL,EAAK6S,MAAQgS,IACvBoa,EAAWrxB,QAAUxC,KAGrBgV,GANCvN,SAWb3F,EAAAA,EAAAA,KAAAA,MAAAA,CAAKrP,MAAOkhC,EAAY9/B,UAAc8N,EAAL,cAElC9L,EAAAA,SAAAA,IAAmBZ,GAAWL,SAAAA,GAC7B,OAAKA,GAAQ6kB,IAAc7kB,EAAK6S,IAGzB5R,EAAAA,aAAmBjB,EAAMoC,OAAOiT,OAAO,GAAIrV,EAAKhC,MAAO,KAFrD,YAhFjB8J,GAAKq3B,KCCL,SAAgBnhC,QAA8B,IAA9BA,IAAAA,EAAuB,IACrC,MAA0EA,EAA1E,IAAQ+O,UAAAA,OAAR,MAAoB,cAApB,EAAmC9N,EAAnC,EAAmCA,UAAwB+N,GAA3D,OAA0EhP,EAA1E,IACA,OAAOkP,EAAAA,EAAAA,KAAAA,OAAAA,EAAAA,EAAAA,GAAAA,CAAKjO,UAAW,CAAC8N,EAAW9N,GAAW8C,OAAOC,SAASC,KAAK,KAAKC,QAAY8K,K,iCCJtF,GAAe/L,EAAAA,YAAqD,SAACjD,EAAOmP,GAC1E,MAA8DnP,EAAtD+O,UAAAA,OAAR,MAAoB,aAApB,EAAkC9N,EAA4BjB,EAA5BiB,UAAc+oB,GAAhD,OAA8DhqB,EAA9D,IACA,OACEkP,EAAAA,EAAAA,KAAAA,YAAAA,EAAAA,EAAAA,GAAAA,CAAUjO,UAAW,CAAC8N,EAAW9N,GAAW8C,OAAOC,SAASC,KAAK,KAAKC,QAAY8lB,EAAlF,CAA6F7a,IAAKA,EAAlG9M,SACGrC,EAAMqC,e,iHCAb,YAAgBrC,QAA6B,IAA7BA,IAAAA,EAAsB,IACpC,MAWIA,EAXJ,IACE+O,UAAAA,OADF,MACc,YADd,EAEE9N,EAFF,EAEEA,UAFF,IAGEuD,UAAAA,OAHF,MAGc,MAHd,MAIEuL,OAAAA,OAJF,SAKEwK,EALF,EAKEA,QACAS,EANF,EAMEA,MANF,IAOEzW,UAAAA,OAPF,aAQEkZ,aAAAA,OARF,SASEpC,EATF,EASEA,gBACGpH,GAVL,OAWIjU,EAXJ,IAYMiP,EAAM,CAACF,EAAW9N,EAAYwc,EAA4B,KAAb,YAAmB1Z,OAAOC,SAASC,KAAK,KAAKC,OAChG,OACEgL,EAAAA,EAAAA,KAAC5E,IAAD,QACE/F,UAAWA,EACXwL,OAAQA,EACRwK,QAASA,EACTS,MAAOA,EACPK,gBAAiBA,EACjB7W,UAAWA,GACPyP,EAPN,CAQEhD,SACEmB,EAAAA,EAAAA,MAAAA,MAAAA,CAAKnR,UAAWgO,EAAhB5M,SAAAA,CACGob,IAAgBvO,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,YAC/BG,EAAAA,EAAAA,KAAAA,MAAAA,CAAKjO,UAAc8N,EAAL,SAAd1M,SAAuCrC,EAAMyE,aAXnDpC,SAe6B,kBAAnBrC,EAAMqC,SAAwBrC,EAAMqC,UAAW6M,EAAAA,EAAAA,KAAAA,OAAAA,CAAA7M,SAAOrC,EAAMqC,e,oJCXpE++B,GAAQ,SAAC,GAAD,IAAGvc,EAAH,EAAGA,MAAH,OAA2C5kB,EAAAA,EAAAA,UAAQ,kBAAMiP,EAAAA,EAAAA,KAAAA,OAAAA,CAAA7M,SAAOwiB,MAAe,CAACA,KAE/E,SAASwc,GAAYrhC,GAClC,IACE+O,EAeE/O,EAfF+O,UACAuyB,EAcEthC,EAdFshC,YACA/+B,EAaEvC,EAbFuC,KACAg/B,EAYEvhC,EAZFuhC,cACAC,EAWExhC,EAXFwhC,WACAC,EAUEzhC,EAVFyhC,SACAC,EASE1hC,EATF0hC,aAEA5gC,EAOEd,EAPFc,KACA6gC,EAME3hC,EANF2hC,MACAC,EAKE5hC,EALF4hC,OAXF,EAgBI5hC,EAHFunB,YAAAA,OAbF,MAagB7b,EAbhB,IAgBI1L,EAFF6hC,eAAAA,OAdF,MAcmBn2B,EAdnB,EAeKuI,GAfL,OAgBIjU,EAhBJ,IAiBI+P,GAAS,EAET6xB,GAAUA,EAAO/sB,MACnB9E,KAAY0xB,GAAYA,EAASpa,QAAQua,EAAO/sB,MAAQ,IAE1D,IAAMse,GAASzG,EAAAA,EAAAA,cAAatf,SAAAA,GAC1BA,EAAKvN,MAAMf,OAAYsO,EAAK8I,aAA5B,OACC,IACGjE,GAAYya,EAAAA,EAAAA,cAAatf,SAAAA,GAC7BA,EAAKvN,MAAMf,OAAS,QACnB,IACGwc,GAAUoR,EAAAA,EAAAA,cAAY,SAACtf,EAAmBmQ,GAC9CnQ,EAAKvN,MAAMf,OAAS,QACnB,IACGiT,GAAa2a,EAAAA,EAAAA,cAAY,SAACtf,EAAmBmQ,GACjDnQ,EAAKvN,MAAMf,OAAYsO,EAAK8I,aAA5B,OACC,IACGlE,GAAY0a,EAAAA,EAAAA,cAAY,SAACtf,EAAmBmQ,GAChDnQ,EAAKvN,MAAMf,OAAS,YACnB,IACH,OACEoQ,EAAAA,EAAAA,KAAC0C,EAAAA,EAAD,CACEC,WAAY9C,EACZ+C,GAAI/B,EACJ7C,QAAS,IACTimB,OAAQA,EACRlhB,UAAWA,EACXqJ,QAASA,EACTtJ,UAAWA,EACXD,WAAYA,EARd1P,UAUE6M,EAAAA,EAAAA,KAAAA,KAAAA,CACEjO,UAAW,CACC,IAAV0gC,GAAe5xB,EAAS,CAAIhB,EAAJ,SAAwB,KACtC,IAAV4yB,GAAgB5xB,EAAkC,KAAzB,CAAIhB,EAAJ,WAExBhL,OAAOC,SACPC,KAAK,KACLC,OAPL7B,SASGvB,EAAKM,KAAI,SAACY,EAAMX,GAAgB,MAC/BW,EAAK4/B,OAASA,EACd,IAAMxgB,KAAcsgB,GAAgBA,EAAara,QAAQrlB,EAAK6S,MAAQ,GAChEitB,GAAW9/B,EAAKK,SAChB0/B,EAAaN,GAAYA,EAASpa,QAAQrlB,EAAK6S,MAAQ,KAAO7S,EAAKK,SACnE2/B,EACY,oBAATz/B,EACHA,EAAKP,EAAM,CACT+N,SAAUgyB,EACVD,QAAAA,EACAL,SAAAA,EACAC,aAAAA,IAEFn/B,EACA0/B,EAAYH,EAAU,GAAKI,GAAalgC,EAAKK,UAC7C8/B,EAAcT,EAAeA,EAAa39B,QAAQ8Q,SAAAA,GAAD,OAASotB,EAAU5a,QAAQxS,IAAQ,KAAK,GACzFutB,EAAgBD,EAAY7lB,OAAS,GAAK2lB,EAAU3lB,SAAW6lB,EAAY7lB,OACjF,OACElK,EAAAA,EAAAA,MAAAA,KAAAA,CAAcvS,MAAO,CAAE4F,QAASzD,EAAKqgC,SAAW,OAAS,SAAzDhgC,SAAAA,EACE+P,EAAAA,EAAAA,MAAAA,MAAAA,CAAKnR,UAAc8N,EAAL,SAAd1M,SAAAA,EACE6M,EAAAA,EAAAA,KAAAA,OAAAA,CAAMjO,UAAc8N,EAAL,YAA2B/J,QAAUqQ,SAAAA,GAAD,OAASkS,EAAYvlB,EAAMqT,IAA9EhT,UACE6M,EAAAA,EAAAA,KAAChH,EAAD,CACEvI,KAAMqiC,GAAY,cAClB/gC,UAAW,CACO,oBAATsB,EAAyBwM,EAAhC,iBAA4D,KAC5D+yB,EAAU,WAAa,KACtBP,EAAiC,KAAjB,eACjBQ,EAAa,OAAS,MAErBh+B,OAAOC,SACPC,KAAK,KACLC,YAGPgL,EAAAA,EAAAA,KAAAA,MAAAA,CACElK,QAAUqQ,SAAAA,GAAD,OAASwsB,EAAe7/B,EAAMqT,IACvCpU,UAAW,CACN8N,EADM,SAETqS,GAAYogB,EAAa,WAAa,KACtCx/B,EAAK4Q,SAAW,WAAa,MAE5B7O,OAAOC,SACPC,KAAK,KACLC,OATL7B,SAWGi/B,EACCA,EAAYt/B,EAAM,CAChBof,SAAAA,EACA0gB,QAAAA,EACAL,SAAAA,EACAW,cAAAA,EACAV,aAAAA,KAGFxyB,EAAAA,EAAAA,KAACkyB,GAAD,CAAOvc,MAAO7iB,EAAK6iB,aAIxB7iB,EAAKK,WACJ6M,EAAAA,EAAAA,KAACmyB,IAAD,UACMptB,GADN,GAGIlF,UAAAA,EACAxM,KAAAA,EACAg/B,cAAAA,EACAC,WAAAA,EACAC,SAAAA,EACAC,aAAAA,EACAna,YAAAA,EACAsa,eAAAA,EACAP,YAAAA,IAXJ,sBAaavyB,IAbb,iBAcQ/M,EAAKK,WAdb,kBAeSs/B,EAAQ,IAfjB,mBAgBU3/B,GAhBV,OAzCKX,U,mOC3CfihC,GAAc,SAACC,EAAUC,GAC7B,KAAMD,aAAa7jB,UAAY8jB,aAAa9jB,OAAQ,OAAO,EAC3D,GAAI6jB,EAAEjmB,OAASkmB,EAAElmB,OAAQ,OAAO,EAEhC,IADA,IAAMmmB,EAAOF,EAAE3N,WACNliB,EAAI,EAAGgwB,EAAMF,EAAElmB,OAAQ5J,EAAIgwB,EAAKhwB,GAAK,EAC5C,IAA4B,IAAxB+vB,EAAKpb,QAAQmb,EAAE9vB,IAAY,OAAO,EAExC,OAAO,GAGIwvB,GAAe,SAAfA,EACX7b,EACAjN,EACAupB,GAUA,YATsB,IAHtBtc,IAAAA,EAAqB,SAGC,IAFtBjN,IAAAA,EAA4B,IAG5BiN,EAAO5X,SAASzM,SAAAA,GACdoX,EAAOsD,KAAK1a,EAAK6S,MACI,kBAAV8tB,GAAwBA,EAAQ,IAEvC3gC,EAAKK,UAAYL,EAAKK,SAASia,OAAS,IAC1ClD,EAASA,EAAO8mB,OAAOgC,EAAalgC,EAAKK,cAAUyC,EAAW69B,EAAQA,EAAQ,OAAI79B,QAG/EsU,GAGHwpB,GAAgB,SAAhBA,EAAiBvc,EAAuBjN,GAO5C,YAP+E,IAA1DiN,IAAAA,EAAmB,SAAuC,IAAnCjN,IAAAA,EAA4B,IACpEiN,EAAOxR,KACTuE,EAAOsD,KAAK2J,EAAOxR,KAEjBwR,EAAOub,SACTxoB,EAASwpB,EAAcvc,EAAOub,OAAQxoB,IAEjCA,GAGHypB,GAAsB,SAAtBA,EACJxc,EACAqb,EACAtoB,GAgBA,YAfG,IAHHiN,IAAAA,EAAmB,SAGhB,IAFHqb,IAAAA,EAAkC,SAE/B,IADHtoB,IAAAA,EAA4B,IAExBiN,EAAOxR,KAAOwR,EAAOhkB,UAAYigC,GAAYZ,EAAcQ,GAAa7b,EAAOhkB,cAAUyC,EAAW,MACtGsU,EAAOsD,KAAK2J,EAAOxR,KACfwR,EAAOub,SAAWvb,EAAOub,OAAOA,SAC9BU,GAAYZ,EAAcQ,GAAa7b,EAAOhkB,aAChDq/B,EAAeA,EAAaxB,OAAO9mB,IAEjCkpB,GAAYZ,EAAcQ,GAAa7b,EAAOub,OAAOv/B,YACvD+W,EAAOsD,KAAK2J,EAAOub,OAAO/sB,OAI5BwR,EAAOub,SACTxoB,EAASypB,EAAoBxc,EAAOub,OAAQF,EAActoB,IAErDA,GAGM,SAAS1P,GAAK1J,GAC3B,MAoBIA,EAnBF+O,UAAAA,OADF,MACc,SADd,IAoBI/O,EAlBFuC,KAAAA,OAFF,MAES,cAFT,IAoBIvC,EAjBFc,KAAAA,OAHF,MAGS,GAHT,IAoBId,EAhBFyhC,SAAAA,OAJF,MAIa,GAJb,IAoBIzhC,EAfF0hC,aAAAA,OALF,MAKiB,GALjB,IAoBI1hC,EAdF8iC,iBAAAA,OANF,WAoBI9iC,EAbF+iC,SAAAA,OAPF,WAoBI/iC,EAZFuhC,cAAAA,OARF,WAoBIvhC,EAXFwhC,WAAAA,OATF,WAoBIxhC,EAVFgjC,cAAAA,OAVF,WAoBIhjC,EATFosB,SAAAA,OAXF,WAoBIpsB,EARFijC,SAAAA,OAZF,MAYav3B,EAZb,IAoBI1L,EAPFqe,WAAAA,OAbF,MAae3S,EAbf,EAeEzK,EAKEjB,EALFiB,UAfF,EAoBIjB,EAJFkjC,iBAAAA,OAhBF,SAiBE5B,EAGEthC,EAHFshC,YACAnhC,EAEEH,EAFFG,SACGuzB,GAnBL,OAoBI1zB,EApBJ,IAsBA,GAAsC6Q,EAAAA,EAAAA,UAAS4wB,GAA/C,eAAO0B,EAAP,KAAoBC,EAApB,KACA,GAA8CvyB,EAAAA,EAAAA,UAAS7Q,EAAME,OAASwhC,GAAtE,eAAO2B,EAAP,KAAwBC,EAAxB,MAEA3zB,EAAAA,EAAAA,YAAU,WACR2zB,EAAmBtjC,EAAM0hC,cAAgB,MACxC,CAACjZ,KAAKC,UAAU1oB,EAAM0hC,iBACzB/xB,EAAAA,EAAAA,YAAU,WACR2zB,EAAmBtjC,EAAME,OAAS,MACjC,CAACuoB,KAAKC,UAAU1oB,EAAME,UAIzByP,EAAAA,EAAAA,YAAU,WACR,IAAI4zB,GAAiC,QAAIJ,GACzC,GAAIL,EACFS,EAAcrB,GAAaphC,QACtB,GAAIoiC,EAAkB,QAC3BK,EAAAA,GAAY7mB,KAAZ6mB,MAAAA,GAAAA,EAAAA,GAAAA,GAAoBrB,GAAaphC,GAAQ,QAAIgE,EAAW,KAE1Ds+B,EAAeG,KACd,IAEH,IAAMt0B,EAAM,CAAChO,EAAW8N,EAAWg0B,EAAch0B,EAAN,QAAyB,MAAMhL,OAAOC,SAASC,KAAK,KAAKC,OAmDpG,OACEgL,EAAAA,EAAAA,KAAAA,OAAAA,EAAAA,EAAAA,GAAAA,CAAKjO,UAAWgO,GAASykB,EAAzB,CAAArxB,UACE6M,EAAAA,EAAAA,KAACmyB,GAAD,CAEI9+B,KAAAA,EACAg/B,cAAAA,EACAC,WAAAA,EACAC,SAAU0B,EACVzB,aAAc2B,EACdt0B,UAAAA,EACAuyB,YAAAA,EAEF/Z,YA7DN,SAAqBvlB,EAAgBqT,GACnC,GAAKrT,EAAKK,SAAV,CAKA,IAAImhC,GAAc,QAAKL,GACjBtuB,EAAM2uB,EAAYzhC,MAAMw4B,SAAAA,GAAD,OAAOA,IAAMv4B,EAAK6S,OACzC5F,EAAMoG,EAAIyH,cAAc7b,UAAUyB,QAAQ,YAAa,IACzD+gC,GAAW,GACV5uB,GAAO7S,EAAK6S,KACf2uB,EAAY9mB,KAAK1a,EAAK6S,KACtBQ,EAAIyH,cAAc7b,UAAY,CAACgO,EAAK,QAAQlL,OAAOC,SAASC,KAAK,KAAKC,OACtEu/B,GAAW,IAEXD,EAAcA,EAAYz/B,QAAQw2B,SAAAA,GAAD,OAAOA,IAAMv4B,EAAK6S,OACnDQ,EAAIyH,cAAc7b,UAAYgO,GAEhCm0B,EAAeI,GACfP,GAAYA,EAASjhC,EAAK6S,IAAK4uB,EAAUzhC,EAAMqT,KA2C3CwsB,eAzCN,SAAwB7/B,EAAgBqT,GAEtC,IAAIquB,GAAU,QAAKL,GACbM,EAAUD,EAAQ3hC,MAAMw4B,SAAAA,GAAD,OAAOA,IAAMv4B,EAAK6S,OAC3CuM,GAAW,EACVuiB,EAIHD,EAAUA,EAAQ3/B,QAAQw2B,SAAAA,GAAD,OAAOA,IAAMv4B,EAAK6S,QAH3CuM,GAAW,EACXsiB,EAAQhnB,KAAK1a,EAAK6S,MAIhBmuB,IACGW,EAMHD,GADAA,EAAUA,EAAQ3/B,QAAQyiB,SAAAA,GAAD,OAAuD,IAA9C0b,GAAalgC,EAAKK,UAAUglB,QAAQb,OACpDziB,QAAQyiB,SAAAA,GAAD,OAAsD,IAA7Coc,GAAc5gC,EAAK4/B,QAAQva,QAAQb,OAJrEkd,GADAA,EAAUA,EAAQxD,OAAOgC,GAAalgC,EAAKK,UAAU0B,QAAQyiB,SAAAA,GAAD,OAAmC,IAA1Bkd,EAAQrc,QAAQb,QACnE0Z,OAAO2C,GAAoB7gC,EAAM0hC,IACnDA,EAAUhlB,MAAMklB,KAAK,IAAIC,IAAIH,MAM5BtX,IACHsX,EAAWC,EAAuB,GAAb,CAAC3hC,EAAK6S,MAE7ByuB,EAAmBI,GACnBrlB,GAAcA,EAAWqlB,EAAS1hC,EAAK6S,IAAKuM,EAAUpf,EAAMqT,GACpD,MAARlV,GAAAA,EAAWujC,IAgBP5iC,KAAMA,EACN6gC,MAAO,O,qBClOA,SAASh4B,GAAT,GAA+F,QAAxEoF,UAAAA,OAAwE,MAA5D,gBAA4D,EAAxC/O,GAAwC,aAK5G,OAJAA,EAAMiB,UAAY,CAAC8N,EAAW/O,EAAMiB,WAAW8C,OAAOC,SAASC,KAAK,KAAKC,OACzElE,EAAMgjC,eAAgB,EACtBhjC,EAAMwhC,YAAa,EACnBxhC,EAAMosB,UAAW,GAEfld,EAAAA,EAAAA,KAACxF,IAAD,QACE43B,YAAa,SAACt/B,EAAgBoL,GAC5B,IAAM02B,EAA8B,GASpC,OARI12B,EAAKg1B,gBACP0B,EAAapd,eAAgB,GAE3BtZ,EAAKgU,SACP0iB,EAAaje,SAAU,EAEvBie,EAAaje,SAAU,GAGvBzT,EAAAA,EAAAA,MAACtO,EAAAA,SAAD,CAAAzB,SAAAA,EACE6M,EAAAA,EAAAA,KAACtH,IAAD,QAAU3G,UAAc8N,EAAL,YAA8B+0B,IAChD9hC,EAAK6iB,QAAS3V,EAAAA,EAAAA,KAAAA,OAAAA,CAAA7M,SAAOL,EAAK6iB,aAI7B7kB,I,wKCkJV,OAhJA,SAAwDA,GACtD,MAkBIA,EAjBF+O,UAAAA,OADF,MACc,gBADd,KAkBI/O,EAhBFm5B,KAgBEn5B,EAfFkT,MAAAA,OAHF,MAGS,UAHT,IAkBIlT,EAdF4S,SAAAA,OAJF,WAkBI5S,EAbFyf,WAAAA,OALF,WAkBIzf,EAZF8S,QAAAA,OANF,SAOE7R,EAWEjB,EAXFiB,UACApB,EAUEG,EAVFH,MACAwgB,EASErgB,EATFqgB,YAEA5b,EAOEzE,EAPFyE,QACA4V,EAMEra,EANFqa,QACA2b,EAKEh2B,EALFg2B,OACA71B,EAIEH,EAJFG,SACAm5B,EAGEt5B,EAHFs5B,SACAyK,EAEE/jC,EAFF+jC,YACGxxB,GAjBL,OAkBIvS,EAlBJ,IAoBMiP,EAAM,CAACF,EAAW9N,GAAW8C,OAAOC,SAASC,KAAK,KAAKC,OAE7D,GAAsC2M,EAAAA,EAAAA,WAAS,GAA/C,eAAO4oB,EAAP,KAAoBC,EAApB,KACA,GAA4C7oB,EAAAA,EAAAA,UAAmBmlB,GAA/D,eAAOgO,EAAP,KAAuBC,EAAvB,KACMC,GAAYz0B,EAAAA,EAAAA,UAClB,GAAsCoB,EAAAA,EAAAA,UAAiB,IAAvD,eAAOszB,EAAP,KAAoBC,EAApB,KACAF,EAAUt0B,SAAU3P,EAAAA,EAAAA,UAAQ,kBAAM+jC,IAAgB,CAACA,IACnD,OAA4CnzB,EAAAA,EAAAA,UAAS,IAArD,eAAOkpB,EAAP,KAAuBC,EAAvB,KACMpc,GAAWnO,EAAAA,EAAAA,QAAyB,MAM1C,SAASorB,EAAiBl7B,GACxB,IAAMo6B,EAA0B,UAATp6B,GAAoB8f,IAAiBukB,EAAe1nB,QAAU6nB,GAAe,QAAU,GAC9GnK,EAAkBD,IANpBpqB,EAAAA,EAAAA,YAAU,WACRs0B,EAAkBjO,KACjB,CAACvN,KAAKC,UAAUsN,KAOnB,IAAM4E,EAAqB,SAACyJ,EAAuBC,EAAaC,QAA8B,IAA9BA,IAAAA,GAAqB,GACnFN,EAAkBI,GAElBlkC,GAAYA,EAASkkC,EAAaC,EAAUC,IAGxC7J,EAAoBxvB,SAAAA,GACxB,IAAM84B,EAAiBE,EAAUt0B,QAC3B40B,EAAeR,EAAe94B,GACpC84B,EAAexc,OAAOtc,EAAO,GAC7B0vB,GAAmB,QAAIoJ,GAAiBQ,GAAc,IAGxD,SAASxJ,EAAkB96B,GACzBkkC,EAAelkC,GACP,MAARo5B,GAAAA,EAAWp5B,GACX85B,EAAkB95B,EAAQ,UAAY,IAkBxC,IAAMukC,GAAaxkC,EAAAA,EAAAA,UAAQ,WACzB,GAAI8jC,EACF,MAA8B,mBAAhBA,GAA4B70B,EAAAA,EAAAA,KAACnE,GAAD,CAAOlL,MAAO,CAAE+T,SAAU,IAAK/U,MAAK,MAAEgB,OAAF,EAAEA,EAAOhB,SAAcklC,EAGvG,IAAMW,GAAW,UACZjgC,EAAQzE,MADC,CAEZqe,WAAYuc,EACZ5E,OAAQgO,EACR3pB,QAAAA,IAEF,OAAOpX,EAAAA,aAAmBwB,EAAwBigC,KACjD,CAACjc,KAAKkc,MAAMlc,KAAKC,UAAUsb,IAAkB3pB,EAAS0pB,IAEzD,OACE70B,EAAAA,EAAAA,KAAC3G,IAAD,QACEtH,UAAWgO,EACXsL,QAAQ,SACJhI,EAHN,CAIExC,OAAQ0pB,EACR33B,MAAMoN,EAAAA,EAAAA,KAACnH,GAAD,CAAMiM,WAA2B,IAAhB+vB,EAAuB,CAAEp+B,QAAS,QAAMb,EAAzDzC,SAAqEoiC,IAL7EpiC,UAOE6M,EAAAA,EAAAA,KAAAA,MAAAA,CACEiO,YAAa,kBAAM0d,EAAiB,UACpCvd,aAAc,kBAAMud,EAAiB,UACrC71B,QAAS,iCAAM4Y,EAAShO,cAAf,EAAMg1B,EAAkBnO,SACjC52B,OAAK,QAAI+T,SAAU,IAAKD,SAAU,QAAW9T,GAJ/CwC,UAME+P,EAAAA,EAAAA,MAAAA,MAAAA,CAAKnR,UAAc8N,EAAL,SAAd1M,SAAAA,EACE+P,EAAAA,EAAAA,MAAAA,MAAAA,CAAKvS,MAAO,CAAE4F,QAAS,OAAQg2B,SAAU,QAAzCp5B,SAAAA,CACG2hC,EAAe5iC,KAAI,SAACY,EAAMkJ,GACzB,OACEgE,EAAAA,EAAAA,KAACrF,GAAD,CACEhK,MAAO,CAAEf,OAAQ,GAAI8pB,OAAQ,EAAGnjB,QAAS,OAAQC,WAAY,UAC7DzE,UAAc8N,EAAL,OAET8pB,UAAQ,EACRj0B,MAAM,UACN8L,QAAUtQ,SAAAA,GACRA,EAAEykC,kBACFnK,EAAiBxvB,IARrB7I,SAWGL,EAAK6iB,OARD3Z,OAYXgE,EAAAA,EAAAA,KAACtG,GAAD,CACEuG,IAAKyO,EACL/d,MAAO,CAAE67B,KAAM,EAAG9nB,SAAU,IAC5B3S,UAAc8N,EAAL,kBACTmE,KAAMA,EACNN,SAAUA,EACV8jB,UA3DZ,SAAsBt2B,GAChB4jC,EAAe1nB,OAAS,IAAM6nB,GAA6B,IAAd/jC,EAAEu7B,SACjDjB,EAAiBsJ,EAAe1nB,OAAS,IA0DjCnc,SAAWC,SAAAA,GAAD,OAA4C46B,EAAkB56B,EAAEC,OAAOH,QACjFA,MAAOikC,EACP9jB,YAAa2jB,EAAe1nB,OAAS,GAAK+D,QAG9CnR,EAAAA,EAAAA,KAAAA,OAAAA,CAAMrP,MAAO,CAAEf,OAAQ,IAAMmC,UAAc8N,EAAL,sBAAtC1M,UACuB,UAAnB03B,GAAkD,YAAnBA,GAAgCjnB,KAC/D5D,EAAAA,EAAAA,KAAChH,EAAD,CAAMvI,KAAMo6B,EAAgBn6B,KAAMkT,GAA8B,YAAnBinB,EAA8B/0B,QA3EvF,SAA4B5E,GAC1BA,EAAEykC,kBACFnL,GAAe,GACfuK,EAAkB,IAClBjJ,EAAkB,IAClBJ,EAAmB,kB,kFC1FvB,SAASkK,GACP9kC,GAEA,OAAwC6Q,EAAAA,EAAAA,UAAuB,IAA/D,eAAOk0B,EAAP,KAAqBC,EAArB,KACA,GAAwBn0B,EAAAA,EAAAA,UAAiC,IAAzD,eAAOxM,EAAP,KAAa4gC,EAAb,MAEAt1B,EAAAA,EAAAA,YAAU,WAAM,MACVo1B,EAA6B,GAC3B1gC,EAAI,SAAGrE,EAAMg2B,aAAT,EAAGkP,EAAc9jC,KAAK+jC,SAAAA,GAE9B,OADAJ,EAAaI,EAAItwB,KAAOswB,EAAItgB,MACrBsgB,EAAItwB,OAEbmwB,EAAgBD,GAChBE,EAAQ5gC,GAAQ,MACf,CAACrE,EAAMg2B,SAEV,IAMMoP,EAAsB,SAAtBA,EAAuBC,EAAuBN,EAA4BO,GAC9E,IAAMC,EAAW,SAAC1wB,EAAsBgQ,EAAeygB,GACjDA,EACFP,EAAalwB,GAAOgQ,SAEbkgB,EAAalwB,IAGlB2wB,EAAkBryB,SAAlBqyB,EAAkBryB,GAEtB,GAAIA,EAAMyuB,OAAQ,CAChB,IAAM6D,EAActyB,EAAMyuB,OAAOv/B,SAAS0B,QAAQoP,SAAAA,GAAD,OAAsB4xB,EAAa5xB,EAAM0B,QAAOyH,OACjGipB,EAASpyB,EAAMyuB,OAAO/sB,IAAK1B,EAAMyuB,OAAO/c,MAAuB,IAAhB4gB,GAC/CD,EAAeryB,EAAMyuB,UAWzB,OAPAyD,EAAU52B,SAAS0E,SAAAA,GAAoB,QAChC,SAACA,EAAM9Q,WAANqjC,EAAgBppB,SACpByoB,EAAeK,EAAoBjyB,EAAM9Q,SAAU0iC,EAAcO,IAEnEC,EAASpyB,EAAM0B,IAAP,SAAa1B,EAAM0R,YAAnB,EAAa8gB,EAAa/Q,WAAa0Q,GAC/CE,EAAeryB,MAEV4xB,GAGT,OACE71B,EAAAA,EAAAA,KAACvF,IAAD,QAAam5B,kBAAkB,GAAU9iC,EAAzC,CAAgDc,KAAMd,EAAMqa,QAASqnB,aAAcr9B,EAAMga,WAlCxE,SAACunB,EAASC,EAAStB,EAAoBlvB,GACxD,IAAMywB,EAAgCV,EAAoB,CAAC/vB,GAAM0vB,EAAcR,GACzEtL,EAAS70B,OAAO0sB,QAAQgV,GAAiB1kC,KAAI,qCAAmB,CAAEyT,IAArB,KAA0BgQ,MAA1B,SACnD7kB,MAAAA,EAAMqe,YAANre,EAAMqe,WAAa4a,EAAQ,CAAEpkB,IAAKQ,EAAIR,IAAKgQ,MAAOxP,EAAIwP,OAAwB0f,OAmClF,SAASwB,GAA0C/lC,GACjD,OAAwB6Q,EAAAA,EAAAA,UAAiC,IAAzD,eAAOxM,EAAP,KAAa4gC,EAAb,MAEAt1B,EAAAA,EAAAA,YAAU,WAAM,MACRtL,EAA+B,GACrC,SAAIrE,EAAMg2B,SAANgQ,EAAc1pB,SAAQjY,EAAK,GAAKrE,EAAMg2B,OAAO,GAAGnhB,KACpDowB,EAAQ5gC,KACP,CAACrE,EAAMg2B,SAQV,OACE9mB,EAAAA,EAAAA,KAACxF,IAAD,QACEo5B,kBAAkB,GACd9iC,EAFN,CAGEosB,UAAU,EACVtrB,KAAMd,EAAMqa,QACZqnB,aAAcr9B,EACdga,WAbe,SAACunB,EAASC,EAAStB,EAAoBlvB,GACxD,IACM4wB,EAAM,CAAEpxB,IADSQ,EAAfR,IACWgQ,MADIxP,EAAVwP,OAEb7kB,MAAAA,EAAMqe,YAANre,EAAMqe,WAAa,CAAC4nB,GAAMA,EAAK1B,OA+FnC,OAtEA,SAAoDvkC,GAClD,IACEG,EAQEH,EARFG,SACAm5B,EAOEt5B,EAPFs5B,SAFF,EASIt5B,EANFosB,SAAAA,OAHF,WASIpsB,EALFqa,QAAAA,OAJF,MAIY,GAJZ,IASIra,EAJFE,MAAAA,OALF,MAKU,GALV,IASIF,EAHF+jC,YAAAA,OANF,OAMiB1pB,EAAQiC,OANzB,EAOE4pB,EAEElmC,EAFFkmC,UACGjyB,GARL,OASIjU,EATJ,IAUA,GAA4C6Q,EAAAA,EAAAA,UAAmB6N,MAAM4H,QAAQpmB,GAASA,EAAQ,CAACA,IAA/F,eAAOimC,EAAP,KAAuBC,EAAvB,KACA,GAA6Cv1B,EAAAA,EAAAA,UAA0BwJ,GAAvE,eAAOgsB,EAAP,KAAwBC,EAAxB,KACA,GAA8Bz1B,EAAAA,EAAAA,UAASkzB,GAAvC,eAAOwC,EAAP,KAAgBC,EAAhB,KA4CA,OA1CA72B,EAAAA,EAAAA,YAAU,WACRy2B,EAAkB1nB,MAAM4H,QAAQpmB,GAASA,EAAQ,MAChD,CAACuoB,KAAKC,UAAUxoB,MAyCjBgP,EAAAA,EAAAA,KAACu3B,IAAD,UACMxyB,EADN,CAEE8vB,YAAawC,EACbjN,SApCa,SAACoN,EAAcC,GAC9B,IAAIpqB,EACJ,OAAQ4nB,SAAAA,GACE,MAAR7K,GAAAA,EAAW6K,GACXt2B,aAAa0O,GACbA,EAAY9O,YAAW,WACrBi5B,EAAGvC,KACFwC,IA6BOC,EAzBUzC,SAAAA,IACK,SAArB0C,EAAsBxB,EAAuByB,QAAiC,IAAjCA,IAAAA,GAAwB,GACzEzB,EAAU52B,SAAS0E,SAAAA,GAAoB,MAC/B4zB,GAAW5zB,EAAM0R,MAAiBvgB,SAAS6/B,EAAYjgC,SAAW4iC,EACxE,GAAK,SAAC3zB,EAAM9Q,WAAN2kC,EAAgB1qB,OAAQ,CAC5BuqB,EAAmB1zB,EAAM9Q,SAAU0kC,GACnC,IAAMhlC,EAAOoR,EAAM9Q,SAASN,MAAMC,SAAAA,GAAD,OAAWA,EAAKqgC,YACjDlvB,EAAMkvB,SAAW0E,IAAWhlC,OAE5BoR,EAAMkvB,SAAW0E,KAIvBF,CAAmBxsB,GACnBisB,GAAkB,QAAIjsB,IAEtB,IAAI4sB,GAAS,EACb5sB,EAAQ5L,SAAS02B,SAAAA,GAAD,OAAU8B,EAASA,KAAY9B,EAAI9C,YACnDmE,EAAWS,KAO0B,KACnC9mC,SA3CmB,SAACw6B,EAAuBsL,EAAQ1B,GACrD6B,EAAkBzL,GACV,MAARx6B,GAAAA,EAAW8lC,EAAKtL,EAAa4J,IA0C3BvO,OAAQmQ,EACR9rB,QAASgsB,EACT5hC,QAAS2nB,GAAWld,EAAAA,EAAAA,KAAC41B,IAAD,UAAkBoB,KAAgBh3B,EAAAA,EAAAA,KAAC62B,IAAD,UAAeG,S,6xMCnKvEgB,EAA2B,GAG/B,SAASC,EAAoBC,GAE5B,IAAIC,EAAeH,EAAyBE,GAC5C,QAAqBtiC,IAAjBuiC,EACH,OAAOA,EAAaC,QAGrB,IAAIC,EAASL,EAAyBE,GAAY,CAGjDE,QAAS,IAOV,OAHAE,EAAoBJ,GAAUxW,KAAK2W,EAAOD,QAASC,EAAQA,EAAOD,QAASH,GAGpEI,EAAOD,QAIfH,EAAoB3M,EAAIgN,E,WCzBxB,IAAIC,EAAW,GACfN,EAAoBO,EAAI,SAAStuB,EAAQuuB,EAAUjB,EAAIkB,GACtD,IAAGD,EAAH,CAMA,IAAIE,EAAeC,EAAAA,EACnB,IAASp1B,EAAI,EAAGA,EAAI+0B,EAASnrB,OAAQ5J,IAAK,CACrCi1B,EAAWF,EAAS/0B,GAAG,GACvBg0B,EAAKe,EAAS/0B,GAAG,GACjBk1B,EAAWH,EAAS/0B,GAAG,GAE3B,IAJA,IAGIq1B,GAAY,EACPC,EAAI,EAAGA,EAAIL,EAASrrB,OAAQ0rB,MACpB,EAAXJ,GAAsBC,GAAgBD,IAAaxjC,OAAOC,KAAK8iC,EAAoBO,GAAGO,OAAM,SAASpzB,GAAO,OAAOsyB,EAAoBO,EAAE7yB,GAAK8yB,EAASK,OAC3JL,EAASngB,OAAOwgB,IAAK,IAErBD,GAAY,EACTH,EAAWC,IAAcA,EAAeD,IAG7C,GAAGG,EAAW,CACbN,EAASjgB,OAAO9U,IAAK,GACrB,IAAIof,EAAI4U,SACE5hC,IAANgtB,IAAiB1Y,EAAS0Y,IAGhC,OAAO1Y,EAzBNwuB,EAAWA,GAAY,EACvB,IAAI,IAAIl1B,EAAI+0B,EAASnrB,OAAQ5J,EAAI,GAAK+0B,EAAS/0B,EAAI,GAAG,GAAKk1B,EAAUl1B,IAAK+0B,EAAS/0B,GAAK+0B,EAAS/0B,EAAI,GACrG+0B,EAAS/0B,GAAK,CAACi1B,EAAUjB,EAAIkB,I,GCJ/BT,EAAoBe,EAAI,SAASX,GAChC,IAAIY,EAASZ,GAAUA,EAAOa,WAC7B,WAAa,OAAOb,EAAgB,SACpC,WAAa,OAAOA,GAErB,OADAJ,EAAoB/nC,EAAE+oC,EAAQ,CAAE5F,EAAG4F,IAC5BA,GCLRhB,EAAoB/nC,EAAI,SAASkoC,EAASe,GACzC,IAAI,IAAIxzB,KAAOwzB,EACXlB,EAAoBmB,EAAED,EAAYxzB,KAASsyB,EAAoBmB,EAAEhB,EAASzyB,IAC5EzQ,OAAOmkC,eAAejB,EAASzyB,EAAK,CAAE2zB,YAAY,EAAMC,IAAKJ,EAAWxzB,MCJ3EsyB,EAAoBuB,EAAI,GAGxBvB,EAAoB/mC,EAAI,SAASuoC,GAChC,OAAOld,QAAQO,IAAI5nB,OAAOC,KAAK8iC,EAAoBuB,GAAGE,QAAO,SAASC,EAAUh0B,GAE/E,OADAsyB,EAAoBuB,EAAE7zB,GAAK8zB,EAASE,GAC7BA,IACL,MCNJ1B,EAAoB2B,EAAI,SAASH,GAEhC,MAAO,cAAgB,CAAC,IAAM,kBAAkB,KAAO,uBAAuB,KAAO,sBAAsBA,IAAYA,GAAW,IAAM,CAAC,IAAM,WAAW,IAAM,WAAW,IAAM,WAAW,IAAM,WAAW,IAAM,WAAW,IAAM,WAAW,IAAM,WAAW,IAAM,WAAW,IAAM,WAAW,IAAM,WAAW,IAAM,WAAW,IAAM,WAAW,IAAM,WAAW,IAAM,WAAW,IAAM,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,YAAYA,GAAW,aCFnoFxB,EAAoB4B,SAAW,SAASJ,GAEvC,MAAO,cAAgBA,EAAU,IAAM,CAAC,IAAM,WAAW,IAAM,WAAW,IAAM,WAAW,IAAM,WAAW,IAAM,WAAW,IAAM,WAAW,IAAM,WAAW,IAAM,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,WAAW,KAAO,YAAYA,GAAW,cCHzxCxB,EAAoB6B,EAAI,WACvB,GAA0B,kBAAfC,WAAyB,OAAOA,WAC3C,IACC,OAAOz7B,MAAQ,IAAI07B,SAAS,cAAb,GACd,MAAO9oC,GACR,GAAsB,kBAAXI,OAAqB,OAAOA,QALjB,GCAxB2mC,EAAoBmB,EAAI,SAAS9nB,EAAK2oB,GAAQ,OAAO/kC,OAAOssB,UAAUC,eAAeC,KAAKpQ,EAAK2oB,I,WCA/F,IAAIC,EAAa,GACbC,EAAoB,WAExBlC,EAAoBmC,EAAI,SAAS30B,EAAK40B,EAAM10B,EAAK8zB,GAChD,GAAGS,EAAWz0B,GAAQy0B,EAAWz0B,GAAK+H,KAAK6sB,OAA3C,CACA,IAAIC,EAAQC,EACZ,QAAW3kC,IAAR+P,EAEF,IADA,IAAI60B,EAAUl+B,SAASm+B,qBAAqB,UACpCj3B,EAAI,EAAGA,EAAIg3B,EAAQptB,OAAQ5J,IAAK,CACvC,IAAIk3B,EAAIF,EAAQh3B,GAChB,GAAGk3B,EAAEC,aAAa,QAAUl1B,GAAOi1B,EAAEC,aAAa,iBAAmBR,EAAoBx0B,EAAK,CAAE20B,EAASI,EAAG,OAG1GJ,IACHC,GAAa,GACbD,EAASh+B,SAAS8D,cAAc,WAEzBw6B,QAAU,QACjBN,EAAOt8B,QAAU,IACbi6B,EAAoB4C,IACvBP,EAAOpS,aAAa,QAAS+P,EAAoB4C,IAElDP,EAAOpS,aAAa,eAAgBiS,EAAoBx0B,GACxD20B,EAAOx0B,IAAML,GAEdy0B,EAAWz0B,GAAO,CAAC40B,GACnB,IAAIS,EAAmB,SAAS7oB,EAAMgV,GAErCqT,EAAOS,QAAUT,EAAOU,OAAS,KACjCr8B,aAAaX,GACb,IAAIi9B,EAAUf,EAAWz0B,GAIzB,UAHOy0B,EAAWz0B,GAClB60B,EAAO/xB,YAAc+xB,EAAO/xB,WAAW5H,YAAY25B,GACnDW,GAAWA,EAAQ17B,SAAQ,SAASi4B,GAAM,OAAOA,EAAGvQ,MACjDhV,EAAM,OAAOA,EAAKgV,IAGlBjpB,EAAUO,WAAWu8B,EAAiB18B,KAAK,UAAMxI,EAAW,CAAEnF,KAAM,UAAWU,OAAQmpC,IAAW,MACtGA,EAAOS,QAAUD,EAAiB18B,KAAK,KAAMk8B,EAAOS,SACpDT,EAAOU,OAASF,EAAiB18B,KAAK,KAAMk8B,EAAOU,QACnDT,GAAcj+B,SAAS4+B,KAAKt6B,YAAY05B,K,GCvCzCrC,EAAoBrV,EAAI,SAASwV,GACX,qBAAX+C,QAA0BA,OAAOC,aAC1ClmC,OAAOmkC,eAAejB,EAAS+C,OAAOC,YAAa,CAAEpqC,MAAO,WAE7DkE,OAAOmkC,eAAejB,EAAS,aAAc,CAAEpnC,OAAO,KCLvDinC,EAAoBoD,EAAI,K,WCAxB,IAyCIC,EAAiB,SAAS7B,GAC7B,OAAO,IAAIld,SAAQ,SAASC,EAAS+e,GACpC,IAAI/pC,EAAOymC,EAAoB4B,SAASJ,GACpC+B,EAAWvD,EAAoBoD,EAAI7pC,EACvC,GAlBmB,SAASA,EAAMgqC,GAEnC,IADA,IAAIC,EAAmBn/B,SAASm+B,qBAAqB,QAC7Cj3B,EAAI,EAAGA,EAAIi4B,EAAiBruB,OAAQ5J,IAAK,CAChD,IACIk4B,GADA5rB,EAAM2rB,EAAiBj4B,IACRm3B,aAAa,cAAgB7qB,EAAI6qB,aAAa,QACjE,GAAe,eAAZ7qB,EAAIja,MAAyB6lC,IAAalqC,GAAQkqC,IAAaF,GAAW,OAAO1rB,EAErF,IAAI6rB,EAAoBr/B,SAASm+B,qBAAqB,SACtD,IAAQj3B,EAAI,EAAGA,EAAIm4B,EAAkBvuB,OAAQ5J,IAAK,CACjD,IAAIsM,EAEJ,IADI4rB,GADA5rB,EAAM6rB,EAAkBn4B,IACTm3B,aAAa,gBAChBnpC,GAAQkqC,IAAaF,EAAU,OAAO1rB,GAOnD8rB,CAAepqC,EAAMgqC,GAAW,OAAOhf,KA7CrB,SAASid,EAAS+B,EAAUhf,EAAS+e,GAC3D,IAAIM,EAAUv/B,SAAS8D,cAAc,QAErCy7B,EAAQhmC,IAAM,aACdgmC,EAAQprC,KAAO,WAiBforC,EAAQd,QAAUc,EAAQb,OAhBL,SAAS/T,GAG7B,GADA4U,EAAQd,QAAUc,EAAQb,OAAS,KAChB,SAAf/T,EAAMx2B,KACT+rB,QACM,CACN,IAAIsf,EAAY7U,IAAyB,SAAfA,EAAMx2B,KAAkB,UAAYw2B,EAAMx2B,MAChEsrC,EAAW9U,GAASA,EAAM91B,QAAU81B,EAAM91B,OAAOK,MAAQgqC,EACzDQ,EAAM,IAAIC,MAAM,qBAAuBxC,EAAU,cAAgBsC,EAAW,KAChFC,EAAIE,KAAO,wBACXF,EAAIvrC,KAAOqrC,EACXE,EAAIG,QAAUJ,EACdF,EAAQtzB,WAAW5H,YAAYk7B,GAC/BN,EAAOS,KAITH,EAAQrqC,KAAOgqC,EAEfl/B,SAAS4+B,KAAKt6B,YAAYi7B,GAsBzBO,CAAiB3C,EAAS+B,EAAUhf,EAAS+e,OAI3Cc,EAAqB,CACxB,IAAK,GAGNpE,EAAoBuB,EAAE8C,QAAU,SAAS7C,EAASE,GAE9C0C,EAAmB5C,GAAUE,EAASnsB,KAAK6uB,EAAmB5C,IACzB,IAAhC4C,EAAmB5C,IAFX,CAAC,IAAM,EAAE,IAAM,EAAE,IAAM,EAAE,IAAM,EAAE,IAAM,EAAE,IAAM,EAAE,IAAM,EAAE,IAAM,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,EAAE,KAAO,GAEtkBA,IACtDE,EAASnsB,KAAK6uB,EAAmB5C,GAAW6B,EAAe7B,GAAS1c,MAAK,WACxEsf,EAAmB5C,GAAW,KAC5B,SAASvoC,GAEX,aADOmrC,EAAmB5C,GACpBvoC,O,cCzDT,IAAIqrC,EAAkB,CACrB,IAAK,GAGNtE,EAAoBuB,EAAEV,EAAI,SAASW,EAASE,GAE1C,IAAI6C,EAAqBvE,EAAoBmB,EAAEmD,EAAiB9C,GAAW8C,EAAgB9C,QAAW7jC,EACtG,GAA0B,IAAvB4mC,EAGF,GAAGA,EACF7C,EAASnsB,KAAKgvB,EAAmB,QAC3B,CAGL,IAAIxb,EAAU,IAAIzE,SAAQ,SAASC,EAAS+e,GAAUiB,EAAqBD,EAAgB9C,GAAW,CAACjd,EAAS+e,MAChH5B,EAASnsB,KAAKgvB,EAAmB,GAAKxb,GAGtC,IAAIvb,EAAMwyB,EAAoBoD,EAAIpD,EAAoB2B,EAAEH,GAEpDnZ,EAAQ,IAAI2b,MAgBhBhE,EAAoBmC,EAAE30B,GAfH,SAASwhB,GAC3B,GAAGgR,EAAoBmB,EAAEmD,EAAiB9C,KAEf,KAD1B+C,EAAqBD,EAAgB9C,MACR8C,EAAgB9C,QAAW7jC,GACrD4mC,GAAoB,CACtB,IAAIV,EAAY7U,IAAyB,SAAfA,EAAMx2B,KAAkB,UAAYw2B,EAAMx2B,MAChEgsC,EAAUxV,GAASA,EAAM91B,QAAU81B,EAAM91B,OAAO2U,IACpDwa,EAAMoc,QAAU,iBAAmBjD,EAAU,cAAgBqC,EAAY,KAAOW,EAAU,IAC1Fnc,EAAMhtB,KAAO,iBACbgtB,EAAM7vB,KAAOqrC,EACbxb,EAAM6b,QAAUM,EAChBD,EAAmB,GAAGlc,MAIgB,SAAWmZ,EAASA,KAclExB,EAAoBO,EAAEM,EAAI,SAASW,GAAW,OAAoC,IAA7B8C,EAAgB9C,IAGrE,IAAIkD,EAAuB,SAASC,EAA4BhrC,GAC/D,IAKIsmC,EAAUuB,EALVhB,EAAW7mC,EAAK,GAChBirC,EAAcjrC,EAAK,GACnBkrC,EAAUlrC,EAAK,GAGI4R,EAAI,EAC3B,GAAGi1B,EAASsE,MAAK,SAASxoC,GAAM,OAA+B,IAAxBgoC,EAAgBhoC,MAAe,CACrE,IAAI2jC,KAAY2E,EACZ5E,EAAoBmB,EAAEyD,EAAa3E,KACrCD,EAAoB3M,EAAE4M,GAAY2E,EAAY3E,IAGhD,GAAG4E,EAAS,IAAI5yB,EAAS4yB,EAAQ7E,GAGlC,IADG2E,GAA4BA,EAA2BhrC,GACrD4R,EAAIi1B,EAASrrB,OAAQ5J,IACzBi2B,EAAUhB,EAASj1B,GAChBy0B,EAAoBmB,EAAEmD,EAAiB9C,IAAY8C,EAAgB9C,IACrE8C,EAAgB9C,GAAS,KAE1B8C,EAAgB9C,GAAW,EAE5B,OAAOxB,EAAoBO,EAAEtuB,IAG1B8yB,EAAqBC,KAA0B,oBAAIA,KAA0B,qBAAK,GACtFD,EAAmBz9B,QAAQo9B,EAAqBv+B,KAAK,KAAM,IAC3D4+B,EAAmBxvB,KAAOmvB,EAAqBv+B,KAAK,KAAM4+B,EAAmBxvB,KAAKpP,KAAK4+B,I,GCpFvF,IAAIE,EAAsBjF,EAAoBO,OAAE5iC,EAAW,CAAC,KAAK,OAAO,WAAa,OAAOqiC,EAAoB,UAChHiF,EAAsBjF,EAAoBO,EAAE0E,G","sources":["components/icons/logo.tsx","components/NoMatch/index.tsx","components/Loading/index.tsx","components/VersionSelect/index.module.less","components/VersionSelect/index.tsx","webpack://website/./src/layouts/index.module.less?ec2c","webpack://website/./src/components/SiderMenu/index.module.less?215c","components/icons/nav.tsx","components/SiderMenu/index.tsx","webpack://website/./src/components/Nav/index.module.less?d89d","contexts/index.ts","components/icons/menu.tsx","components/Nav/index.tsx","layouts/BaseLayout.tsx","routers.tsx","index.tsx","../../packages/utils/src/noop.ts","../../packages/utils/src/getScroll.ts","../../packages/react-affix/src/utils.ts","../../packages/react-affix/src/index.tsx","../../packages/react-portal/src/index.tsx","../../packages/react-overlay/src/index.tsx","../../packages/react-icon/src/index.tsx","../../packages/react-button/src/index.tsx","../../packages/react-modal/src/index.tsx","../../packages/react-alert/src/index.tsx","../../packages/react-auto-link/src/index.tsx","../../packages/react-avatar/src/index.tsx","../../packages/react-back-top/src/utils.ts","../../packages/react-back-top/src/index.tsx","../../packages/react-badge/src/index.tsx","../../packages/react-breadcrumb/src/Item.tsx","../../packages/react-breadcrumb/src/Breadcrumb.tsx","../../packages/react-breadcrumb/src/index.ts","../../packages/react-button-group/src/index.tsx","../../packages/react-overlay-trigger/src/utils.ts","../../packages/react-overlay-trigger/src/util/getBordersSize.ts","../../packages/react-overlay-trigger/src/util/isBrowser.ts","../../packages/react-overlay-trigger/src/util/isIE.ts","../../packages/react-overlay-trigger/src/util/getWindowSizes.ts","../../packages/react-overlay-trigger/src/util/getBoundingClientRect.ts","../../packages/react-overlay-trigger/src/util/getClientRect.ts","../../packages/react-overlay-trigger/src/util/getStyleComputedProperty.ts","../../packages/react-overlay-trigger/src/util/getOuterSizes.ts","../../packages/react-overlay-trigger/src/getStyle.ts","../../packages/react-overlay-trigger/src/index.tsx","../../packages/react-popover/src/index.tsx","../../packages/react-input/src/index.tsx","../../packages/react-time-picker/src/Panel.tsx","../../packages/react-time-picker/src/Time.tsx","../../packages/react-time-picker/src/index.tsx","../../packages/react-date-picker/src/DatePickerDay.tsx","../../packages/react-date-picker/src/DatePickerMonth.tsx","../../packages/react-date-picker/src/DatePickerYear.tsx","../../packages/react-date-picker/src/DatePickerCaption.tsx","../../packages/react-date-picker/src/index.tsx","../../packages/react-calendar/src/DayLabel.tsx","../../packages/react-calendar/src/index.tsx","../../packages/react-card/src/index.tsx","../../packages/react-radio/src/RadioAbstract.tsx","../../packages/react-radio/src/Radio.tsx","../../packages/react-radio/src/RadioGroup.tsx","../../packages/react-checkbox/src/Group.tsx","../../packages/react-checkbox/src/Checkbox.tsx","../../packages/react-checkbox/src/index.ts","../../packages/react-collapse/src/Collapse.tsx","../../packages/react-collapse/src/Panel.tsx","../../packages/react-collapse/src/index.ts","../../packages/react-copy-to-clipboard/src/index.tsx","../../packages/react-date-input/src/DateInputRange.tsx","../../packages/react-date-input/src/index.tsx","../../packages/react-descriptions/src/DescriptionsItem.tsx","../../packages/react-descriptions/src/Cell.tsx","../../packages/react-descriptions/src/Row.tsx","../../packages/react-descriptions/src/index.tsx","../../packages/react-divider/src/index.tsx","../../packages/react-drawer/src/index.tsx","../../packages/react-dropdown/src/index.tsx","../../packages/react-empty/src/index.tsx","../../packages/react-file-input/src/Input.tsx","../../packages/react-file-input/src/List.tsx","../../packages/react-file-input/src/Card.tsx","../../packages/react-file-input/src/utils.ts","../../packages/react-file-input/src/FileList.tsx","../../packages/react-file-input/src/index.tsx","../../packages/react-grid/src/Col.tsx","../../packages/react-grid/src/Row.tsx","../../packages/react-form/src/FormItem.tsx","../../packages/react-form/src/Form.tsx","../../packages/react-form/src/index.ts","../../packages/react-list/src/Item.tsx","../../packages/react-list/src/index.tsx","../../packages/react-loader/src/index.tsx","../../packages/react-menu/src/MenuItem.tsx","../../packages/react-menu/src/Divider.tsx","../../packages/react-menu/src/SubMenu.tsx","../../packages/react-menu/src/Menu.tsx","../../packages/react-menu/src/index.ts","../../packages/react-message/src/index.tsx","../../packages/react-month-picker/src/index.tsx","../../packages/react-notify/src/Container.tsx","../../packages/react-notify/src/index.tsx","../../packages/utils/src/randomid.ts","../../packages/react-select/src/Option.tsx","../../packages/react-select/src/Group.tsx","../../packages/react-select/src/index.tsx","../../packages/react-pagination/src/index.tsx","../../packages/react-pin-code/src/index.tsx","../../packages/react-progress/src/utils.tsx","../../packages/react-progress/src/Circle.tsx","../../packages/react-progress/src/Line.tsx","../../packages/react-progress/src/index.ts","../../packages/react-rate/src/index.tsx","../../packages/react-tag/src/index.tsx","../../packages/react-search-select/src/index.tsx","../../packages/react-steps/src/Steps.tsx","../../packages/react-steps/src/Step.tsx","../../packages/react-steps/src/index.ts","../../packages/react-slider/src/Dots.tsx","../../packages/react-slider/src/index.tsx","../../packages/react-switch/src/index.tsx","../../packages/react-table/src/Thead.tsx","../../packages/react-table/src/util.ts","../../packages/react-table/src/index.tsx","../../packages/react-tabs/src/index.tsx","../../packages/react-tabs/src/Pane.tsx","../../packages/react-textarea/src/index.tsx","../../packages/react-tooltip/src/index.tsx","../../packages/react-tree/src/TreeNode.tsx","../../packages/react-tree/src/index.tsx","../../packages/react-tree-checked/src/index.tsx","../../packages/react-search-tree/src/SearchTagInput.tsx","../../packages/react-search-tree/src/index.tsx","../webpack/bootstrap","../webpack/runtime/chunk loaded","../webpack/runtime/compat get default export","../webpack/runtime/define property getters","../webpack/runtime/ensure chunk","../webpack/runtime/get javascript chunk filename","../webpack/runtime/get mini-css chunk filename","../webpack/runtime/global","../webpack/runtime/hasOwnProperty shorthand","../webpack/runtime/load script","../webpack/runtime/make namespace object","../webpack/runtime/publicPath","../webpack/runtime/css loading","../webpack/runtime/jsonp chunk loading","../webpack/startup"],"sourcesContent":["import React from 'react';\n\nconst logo = (\n <svg viewBox=\"0 0 20 20\" width=\"23\" height=\"23\" version=\"1.1\">\n <g stroke=\"none\" strokeWidth=\"1\" fill=\"none\" fillRule=\"evenodd\">\n <path\n d=\"M5.70480219,0 L10.4096044,3.41834667 L8.61252986,8.94934776 L2.79707453,8.94934776 L1,3.41834667 L5.70480219,0 Z M5.70480219,20 L1,16.5816533 L2.79707453,11.0506522 L8.61252986,11.0506522 L10.4096044,16.5816533 L5.70480219,20 Z M18.8709653,12.9678909 L13.3400514,14.7649021 L9.92167142,10.0599974 L13.3399103,5.35519519 L18.8708781,7.15237223 L18.8709653,12.9678909 Z\"\n fill=\"#FFFFFF\"\n />\n </g>\n </svg>\n);\n\nconst dark = logo;\n\nconst light = (\n <svg viewBox=\"0 0 20 20\" version=\"1.1\">\n <g stroke=\"none\" strokeWidth=\"1\" fill=\"none\" fillRule=\"evenodd\">\n <path\n d=\"M5.70480219,0 L10.4096044,3.41834667 L8.61252986,8.94934776 L2.79707453,8.94934776 L1,3.41834667 L5.70480219,0 Z M5.70480219,20 L1,16.5816533 L2.79707453,11.0506522 L8.61252986,11.0506522 L10.4096044,16.5816533 L5.70480219,20 Z M18.8709653,12.9678909 L13.3400514,14.7649021 L9.92167142,10.0599974 L13.3399103,5.35519519 L18.8708781,7.15237223 L18.8709653,12.9678909 Z\"\n fill=\"#FFFFFF\"\n />\n </g>\n </svg>\n);\n\nexport default {\n dark,\n light,\n};\n","import { Link } from 'react-router-dom';\n\nexport default function NoMatch() {\n return (\n <div>\n <h2>It looks like you're lost...</h2>\n <p>\n <Link to=\"/\">Go to the home page</Link>\n </p>\n </div>\n );\n}\n","import { Loader, Icon } from 'uiw';\n\nexport default function De() {\n return (\n <Loader tip=\"Loading...\" indicator={<Icon type=\"loading\" spin={true} style={{ verticalAlign: 'text-top' }} />} />\n );\n}\n","// extracted by mini-css-extract-plugin\nexport default {};","import React, { useMemo } from 'react';\nimport { Select } from 'uiw';\nimport pkg from 'uiw/package.json';\nimport styles from './index.module.less';\n\ntype OptionsProps = {\n version?: string;\n};\n\nfunction Options(props = {} as OptionsProps) {\n return useMemo(() => <Select.Option value={props.version}>{props.version}</Select.Option>, [props.version]);\n}\n\nexport type VersionSelectProps = {\n data: string[];\n};\n\nconst VersionSelect = (props = {} as VersionSelectProps) => {\n function onChange(e: React.ChangeEvent<HTMLSelectElement>) {\n const version = e.target.value;\n const isV1 = version.split('.')[0] === '1';\n if (isV1) {\n window.location.href = `https://unpkg.com/uiw@${version}/dist/index.html`;\n } else {\n window.location.href = `https://unpkg.com/@uiw/doc@${version}/web/index.html`;\n }\n }\n // @ts-ignore\n // eslint-disable-next-line no-undef\n const currentVersion = pkg.version;\n const versionList = props.data;\n const firstVersion = versionList[0];\n if (firstVersion !== currentVersion) {\n versionList.unshift(currentVersion);\n }\n return useMemo(\n () => (\n <div className={styles.nav}>\n <Select defaultValue={versionList[0]} onChange={onChange}>\n {versionList.map((version, idx) => {\n return <Options key={idx} version={version} />;\n })}\n </Select>\n </div>\n ),\n [versionList],\n );\n};\n\nexport default VersionSelect;\n","// extracted by mini-css-extract-plugin\nexport default {\"sider\":\"index_sider__vrASx\",\"menuWarpper\":\"index_menuWarpper__asOzy\",\"subMenu\":\"index_subMenu__c4Mvo\",\"layoutWrap\":\"index_layoutWrap__6CE3D\",\"layoutSider\":\"index_layoutSider__1t-SG\"};","// extracted by mini-css-extract-plugin\nexport default {\"title\":\"index_title__O5TzH\",\"menu\":\"index_menu__9HE8I\",\"divider\":\"index_divider__1cINS\"};","import React from 'react';\n\nexport default {\n home: (\n <svg width=\"23\" height=\"24\" viewBox=\"0 0 23 24\">\n <path\n fill=\"#555\"\n d=\"M7.95808665,21.4797568 L7.95808665,14.2926972 C7.95808665,13.872855 8.29729322,13.5325056 8.71572573,13.5325056 L14.7768383,13.5325056 C15.1952708,13.5325056 15.5344774,13.872855 15.5344774,14.2926972 L15.5344774,21.4800639 L18.3333605,21.4801773 C18.4412665,21.4760176 18.5251665,21.4671569 18.58271,21.4596448 C18.588514,21.3995182 18.5915777,21.3235793 18.5907536,21.2318213 L18.5909124,14.2893672 C18.590922,13.869525 18.9301364,13.5291834 19.3485689,13.5291931 C19.7670014,13.5292027 20.1062001,13.8695599 20.1061905,14.2894021 L20.1059996,21.2248359 C20.1119888,21.8771673 19.9896563,22.3494462 19.5993559,22.6516032 C19.3010239,22.8825616 18.9057568,22.9796164 18.3624477,23 L4.48346492,22.9997015 C3.86961191,22.9824374 3.38486601,22.8118189 3.07125061,22.4182996 C2.79329968,22.0695315 2.68322544,21.5965073 2.68425496,20.9934992 L2.68424909,14.2893853 C2.68424872,13.8695431 3.02345499,13.5291934 3.4418875,13.5291931 C3.86032001,13.5291927 4.19952687,13.8695418 4.19952724,14.289384 L4.199532,20.9947994 C4.19904359,21.2811808 4.23526541,21.4410529 4.2538782,21.4676906 C4.24030246,21.4480656 4.31738234,21.474056 4.50469304,21.4796169 L7.95808665,21.4797568 Z M9.4733648,21.4798183 L14.0191993,21.4800025 L14.0191993,15.0528888 L9.4733648,15.0528888 L9.4733648,21.4798183 Z M2.28332829,11.4133771 C1.98200714,11.7046849 1.50237937,11.6957445 1.21204968,11.3934082 C0.921719999,11.0910719 0.930630346,10.6098283 1.2319515,10.3185205 L10.4507678,1.41136668 C10.7833916,1.14885042 11.1310579,1 11.4999998,1 C11.9102569,1 12.2738276,1.19453217 12.5845816,1.51087139 L21.7658664,10.3164197 C22.0683439,10.6065186 22.0791684,11.0877227 21.7900436,11.3912192 C21.5009189,11.6947157 21.0213305,11.7055767 20.718853,11.4154779 L11.5218713,2.5944308 C11.4545418,2.52599021 11.4440624,2.52038312 11.4999998,2.52038312 C11.514622,2.52038312 11.4750696,2.53731716 11.4448602,2.55629655 L2.28332829,11.4133771 Z\"\n />\n </svg>\n ),\n component: (\n <svg viewBox=\"0 0 1041 1024\" width=\"20\" height=\"20\">\n <path\n d=\"M133.498105 661.882904h31.175644v195.047619a34.373146 34.373146 0 0 0 34.373146 34.373146h109.514441a34.373146 34.373146 0 1 0 0-68.746292h-75.141295V627.509758a35.172521 35.172521 0 0 0-34.373146-35.172521h-65.54879a63.950039 63.950039 0 0 1 0-127.900079h65.54879a35.172521 35.172521 0 0 0 34.373146-35.172521V233.417642h195.846994a35.172521 35.172521 0 0 0 35.172522-34.373146v-65.54879a63.950039 63.950039 0 0 1 127.900078 0v65.54879a35.172521 35.172521 0 0 0 35.172521 34.373146h195.047619v74.341921a34.373146 34.373146 0 0 0 68.746292 0V199.044496a34.373146 34.373146 0 0 0-34.373146-34.373145H661.885302v-31.175645a133.495706 133.495706 0 0 0-266.991413 0v31.175645H199.046895a34.373146 34.373146 0 0 0-34.373146 34.373145v195.846995h-31.175644A132.696331 132.696331 0 0 0 0.002398 527.587822a133.495706 133.495706 0 0 0 133.495707 134.295082z\"\n fill=\"#6F737E\"\n />\n <path\n d=\"M1004.817386 840.943013a79.937549 79.937549 0 1 1 0-159.875097 34.373146 34.373146 0 0 0 34.373146-32.774395V533.982826a34.373146 34.373146 0 0 0-34.373146-34.373146H879.315435v-10.391881a103.119438 103.119438 0 1 0-206.238876 0v10.391881H549.972734a35.172521 35.172521 0 0 0-35.172522 34.373146v124.702576h-10.391881a103.119438 103.119438 0 1 0 0 206.238876h10.391881v124.702576a35.172521 35.172521 0 0 0 35.172522 34.373146H663.484053a34.373146 34.373146 0 0 0 34.373146-34.373146 79.937549 79.937549 0 0 1 159.875098 0 34.373146 34.373146 0 0 0 34.373146 34.373146h114.310694a34.373146 34.373146 0 0 0 34.373146-34.373146V879.313037a34.373146 34.373146 0 0 0-35.971897-38.370024z\"\n fill=\"#6F737E\"\n />\n </svg>\n ),\n github: (\n <svg viewBox=\"0 0 1049 1024\" width=\"20\" height=\"20\">\n <path\n d=\"M524.979332 0C234.676191 0 0 234.676191 0 524.979332c0 232.068678 150.366597 428.501342 358.967656 498.035028 26.075132 5.215026 35.636014-11.299224 35.636014-25.205961 0-12.168395-0.869171-53.888607-0.869171-97.347161-146.020741 31.290159-176.441729-62.580318-176.441729-62.580318-23.467619-60.841976-58.234462-76.487055-58.234463-76.487055-47.804409-32.15933 3.476684-32.15933 3.476685-32.15933 53.019436 3.476684 80.83291 53.888607 80.83291 53.888607 46.935238 79.963739 122.553122 57.365291 152.97411 43.458554 4.345855-33.897672 18.252593-57.365291 33.028501-70.402857-116.468925-12.168395-239.022047-57.365291-239.022047-259.012982 0-57.365291 20.860106-104.300529 53.888607-140.805715-5.215026-13.037566-23.467619-66.926173 5.215027-139.067372 0 0 44.327725-13.906737 144.282399 53.888607 41.720212-11.299224 86.917108-17.383422 131.244833-17.383422s89.524621 6.084198 131.244833 17.383422C756.178839 203.386032 800.506564 217.29277 800.506564 217.29277c28.682646 72.1412 10.430053 126.029806 5.215026 139.067372 33.897672 36.505185 53.888607 83.440424 53.888607 140.805715 0 201.64769-122.553122 245.975415-239.891218 259.012982 19.121764 16.514251 35.636014 47.804409 35.636015 97.347161 0 70.402857-0.869171 126.898978-0.869172 144.282399 0 13.906737 9.560882 30.420988 35.636015 25.205961 208.601059-69.533686 358.967656-265.96635 358.967655-498.035028C1049.958663 234.676191 814.413301 0 524.979332 0z\"\n fill=\"#191717\"\n />\n <path\n d=\"M199.040177 753.571326c-0.869171 2.607513-5.215026 3.476684-8.691711 1.738342s-6.084198-5.215026-4.345855-7.82254c0.869171-2.607513 5.215026-3.476684 8.691711-1.738342s5.215026 5.215026 4.345855 7.82254z m-6.953369-4.345856M219.900283 777.038945c-2.607513 2.607513-7.82254 0.869171-10.430053-2.607514-3.476684-3.476684-4.345855-8.691711-1.738342-11.299224 2.607513-2.607513 6.953369-0.869171 10.430053 2.607514 3.476684 4.345855 4.345855 9.560882 1.738342 11.299224z m-5.215026-5.215027M240.760389 807.459932c-3.476684 2.607513-8.691711 0-11.299224-4.345855-3.476684-4.345855-3.476684-10.430053 0-12.168395 3.476684-2.607513 8.691711 0 11.299224 4.345855 3.476684 4.345855 3.476684 9.560882 0 12.168395z m0 0M269.443034 837.011749c-2.607513 3.476684-8.691711 2.607513-13.906737-1.738342-4.345855-4.345855-6.084198-10.430053-2.607513-13.037566 2.607513-3.476684 8.691711-2.607513 13.906737 1.738342 4.345855 3.476684 5.215026 9.560882 2.607513 13.037566z m0 0M308.555733 853.526c-0.869171 4.345855-6.953369 6.084198-13.037566 4.345855-6.084198-1.738342-9.560882-6.953369-8.691711-10.430053 0.869171-4.345855 6.953369-6.084198 13.037566-4.345855 6.084198 1.738342 9.560882 6.084198 8.691711 10.430053z m0 0M351.145116 857.002684c0 4.345855-5.215026 7.82254-11.299224 7.82254-6.084198 0-11.299224-3.476684-11.299224-7.82254s5.215026-7.82254 11.299224-7.82254c6.084198 0 11.299224 3.476684 11.299224 7.82254z m0 0M391.126986 850.049315c0.869171 4.345855-3.476684 8.691711-9.560882 9.560882-6.084198 0.869171-11.299224-1.738342-12.168395-6.084197-0.869171-4.345855 3.476684-8.691711 9.560881-9.560882 6.084198-0.869171 11.299224 1.738342 12.168396 6.084197z m0 0\"\n fill=\"#191717\"\n />\n </svg>\n ),\n issue: (\n <svg className=\"issue\" viewBox=\"0 0 1024 1024\" width=\"23\" height=\"23\">\n <path\n d=\"M1022.976 698.368c0-58.88-24.064-113.664-64.512-155.648-44.544 175.616-223.744 307.2-438.784 310.784 51.712 55.296 131.072 90.624 219.648 90.624 21.504 0 41.984-2.048 61.952-6.144 54.784 75.776 121.856 72.192 121.856 72.192-24.064-14.848-27.136-69.632-26.112-108.032 76.288-44.032 125.952-119.296 125.952-203.776z m0 0\"\n fill=\"#558EFF\"\n ></path>\n <path\n d=\"M458.24 13.824C205.312 13.824 0 191.488 0 410.624c0 137.216 80.384 258.048 202.24 329.216 1.536 61.44-3.584 150.016-41.984 174.592 0 0 108.544 5.632 197.12-116.736 32.256 6.144 66.048 9.728 100.352 9.728H465.92c215.04-3.584 394.24-135.168 438.784-310.784 7.168-27.648 10.752-56.32 10.752-86.016 0.512-219.136-204.288-396.8-457.216-396.8zM256 462.848c-33.792 0-60.928-27.136-60.928-60.928 0-33.792 27.136-60.928 60.928-60.928 33.792 0 60.928 27.136 60.928 60.928 0 33.792-27.136 60.928-60.928 60.928z m202.24 0c-33.792 0-60.928-27.136-60.928-60.928 0-33.792 27.136-60.928 60.928-60.928 33.792 0 60.928 27.136 60.928 60.928 0 33.792-27.136 60.928-60.928 60.928z m202.24 0c-33.792 0-60.928-27.136-60.928-60.928 0-33.792 27.136-60.928 60.928-60.928 33.792 0 60.928 27.136 60.928 60.928 0 33.792-27.136 60.928-60.928 60.928z m0 0\"\n fill=\"#549EFF\"\n ></path>\n </svg>\n ),\n gitee: (\n <svg className=\"gitee\" viewBox=\"0 0 1024 1024\" width=\"200\" height=\"200\">\n <path\n d=\"M512 1024C229.222 1024 0 794.778 0 512S229.222 0 512 0s512 229.222 512 512-229.222 512-512 512z m259.149-568.883h-290.74a25.293 25.293 0 0 0-25.292 25.293l-0.026 63.206c0 13.952 11.315 25.293 25.267 25.293h177.024c13.978 0 25.293 11.315 25.293 25.267v12.646a75.853 75.853 0 0 1-75.853 75.853h-240.23a25.293 25.293 0 0 1-25.267-25.293V417.203a75.853 75.853 0 0 1 75.827-75.853h353.946a25.293 25.293 0 0 0 25.267-25.292l0.077-63.207a25.293 25.293 0 0 0-25.268-25.293H417.152a189.62 189.62 0 0 0-189.62 189.645V771.15c0 13.977 11.316 25.293 25.294 25.293h372.94a170.65 170.65 0 0 0 170.65-170.65V480.384a25.293 25.293 0 0 0-25.293-25.267z\"\n fill=\"#C71D23\"\n ></path>\n </svg>\n ),\n plugin: (\n <svg viewBox=\"0 0 1024 1024\" width=\"24\" height=\"24\">\n <path d=\"M937.6 251.3L538 69.7c-11.5-5.1-24.6-5.1-36.1 0L102.4 251.3c-22.4 9.9-32.5 32.2-22.6 54.6 4.5 10.1 12.5 15.1 22.6 19.6L502 506.1c11.5 5.1 24.6 5.1 36.1 0l399.6-180.6c22.4-9.9 32.5-33.2 22.6-55.6-4.6-10.1-12.6-14.1-22.7-18.6zM497.6 723.4l-398.7-165c-18.4-7.6-27.1-28.7-19.5-47 7.6-18.4 28.7-27.1 47-19.5l398.7 165c18.4 7.6 27.1 28.7 19.5 47-7.6 18.3-28.6 27.1-47 19.5z\" />\n <path d=\"M526.4 723.4l398.7-165c18.4-7.6 27.1-28.7 19.5-47-7.6-18.4-28.7-27.1-47-19.5l-398.7 165c-18.4 7.6-27.1 28.7-19.5 47 7.6 18.3 28.6 27.1 47 19.5z\" />\n <path d=\"M497.6 955.4l-398.7-165c-18.4-7.6-27.1-28.7-19.5-47 7.6-18.4 28.7-27.1 47-19.5l398.7 165c18.4 7.6 27.1 28.7 19.5 47-7.6 18.3-28.6 27.1-47 19.5z\" />\n <path d=\"M526.4 955.4l398.7-165c18.4-7.6 27.1-28.7 19.5-47-7.6-18.4-28.7-27.1-47-19.5l-398.7 165c-18.4 7.6-27.1 28.7-19.5 47 7.6 18.3 28.6 27.1 47 19.5z\" />\n </svg>\n ),\n};\n","import { NavLink } from 'react-router-dom';\nimport { useLocation } from 'react-router-dom';\nimport styles from './index.module.less';\nimport menu from '../../menu.json';\nimport nav from '../icons/nav';\n\nexport default function SiderMenu() {\n const location = useLocation();\n const data = menu.find((item) => new RegExp(`^${item.path || ''}`).test(location.pathname));\n\n if (!data?.children) {\n return null;\n }\n return (\n <div className={styles.wapper}>\n <h2 className={styles.title}>\n {(nav as any)[data.icon]}\n <span>{data.name}</span>\n </h2>\n <div className={styles.menu}>\n {data.children &&\n data.children.map((item, idx) => {\n if (item.divider) {\n return (\n <div key={idx} className={styles.divider}>\n {item.name}\n </div>\n );\n }\n if (/^http(?:|s):\\/\\//.test(item.path || '')) {\n return (\n <a key={idx} href={item.path} target=\"__blank\">\n {item.name}\n <svg viewBox=\"0 0 1024 1024\" width={14}>\n <path d=\"M821.1456 276.8384c-235.9296 25.1392-449.1776 226.7136-490.5472 452.352a38.4 38.4 0 1 1-75.5712-13.824c45.568-248.576 269.312-468.48 526.6944-510.6688l-117.8112-69.1712a38.4 38.4 0 0 1 38.912-66.2528l223.3344 131.1744a38.4 38.4 0 0 1 10.1376 57.6l-170.752 206.6432a38.4 38.4 0 1 1-59.1872-48.9472l114.7904-138.9056z\" />\n <path d=\"M832 620.0832a38.4 38.4 0 0 1 76.8 0v158.208c0 85.9648-61.5936 157.8496-140.8 157.8496H204.8c-79.2064 0-140.8-71.8848-140.8-157.9008V300.3904c0-86.016 61.5936-157.8496 140.8-157.8496h220.2112a38.4 38.4 0 1 1 0 76.8H204.8c-33.8944 0-64 35.072-64 81.0496V778.24c0 45.9776 30.1056 81.1008 64 81.1008h563.2c33.8944 0 64-35.1232 64-81.1008v-158.1568z\" />\n </svg>\n </a>\n );\n }\n return (\n <NavLink key={idx} to={item.path || ''} replace>\n {item.name}\n </NavLink>\n );\n })}\n </div>\n </div>\n );\n}\n","// extracted by mini-css-extract-plugin\nexport default {\"logo\":\"index_logo__kUQOi\",\"top\":\"index_top__DLxV-\",\"nav\":\"index_nav__SdXbb\",\"navTop\":\"index_navTop__08yh1\",\"btn\":\"index_btn__YYGUe\",\"btnTop\":\"index_btnTop__PlNw6\"};","import React from 'react';\n\ntype InitialState = {\n layout: 'top' | 'left' | 'mix';\n};\n\nexport const initialState: InitialState = {\n layout: 'top',\n};\n\nexport const reducer = (state: InitialState, action: InitialState) => {\n return {\n ...state,\n ...action,\n };\n};\n\nexport interface Context {\n state: InitialState;\n dispatch: React.Dispatch<InitialState>;\n}\n\nexport const ThemeContext = React.createContext<Context>({\n state: initialState,\n dispatch: () => null,\n});\n","import React from 'react';\n\nexport default {\n menu: (\n <svg width=\"19\" height=\"19\" viewBox=\"0 0 26 26\">\n <g fill=\"none\" fillRule=\"evenodd\">\n <rect width=\"26\" height=\"26\" fill=\"#9E9E9E\" rx=\"4\" />\n <rect width=\"5\" height=\"20\" x=\"3\" y=\"3\" fill=\"#202224\" rx=\"2.5\" />\n <rect width=\"12\" height=\"20\" x=\"11\" y=\"3\" fill=\"#FFF\" fillOpacity=\".657\" rx=\"2\" />\n </g>\n </svg>\n ),\n menutop: (\n <svg width=\"19\" height=\"19\" viewBox=\"0 0 26 26\">\n <g fill=\"none\" fillRule=\"evenodd\">\n <rect width=\"26\" height=\"26\" fill=\"#9E9E9E\" rx=\"4\" />\n <rect width=\"20\" height=\"5\" x=\"3\" y=\"3\" fill=\"#202224\" rx=\"2.5\" />\n <rect width=\"20\" height=\"12\" x=\"3\" y=\"11\" fill=\"#FFF\" fillOpacity=\".66\" rx=\"2\" />\n </g>\n </svg>\n ),\n china: (\n <svg className=\"flag\" width=\"19\" height=\"19\" viewBox=\"0 0 512 512\">\n <defs>\n <path id=\"a\" fill=\"#ffde00\" d=\"M1-.3L-.7.8 0-1 .6.8-1-.3z\" />\n </defs>\n <path fill=\"#de2910\" d=\"M0 0h512v512H0z\" />\n <use width=\"30\" height=\"20\" transform=\"matrix(76.8 0 0 76.8 128 128)\" xlinkHref=\"#a\" />\n <use width=\"30\" height=\"20\" transform=\"rotate(-121 142.6 -47) scale(25.5827)\" xlinkHref=\"#a\" />\n <use width=\"30\" height=\"20\" transform=\"rotate(-98.1 198 -82) scale(25.6)\" xlinkHref=\"#a\" />\n <use width=\"30\" height=\"20\" transform=\"rotate(-74 272.4 -114) scale(25.6137)\" xlinkHref=\"#a\" />\n <use width=\"30\" height=\"20\" transform=\"matrix(16 -19.968 19.968 16 256 230.4)\" xlinkHref=\"#a\" />\n </svg>\n ),\n};\n","import { Fragment, useContext } from 'react';\nimport { Tooltip } from 'uiw';\nimport { NavLink, Link } from 'react-router-dom';\nimport styles from './index.module.less';\nimport data from '../../menu.json';\nimport { ThemeContext } from '../../contexts';\nimport nav from '../icons/nav';\nimport logo from '../icons/logo';\nimport menu from '../icons/menu';\nimport pkg from 'uiw/package.json';\n\nexport default function Nav() {\n const { state, dispatch } = useContext(ThemeContext);\n return (\n <Fragment>\n <div className={[styles.logo, state.layout === 'left' ? null : styles.top].filter(Boolean).join(' ').trim()}>\n <Link to=\"/\">\n {logo.dark}\n {state.layout === 'top' && (\n <span>\n UIW<sup>{pkg.version}</sup>\n </span>\n )}\n </Link>\n </div>\n <div className={[styles.nav, state.layout === 'left' ? null : styles.navTop].filter(Boolean).join(' ').trim()}>\n {data.map(({ path, name, icon }, idx) => {\n if (Object.keys(nav).includes(icon)) {\n icon = (nav as any)[icon];\n }\n if (/^https?:(?:\\/\\/)?/.test(path)) {\n if (state.layout === 'top') {\n return (\n <a key={idx} target=\"__blank\" href={path} className={styles.outerUrl}>\n {icon} <span>{name}</span>\n </a>\n );\n }\n return (\n <Tooltip\n usePortal={false}\n key={idx}\n placement={state.layout === 'left' ? 'right' : 'bottom'}\n content={<span style={{ whiteSpace: 'nowrap' }}>{name}</span>}\n >\n <a target=\"__blank\" href={path} className={styles.outerUrl}>\n {icon}\n </a>\n </Tooltip>\n );\n }\n let activeStyle: React.CSSProperties = {\n color: '#fff',\n };\n if (state.layout === 'top') {\n return (\n <NavLink\n to={path}\n key={idx}\n // @ts-ignore\n style={({ isActive }) => (isActive ? activeStyle : undefined)}\n >\n {icon} <span>{name}</span>\n </NavLink>\n );\n }\n\n return (\n <Tooltip\n usePortal={false}\n key={idx}\n placement={state.layout === 'left' ? 'right' : 'bottom'}\n content={<span style={{ whiteSpace: 'nowrap' }}>{name}</span>}\n >\n <NavLink\n to={path}\n // @ts-ignore\n style={({ isActive }) => (isActive ? activeStyle : undefined)}\n >\n {icon}\n </NavLink>\n </Tooltip>\n );\n })}\n </div>\n <div className={[styles.btn, state.layout === 'left' ? null : styles.btnTop].filter(Boolean).join(' ').trim()}>\n <Tooltip placement={state.layout === 'left' ? 'right' : 'bottom'} content=\"国内镜像站点\">\n <a href=\"http://uiw.gitee.io\" rel=\"noopener noreferrer\" target=\"_blank\">\n {menu.china}\n </a>\n </Tooltip>\n <button onClick={() => dispatch({ layout: state.layout === 'left' ? 'top' : 'left' })}>\n {state.layout === 'left' ? menu.menu : menu.menutop}\n </button>\n </div>\n </Fragment>\n );\n}\n","import { Fragment, useContext } from 'react';\nimport { Outlet } from 'react-router-dom';\nimport { Layout, Affix } from 'uiw';\nimport VersionSelect from '../components/VersionSelect';\nimport styles from './index.module.less';\nimport version from '../version.json';\nimport SiderMenu from '../components/SiderMenu';\nimport Nav from '../components/Nav';\nimport { ThemeContext } from '../contexts';\n\nconst { Header, Sider, Content } = Layout;\nexport interface ComponentsProps {\n siderMenu?: boolean;\n}\n\nexport default function Components(props: ComponentsProps) {\n const { siderMenu = true } = props;\n const { state } = useContext(ThemeContext);\n return (\n <Layout className={styles.layout}>\n {state.layout === 'top' ? (\n <Fragment>\n <Affix offsetTop={0} style={{ zIndex: 999 }}>\n <Header style={{ display: 'flex', alignItems: 'center' }}>\n <Nav />\n </Header>\n </Affix>\n <Layout className={styles.layoutWrap}>\n <Sider width={siderMenu ? 260 : 0} className={styles.layoutSider}>\n <div style={{ width: siderMenu ? 260 : 0, height: 'calc(100vh - 53px)' }}>\n <SiderMenu />\n </div>\n </Sider>\n <Content style={{ padding: 20 }} className={styles.layoutContent}>\n <Outlet />\n </Content>\n </Layout>\n </Fragment>\n ) : (\n <Fragment>\n <Sider width={siderMenu ? 330 : 64}>\n <Layout className={styles.sider}>\n <Sider className={styles.menuWarpper} width={64}>\n <Nav />\n </Sider>\n <Layout\n style={{\n position: 'fixed',\n width: siderMenu ? 330 : 64,\n zIndex: 1,\n left: 0,\n top: 0,\n bottom: 0,\n overflow: 'auto',\n }}\n >\n <Content className={styles.subMenu} style={{ paddingLeft: 64 }}>\n <SiderMenu />\n </Content>\n </Layout>\n </Layout>\n </Sider>\n <Layout style={{ position: 'relative' }}>\n <Header\n style={{\n height: 'inherit',\n lineHeight: '32px',\n position: 'absolute',\n padding: '5px 10px',\n width: '100%',\n display: 'flex',\n flexDirection: 'row',\n justifyContent: 'flex-end',\n backgroundColor: 'transparent',\n zIndex: 99,\n }}\n >\n <VersionSelect data={version} />\n </Header>\n <Content style={{ padding: 20 }} className={styles.layoutContent}>\n <Outlet />\n </Content>\n </Layout>\n </Fragment>\n )}\n </Layout>\n );\n}\n","import { lazy, Suspense } from 'react';\nimport { RouteObject } from 'react-router-dom';\nimport NoMatch from './components/NoMatch';\nimport Loading from './components/Loading';\nimport BaseLayout from './layouts/BaseLayout';\n\nconst Loadable = (Component: any) => (props: any) =>\n (\n <Suspense fallback={<Loading />}>\n <Component {...props} />\n </Suspense>\n );\n\nconst Home = Loadable(lazy(() => import('./routes/home')));\nconst Extensions = Loadable(lazy(() => import('./routes/extensions')));\n\nconst GuideQuickStart = Loadable(lazy(() => import('./routes/guide/quick-start')));\nconst GuideImport = Loadable(lazy(() => import('./routes/guide/import')));\nconst GuideCreateReactApp = Loadable(lazy(() => import('./routes/guide/create-react-app')));\nconst GuideKKT = Loadable(lazy(() => import('./routes/guide/kkt')));\nconst GuideDocs = Loadable(lazy(() => import('./routes/guide/docs')));\nconst GuideVscode = Loadable(lazy(() => import('./routes/guide/vscode')));\nconst GuideRecommendation = Loadable(lazy(() => import('./routes/guide/recommendation')));\n\nconst Overview = Loadable(lazy(() => import('./routes/overview')));\nconst Colors = Loadable(lazy(() => import('./routes/components/colors')));\nconst Alert = Loadable(lazy(() => import('./routes/components/alert')));\nconst AutoLink = Loadable(lazy(() => import('./routes/components/auto-link')));\nconst ResetCss = Loadable(lazy(() => import('./routes/components/reset-css')));\nconst Avatar = Loadable(lazy(() => import('./routes/components/avatar')));\nconst Affix = Loadable(lazy(() => import('./routes/components/affix')));\nconst Calendar = Loadable(lazy(() => import('./routes/components/calendar')));\nconst Checkbox = Loadable(lazy(() => import('./routes/components/checkbox')));\nconst CopyToClipboard = Loadable(lazy(() => import('./routes/components/copy-to-clipboard')));\nconst Collapse = Loadable(lazy(() => import('./routes/components/collapse')));\nconst Card = Loadable(lazy(() => import('./routes/components/card')));\nconst Descriptions = Loadable(lazy(() => import('./routes/components/descriptions')));\nconst Loader = Loadable(lazy(() => import('./routes/components/loader')));\nconst Icon = Loadable(lazy(() => import('./routes/components/icon')));\nconst Divider = Loadable(lazy(() => import('./routes/components/divider')));\nconst Drawer = Loadable(lazy(() => import('./routes/components/drawer')));\nconst DatePicker = Loadable(lazy(() => import('./routes/components/date-picker')));\nconst DateInput = Loadable(lazy(() => import('./routes/components/date-input')));\nconst Dropdown = Loadable(lazy(() => import('./routes/components/dropdown')));\nconst Badge = Loadable(lazy(() => import('./routes/components/badge')));\nconst Progress = Loadable(lazy(() => import('./routes/components/progress')));\nconst Pagination = Loadable(lazy(() => import('./routes/components/pagination')));\nconst PinCode = Loadable(lazy(() => import('./routes/components/pin-code')));\nconst Input = Loadable(lazy(() => import('./routes/components/input')));\nconst Button = Loadable(lazy(() => import('./routes/components/button')));\nconst Radio = Loadable(lazy(() => import('./routes/components/radio')));\nconst Select = Loadable(lazy(() => import('./routes/components/select')));\nconst SearchSelect = Loadable(lazy(() => import('./routes/components/search-select')));\nconst Split = Loadable(lazy(() => import('./routes/components/split')));\nconst Switch = Loadable(lazy(() => import('./routes/components/switch')));\nconst Slider = Loadable(lazy(() => import('./routes/components/slider')));\nconst Grid = Loadable(lazy(() => import('./routes/components/grid')));\nconst Form = Loadable(lazy(() => import('./routes/components/form')));\nconst FileInput = Loadable(lazy(() => import('./routes/components/file-input')));\nconst Breadcrumb = Loadable(lazy(() => import('./routes/components/breadcrumb')));\nconst List = Loadable(lazy(() => import('./routes/components/list')));\nconst Layout = Loadable(lazy(() => import('./routes/components/layout')));\nconst Notify = Loadable(lazy(() => import('./routes/components/notify')));\nconst Tree = Loadable(lazy(() => import('./routes/components/tree')));\nconst TreeChecked = Loadable(lazy(() => import('./routes/components/tree-checked')));\nconst SearchTree = Loadable(lazy(() => import('./routes/components/search-tree')));\nconst Tag = Loadable(lazy(() => import('./routes/components/tag')));\nconst Tabs = Loadable(lazy(() => import('./routes/components/tabs')));\nconst Tooltip = Loadable(lazy(() => import('./routes/components/tooltip')));\nconst Table = Loadable(lazy(() => import('./routes/components/table')));\nconst TimePicker = Loadable(lazy(() => import('./routes/components/time-picker')));\nconst Rate = Loadable(lazy(() => import('./routes/components/rate')));\nconst Overlay = Loadable(lazy(() => import('./routes/components/overlay')));\nconst BackTop = Loadable(lazy(() => import('./routes/components/back-top')));\nconst Portal = Loadable(lazy(() => import('./routes/components/portal')));\nconst OverlayTrigger = Loadable(lazy(() => import('./routes/components/overlay-trigger')));\nconst Popover = Loadable(lazy(() => import('./routes/components/popover')));\nconst Message = Loadable(lazy(() => import('./routes/components/message')));\nconst MonthPicker = Loadable(lazy(() => import('./routes/components/month-picker')));\nconst Textarea = Loadable(lazy(() => import('./routes/components/textarea')));\nconst Modal = Loadable(lazy(() => import('./routes/components/modal')));\nconst Formatter = Loadable(lazy(() => import('./routes/components/formatter')));\nconst Steps = Loadable(lazy(() => import('./routes/components/steps')));\nconst Menu = Loadable(lazy(() => import('./routes/components/menu')));\nconst Empty = Loadable(lazy(() => import('./routes/components/empty')));\n\nexport const routes: RouteObject[] = [\n {\n path: '/extensions',\n element: <BaseLayout siderMenu={false} />,\n children: [\n { index: true, element: <Extensions /> },\n { path: '*', element: <NoMatch /> },\n ],\n },\n {\n path: '/guide',\n element: <BaseLayout />,\n children: [\n { index: true, element: <GuideQuickStart /> },\n { path: '/guide/quick-start', element: <GuideQuickStart /> },\n { path: '/guide/import', element: <GuideImport /> },\n { path: '/guide/create-react-app', element: <GuideCreateReactApp /> },\n { path: '/guide/kkt', element: <GuideKKT /> },\n { path: '/guide/vscode', element: <GuideVscode /> },\n { path: '/guide/docs', element: <GuideDocs /> },\n { path: '/guide/recommendation', element: <GuideRecommendation /> },\n { path: '*', element: <NoMatch /> },\n ],\n },\n {\n path: '/components',\n element: <BaseLayout />,\n children: [\n { index: true, element: <Overview /> },\n { path: '/components/overview', element: <Overview /> },\n { path: '/components/colors', element: <Colors /> },\n { path: '/components/reset-css', element: <ResetCss /> },\n { path: '/components/alert', element: <Alert /> },\n { path: '/components/auto-link', element: <AutoLink /> },\n { path: '/components/avatar', element: <Avatar /> },\n { path: '/components/affix', element: <Affix /> },\n { path: '/components/calendar', element: <Calendar /> },\n { path: '/components/checkbox', element: <Checkbox /> },\n { path: '/components/copy-to-clipboard', element: <CopyToClipboard /> },\n { path: '/components/collapse', element: <Collapse /> },\n { path: '/components/card', element: <Card /> },\n { path: '/components/descriptions', element: <Descriptions /> },\n { path: '/components/loader', element: <Loader /> },\n { path: '/components/icon', element: <Icon /> },\n { path: '/components/divider', element: <Divider /> },\n { path: '/components/drawer', element: <Drawer /> },\n { path: '/components/date-picker', element: <DatePicker /> },\n { path: '/components/date-input', element: <DateInput /> },\n { path: '/components/dropdown', element: <Dropdown /> },\n { path: '/components/badge', element: <Badge /> },\n { path: '/components/progress', element: <Progress /> },\n { path: '/components/pagination', element: <Pagination /> },\n { path: '/components/pin-code', element: <PinCode /> },\n { path: '/components/input', element: <Input /> },\n { path: '/components/button', element: <Button /> },\n { path: '/components/radio', element: <Radio /> },\n { path: '/components/select', element: <Select /> },\n { path: '/components/search-select', element: <SearchSelect /> },\n { path: '/components/split', element: <Split /> },\n { path: '/components/switch', element: <Switch /> },\n { path: '/components/slider', element: <Slider /> },\n { path: '/components/grid', element: <Grid /> },\n { path: '/components/form', element: <Form /> },\n { path: '/components/file-input', element: <FileInput /> },\n { path: '/components/breadcrumb', element: <Breadcrumb /> },\n { path: '/components/list', element: <List /> },\n { path: '/components/layout', element: <Layout /> },\n { path: '/components/notify', element: <Notify /> },\n { path: '/components/tree', element: <Tree /> },\n { path: '/components/tree-checked', element: <TreeChecked /> },\n { path: '/components/search-tree', element: <SearchTree /> },\n { path: '/components/tag', element: <Tag /> },\n { path: '/components/tabs', element: <Tabs /> },\n { path: '/components/tooltip', element: <Tooltip /> },\n { path: '/components/table', element: <Table /> },\n { path: '/components/time-picker', element: <TimePicker /> },\n { path: '/components/rate', element: <Rate /> },\n { path: '/components/overlay', element: <Overlay /> },\n { path: '/components/back-top', element: <BackTop /> },\n { path: '/components/portal', element: <Portal /> },\n { path: '/components/overlay-trigger', element: <OverlayTrigger /> },\n { path: '/components/popover', element: <Popover /> },\n { path: '/components/message', element: <Message /> },\n { path: '/components/month-picker', element: <MonthPicker /> },\n { path: '/components/textarea', element: <Textarea /> },\n { path: '/components/modal', element: <Modal /> },\n { path: '/components/formatter', element: <Formatter /> },\n { path: '/components/steps', element: <Steps /> },\n { path: '/components/menu', element: <Menu /> },\n { path: '/components/empty', element: <Empty /> },\n { path: '*', element: <NoMatch /> },\n ],\n },\n {\n path: '/',\n element: <Home />,\n },\n];\n","import React, { useReducer } from 'react';\nimport ReactDOM from 'react-dom';\nimport { useRoutes, HashRouter } from 'react-router-dom';\nimport '@uiw/reset.css';\nimport { routes } from './routers';\nimport './styles/index.less';\nimport { ThemeContext, reducer, initialState } from './contexts';\n\nconst App = () => useRoutes(routes);\nexport const Provider = ({ children }: { children: React.ReactNode }) => {\n const [state, dispatch] = useReducer(reducer, initialState);\n return <ThemeContext.Provider value={{ state, dispatch }}>{children}</ThemeContext.Provider>;\n};\n\nReactDOM.render(\n <HashRouter>\n <Provider>\n <App />\n </Provider>\n </HashRouter>,\n document.getElementById('root'),\n);\n","export function noop() {}\n","/**\n * Gets the scroll value of the given element in the given side (top and left)\n * @method\n * @memberof Popper.Utils\n * @argument {Element} element\n * @argument {String} top `true` or `false`\n * @returns {number} amount of scrolled pixels\n */\nexport function getScroll(target: HTMLElement | Window | null, top?: boolean) {\n if (typeof window === 'undefined') {\n return 0;\n }\n\n const prop = top ? 'pageYOffset' : 'pageXOffset';\n const method = top ? 'scrollTop' : 'scrollLeft';\n const isWindow: boolean = target === window;\n\n let ret = isWindow ? (target as Window)[prop] : (target as HTMLElement)[method];\n if (isWindow && typeof ret !== 'number') {\n ret = document.documentElement[method];\n }\n\n return ret;\n}\n","import { getScroll } from '@uiw/utils';\n\nexport const getTargetRect = (target: HTMLElement | Window | null) => {\n return target !== window\n ? (target as HTMLElement).getBoundingClientRect()\n : ({ top: 0, left: 0, bottom: 0 } as ClientRect);\n};\n\nexport const getOffset = (element: HTMLElement, target: HTMLElement | Window | null) => {\n const elemRect = element.getBoundingClientRect();\n const targetRect = getTargetRect(target);\n const scrollTop = getScroll(target, true);\n const scrollLeft = getScroll(target);\n\n const docElem = window.document.body;\n const clientTop = docElem.clientTop || 0;\n const clientLeft = docElem.clientLeft || 0;\n\n return {\n top: elemRect.top - targetRect.top + scrollTop - clientTop,\n left: elemRect.left - targetRect.left + scrollLeft - clientLeft,\n width: elemRect.width,\n height: elemRect.height,\n };\n};\n\nexport const getDefaultTarget = () => (typeof window !== 'undefined' ? window : null);\n","import React from 'react';\nimport { IProps, HTMLDivProps, noop } from '@uiw/utils';\nimport { getDefaultTarget, getOffset } from './utils';\n\nexport interface AffixProps extends IProps, Omit<HTMLDivProps, 'onChange'> {\n /**\n * 距离窗口顶部达到指定偏移量后触发\n */\n offsetTop?: number;\n /**\n * 距离窗口底部达到指定偏移量后触发\n */\n offsetBottom?: number;\n target?: () => Window | HTMLElement | null;\n /**\n * 固定状态改变时触发的回调函数\n */\n onChange?: (affixed?: boolean) => void;\n}\n\nexport interface AffixState {\n affixStyle?: React.CSSProperties;\n placeholderStyle?: React.CSSProperties;\n}\n\nexport default class Affix extends React.Component<AffixProps, AffixState> {\n public static defaultProps: AffixProps = {\n prefixCls: 'w-affix',\n onChange: noop,\n };\n public state: AffixState = {\n placeholderStyle: undefined,\n affixStyle: undefined,\n };\n private box: any;\n private target!: Window | HTMLElement | null;\n private readonly events = ['resize', 'scroll', 'touchstart', 'touchmove', 'touchend', 'pageshow', 'load'];\n private eventHandlers: Record<string, any> = {};\n private timeout?: number;\n constructor(props: AffixProps & HTMLDivProps) {\n super(props);\n this.updatePosition = this.updatePosition.bind(this);\n }\n componentDidMount() {\n const target = this.props.target || getDefaultTarget;\n // Wait for parent component ref has its value\n this.timeout = window.setTimeout(() => {\n this.target = target();\n this.setTargetEventListeners();\n });\n }\n componentWillUnmount() {\n this.clearEventListeners();\n clearTimeout(this.timeout);\n }\n updatePosition() {\n let { offsetTop } = this.props;\n const { offsetBottom } = this.props;\n if (!this.box || !this.box.offsetParent) {\n return;\n }\n\n const elemSize = {\n width: this.box.clientWidth,\n height: this.box.clientHeight,\n };\n const offsetMode = { top: true, bottom: false };\n if (typeof offsetTop !== 'number' && typeof offsetBottom !== 'number') {\n offsetMode.top = true;\n offsetTop = 0;\n }\n\n if (typeof offsetBottom === 'number') {\n offsetMode.top = false;\n offsetMode.bottom = true;\n }\n\n const elemOffset = getOffset(this.box, this.target);\n const box = this.box.getBoundingClientRect();\n const bottom = document.documentElement.clientHeight - box.y - elemOffset.height;\n\n if (offsetMode.top && box.y < 0) {\n this.setPlaceholderStyle({ ...elemSize });\n this.setAffixStyle({\n position: 'fixed',\n top: offsetTop || 0,\n left: elemOffset.left,\n width: elemOffset.width,\n });\n } else if (offsetMode.bottom && bottom < 0) {\n this.setPlaceholderStyle({ ...elemSize });\n this.setAffixStyle({\n position: 'fixed',\n bottom: offsetBottom || 0,\n left: elemOffset.left,\n width: elemOffset.width,\n });\n } else {\n this.setPlaceholderStyle();\n this.setAffixStyle();\n }\n }\n setAffixStyle(affixStyle?: React.CSSProperties) {\n const { onChange } = this.props;\n const affixed = !!this.state.affixStyle;\n this.setState({ affixStyle }, () => {\n onChange && onChange(affixed);\n });\n }\n setPlaceholderStyle(placeholderStyle?: React.CSSProperties) {\n this.setState({ placeholderStyle });\n }\n // 设置监听事件\n setTargetEventListeners() {\n this.clearEventListeners();\n this.events.forEach((eventName) => {\n this.eventHandlers[eventName] = this.updatePosition;\n this.target && this.target.addEventListener(eventName, this.updatePosition, false);\n });\n }\n clearEventListeners() {\n this.events.forEach((eventName) => {\n const handler = this.eventHandlers[eventName];\n this.target && this.target.removeEventListener(eventName, handler, false);\n });\n }\n getInstance = (node: HTMLDivElement) => {\n if (node) {\n this.box = node;\n }\n };\n public render() {\n const { prefixCls, className, children, offsetTop, offsetBottom, target, onChange, ...resetProps } = this.props;\n const cls = [className, prefixCls].filter(Boolean).join(' ').trim();\n return (\n <div {...resetProps} ref={this.getInstance} style={{ ...this.state.placeholderStyle, ...this.props.style }}>\n <div className={cls} style={this.state.affixStyle}>\n {children}\n </div>\n </div>\n );\n }\n}\n","import React, { useEffect, useRef } from 'react';\nimport ReactDOM from 'react-dom';\n\nexport const canUseDOM = !!(typeof window !== 'undefined' && window.document && window.document.createElement);\n\nexport interface PortalProps {\n children?: React.ReactNode;\n /**\n * The HTML element that children will be mounted to.\n * @default document.body\n */\n container?: HTMLElement;\n /**\n * Callback invoked when the children of this `Portal` have been added to the DOM.\n * @deprecated v4.9.0+\n */\n onChildrenMount?: (portalElement: HTMLElement) => void;\n /** @deprecated v4.9.0+ */\n visible?: boolean;\n}\n\nexport default function Portal(props: PortalProps) {\n const { container } = props;\n const defaultNode = useRef<HTMLDivElement>();\n const containerRef = useRef<HTMLElement | undefined>(container);\n\n useEffect(() => {\n return () => {\n if (defaultNode.current && containerRef.current) {\n containerRef.current.removeChild(defaultNode.current);\n defaultNode.current = undefined;\n }\n };\n }, []);\n\n if (!canUseDOM) {\n return null;\n }\n if (!containerRef.current) {\n containerRef.current = document.body;\n }\n if (!defaultNode.current) {\n defaultNode.current = document.createElement('div');\n containerRef.current.appendChild(defaultNode.current);\n }\n return ReactDOM.createPortal(props.children, defaultNode.current);\n}\n","/**\n * Overlay 组件\n * ---------------\n * 动画库 react-transition-group 文档\n * 老的文档\n * https://facebook.github.io/react/docs/animation.html\n * 新的文档\n * https://reactcommunity.org/react-transition-group/\n * 动画效果\n * https://daneden.github.io/animate.css/\n */\nimport React, { cloneElement, useEffect, useRef, useState } from 'react';\nimport { CSSTransition } from 'react-transition-group';\nimport { TransitionProps } from 'react-transition-group/Transition';\nimport Portal, { PortalProps } from '@uiw/react-portal';\nimport { IProps, noop } from '@uiw/utils';\n\nimport './style/index.less';\n\nexport interface OverlayProps extends IProps, Omit<TransitionProps, 'timeout'> {\n timeout?: TransitionProps['timeout'];\n isOpen?: boolean;\n usePortal?: boolean;\n maskClosable?: boolean;\n dialogProps?: React.HTMLProps<HTMLElement>;\n backdropProps?: React.HTMLProps<HTMLDivElement>;\n portalProps?: PortalProps;\n hasBackdrop?: boolean;\n unmountOnExit?: boolean;\n transitionName?: string;\n onEnter?: (node: HTMLElement, isAppearing: boolean) => void;\n onOpening?: (node: HTMLElement, isAppearing: boolean) => void;\n onOpened?: (node: HTMLElement, isAppearing: boolean) => void;\n onClosing?: (node: HTMLElement) => void;\n onClosed?: (node: HTMLElement | React.MouseEvent<HTMLButtonElement, MouseEvent>) => void;\n onClose?: (evn: React.MouseEvent<HTMLElement, MouseEvent>) => void;\n}\n\nexport default function Overlay(props: OverlayProps) {\n const {\n className,\n style,\n isOpen: _ = false,\n prefixCls = 'w-overlay',\n usePortal = true,\n maskClosable = true,\n backdropProps = {},\n portalProps = {},\n hasBackdrop = true,\n unmountOnExit = true, // 设置 true 销毁根节点\n timeout = 300,\n transitionName = 'w-overlay',\n // onEnter = noop,\n onOpening = noop,\n onOpened = noop,\n onClosing = noop,\n onClosed = noop,\n onClose = noop,\n children,\n dialogProps = {},\n ...otherProps\n } = props;\n\n const [isOpen, setIsOpen] = useState(props.isOpen || false);\n const [visible, setVisible] = useState(false);\n const container = useRef<HTMLDivElement>(null);\n const overlay = useRef<HTMLDivElement>(null);\n useEffect(() => {\n if (isOpen !== props.isOpen && props.isOpen) {\n setVisible(true);\n }\n if (isOpen !== props.isOpen && !props.isOpen) {\n overlayWillClose();\n setIsOpen(false);\n }\n }, [props.isOpen]);\n\n useEffect(() => {\n if (visible) {\n overlayWillOpen();\n setIsOpen(true);\n }\n }, [visible]);\n\n const decoratedChild =\n typeof children === 'object' ? (\n cloneElement(children, {\n ...dialogProps,\n style: { ...children.props.style, ...dialogProps.style },\n className: [children.props.className, `${prefixCls}-content`].filter(Boolean).join(' ').trim(),\n tabIndex: 0,\n })\n ) : (\n <span {...dialogProps} className={`${prefixCls}-content`}>\n {children}\n </span>\n );\n\n function handleClosed(node: HTMLElement | React.MouseEvent<HTMLButtonElement, MouseEvent>) {\n setVisible(false);\n onClosed && onClosed(node);\n }\n\n function handleBackdropMouseDown(e: React.MouseEvent<HTMLDivElement, MouseEvent>) {\n if (e.target !== container.current && usePortal) {\n return;\n }\n if (maskClosable && hasBackdrop) {\n overlayWillClose();\n setIsOpen(false);\n onClose && onClose(e);\n }\n backdropProps && backdropProps.onMouseDown && backdropProps.onMouseDown(e);\n }\n\n function overlayWillOpen() {\n if (hasBackdrop && usePortal) {\n document.body.classList.add(`${prefixCls}-open`);\n }\n }\n\n function overlayWillClose() {\n if (hasBackdrop && usePortal) {\n document.body.classList.remove(`${prefixCls}-open`);\n }\n // if (unmountOnExit) {\n // setVisible(false)\n // }\n }\n\n const TransitionGroupComp = (\n <CSSTransition\n classNames={transitionName}\n unmountOnExit={unmountOnExit}\n timeout={timeout!}\n in={isOpen}\n onEntering={onOpening}\n onEntered={onOpened}\n onExiting={onClosing}\n onExited={handleClosed}\n {...otherProps}\n >\n {(status) => {\n return (\n <div\n style={style}\n ref={overlay}\n className={[\n prefixCls,\n className,\n !usePortal ? `${prefixCls}-inline` : null,\n isOpen ? `${prefixCls}-enter-done` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim()}\n >\n {hasBackdrop &&\n cloneElement(<div />, {\n ...backdropProps,\n onMouseDown: handleBackdropMouseDown,\n className: [`${prefixCls}-backdrop`, backdropProps.className].filter(Boolean).join(' ').trim(),\n tabIndex: maskClosable ? 0 : null,\n })}\n {usePortal ? (\n <div ref={container} onMouseDown={handleBackdropMouseDown} className={`${prefixCls}-container`}>\n {cloneElement(decoratedChild, { 'data-status': status })}\n </div>\n ) : (\n cloneElement(decoratedChild, { 'data-status': status })\n )}\n </div>\n );\n }}\n </CSSTransition>\n );\n if (visible && usePortal) {\n return <Portal {...{ ...portalProps }}>{TransitionGroupComp}</Portal>;\n } else {\n return TransitionGroupComp;\n }\n}\n","import React from 'react';\nimport svgPaths from '@uiw/icons/fonts/w-icon.json';\nimport './style/index.less';\n\nexport type IconsName = keyof typeof svgPaths;\ntype TagType = React.ComponentType | keyof JSX.IntrinsicElements;\n\nexport interface IconProps<Tag extends TagType = 'span', E = React.ReactElement> extends React.HTMLAttributes<Tag> {\n style?: React.CSSProperties;\n className?: string;\n prefixCls?: string;\n /**\n * HTML tag to use for the rendered element.\n * @default \"span\"\n */\n tagName?: Tag;\n type?: IconsName | null | E;\n spin?: boolean;\n color?: string;\n verticalAlign?: 'middle' | 'baseline';\n}\n\nexport default function Icon<Tag extends TagType = 'span'>(props: IconProps<Tag>) {\n const {\n className,\n prefixCls = 'w-icon',\n verticalAlign = 'middle',\n tagName: TagName = 'span',\n color,\n type,\n spin = false,\n ...others\n } = props;\n\n let svg = null;\n if (typeof type === 'string') {\n svg = (\n <svg fill={color} viewBox=\"0 0 20 20\">\n {(svgPaths[type] || []).map((d, i) => (\n <path key={i} d={d} fillRule=\"evenodd\" />\n ))}\n </svg>\n );\n } else if (React.isValidElement(type)) {\n svg = React.cloneElement(type, {\n fill: color,\n });\n } else {\n return null;\n }\n others.style = { fill: 'currentColor', ...others.style };\n const propps = {\n ...others,\n className: [\n prefixCls,\n className,\n prefixCls && verticalAlign ? `${prefixCls}-${verticalAlign}` : null,\n spin && prefixCls ? `${prefixCls}-spin` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim(),\n };\n\n return React.createElement(TagName, { ...propps } as any, svg);\n}\n","import React from 'react';\nimport Icon, { IconProps } from '@uiw/react-icon';\nimport { IProps, HTMLButtonProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport type ButtonType = 'primary' | 'success' | 'warning' | 'danger' | 'light' | 'dark' | 'link';\nexport type ButtonSize = 'large' | 'default' | 'small';\n\nexport interface ButtonProps extends IProps, Omit<HTMLButtonProps, 'size'> {\n basic?: boolean;\n disabled?: boolean;\n active?: boolean;\n loading?: boolean;\n block?: boolean;\n icon?: IconProps['type'];\n type?: ButtonType;\n size?: ButtonSize;\n htmlType?: 'button' | 'submit' | 'reset';\n onClick?: (e: React.MouseEvent<HTMLButtonElement> & MouseEvent) => void;\n}\n\nexport default React.forwardRef<HTMLButtonElement, ButtonProps>((props, ref) => {\n const {\n prefixCls = 'w-btn',\n disabled = false,\n active = false,\n loading = false,\n block = false,\n basic = false,\n htmlType = 'button',\n type = 'light',\n size = 'default',\n icon,\n className,\n children,\n ...others\n } = props;\n const cls = [\n className,\n prefixCls,\n size ? `${prefixCls}-size-${size}` : null,\n type ? `${prefixCls}-${type}` : null,\n basic ? `${prefixCls}-basic` : null,\n loading ? `${prefixCls}-loading` : null,\n disabled || loading ? 'disabled' : null,\n active ? 'active' : null,\n block ? 'block' : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim();\n\n return (\n <button {...others} ref={ref} type={htmlType} disabled={disabled || loading} className={cls}>\n {icon && <Icon type={icon} />}\n {children &&\n React.Children.map(children, (child: React.ReactNode) => {\n if (!child) return child;\n if (React.isValidElement(child)) return child;\n return <span>{child}</span>;\n })}\n </button>\n );\n});\n","import React, { useState, useEffect } from 'react';\nimport Overlay, { OverlayProps } from '@uiw/react-overlay';\nimport Button, { ButtonType, ButtonProps } from '@uiw/react-button';\nimport Icon, { IconProps } from '@uiw/react-icon';\nimport { IProps, noop } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface ModalProps extends IProps, OverlayProps {\n type?: ButtonType;\n cancelText?: string;\n confirmButtonProps?: Omit<ButtonProps, 'ref'>;\n cancelButtonProps?: Omit<ButtonProps, 'ref'>;\n content?: React.ReactNode;\n confirmText?: string;\n title?: string;\n icon?: IconProps['type'];\n useButton?: boolean;\n usePortal?: boolean;\n autoFocus?: boolean;\n isCloseButtonShown?: boolean;\n isOpen?: boolean;\n bodyStyle?: React.CSSProperties;\n maxWidth?: number;\n minWidth?: number;\n width?: number;\n onCancel?: (evn: React.MouseEvent<HTMLButtonElement> & MouseEvent) => void;\n onConfirm?: (evn: React.MouseEvent<HTMLButtonElement> & MouseEvent) => void;\n}\n\nexport default React.forwardRef<OverlayProps, ModalProps>((props, ref) => {\n const {\n prefixCls = 'w-modal',\n className,\n children,\n useButton = true,\n usePortal = true,\n autoFocus = false,\n isOpen: _ = false,\n title,\n cancelText,\n cancelButtonProps,\n confirmButtonProps,\n content,\n confirmText = '确认',\n type = 'light',\n icon,\n maxWidth = 500,\n minWidth = 320,\n width,\n isCloseButtonShown = true,\n onCancel = noop,\n onConfirm = noop,\n bodyStyle,\n ...other\n } = props;\n const [isOpen, setIsOpen] = useState(props.isOpen);\n useEffect(() => {\n if (props.isOpen !== isOpen) {\n setIsOpen(props.isOpen);\n }\n }, [props.isOpen]);\n\n const [loading, setLoading] = useState(false);\n const cls = [prefixCls, className, type ? `${type}` : null].filter(Boolean).join(' ').trim();\n function onClose() {\n setIsOpen(false);\n }\n async function handleCancel(e: React.MouseEvent<HTMLButtonElement, MouseEvent> & MouseEvent) {\n setLoading(true);\n try {\n onCancel && (await onCancel(e));\n } catch (e) {}\n setIsOpen(false);\n setLoading(false);\n }\n async function handleConfirm(e: React.MouseEvent<HTMLButtonElement, MouseEvent> & MouseEvent) {\n setLoading(true);\n try {\n onConfirm && (await onConfirm(e));\n } catch (e) {}\n setIsOpen(false);\n setLoading(false);\n }\n return (\n <Overlay usePortal={usePortal} isOpen={isOpen} {...other} onClose={onClose} className={cls}>\n <div className={`${prefixCls}-container`}>\n <div\n className={[\n `${prefixCls}-inner`,\n title ? `${prefixCls}-shown-title` : null,\n icon ? `${prefixCls}-shown-icon` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim()}\n style={{ maxWidth, minWidth, width }}\n >\n {(title || icon) && (\n <div className={`${prefixCls}-header`}>\n {icon && <Icon type={icon} />}\n {title && <h4>{title}</h4>}\n {isCloseButtonShown && <Button basic onClick={(e) => handleCancel(e)} icon=\"close\" type=\"light\" />}\n </div>\n )}\n <div className={`${prefixCls}-body`} style={bodyStyle}>\n {children || content}\n </div>\n {useButton && (\n <div className={`${prefixCls}-footer`}>\n <Button\n autoFocus={autoFocus}\n type={type}\n loading={loading}\n disabled={loading}\n {...confirmButtonProps}\n onClick={(e) => handleConfirm(e)}\n >\n {confirmText}\n </Button>\n {cancelText && (\n <Button {...cancelButtonProps} onClick={(e) => handleCancel(e)}>\n {cancelText}\n </Button>\n )}\n </div>\n )}\n </div>\n </div>\n </Overlay>\n );\n});\n","import React from 'react';\nimport Modal, { ModalProps } from '@uiw/react-modal';\nimport { IProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface AlertProps extends IProps, ModalProps {\n width?: number;\n}\n\nexport default (props: AlertProps = {}) => {\n const { prefixCls = 'w-alert', className, width = 400, ...other } = props;\n const cls = [prefixCls, className].filter(Boolean).join(' ').trim();\n return (\n <Modal {...other} width={width} className={cls}>\n {props.children}\n </Modal>\n );\n};\n","import React, { Fragment } from 'react';\n\nconst delimiter =\n /((?:https?:\\/\\/)?(?:(?:[a-z0-9]?(?:[a-z0-9\\-]{1,61}[a-z0-9])?\\.[^\\.|\\s])+[a-z\\.]*[a-z]+|(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)(?:\\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3})(?::\\d{1,5})*[a-z0-9.,_\\/~#&=;%+?\\-\\\\(\\\\)]*)/gi;\n\nexport type AutoLinkProps = {\n text?: string;\n} & React.AnchorHTMLAttributes<HTMLAnchorElement>;\n\nexport default (props: AutoLinkProps = {}) => {\n const { text = '', ...other } = props;\n return (\n <Fragment>\n {text.split(delimiter).map((word, idx) => {\n const match = word.match(delimiter);\n if (match && match[0]) {\n const url = match[0];\n return (\n <a {...other} key={idx} href={url.startsWith('http') ? url : `http://${url}`}>\n {url}\n </a>\n );\n }\n return <Fragment key={idx}>{word}</Fragment>;\n })}\n </Fragment>\n );\n};\n","import React from 'react';\nimport Icon, { IconProps } from '@uiw/react-icon';\nimport { HTMLSpanProps, noop } from '@uiw/utils';\nimport './style/index.less';\nimport { useState } from 'react';\nimport { useEffect } from 'react';\n\nexport interface AvatarProps extends HTMLSpanProps {\n style?: React.CSSProperties;\n className?: string;\n prefixCls?: string;\n icon?: IconProps['type'];\n alt?: string;\n src?: string;\n size?: 'large' | 'default' | 'small' | 'mini';\n shape?: 'square' | 'circle';\n onError?: (event: React.SyntheticEvent<HTMLImageElement, Event>) => boolean;\n}\n\nexport default React.forwardRef<HTMLSpanElement, AvatarProps>((props, ref) => {\n const {\n prefixCls = 'w-avatar',\n shape = 'circle',\n size = 'default',\n className,\n src,\n alt,\n icon,\n onError = noop,\n ...resetProps\n } = props;\n let children = props.children;\n const [isImgExist, setIsImgExist] = useState(true);\n const cls = [\n prefixCls,\n className,\n size ? `${prefixCls}-${size}` : null,\n shape ? `${prefixCls}-${shape}` : null,\n src ? `${prefixCls}-image` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim();\n\n useEffect(() => {\n setIsImgExist(true);\n }, [props.src]);\n\n if (isImgExist && src) {\n children = (\n <img\n src={src}\n alt={alt}\n onError={(evn) => {\n const errorFlag = onError ? onError(evn) : undefined;\n if (errorFlag !== false) {\n setIsImgExist(false);\n }\n }}\n />\n );\n } else if (icon && typeof icon === 'string') {\n children = <Icon type={icon} />;\n } else if (icon && React.isValidElement(icon)) {\n children = icon;\n }\n return (\n <span {...resetProps} className={cls} ref={ref}>\n {children}\n </span>\n );\n});\n","/**\n * 获取当前滚动条所在位置\n */\nexport function getScrollTop() {\n let scrollTop = 0;\n if (document && document.documentElement && document.documentElement.scrollTop) {\n scrollTop = document.documentElement.scrollTop;\n } else if (document.body) {\n scrollTop = document.body.scrollTop;\n }\n return scrollTop;\n}\n\n/**\n * TODO\n * @param {*} position 滚动到何处\n * @param {*} step 步长\n * @param {*} current 滚动条当前位置\n */\nexport function scrollToAnimate(position: number = 0, step: number = 100, current: number = 0) {\n let start = 0;\n const timer = setInterval(() => {\n if (current - start >= position) {\n start += step;\n if (current - start >= position) {\n window.scrollTo(0, current - start);\n } else {\n window.scrollTo(0, position);\n }\n } else {\n clearInterval(timer);\n }\n }, 0);\n}\n/**\n * 获取滚动条位置百分比\n */\nexport function getScrollPercent(offsetTop: number = 0) {\n let percent = 0;\n if (offsetTop < getScrollTop()) {\n percent = Math.round(\n ((getScrollTop() - offsetTop) / (document.body.scrollHeight - offsetTop - window.innerHeight)) * 100,\n );\n }\n return percent > 100 ? 100 : percent;\n}\n","import React, { useState, useEffect } from 'react';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\nimport { getScrollPercent, getScrollTop, scrollToAnimate } from './utils';\nimport './style/index.less';\n\nexport interface BackTopProps extends IProps, HTMLDivProps {\n offsetTop?: number;\n clickable?: boolean;\n content?: JSX.Element | string;\n fixed?: boolean;\n /**\n * 滚动距离多少时显示组件\n */\n showBelow?: number;\n speed?: number;\n}\n\nexport interface IBackTopState {\n percent: number;\n current: number;\n}\n\nexport default React.forwardRef<HTMLDivElement, BackTopProps>((props, ref) => {\n const {\n prefixCls = 'w-back-top',\n className,\n content,\n children,\n offsetTop = 0,\n fixed = true,\n speed = 100,\n showBelow = 1,\n clickable = true,\n ...other\n } = props;\n const topShowBelow = !fixed ? 0 : showBelow || 0;\n const [percent, setPercent] = useState(0);\n const [current, setCurrent] = useState(0);\n const visible = percent >= topShowBelow;\n const cls = [\n prefixCls,\n className,\n !fixed ? 'no-fixed' : null,\n visible ? `${prefixCls}-show` : null,\n !visible ? `${prefixCls}-hide` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim();\n useEffect(() => {\n window && window.addEventListener('scroll', onScroll);\n return function () {\n window && window.removeEventListener('scroll', onScroll);\n };\n });\n function onScroll() {\n setPercent(getScrollPercent(offsetTop));\n setCurrent(getScrollTop());\n }\n function scrollToTop() {\n if (typeof offsetTop === 'number' && typeof speed === 'number' && typeof current === 'number') {\n scrollToAnimate(offsetTop, speed, current);\n }\n }\n return (\n <div onClick={() => clickable && scrollToTop()} className={cls} {...other} ref={ref}>\n {content}\n {typeof children !== 'function' ? children : children({ percent, current, scrollToTop: scrollToTop })}\n </div>\n );\n});\n","import React from 'react';\nimport { IProps, HTMLSpanProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface BadgeProps extends IProps, HTMLSpanProps {\n color?: string;\n dot?: boolean;\n processing?: boolean;\n max?: number;\n count?: number;\n}\n\nexport default React.forwardRef<HTMLSpanElement, BadgeProps>((props, ref) => {\n const {\n prefixCls = 'w-badge',\n className,\n style = {},\n color,\n max = 99,\n dot = false,\n processing = false,\n count,\n children,\n ...other\n } = props;\n const supProps = {\n className: [!dot ? `${prefixCls}-count` : null, dot ? 'dot' : null].filter(Boolean).join(' ').trim(),\n style: {},\n };\n const cls = [\n className,\n prefixCls,\n !children ? 'nowrap' : null,\n !children ? `${prefixCls}-status` : null,\n processing ? `${prefixCls}-processing` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim();\n\n const warpperProps: HTMLSpanProps = {};\n if (count || count === 0) {\n supProps.style = { backgroundColor: color, ...style };\n } else {\n warpperProps.style = style || {};\n }\n return (\n <span className={cls} {...other} {...warpperProps} ref={ref}>\n {color && <span className={`${prefixCls}-dot`} style={{ backgroundColor: color }} />}\n {children}\n {count !== 0 && !color && <sup {...supProps}>{!dot && count && max && count > max ? `${max}+` : count}</sup>}\n </span>\n );\n});\n","import React, { Fragment } from 'react';\nimport { IProps } from '@uiw/utils';\nimport './style/item.less';\n\ntype ElementTag<T = any> = T extends HTMLElement ? React.HTMLAttributes<T> : T;\n\nexport interface BreadcrumbItemProps<T = any> extends IProps, ElementTag {\n tagName?: T extends HTMLElement ? keyof JSX.IntrinsicElements : T;\n separator?: JSX.Element | string;\n active?: boolean;\n 'data-separator'?: JSX.Element | string;\n}\n\ntype RefElement<T = HTMLSpanElement> = T extends HTMLElement ? T : never;\n\nconst BreadcrumbItem = React.forwardRef<RefElement, BreadcrumbItemProps>((props, ref) => {\n const { prefixCls = 'w-breadcrumb', className, tagName: TagName = 'span', active, separator, ...other } = props;\n const isElm = React.isValidElement(separator);\n const cls = [\n `${prefixCls}-item`,\n className,\n active ? 'active' : null,\n !separator ? 'no-separator' : null,\n isElm ? 'no-before' : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim();\n const otherProps = { className: cls, ...other };\n if (!isElm) {\n otherProps['data-separator'] = separator;\n }\n return React.createElement(\n TagName,\n {\n ...otherProps,\n ref,\n },\n <Fragment>\n {isElm && <span className={`${prefixCls}-separator`}>{separator}</span>}\n {props.children}\n </Fragment>,\n );\n});\n\nexport default BreadcrumbItem;\n","import React from 'react';\nimport { HTMLDivProps } from '@uiw/utils';\nimport Item from './Item';\nimport './style/index.less';\n\nexport interface BreadcrumbProps extends HTMLDivProps {\n style?: React.CSSProperties;\n className?: string;\n prefixCls?: string;\n separator?: JSX.Element | string;\n}\n\nconst Breadcrumb = React.forwardRef<HTMLDivElement, BreadcrumbProps>((props, ref) => {\n const { prefixCls = 'w-breadcrumb', className, separator = '/', ...other } = props;\n const cls = [prefixCls, className].filter(Boolean).join(' ').trim();\n return (\n <div {...{ className: cls, ...other }} ref={ref}>\n {React.Children.map(props.children, (element: any) => {\n return React.cloneElement(element, Object.assign({ separator }, element.props, {}));\n })}\n </div>\n );\n});\ntype Breadcrumb = typeof Breadcrumb & {\n Item: typeof Item;\n};\n\n(Breadcrumb as Breadcrumb).Item = Item;\n\nexport default Breadcrumb as Breadcrumb;\n","import Breadcrumb from './Breadcrumb';\n\nexport * from './Item';\nexport * from './Breadcrumb';\n\nexport default Breadcrumb;\n","import React from 'react';\nimport { HTMLDivProps, IProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface ButtonGroupProps extends IProps, HTMLDivProps {\n vertical?: boolean;\n}\n\nexport default React.forwardRef<HTMLDivElement, ButtonGroupProps>((props, ref) => {\n const { prefixCls = 'w-btn-group', vertical = false, children, className, ...resetProps } = props;\n\n const cls = [prefixCls, className, vertical && `${prefixCls}-vertical`].filter(Boolean).join(' ').trim();\n\n return (\n <div className={cls} {...resetProps} ref={ref}>\n {children}\n </div>\n );\n});\n","const canUseDOM = !!(typeof window !== 'undefined' && window.document && window.document.createElement);\n\nfunction fallback(context: HTMLElement, node: HTMLElement) {\n if (node) {\n do {\n if (node === context) return true;\n } while ((node = node.parentNode as HTMLElement));\n }\n\n return false;\n}\n\nfunction isDOM(item: Node) {\n return typeof HTMLElement === 'function'\n ? item instanceof HTMLElement\n : item && typeof item === 'object' && item.nodeType === 1 && typeof item.nodeName === 'string';\n}\n\nconst contains = (() => {\n // HTML DOM and SVG DOM may have different support levels,\n // so we need to check on context instead of a document root element.\n return canUseDOM\n ? function (context: HTMLElement, node: HTMLElement) {\n if (context && context.contains && typeof context.contains === 'function' && isDOM(node)) {\n return context.contains(node);\n }\n if (context && context.compareDocumentPosition && isDOM(node)) {\n return context === node || !!(context.compareDocumentPosition(node) && 16);\n }\n return fallback(context, node);\n }\n : fallback;\n})();\n\nexport default contains;\n","export interface BordersSize extends CSSStyleDeclaration {\n [key: string]: any;\n}\n\n/*\n * Helper to detect borders of a given element\n * @method\n * @memberof Popper.Utils\n * @param {CSSStyleDeclaration} styles\n * Result of `getStyleComputedProperty` on the given element\n * @param {String} axis - `x` or `y`\n * @return {number} borders - The borders size of the given axis\n */\n\nexport default function getBordersSize(styles: BordersSize, axis: 'x' | 'y'): number {\n const sideA: string = axis === 'x' ? 'Left' : 'Top';\n const sideB: string = sideA === 'Left' ? 'Right' : 'Bottom';\n return parseFloat(styles[`border${sideA}Width`]) + parseFloat(styles[`border${sideB}Width`]);\n}\n","export default typeof window !== 'undefined' && typeof document !== 'undefined';\n","import isBrowser from './isBrowser';\n\ninterface Document {\n documentMode?: any;\n}\n\ninterface Window {\n MSInputMethodContext?: any;\n}\n\nconst isIE11 = isBrowser && !!((window as Window).MSInputMethodContext && (document as Document).documentMode);\nconst isIE10 = isBrowser && /MSIE 10/.test(navigator.userAgent);\n\n/**\n * Determines if the browser is Internet Explorer\n * @method\n * @memberof Popper.Utils\n * @param {Number} version to check\n * @returns {Boolean} isIE\n */\nexport default function isIE(version: number) {\n if (version === 11) {\n return isIE11;\n }\n if (version === 10) {\n return isIE10;\n }\n return isIE11 || isIE10;\n}\n","import isIE from './isIE';\n\ninterface BodyElement extends HTMLBodyElement {\n [key: string]: any;\n}\n\ninterface IHTMLElement extends HTMLElement {\n [key: string]: any;\n}\n\ninterface ComputedStyle extends CSSStyleDeclaration {\n [key: string]: any;\n}\n\nfunction getSize(axis: 'Height' | 'Width', body: BodyElement, html: IHTMLElement, computedStyle: ComputedStyle) {\n return Math.max(\n body[`offset${axis}`],\n body[`scroll${axis}`],\n html[`client${axis}`],\n html[`offset${axis}`],\n html[`scroll${axis}`],\n isIE(10)\n ? parseInt(html[`offset${axis}`], 10) +\n parseInt(computedStyle[`margin${axis === 'Height' ? 'Top' : 'Left'}`], 10) +\n parseInt(computedStyle[`margin${axis === 'Height' ? 'Bottom' : 'Right'}`], 10)\n : 0,\n );\n}\n\nexport type WindowSize = { height?: number; width?: number };\n\nexport default function getWindowSizes(document: HTMLDocument): WindowSize {\n const body = document.body as HTMLBodyElement;\n const html = document.documentElement as HTMLElement;\n const computedStyle = getComputedStyle(html) as CSSStyleDeclaration;\n\n return {\n height: getSize('Height', body, html, computedStyle),\n width: getSize('Width', body, html, computedStyle),\n };\n}\n","import { getScroll } from '@uiw/utils';\nimport getStyleComputedProperty from './getStyleComputedProperty';\nimport getBordersSize from './getBordersSize';\nimport getWindowSizes, { WindowSize } from './getWindowSizes';\nimport getClientRect from './getClientRect';\nimport isIE from './isIE';\n\nexport interface IBoundingClientRect {\n left: number;\n right: number;\n top: number;\n bottom: number;\n width: number;\n height: number;\n offsetLeft?: number;\n offsetTop?: number;\n}\n\n/**\n * Get bounding client rect of given element\n * @method\n * @memberof Popper.Utils\n * @param {HTMLElement} element\n * @return {Object} client rect\n */\nexport default function getBoundingClientRect(element: HTMLElement) {\n let rect = {} as IBoundingClientRect;\n\n // IE10 10 FIX: Please, don't ask, the element isn't\n // considered in DOM in some circumstances...\n // This isn't reproducible in IE10 compatibility mode of IE11\n try {\n if (isIE(10)) {\n rect = element.getBoundingClientRect();\n const scrollTop = getScroll(element, true);\n const scrollLeft = getScroll(element);\n rect.top += scrollTop;\n rect.left += scrollLeft;\n rect.bottom += scrollTop;\n rect.right += scrollLeft;\n } else {\n rect = element.getBoundingClientRect();\n }\n // eslint-disable-next-line\n } catch (e) {}\n\n const result = {\n left: rect.left,\n top: rect.top,\n width: rect.right - rect.left,\n height: rect.bottom - rect.top,\n } as IBoundingClientRect;\n\n // subtract scrollbar size from sizes\n const sizes: WindowSize = element.nodeName === 'HTML' ? getWindowSizes(element.ownerDocument!) : {};\n const width = sizes.width || element.clientWidth || result.right - result.left;\n const height = sizes.height || element.clientHeight || result.bottom - result.top;\n\n let horizScrollbar = element.offsetWidth - width;\n let vertScrollbar = element.offsetHeight - height;\n\n result.offsetLeft = element.offsetLeft || element.scrollLeft || 0;\n result.offsetTop = element.offsetTop || element.offsetTop || 0;\n\n // if an hypothetical scrollbar is detected, we must be sure it's not a `border`\n // we make this check conditional for performance reasons\n if (horizScrollbar || vertScrollbar) {\n const styles = getStyleComputedProperty(element);\n horizScrollbar -= getBordersSize(styles, 'x');\n vertScrollbar -= getBordersSize(styles, 'y');\n\n result.width -= horizScrollbar;\n result.height -= vertScrollbar;\n }\n\n return getClientRect(result) as IBoundingClientRect;\n}\n","/**\n * Given element offsets, generate an output similar to getBoundingClientRect\n * @method\n * @memberof Popper.Utils\n * @argument {Object} offsets\n * @returns {Object} ClientRect like output\n */\nexport default function getClientRect(offsets: ClientRect): ClientRect {\n return {\n ...offsets,\n right: offsets.left + offsets.width,\n bottom: offsets.top + offsets.height,\n };\n}\n","/**\n * Get CSS computed property of the given element\n * @method\n * @memberof Popper.Utils\n * @argument {Eement} element\n * @argument {String} property\n */\nexport default function getStyleComputedProperty(\n element: HTMLElement,\n property?: keyof CSSStyleDeclaration,\n): CSSStyleDeclaration | any {\n if (element.nodeType !== 1) {\n return [];\n }\n // NOTE: 1 DOM access here\n const window = element.ownerDocument!.defaultView;\n const css: CSSStyleDeclaration = (window as Window).getComputedStyle(element, null);\n return property ? css[property] : css;\n}\n","export type Sizes = {\n width: number;\n height: number;\n};\n\n/**\n * Get the outer sizes of the given element (offset size + margins)\n * @method\n * @memberof Popper.Utils\n * @argument {Element} element\n * @returns {Object} object containing width and height properties\n */\nexport default function getOuterSizes(element: HTMLElement): Sizes {\n let rect = element.getBoundingClientRect();\n // const window = element.ownerDocument.defaultView;\n // const styles = window.getComputedStyle(element);\n // const x = parseFloat(styles.marginTop || 0) + parseFloat(styles.marginBottom || 0);\n // const y = parseFloat(styles.marginLeft || 0) + parseFloat(styles.marginRight || 0);\n const result: Sizes = {\n width: element.offsetWidth || element.scrollWidth || rect.width || 0,\n height: element.offsetHeight || element.scrollHeight || rect.height || 0,\n };\n return result;\n}\n","import { getScroll } from '@uiw/utils';\nimport getBoundingClientRect, { IBoundingClientRect } from './util/getBoundingClientRect';\nimport getOuterSizes from './util/getOuterSizes';\nimport { OverlayStyl, OverlayTriggerProps, Placement } from './';\n\ntype GetStyleOptions = {\n trigger: HTMLElement | IBoundingClientRect;\n popup: HTMLElement | IBoundingClientRect;\n placement: OverlayStyl['placement'];\n usePortal: OverlayTriggerProps['usePortal'];\n autoAdjustOverflow: OverlayTriggerProps['autoAdjustOverflow'];\n};\n\nexport function getStyle(options: GetStyleOptions) {\n let { trigger: triggerDom, popup: popupDom, placement, usePortal, autoAdjustOverflow } = options || {};\n const sty = {\n left: 0,\n top: 0,\n placement,\n } as OverlayStyl;\n\n if (!triggerDom || !popupDom || !document) {\n return sty;\n }\n\n const winSizeHeight = Math.max(document.documentElement.clientHeight, window.innerHeight || 0);\n const winSizeWidth = Math.max(document.documentElement.clientWidth, window.innerWidth || 0);\n\n sty.placement = placement;\n const scrollTop = getScroll((triggerDom as HTMLElement).ownerDocument!.documentElement, true);\n const scrollLeft = getScroll((triggerDom as HTMLElement).ownerDocument!.documentElement);\n const trigger = {\n ...getBoundingClientRect(triggerDom as HTMLElement),\n ...getOuterSizes(triggerDom as HTMLElement),\n };\n const popup = {\n ...getBoundingClientRect(popupDom as HTMLElement),\n ...getOuterSizes(popupDom as HTMLElement),\n };\n\n const bottom = winSizeHeight - trigger.bottom;\n const right = winSizeWidth - trigger.left - trigger.width;\n\n sty.top = trigger.top + scrollTop;\n sty.left = trigger.left;\n\n if (!usePortal) {\n sty.top = trigger.offsetTop as number;\n sty.left = trigger.offsetLeft as number;\n }\n\n if (placement && /^(top)/.test(placement)) {\n sty.top -= popup.height;\n }\n if (placement && /^(right)/.test(placement)) {\n sty.left += trigger.width;\n }\n if (placement && /^(bottom)/.test(placement)) {\n sty.top += trigger.height;\n }\n if (placement && /^(left)/.test(placement)) {\n sty.left -= popup.width;\n }\n switch (sty.placement) {\n case 'bottomLeft':\n case 'topLeft':\n break;\n case 'bottom':\n // eslint-disable-next-line\n case 'top':\n sty.left = sty.left - (popup.width - trigger.width) / 2;\n break;\n case 'bottomRight':\n case 'topRight':\n sty.left = sty.left + scrollLeft + trigger.width - popup.width;\n break;\n case 'rightTop':\n case 'leftTop':\n break;\n case 'right':\n // eslint-disable-next-line\n case 'left':\n sty.top = sty.top - (popup.height - trigger.height) / 2;\n break;\n case 'rightBottom':\n case 'leftBottom':\n sty.top = sty.top - popup.height + trigger.height;\n break;\n default:\n break;\n }\n if (autoAdjustOverflow) {\n if (placement && /^(top)/.test(placement) && trigger.top < popup.height && bottom > popup.height) {\n sty.placement = placement.replace(/^top/, 'bottom') as Placement;\n sty.top = sty.top + popup.height + trigger.height;\n }\n if (placement && /^(bottom)/.test(placement) && bottom < popup.height && trigger.top > popup.height) {\n sty.placement = placement.replace(/^bottom/, 'top') as Placement;\n sty.top = sty.top - popup.height - trigger.height;\n }\n if (placement && /^(right)/.test(placement) && right < popup.width) {\n sty.placement = placement.replace(/^right/, 'left') as Placement;\n sty.left = sty.left - trigger.width - popup.width;\n }\n if (placement && /^(left)/.test(placement) && trigger.left < popup.width) {\n sty.placement = placement.replace(/^left/, 'right') as Placement;\n sty.left = sty.left + trigger.width + popup.width;\n }\n\n if (placement && /^(left|right)/.test(placement) && usePortal) {\n // Top\n if (\n (/(Top)$/.test(placement) && trigger.top < 0) ||\n (/(right|left)$/.test(placement) && trigger.top + trigger.height / 2 < popup.height / 2) ||\n (/(Bottom)$/.test(placement) && trigger.top + trigger.height < popup.height)\n ) {\n sty.top = scrollTop;\n }\n } else {\n // Top\n if (placement && /(Top)$/.test(placement) && trigger.top < 0) {\n sty.top -= trigger.top;\n }\n if (placement && /(Bottom)$/.test(placement) && trigger.bottom < popup.height) {\n // eslint-disable-next-line\n sty.top = sty.top + (popup.height - trigger.bottom);\n }\n if (placement && /(right|left)$/.test(placement) && trigger.bottom - trigger.height / 2 < popup.height / 2) {\n sty.top = sty.top + popup.height / 2 - (trigger.bottom - trigger.height / 2);\n }\n }\n // Bottom Public Part\n if (placement && /^(left|right)/.test(placement)) {\n if (/(Top)$/.test(placement) && bottom + trigger.height < popup.height) {\n sty.top = sty.top - (popup.height - bottom - trigger.height); // eslint-disable-line\n }\n if (/(right|left)$/.test(placement) && bottom + trigger.height / 2 < popup.height / 2) {\n sty.top = sty.top - (popup.height / 2 - bottom - trigger.height / 2); // eslint-disable-line\n }\n if (/(Bottom)$/.test(placement) && bottom < 0) {\n sty.top = sty.top + bottom; // eslint-disable-line\n }\n }\n\n if (placement && /^(top|bottom)/.test(placement) && usePortal) {\n // left\n if (\n (/(Left)$/.test(placement) && trigger.left < 0) ||\n (/(top|bottom)$/.test(placement) && trigger.left + trigger.width / 2 < popup.width / 2) ||\n (/(Right)$/.test(placement) && trigger.left + trigger.width < popup.width)\n ) {\n sty.left = scrollLeft;\n }\n // right\n if (/(top|bottom)$/.test(placement) && right + trigger.width / 2 < popup.width / 2) {\n sty.left = trigger.left + trigger.width + right - popup.width;\n }\n } else if (placement && /(top|bottom)$/.test(placement) && right + trigger.width / 2 < popup.width / 2) {\n sty.left = sty.left + (right + trigger.width / 2 - popup.width / 2); // eslint-disable-line\n }\n if (placement && /^(top|bottom)/.test(placement)) {\n if (/(Left)$/.test(placement) && trigger.width + right < popup.width) {\n sty.left = sty.left - (popup.width - trigger.width - right);\n }\n if (/(Right)$/.test(placement) && right < 0) {\n sty.left = sty.left + right; // eslint-disable-line\n }\n }\n }\n return sty;\n}\n","import React, { cloneElement, useEffect, useRef, useState, useImperativeHandle } from 'react';\nimport { IProps, noop } from '@uiw/utils';\nimport Overlay, { OverlayProps } from '@uiw/react-overlay';\nimport contains from './utils';\nimport { IBoundingClientRect } from './util/getBoundingClientRect';\nimport { getStyle } from './getStyle';\nimport './style/index.less';\n\nexport interface OverlayTriggerProps extends IProps, OverlayProps {\n onVisibleChange?: (isVisbale: boolean) => void;\n onEnter?: (node: HTMLElement, isAppearing: boolean) => void;\n overlay?: React.ReactNode | any;\n trigger?: 'click' | 'hover' | 'focus';\n usePortal?: boolean;\n isOpen?: boolean;\n disabled?: boolean;\n isOutside?: boolean;\n isClickOutside?: boolean;\n autoAdjustOverflow?: boolean;\n placement?: Placement;\n delay?: Delay;\n}\n\nexport interface OverlayTriggerState {\n show: boolean;\n trigger: OverlayTriggerProps['trigger'];\n overlayStyl: OverlayStyl;\n transitionName: OverlayProps['transitionName'];\n}\n\nexport type Delay =\n | number\n | {\n show?: number;\n hide?: number;\n };\n\nexport type Placement =\n | 'top'\n | 'topLeft'\n | 'topRight'\n | 'left'\n | 'leftTop'\n | 'leftBottom'\n | 'right'\n | 'rightTop'\n | 'rightBottom'\n | 'bottom'\n | 'bottomLeft'\n | 'bottomRight';\n\nexport type OverlayStyl = {\n placement: Placement;\n top: number;\n bottom: number;\n left: number;\n right: number;\n zIndex: number;\n};\n\ninterface ITriggerProps {\n onClick?: (e: MouseEvent) => void;\n onFocus?: (e: MouseEvent) => void;\n onMouseOver?: (e: React.MouseEvent<HTMLElement, MouseEvent>) => void;\n onMouseOut?: (e: React.MouseEvent<HTMLElement, MouseEvent>) => void;\n onMouseEnter?: (e: React.MouseEvent<HTMLElement, MouseEvent>) => void;\n onMouseLeave?: (e: React.MouseEvent<HTMLElement, MouseEvent>) => void;\n}\n\nconst normalizeDelay = (delay?: Delay) => (delay && typeof delay === 'object' ? delay : { show: delay, hide: delay });\n\nexport type OverlayTriggerRef = {\n hide: () => void;\n show: () => void;\n};\n\nexport default React.forwardRef<OverlayTriggerRef, OverlayTriggerProps>((props, ref) => {\n const {\n className,\n\n prefixCls = 'w-overlay-trigger',\n usePortal = true,\n isOutside = false,\n isClickOutside = true,\n disabled = false,\n isOpen: _ = false,\n trigger = 'hover',\n placement = 'top',\n\n autoAdjustOverflow,\n transitionName,\n\n children,\n overlay,\n onVisibleChange = noop,\n onEnter = noop,\n ...other\n } = props;\n\n const zIndex = useRef<number>(990);\n const triggerRef = useRef<HTMLElement>();\n const popupRef = useRef<HTMLElement>();\n const timeoutRef = useRef<number[]>([]);\n const hoverStateRef = useRef<'show' | 'hide' | null>(null);\n const [isOpen, setIsOpen] = useState(!!props.isOpen);\n const [overlayStyl, setOverlayStyl] = useState<OverlayStyl>({\n placement,\n top: 0,\n bottom: 0,\n left: 0,\n right: 0,\n zIndex: zIndex.current,\n });\n useImperativeHandle(ref, () => ({\n hide: () => hide(),\n show: () => show(),\n }));\n\n const child: any = React.Children.only(children);\n const overlayProps: OverlayProps = {\n ...other,\n placement,\n isOpen,\n dialogProps: {},\n };\n const triggerProps: ITriggerProps = {};\n\n function getChildProps() {\n if (child && React.isValidElement(child)) {\n return child.props;\n }\n return {};\n }\n\n useEffect(() => {\n if (isClickOutside) {\n document && document.addEventListener('mousedown', handleClickOutside);\n window.addEventListener('resize', handleResize);\n }\n return () => {\n document && isClickOutside && document.removeEventListener('mousedown', handleClickOutside);\n window.removeEventListener('resize', handleResize);\n };\n }, []);\n\n useEffect(() => {\n if (props.isOpen !== isOpen) {\n setIsOpen(!!props.isOpen);\n }\n }, [props.isOpen]);\n\n useEffect(() => {\n const styls = getStyle({\n placement: overlayStyl.placement || placement,\n trigger: triggerRef.current as HTMLElement | IBoundingClientRect,\n popup: popupRef.current as HTMLElement | IBoundingClientRect,\n usePortal,\n autoAdjustOverflow,\n });\n setOverlayStyl({ ...styls, zIndex: zIndex.current });\n onVisibleChange(isOpen);\n }, [isOpen]);\n\n const handleResize = () => {\n zIndex.current -= 1;\n setIsOpen(false);\n onVisibleChange && onVisibleChange(false);\n };\n\n const handleClickOutside = (e: MouseEvent) => {\n const popNode = popupRef.current;\n const childNode = triggerRef.current;\n if (\n popNode &&\n childNode &&\n e.target &&\n !contains(popNode, e.target as HTMLElement) &&\n !contains(childNode, e.target as HTMLElement)\n ) {\n zIndex.current -= 1;\n setIsOpen(false);\n onVisibleChange && onVisibleChange(false);\n }\n };\n\n function clearTimeouts() {\n if (timeoutRef.current.length > 0) {\n for (const timeoutId of timeoutRef.current) {\n window.clearTimeout(timeoutId);\n }\n timeoutRef.current = [];\n }\n }\n function handleShow() {\n clearTimeouts();\n hoverStateRef.current = 'show';\n\n const delay = normalizeDelay(props.delay);\n\n if (!delay.show) {\n show();\n return;\n }\n const handle = window.setTimeout(() => {\n if (hoverStateRef.current === 'show') show();\n }, delay.show);\n timeoutRef.current.push(handle);\n }\n\n function handleHide(isOutside: boolean) {\n clearTimeouts();\n if (!isOutside && props.isOutside) return;\n hoverStateRef.current = 'hide';\n\n const delay = normalizeDelay(props.delay);\n\n if (!delay.hide) {\n hide();\n return;\n }\n\n const handle = window.setTimeout(() => {\n if (hoverStateRef.current === 'hide') hide();\n }, delay.hide);\n\n timeoutRef.current.push(handle);\n }\n\n // Simple implementation of mouseEnter and mouseLeave.\n // React's built version is broken: https://github.com/facebook/react/issues/4251\n // for cases when the trigger is disabled and mouseOut/Over can cause flicker\n // moving from one child element to another.\n function handleMouseOverOut(handler: Function, e: React.MouseEvent, relatedNative: 'fromElement' | 'toElement') {\n const target = e.currentTarget as HTMLElement;\n const related = (e.relatedTarget || (e.nativeEvent as any)[relatedNative]) as HTMLElement;\n let isOutside = true;\n if (\n (popupRef.current && contains(popupRef.current, related)) ||\n (triggerRef.current && contains(triggerRef.current, related))\n ) {\n isOutside = false;\n }\n if ((!related || related !== target) && !contains(target, related)) {\n handler(isOutside, e);\n }\n }\n\n function hide() {\n if (!isOpen) return;\n zIndex.current -= 1;\n setIsOpen(false);\n }\n\n function show() {\n if (isOpen) return;\n zIndex.current += 1;\n setIsOpen(true);\n }\n\n function handleEnter(node: HTMLElement, isAppearing: boolean) {\n onEnter && onEnter(node, isAppearing);\n const styls = getStyle({\n placement: overlayStyl.placement || placement,\n trigger: triggerRef.current as HTMLElement | IBoundingClientRect,\n popup: popupRef.current as HTMLElement | IBoundingClientRect,\n usePortal,\n autoAdjustOverflow,\n });\n setOverlayStyl({ ...styls, zIndex: zIndex.current });\n }\n\n if (trigger === 'click' && !disabled) {\n triggerProps.onClick = (e) => {\n const { onClick } = getChildProps() as any;\n isOpen ? hide() : show();\n if (onClick) onClick(e, !isOpen);\n };\n }\n if (trigger === 'focus' && !disabled) {\n triggerProps.onFocus = () => handleShow();\n }\n\n if (trigger === 'hover' && !disabled) {\n triggerProps.onMouseOver = triggerProps.onMouseEnter = (e) => {\n handleMouseOverOut(handleShow, e, 'fromElement');\n };\n triggerProps.onMouseOut = triggerProps.onMouseLeave = (e) => {\n handleMouseOverOut(handleHide, e, 'toElement');\n };\n if (overlayProps.dialogProps) {\n overlayProps.dialogProps!.onMouseLeave = (e) => {\n handleMouseOverOut(handleHide, e, 'toElement');\n };\n }\n }\n overlayProps.style = { ...overlayProps.style, ...overlayStyl };\n return (\n <React.Fragment>\n {cloneElement(\n child,\n Object.assign({}, child.props, {\n ...triggerProps,\n ref: triggerRef,\n className: [child.props.className, disabled ? `${prefixCls}-disabled` : null]\n .filter(Boolean)\n .join(' ')\n .trim(),\n }),\n )}\n <Overlay\n {...overlayProps}\n style={{ ...overlayProps.style, ...overlayStyl }}\n onEnter={handleEnter}\n className={[prefixCls, className, overlayStyl.placement].filter(Boolean).join(' ').trim()}\n usePortal={usePortal}\n transitionName={transitionName}\n isOpen={isOpen}\n hasBackdrop={false}\n >\n {cloneElement(\n overlay,\n Object.assign({\n ...overlay.props,\n ref: popupRef,\n className: [overlay.props && overlay.props.className, placement].filter(Boolean).join(' ').trim(),\n }),\n )}\n </Overlay>\n </React.Fragment>\n );\n});\n","import React from 'react';\nimport OverlayTrigger, { OverlayTriggerProps } from '@uiw/react-overlay-trigger';\nimport './style/index.less';\n\nexport interface PopoverProps extends OverlayTriggerProps {\n content?: React.ReactNode;\n visibleArrow?: boolean;\n}\n\nexport default class Popover extends React.Component<PopoverProps> {\n public static defaultProps: PopoverProps = {\n prefixCls: 'w-popover',\n placement: 'top',\n usePortal: true,\n isOpen: false,\n visibleArrow: true,\n };\n renderArrow = () => {\n const { prefixCls } = this.props;\n return (\n <div className={`${prefixCls}-arrow`}>\n <svg viewBox=\"0 0 30 30\">\n <path\n fillOpacity=\"0.2\"\n d=\"M8.11 6.302c1.015-.936 1.887-2.922 1.887-4.297v26c0-1.378-.868-3.357-1.888-4.297L.925 17.09c-1.237-1.14-1.233-3.034 0-4.17L8.11 6.302z\"\n />\n <path\n fill=\"#fff\"\n d=\"M8.787 7.036c1.22-1.125 2.21-3.376 2.21-5.03V0v30-2.005c0-1.654-.983-3.9-2.21-5.03l-7.183-6.616c-.81-.746-.802-1.96 0-2.7l7.183-6.614z\"\n />\n </svg>\n </div>\n );\n };\n render() {\n const { prefixCls, className, content, visibleArrow, ...other } = this.props;\n const cls = [prefixCls, className, !visibleArrow ? 'no-arrow' : null].filter(Boolean).join(' ').trim();\n return (\n <OverlayTrigger\n {...other}\n overlay={\n <div className={cls}>\n {visibleArrow && this.renderArrow()}\n <div className={`${prefixCls}-inner`}>{this.props.content}</div>\n </div>\n }\n >\n {typeof this.props.children === 'object' ? this.props.children : <span>{this.props.children}</span>}\n </OverlayTrigger>\n );\n }\n}\n","import React, { useEffect, useImperativeHandle } from 'react';\nimport Icon, { IconProps } from '@uiw/react-icon';\nimport { IProps, HTMLInputProps } from '@uiw/utils';\nimport './style/input.less';\n\nexport interface InputProps extends IProps, Omit<HTMLInputProps, 'size'> {\n preIcon?: IconProps['type'];\n addonAfter?: React.ReactNode;\n size?: 'large' | 'default' | 'small';\n}\n\nexport default React.forwardRef<HTMLInputElement, InputProps>((props, ref) => {\n const {\n prefixCls = 'w-input',\n className,\n style,\n size = 'default',\n type = 'text',\n preIcon = null,\n addonAfter,\n ...otherProps\n } = props;\n const inputRef = React.useRef<HTMLInputElement>(null);\n const addonRef = React.useRef<HTMLSpanElement>(null);\n useImperativeHandle<HTMLInputElement | null, HTMLInputElement | null>(ref, () => inputRef.current);\n const cls = [\n prefixCls,\n className,\n size ? `${prefixCls}-${size}` : null,\n addonAfter ? `${prefixCls}-addon` : null,\n props.disabled ? 'disabled' : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim();\n\n useEffect(() => {\n computedInputPadding();\n });\n\n function computedInputPadding() {\n if (addonRef.current && inputRef.current) {\n const input = window && window.getComputedStyle(addonRef.current, null);\n inputRef.current.style.paddingRight = `${\n addonRef.current.clientWidth + parseInt(input.right as string, 10) * 2\n }px`;\n }\n }\n return (\n <div className={cls} style={style}>\n <Icon type={preIcon} />\n <input ref={inputRef} type={type} autoComplete=\"off\" {...otherProps} className={`${prefixCls}-inner`} />\n {addonAfter && (\n <span className={`${prefixCls}-addon-after`} ref={addonRef}>\n {addonAfter}\n </span>\n )}\n </div>\n );\n});\n","import React, { useMemo, useRef } from 'react';\nimport { IProps, HTMLDivProps, HTMLLiProps } from '@uiw/utils';\nimport './style/time-picker.less';\n\nexport interface TimePickerPanelProps extends IProps, HTMLDivProps {\n onSelected?: (\n type: TimePickerPanelProps['type'],\n num: number,\n disableds: number[],\n date: TimePickerPanelProps['date'],\n ) => void;\n count?: number;\n hideDisabled?: boolean;\n disabledHours?: (\n num: number,\n type: TimePickerPanelProps['type'],\n date: TimePickerPanelProps['date'],\n ) => boolean | undefined;\n disabledMinutes?: (\n num: number,\n type: TimePickerPanelProps['type'],\n date: TimePickerPanelProps['date'],\n ) => boolean | undefined;\n disabledSeconds?: (\n num: number,\n type: TimePickerPanelProps['type'],\n date: TimePickerPanelProps['date'],\n ) => boolean | undefined;\n type?: 'Hours' | 'Minutes' | 'Seconds';\n date?: Date;\n}\n\nexport default function TimePickerPanel(props: TimePickerPanelProps) {\n const {\n prefixCls = 'w-timepicker',\n className,\n count = 24,\n date,\n type = 'Hours',\n disabledHours,\n disabledMinutes,\n disabledSeconds,\n hideDisabled,\n onSelected,\n ...other\n } = props;\n const disableds = useRef<number[]>([]);\n function getMaybeNumber() {\n if (date && type) {\n return new Date(date)[`get${type}` as 'getHours' | 'getMinutes' | 'getSeconds']();\n }\n return 0;\n }\n function handleClick(num: number, e: React.MouseEvent<HTMLLIElement>) {\n if (!date) return;\n const currentDate = new Date(date);\n currentDate[`set${type}` as 'setHours' | 'setMinutes' | 'setSeconds'](num);\n onSelected && onSelected(type, num, disableds.current, currentDate);\n }\n function getDisabledItem(num: number) {\n const disabled = props[`disabled${type}` as 'disabledHours' | 'disabledMinutes' | 'disabledSeconds'];\n if (disabled) {\n return disabled(num, type, new Date(date!));\n }\n return false;\n }\n function getItemInstance(tag: HTMLLIElement) {\n if (tag && tag.parentNode && tag.dataset['index']) {\n const offsetTop = Number(tag.dataset['index']) * tag.clientHeight;\n if (tag.parentNode.parentNode) {\n (tag.parentNode.parentNode as HTMLDivElement).scrollTop = offsetTop;\n }\n }\n }\n const data = useMemo(() => {\n return [...Array(count)]\n .map((_, idx) => {\n const disabled = getDisabledItem(idx);\n if (disabled) disableds.current.push(idx);\n return {\n count: idx,\n disabled: getDisabledItem(idx),\n };\n })\n .filter((item) => (hideDisabled && item.disabled ? false : true));\n }, [hideDisabled]);\n\n return (\n <div className={`${prefixCls}-spinner`} {...other}>\n <ul>\n {data.map((item, idx) => {\n const liProps = {} as HTMLLiProps;\n if (!item.disabled) {\n liProps.onClick = (e) => handleClick(item.count, e);\n }\n const currentCount = getMaybeNumber();\n return (\n <li\n key={idx}\n data-index={currentCount === item.count ? idx : undefined}\n ref={(tag) => tag && getItemInstance(tag)}\n {...liProps}\n className={[\n item.disabled ? 'disabled' : null,\n currentCount === item.count ? 'selected' : null,\n hideDisabled && item.disabled ? 'hide' : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim()}\n >\n {item.count < 10 ? `0${item.count}` : item.count}\n </li>\n );\n })}\n </ul>\n </div>\n );\n}\n","import React from 'react';\nimport { IProps } from '@uiw/utils';\nimport TimePanel, { TimePickerPanelProps } from './Panel';\nimport './style/time-picker.less';\n\nexport interface TimePickerTimeProps extends IProps, TimePickerPanelProps {\n precision?: Precision;\n}\n\nexport type Precision = 'hour' | 'minute' | 'second';\n\nexport function TimePickerTime(props: TimePickerTimeProps) {\n const { prefixCls = 'w-timepicker', className, precision = 'second', ...other } = props;\n return (\n <div className={[prefixCls, className].filter(Boolean).join(' ').trim()}>\n {/^(second|minute|hour)$/.test(precision as Precision) && <TimePanel type=\"Hours\" count={24} {...other} />}\n {/^(second|minute)$/.test(precision as Precision) && <TimePanel type=\"Minutes\" count={60} {...other} />}\n {/^(second)$/.test(precision as Precision) && <TimePanel type=\"Seconds\" count={60} {...other} />}\n </div>\n );\n}\n","import React, { useEffect, useState } from 'react';\nimport Popover, { PopoverProps } from '@uiw/react-popover';\nimport Input, { InputProps } from '@uiw/react-input';\nimport Button from '@uiw/react-button';\nimport { IProps } from '@uiw/utils';\nimport formatter from '@uiw/formatter';\nimport { TimePickerTime, TimePickerTimeProps } from './Time';\nimport './style/index.less';\n\nexport * from './Panel';\nexport * from './Time';\n\nexport interface TimePickerProps extends IProps, Omit<InputProps, 'onChange' | 'value'> {\n value?: Date;\n format?: string;\n popoverProps?: PopoverProps;\n disabledHours?: TimePickerTimeProps['disabledHours'];\n precision?: TimePickerTimeProps['precision'];\n disabledMinutes?: TimePickerTimeProps['disabledMinutes'];\n disabledSeconds?: TimePickerTimeProps['disabledSeconds'];\n hideDisabled?: TimePickerTimeProps['hideDisabled'];\n allowClear?: boolean;\n disabled?: boolean;\n onChange?: (\n dataStr?: string,\n date?: Date | '',\n type?: TimePickerTimeProps['type'],\n num?: number,\n disableds?: number[],\n ) => void;\n}\n\nexport default function TimePicker(props: TimePickerProps) {\n const {\n prefixCls = 'w-timepicker',\n className,\n disabled,\n value,\n format = 'HH:mm:ss',\n popoverProps,\n allowClear = true,\n onChange,\n disabledHours,\n disabledMinutes,\n disabledSeconds,\n hideDisabled,\n precision,\n ...inputProps\n } = props;\n const [date, setDate] = useState(props.value);\n useEffect(() => setDate(props.value), [props.value]);\n const timeProps = {\n disabledHours,\n disabledMinutes,\n disabledSeconds,\n hideDisabled,\n precision,\n };\n const inputValue = date ? formatter(format, new Date(date)) : '';\n const datePickerTime = date || new Date();\n const _props: InputProps = { ...inputProps, value: inputValue };\n if (allowClear && inputValue !== '' && !!inputValue) {\n _props.addonAfter = (\n <Button\n className={`${prefixCls}-close-btn`}\n icon=\"close\"\n disabled={props.disabled}\n onClick={() => {\n setDate(undefined);\n onChange && onChange();\n }}\n size={props.size}\n basic\n type=\"light\"\n />\n );\n }\n return (\n <Popover\n trigger=\"focus\"\n placement=\"bottomLeft\"\n autoAdjustOverflow\n visibleArrow={false}\n {...popoverProps}\n content={\n <TimePickerTime\n className={`${prefixCls}-popover`}\n {...timeProps}\n date={datePickerTime}\n onSelected={(type, num, disableds, currentDate) => {\n setDate(new Date(currentDate!));\n const dataStr = currentDate ? formatter(format, currentDate) : '';\n onChange && onChange(dataStr, currentDate, type, num, disableds);\n }}\n />\n }\n >\n <Input\n placeholder=\"请选择时间\"\n readOnly\n disabled={disabled}\n {..._props}\n className={[`${prefixCls}-input`, className].filter(Boolean).join(' ').trim()}\n />\n </Popover>\n );\n}\n","import React, { useMemo } from 'react';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\nimport './style/day.less';\n\nfunction isValidDate(date: Date) {\n return date instanceof Date && !isNaN(date.getTime());\n}\n\nexport interface DatePickerDayDateSource {\n day?: number;\n month?: number;\n year?: number;\n}\n\nfunction classnames(obj: Record<string, boolean>) {\n return Object.keys(obj || {})\n .map((keyName) => (obj[keyName] ? keyName : null))\n .filter(Boolean)\n .join(' ')\n .trim();\n}\n\nexport interface DatePickerDayProps extends IProps, HTMLDivProps {\n weekday?: string[];\n weekTitle?: string[];\n panelDate?: Date;\n date?: Date;\n today?: Date;\n prefixCls?: string;\n onSelectDay?: (selectedDate?: Date, dateSource?: DatePickerDayDateSource) => void;\n renderDay?: (day: number, props: DatePickerDayRenderDay & DatePickerDayRenderDayProps) => React.ReactNode;\n disabledDate?: (cellDate: Date, props: DatePickerDayRenderDay & DatePickerDayRenderDayProps) => boolean;\n}\n\nexport interface PickerDayState {\n selected?: Date;\n panelDate?: Date;\n}\n\nexport type DatePickerDayRenderDay = {\n end: boolean;\n prev: boolean;\n today: boolean;\n selected: boolean;\n next: boolean;\n disabled: boolean;\n date?: Date;\n};\n\nexport type DatePickerDayRenderDayProps = {\n key?: number;\n date?: Date;\n onClick?: (cellDate: Date, event: React.MouseEvent<HTMLDivProps>) => void;\n};\n\nexport type DayRectProps = {\n col: number;\n row: number;\n index: number;\n date?: DatePickerDayProps['date'];\n today?: DatePickerDayProps['today'];\n disabledDate?: DatePickerDayProps['disabledDate'];\n renderDay?: DatePickerDayProps['renderDay'];\n panelDate?: DatePickerDayProps['panelDate'];\n onSelectDay?: DatePickerDayProps['onSelectDay'];\n};\n\nexport function DayRect(props: DayRectProps) {\n const {\n date: selectedDate,\n row,\n col,\n index,\n today,\n panelDate,\n disabledDate,\n renderDay,\n onSelectDay,\n ...other\n } = props;\n const cls: Omit<DatePickerDayRenderDay, 'date'> = {\n end: col === 0 || col === 6,\n prev: false,\n today: false,\n selected: false,\n next: false,\n disabled: false,\n };\n let date = panelDate;\n if (!date || !isValidDate(date)) date = new Date();\n const year = date.getFullYear();\n const month = date.getMonth();\n const week = useMemo(() => new Date(new Date(date!).setDate(1)).getDay(), [date.toDateString()]);\n const lastDay = useMemo(() => new Date(year, month === 0 ? 12 : month + 1, 0).getDate(), [date.toDateString()]);\n let day = index;\n if (date) {\n day = day - week + 1;\n if (day < 1) {\n cls.prev = true;\n }\n if (day > lastDay) {\n cls.next = true;\n }\n }\n let cellDate = useMemo(() => new Date(new Date(date!).setDate(day)), [day]);\n if (today && today.toDateString() === cellDate.toDateString()) {\n cls.today = true;\n }\n if (selectedDate && selectedDate.toDateString() === cellDate.toDateString()) {\n cls.selected = true;\n }\n const divProps: React.HTMLAttributes<HTMLDivElement> = {\n onClick: () => {\n const cellMonth = cellDate.getMonth();\n onSelectDay &&\n onSelectDay!(cellDate, {\n year: cellDate.getFullYear(),\n month: cellMonth === 0 ? 12 : cellMonth + 1,\n day: cellDate.getDate(),\n });\n },\n };\n if (disabledDate && disabledDate(cellDate, { ...props, ...cls })) {\n cls.disabled = true;\n delete divProps.onClick;\n }\n return (\n <div className={classnames(cls)} {...other} {...divProps}>\n {renderDay ? (\n renderDay(cellDate.getDate(), { ...props, ...cls, date: cellDate })\n ) : (\n <div>{cellDate.getDate()}</div>\n )}\n </div>\n );\n}\n\nconst WEEKTITLE = ['星期天', '星期一', '星期二', '星期三', '星期四', '星期五', '星期六'];\nconst WEEKDAY = ['日', '一', '二', '三', '四', '五', '六'];\n\nexport function DatePickerDay(props: DatePickerDayProps) {\n const {\n prefixCls = 'w-datepicker',\n className,\n weekday = WEEKDAY,\n weekTitle = WEEKTITLE,\n date,\n today,\n panelDate,\n disabledDate,\n renderDay,\n onSelectDay,\n ...other\n } = props;\n\n const weekdayLabel = useMemo(\n () => (\n <div className={`${prefixCls}-weekday`}>\n {(weekday || []).map((week, idx) => (\n <div key={idx} className={classnames({ end: idx === 0 || idx === 6 })} title={weekTitle && weekTitle[idx]}>\n {week}\n </div>\n ))}\n </div>\n ),\n [prefixCls, weekday, weekTitle],\n );\n\n return (\n <div {...other} className={[prefixCls ? `${prefixCls}-body` : null, className].filter(Boolean).join(' ').trim()}>\n {weekdayLabel}\n <div className={[prefixCls ? `${prefixCls}-day-body` : null].filter(Boolean).join(' ').trim()}>\n {[...Array(6)].map((_, idx) => (\n <div key={idx} className={`${prefixCls}-week`}>\n {[...Array(7)].map((_, col) => (\n <DayRect\n date={date}\n today={today}\n disabledDate={disabledDate}\n renderDay={renderDay}\n panelDate={panelDate}\n key={col}\n col={col}\n row={idx}\n onSelectDay={(curDate, data) => {\n onSelectDay && onSelectDay(curDate, data);\n }}\n index={idx * 7 + col}\n />\n ))}\n </div>\n ))}\n </div>\n </div>\n );\n}\n","import React from 'react';\nimport { IProps, HTMLDivProps, noop } from '@uiw/utils';\nimport './style/year-month.less';\n\nexport interface DatePickerMonthProps extends IProps, HTMLDivProps {\n panelDate?: Date;\n onSelected?: (month: number, paging?: boolean) => void;\n monthLabel?: React.ReactNode[];\n}\n\nexport function DatePickerMonth(props: DatePickerMonthProps) {\n const {\n prefixCls = 'w-datepicker',\n className,\n panelDate = new Date(),\n monthLabel,\n onSelected = noop,\n ...other\n } = props;\n return (\n <div className={[prefixCls ? `${prefixCls}-month` : null, className].filter(Boolean).join(' ').trim()} {...other}>\n {[...Array(12)].map((_, idx) => {\n const selectedMonth = panelDate!.getMonth();\n return (\n <div key={idx} className={[selectedMonth === idx ? 'selected' : null].filter(Boolean).join(' ').trim()}>\n <span onClick={() => onSelected(idx, false)}>{(monthLabel && monthLabel[idx]) || idx}</span>\n </div>\n );\n })}\n </div>\n );\n}\n","import React, { useState } from 'react';\nimport { IProps, HTMLDivProps, noop } from '@uiw/utils';\nimport './style/year-month.less';\n\nexport interface DatePickerYearProps extends IProps, HTMLDivProps {\n panelDate?: Date;\n panelNum?: number[];\n onSelected?: (year: number, paging?: boolean) => void;\n}\n\nexport function DatePickerYear(props: DatePickerYearProps) {\n const {\n prefixCls = 'w-datepicker',\n panelNum = [-7, -6, -5, -4, -3, -2, -1, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10],\n className,\n panelDate,\n onSelected = noop,\n ...other\n } = props;\n const [activeYear, setActiveYear] = useState(props.panelDate);\n function handleSelected(year: number, idx: number) {\n if (idx === 0 || idx === panelNum!.length - 1) {\n const date = new Date(activeYear!);\n date.setFullYear(year);\n setActiveYear(date);\n onSelected!(year, true);\n } else {\n onSelected!(year);\n }\n }\n return (\n <div className={[prefixCls ? `${prefixCls}-year` : null, className].filter(Boolean).join(' ').trim()} {...other}>\n {panelNum &&\n panelNum.map((_, idx) => {\n const selectedYear = activeYear!.getFullYear();\n const year = selectedYear + panelNum[idx];\n return (\n <div\n key={idx}\n className={[\n selectedYear === year ? 'selected' : null,\n idx === 0 || idx === panelNum.length - 1 ? 'paging' : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim()}\n >\n <span onClick={() => handleSelected(year, idx)}>{year}</span>\n </div>\n );\n })}\n </div>\n );\n}\n","import React, { useMemo } from 'react';\nimport { IProps, HTMLDivProps, noop } from '@uiw/utils';\nimport './style/caption.less';\n\nfunction classnames(...arg: (string | null | undefined)[]) {\n return [...arg].filter(Boolean).join(' ').trim();\n}\n\nexport type DatePickerCaptionType = 'prev' | 'month' | 'year' | 'today' | 'next';\n\nexport interface DatePickerCaptionProps extends IProps, HTMLDivProps {\n panelDate?: Date;\n monthLabel?: React.ReactNode[];\n todayButton?: string;\n onSelected?: (captionType: DatePickerCaptionType) => void;\n}\n\nexport function DatePickerCaption(props: DatePickerCaptionProps) {\n const {\n prefixCls = 'w-datepicker',\n className,\n panelDate = new Date(),\n monthLabel,\n onSelected = noop,\n todayButton,\n ...other\n } = props;\n\n const renderMonth = useMemo(() => {\n const month = panelDate.getMonth();\n return (monthLabel && monthLabel[month]) || month + 1;\n }, [panelDate.toDateString(), monthLabel]);\n return (\n <div className={classnames(prefixCls ? `${prefixCls}-caption` : null, className)} {...other}>\n <div\n className={classnames(prefixCls ? `${prefixCls}-caption-pane` : null, 'prev')}\n onClick={() => onSelected('prev')}\n />\n <div\n className={classnames(prefixCls ? `${prefixCls}-caption-pane` : null, 'month')}\n onClick={() => onSelected('month')}\n >\n {renderMonth}\n </div>\n <div\n className={classnames(prefixCls ? `${prefixCls}-caption-pane` : null, 'year')}\n onClick={() => onSelected('year')}\n >\n {panelDate!.getFullYear()}\n </div>\n {todayButton && (\n <div\n className={classnames(prefixCls ? `${prefixCls}-caption-today` : null)}\n onClick={() => onSelected('today')}\n title={todayButton}\n />\n )}\n <div\n className={classnames(prefixCls ? `${prefixCls}-caption-pane` : null, 'next')}\n onClick={() => onSelected('next')}\n />\n </div>\n );\n}\n","import React, { useEffect, useMemo, useState } from 'react';\nimport formatter from '@uiw/formatter';\nimport { IProps, HTMLDivProps, noop } from '@uiw/utils';\nimport { TimePickerTime, TimePickerPanelProps } from '@uiw/react-time-picker';\nimport { DatePickerDay, DatePickerDayProps, DatePickerDayDateSource } from './DatePickerDay';\nimport { DatePickerMonth } from './DatePickerMonth';\nimport { DatePickerYear } from './DatePickerYear';\nimport { DatePickerCaption, DatePickerCaptionType } from './DatePickerCaption';\nimport './style/index.less';\n\nexport * from './DatePickerDay';\nexport * from './DatePickerMonth';\nexport * from './DatePickerYear';\nexport * from './DatePickerCaption';\n\nconst MONTH_LABEL = [\n '一月',\n '二月',\n '三月',\n '四月',\n '五月',\n '六月',\n '七月',\n '八月',\n '九月',\n '十月',\n '十一月',\n '十二月',\n];\n\nexport interface DatePickerShowTimeProps extends TimePickerPanelProps {\n format?: string;\n}\nexport interface DatePickerProps extends IProps, Omit<HTMLDivProps, 'onChange'> {\n onChange?: (selectedDate?: Date, dateSource?: DatePickerDayDateSource) => void;\n renderDay?: DatePickerDayProps['renderDay'];\n disabledDate?: DatePickerDayProps['disabledDate'];\n showTime?: DatePickerShowTimeProps | boolean;\n monthLabel?: React.ReactNode[];\n weekday?: string[];\n weekTitle?: string[];\n date?: Date;\n panelDate?: Date;\n today?: Date;\n todayButton?: string;\n onPanelChange?: (date?: Date, mode?: 'next' | 'prev') => void;\n}\nexport interface DatePickerState {\n panelDate?: Date;\n date?: Date;\n type?: 'day' | 'time' | DatePickerCaptionType;\n}\n\nexport default function DatePicker(props: DatePickerProps) {\n const {\n prefixCls = 'w-datepicker',\n className,\n weekday,\n weekTitle,\n monthLabel = MONTH_LABEL,\n date,\n today = new Date(),\n todayButton,\n panelDate = new Date(),\n disabledDate,\n renderDay,\n onChange = noop,\n onPanelChange = noop,\n showTime,\n ...other\n } = props;\n const [type, setType] = useState<DatePickerState['type']>('day');\n const [selectDate, setSelectDate] = useState(date);\n const [selectPanelDate, setSelectPanelDate] = useState(panelDate);\n\n useEffect(() => {\n if (date) {\n setSelectDate(date);\n setSelectPanelDate(date);\n }\n }, [date]);\n\n const format = useMemo(\n () =>\n showTime && (showTime as DatePickerShowTimeProps).format\n ? (showTime as DatePickerShowTimeProps).format\n : 'HH:mm:ss',\n [showTime],\n );\n function handleSelected(curType: DatePickerState['type']) {\n if (curType && /^(year|month|time)$/.test(curType)) {\n if (type === 'time') {\n curType = 'day';\n }\n setType(curType);\n } else {\n let currentDate = new Date(selectDate || selectPanelDate);\n let month = currentDate.getMonth();\n if (curType === 'prev') {\n month -= 1;\n }\n if (curType === 'next') {\n month += 1;\n }\n currentDate.setMonth(month);\n if (curType === 'prev' || curType === 'next') {\n onPanelChange && onPanelChange(new Date(currentDate), curType);\n }\n setSelectPanelDate(curType === 'today' ? today : currentDate);\n setSelectDate(curType === 'today' ? today : currentDate);\n\n setType('day');\n }\n }\n\n function onSelectedTime(type: TimePickerPanelProps['type'], num: number) {\n (selectPanelDate || new Date())[`set${type}` as 'setHours'](num);\n setSelectPanelDate(new Date(selectPanelDate));\n onChange && onChange(new Date(selectPanelDate));\n }\n\n function onSelectedDate(type: 'setMonth' | 'setFullYear', month: number, paging?: boolean) {\n (selectPanelDate || new Date())[type](month);\n setSelectPanelDate(new Date(selectPanelDate));\n setType('day');\n onChange && onChange(new Date(selectPanelDate));\n }\n return (\n <div className={[prefixCls, className].filter(Boolean).join(' ').trim()} {...other}>\n <DatePickerCaption\n todayButton={todayButton}\n panelDate={selectPanelDate}\n monthLabel={monthLabel}\n onSelected={handleSelected}\n />\n {type === 'day' && (\n <DatePickerDay\n prefixCls={prefixCls}\n disabledDate={disabledDate}\n onSelectDay={(selectedDate, dateSource) => {\n setSelectPanelDate(selectedDate!);\n onChange(selectedDate, dateSource);\n }}\n renderDay={renderDay}\n date={selectDate}\n today={today || new Date()}\n panelDate={selectPanelDate}\n weekday={weekday}\n weekTitle={weekTitle}\n />\n )}\n {type === 'month' && (\n <DatePickerMonth\n panelDate={selectPanelDate}\n monthLabel={monthLabel}\n prefixCls={prefixCls}\n onSelected={(num) => onSelectedDate('setMonth', num)}\n />\n )}\n {type === 'year' && (\n <DatePickerYear\n prefixCls={prefixCls}\n panelDate={selectDate || selectPanelDate}\n onSelected={(num) => onSelectedDate('setFullYear', num)}\n />\n )}\n {type === 'time' && (\n <TimePickerTime\n date={selectPanelDate}\n {...showTime}\n className={`${prefixCls}-timepicker`}\n onSelected={onSelectedTime}\n />\n )}\n {showTime && format && (\n <div className={`${prefixCls}-time-btn`} onClick={() => handleSelected('time')}>\n {formatter(format!, selectDate || selectPanelDate)}\n </div>\n )}\n </div>\n );\n}\n","import React, { useMemo } from 'react';\nimport { CalendarProps } from './';\n\nexport type RenderDayProps = {\n prefixCls?: string;\n day?: number;\n data?: CalendarProps['data'];\n currentDate?: Date;\n};\n\nexport default function RenderDay(props: RenderDayProps) {\n const { prefixCls, day, data, currentDate } = props;\n\n const dayData = useMemo(\n () =>\n (data || []).filter((item) => {\n let arr: number[] = ((item.date && item.date.split('/')) || []).map((num) => Number(num));\n if (arr.length === 1) {\n return day === arr[0];\n }\n if (currentDate && arr.length === 2) {\n return currentDate.getMonth() + 1 === arr[0] && day === arr[1];\n }\n if (currentDate && arr.length === 3) {\n return currentDate.getFullYear() === arr[0] && currentDate.getMonth() + 1 === arr[1] && day === arr[2];\n }\n return false;\n }),\n [currentDate, day, data],\n );\n\n return useMemo(\n () => (\n <div className={`${prefixCls}-inner`}>\n <div className={`${prefixCls}-day`}>{day}</div>\n <div className={`${prefixCls}-panel`}>\n {dayData &&\n dayData.length > 0 &&\n dayData.map((item, idx) => {\n const { date, label, ...other } = item;\n return (\n <div key={idx} {...other}>\n {label}\n </div>\n );\n })}\n </div>\n </div>\n ),\n [dayData, day],\n );\n}\n","import React, { useEffect, useMemo, useState } from 'react';\nimport { DatePickerDay, DatePickerDayProps, DatePickerDayDateSource } from '@uiw/react-date-picker';\nimport Icon from '@uiw/react-icon';\nimport formatter from '@uiw/formatter';\nimport { IProps } from '@uiw/utils';\nimport RenderDay from './DayLabel';\nimport './style/index.less';\n\nexport interface CalendarProps extends IProps, DatePickerDayProps {\n /**\n * 设置日历面板上面的日期标题。\n */\n titleFormat?: string;\n /**\n * 点击选择日期回调\n */\n onSelectDay?: (selectDay?: Date, dateSource?: DatePickerDayDateSource) => void;\n /**\n * 日历面板默认展示哪一页\n */\n panelDate?: Date;\n /**\n * 默认高亮当天日期\n */\n today?: Date;\n /**\n * 在日历面板上面添加通知,数组中的对象可以设置 `ElementProps`,如:`style`, `onClick` 等属性。\n */\n data?: ICalendarData[];\n /**\n * 选中的日期\n */\n date?: Date;\n /**\n * `今天` 按钮的文本设置\n */\n todayLabel?: string;\n /**\n * 月份显示文本\n */\n monthLabel?: string[];\n /** 翻页触发事件 */\n onPaging?: (type: 'prev' | 'next' | 'today', month: number, panelDate?: Date) => void;\n}\n\nexport interface ICalendarData {\n label?: React.ReactNode;\n date?: string;\n [key: string]: any;\n}\n\nconst MONTH_LABEL = [\n '一月',\n '二月',\n '三月',\n '四月',\n '五月',\n '六月',\n '七月',\n '八月',\n '九月',\n '十月',\n '十一月',\n '十二月',\n];\n\nexport default function Calendar(props: CalendarProps) {\n const {\n prefixCls = 'w-calendar',\n className,\n style,\n today = new Date(),\n date,\n data,\n monthLabel = MONTH_LABEL,\n titleFormat = 'YYYY/MM',\n todayLabel = '今天',\n panelDate: _,\n onPaging,\n onSelectDay,\n ...otherProps\n } = props;\n const cls = [prefixCls, className].filter(Boolean).join(' ').trim();\n const [panelDate, setPanelDate] = useState<Date>(props.panelDate || new Date());\n\n useEffect(() => {\n if (props.panelDate !== panelDate) {\n setPanelDate(panelDate);\n }\n }, [props.panelDate]);\n\n function handlePaging(type: 'prev' | 'next' | 'today') {\n let currentDate = new Date();\n if (type === 'today') {\n currentDate = today || new Date();\n } else {\n const month = panelDate.getMonth();\n if (panelDate && type === 'prev') {\n panelDate.setMonth(month - 1);\n }\n if (panelDate && type === 'next') {\n panelDate.setMonth(month + 1);\n }\n currentDate = panelDate;\n }\n setPanelDate(new Date(currentDate));\n onPaging && onPaging(type, currentDate!.getMonth() + 1, currentDate);\n }\n\n const titleLable = useMemo(\n () => <div className={`${prefixCls}-title`}>{formatter(titleFormat, panelDate)}</div>,\n [prefixCls, titleFormat, panelDate],\n );\n\n const btngroup = useMemo(\n () => (\n <div className={`${prefixCls}-btn-group`}>\n <Icon type=\"down\" onClick={() => handlePaging('prev')} />\n <span className={`${prefixCls}-btn`} onClick={() => handlePaging('today')}>\n {todayLabel}\n </span>\n <Icon type=\"down\" onClick={() => handlePaging('next')} />\n </div>\n ),\n [prefixCls, todayLabel],\n );\n\n return (\n <div className={cls} style={style}>\n <div className={`${prefixCls}-caption`}>\n {titleLable}\n {btngroup}\n </div>\n <DatePickerDay\n onSelectDay={(currentDate, dateSource) => {\n setPanelDate(currentDate!);\n onSelectDay && onSelectDay(currentDate, dateSource);\n }}\n renderDay={(day, propsNext) => (\n <RenderDay prefixCls={prefixCls} day={day} data={data} currentDate={propsNext.date} />\n )}\n date={date}\n today={today}\n panelDate={panelDate || new Date()}\n {...otherProps}\n />\n </div>\n );\n}\n","import React, { useMemo } from 'react';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface CardProps extends IProps, Omit<HTMLDivProps, 'title'> {\n active?: boolean;\n bordered?: boolean;\n bodyStyle?: React.CSSProperties;\n bodyClassName?: string;\n title?: React.ReactNode;\n noHover?: boolean;\n extra?: React.ReactNode;\n footer?: React.ReactNode;\n}\n\nexport default React.forwardRef<HTMLDivElement, CardProps>((props, ref) => {\n const {\n prefixCls = 'w-card',\n className,\n title,\n extra,\n footer,\n bordered = true,\n noHover = false,\n active = false,\n bodyStyle,\n bodyClassName,\n children,\n ...resetProps\n } = props;\n const cls = useMemo(\n () =>\n [\n prefixCls,\n className,\n bordered ? `${prefixCls}-bordered` : null,\n noHover ? `${prefixCls}-no-hover` : null,\n active ? 'active' : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim(),\n [prefixCls, className, bordered, noHover],\n );\n\n return (\n <div {...resetProps} className={cls} ref={ref}>\n {(title || extra) && (\n <div className={`${prefixCls}-head`}>\n {title && <div className={`${prefixCls}-head-title`}>{title}</div>}\n {extra && <div className={`${prefixCls}-extra`}>{extra}</div>}\n </div>\n )}\n {children && (\n <div className={[`${prefixCls}-body`, bodyClassName].filter(Boolean).join(' ').trim()} style={bodyStyle}>\n {children}\n </div>\n )}\n {footer && <div className={`${prefixCls}-footer`}>{footer}</div>}\n </div>\n );\n});\n","import React, { useState, useMemo } from 'react';\nimport { IProps, HTMLInputProps } from '@uiw/utils';\n\n/**\n * Constructs a type by picking all properties from `HTMLInputProps` and then removing `size`.\n * Omit: https://www.typescriptlang.org/docs/handbook/utility-types.html#omittk\n */\nexport interface RadioAbstractProps extends IProps, Omit<HTMLInputProps, 'size'> {\n size?: 'large' | 'default' | 'small';\n checked?: boolean;\n disabled?: boolean;\n onChange?: (even: React.ChangeEvent<HTMLInputElement>) => void;\n}\n\nexport const RadioAbstract = React.forwardRef<HTMLInputElement, RadioAbstractProps>((props, ref) => {\n const {\n prefixCls = 'w-radio',\n type = 'radio',\n disabled = false,\n value = '',\n className,\n style,\n children,\n size,\n checked: prChecked = false,\n onChange,\n ...other\n } = props;\n\n const [checked, setChecked] = useState(prChecked);\n const [prevChecked, setPrevChecked] = useState<boolean>();\n if (prChecked !== prevChecked) {\n setPrevChecked(prChecked);\n }\n useMemo(() => {\n if (prChecked !== prevChecked) {\n setChecked(prChecked);\n }\n }, [prevChecked]);\n\n const cls = [prefixCls, className, disabled ? 'disabled' : null, size ? `${prefixCls}-${size}` : null]\n .filter(Boolean)\n .join(' ')\n .trim();\n useMemo(() => {\n if (checked !== props.checked) {\n setChecked(!!props.checked);\n }\n }, [props.checked]);\n\n function handleChange(e: React.ChangeEvent<HTMLInputElement>) {\n e.persist();\n setChecked(e.target.checked);\n onChange && onChange(e);\n }\n\n const label = children || value;\n return (\n <label {...{ className: cls, style }}>\n <input {...{ ...other, type, disabled, value }} checked={checked} onChange={handleChange} ref={ref} />\n {label && <div className={`${prefixCls}-text`}>{label}</div>}\n </label>\n );\n});\n","import React from 'react';\nimport { RadioAbstract, RadioAbstractProps } from './RadioAbstract';\nimport './style/index.less';\n\nexport interface RadioProps extends RadioAbstractProps {}\n\nexport default React.forwardRef<HTMLInputElement, RadioProps>((props, ref) => {\n return <RadioAbstract ref={ref} {...props} />;\n});\n","import React from 'react';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\nimport { RadioProps } from './Radio';\nimport './style/group.less';\n\nexport interface RadioGroupProps extends IProps, HTMLDivProps {\n name?: RadioProps['name'];\n value?: RadioProps['value'];\n onChange?: RadioProps['onChange'];\n}\n\nexport default React.forwardRef<HTMLDivElement, RadioGroupProps>((props, ref) => {\n const { prefixCls = 'w-radio-group', className, name, value, onChange, children, ...other } = props;\n return (\n <div {...other} ref={ref} className={[prefixCls, className].filter(Boolean).join(' ').trim()}>\n {React.Children.toArray(children).map((child) => {\n if (!child) return;\n if (!React.isValidElement(child)) return child;\n return React.cloneElement(child, {\n ...(child.props || {}),\n ...{\n checked: child.props.value === value,\n name,\n onChange,\n },\n });\n })}\n </div>\n );\n});\n","import React, { useMemo, useRef } from 'react';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\nimport './style/group.less';\n\nexport type Value = string | number;\nexport interface CheckboxGroupPorps extends IProps, Omit<HTMLDivProps, 'onChange'> {\n value?: Value[];\n name?: string;\n onChange?: (e: React.ChangeEvent<HTMLInputElement>, values: Value[]) => void;\n}\n\nexport const CheckboxGroup = React.forwardRef<HTMLDivElement, CheckboxGroupPorps>((props, ref) => {\n const { prefixCls = 'w-checkbox-group', className, name, value, onChange, ...other } = props;\n const valueRef = useRef<Value[]>([]);\n const cls = [prefixCls, className].filter(Boolean).join(' ').trim();\n const childs = React.Children.toArray(props.children);\n useMemo(() => (valueRef.current = value || []), [value]);\n return (\n <div {...other} className={cls} ref={ref}>\n {React.Children.map(childs, (element: React.ReactNode) => {\n if (!React.isValidElement(element)) return;\n if (\n Array.isArray(value) &&\n element &&\n element.props &&\n element.props.value &&\n value.includes(element.props.value)\n ) {\n if (!valueRef.current.includes(element.props.value)) {\n valueRef.current.push(element.props.value);\n }\n }\n return React.cloneElement(\n element,\n Object.assign({}, element.props, {\n name,\n checked: valueRef.current.includes(element.props.value),\n onChange: (e: React.ChangeEvent<HTMLInputElement>) => {\n if (e.target.type && e.target.type !== 'checkbox') return;\n const checked = e.target.checked;\n const include = valueRef.current.includes(element.props.value);\n if (!include && checked) {\n valueRef.current.push(element.props.value);\n } else if (include && !checked) {\n valueRef.current = valueRef.current.filter((val) => val !== element.props.value);\n }\n onChange && onChange(e, valueRef.current);\n },\n }),\n );\n })}\n </div>\n );\n});\n","import React from 'react';\nimport { RadioAbstract, RadioAbstractProps } from '@uiw/react-radio';\nimport { CheckboxGroup } from './Group';\nimport './style/index.less';\n\nexport interface CheckboxProps extends RadioAbstractProps {\n indeterminate?: boolean;\n}\n\nfunction InternalCheckbox(props: CheckboxProps, ref: React.ForwardedRef<HTMLInputElement>) {\n const {\n className,\n prefixCls = 'w-checkbox',\n type = 'checkbox',\n indeterminate = false,\n disabled = false,\n value = '',\n ...other\n } = props;\n\n const cls = [className, indeterminate && 'indeterminate'].filter(Boolean).join(' ').trim();\n return (\n <RadioAbstract\n ref={ref}\n {...other}\n type={type}\n prefixCls={prefixCls}\n disabled={disabled}\n value={value}\n className={cls}\n />\n );\n}\n\nconst Checkbox = React.forwardRef<HTMLInputElement, CheckboxProps>(InternalCheckbox);\ntype Checkbox = typeof Checkbox & {\n Group: typeof CheckboxGroup;\n};\n\n(Checkbox as Checkbox).Group = CheckboxGroup;\n\nexport default Checkbox as Checkbox;\n","import Checkbox from './Checkbox';\n\nexport * from './Checkbox';\nexport * from './Group';\nexport default Checkbox;\n","import React, { useState, useMemo } from 'react';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\nimport Panel from './Panel';\nimport './style/index.less';\n\nexport interface CollapseProps extends IProps, Omit<HTMLDivProps, 'onChange'> {\n accordion?: boolean;\n activeKey?: string | string[];\n bordered?: boolean;\n showArrow?: boolean;\n onChange?: (activeKey: string[]) => void;\n}\n\nexport interface CollapseState {\n activeKey: string[];\n}\n\nfunction toArray(activeKey: CollapseProps['activeKey']) {\n let currentActiveKey = activeKey;\n if (!Array.isArray(currentActiveKey)) {\n currentActiveKey = currentActiveKey ? [currentActiveKey] : [];\n }\n return currentActiveKey;\n}\n\nfunction InternalCollapse(props: CollapseProps, ref: React.ForwardedRef<HTMLDivElement>) {\n const {\n prefixCls = 'w-collapse',\n className,\n children,\n accordion = false,\n bordered,\n showArrow = true,\n activeKey: propsActiveKey,\n onChange,\n ...resetProps\n } = props;\n const [activeKey, setActiveKey] = useState(toArray(propsActiveKey));\n const cls = [prefixCls, className, bordered ? 'w-noborder' : null].filter(Boolean).join(' ').trim();\n function onItemClick(key: string) {\n let keys = activeKey;\n if (accordion) {\n keys = keys[0] === key ? [] : [key];\n } else {\n keys = [...keys];\n const index = keys.indexOf(key);\n const isActive = index > -1;\n if (isActive) {\n keys.splice(index, 1);\n } else {\n keys.push(key);\n }\n }\n setActiveKey(keys);\n }\n useMemo(() => {\n if (propsActiveKey !== activeKey) {\n setActiveKey(toArray(propsActiveKey));\n }\n }, [propsActiveKey]);\n useMemo(() => {\n if (propsActiveKey !== activeKey) {\n onChange && onChange(activeKey);\n }\n }, [activeKey, propsActiveKey]);\n return (\n <div className={cls} {...resetProps} ref={ref}>\n {React.Children.map(children, (child: any, index) => {\n // 如果没有密钥提供,请使用面板顺序作为默认密钥\n const key = child.key || String(index);\n const { disabled } = child.props;\n let isActive = false;\n if (accordion) {\n // 手风琴模式下默认选择第一个\n isActive = activeKey[0] === key;\n } else {\n isActive = activeKey.indexOf(key) > -1;\n }\n const childProps = {\n prefixCls,\n isActive,\n disabled,\n showArrow,\n onItemClick: disabled ? () => {} : () => onItemClick(key),\n ...child.props,\n };\n return React.cloneElement(child, childProps);\n })}\n </div>\n );\n}\n\nconst Collapse = React.forwardRef<HTMLDivElement, CollapseProps>(InternalCollapse);\ntype Collapse = typeof Collapse & {\n Panel: typeof Panel;\n};\n\n(Collapse as Collapse).Panel = Panel;\n\nexport default Collapse as Collapse;\n","import React from 'react';\nimport { CSSTransition } from 'react-transition-group';\nimport { TransitionStatus } from 'react-transition-group/Transition';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\nimport Icon, { IconProps } from '@uiw/react-icon';\n\nexport interface CollapsePanelProps extends IProps, HTMLDivProps {\n disabled?: boolean;\n showArrow?: boolean;\n isActive?: boolean;\n header?: React.ReactNode;\n icon?: IconProps['type'];\n extra?: React.ReactNode;\n onItemClick?: (evn: React.MouseEvent<HTMLDivElement>) => void;\n}\n\nexport default function Panel(props: CollapsePanelProps) {\n const {\n prefixCls = 'w-collapse',\n className,\n icon = 'down',\n children,\n isActive,\n onItemClick,\n disabled = false,\n showArrow,\n header,\n extra,\n ...resetProps\n } = props;\n const cls = [\n prefixCls ? `${prefixCls}-item` : null,\n className,\n isActive ? `${prefixCls}-active` : null,\n disabled ? `${prefixCls}-disabled` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim();\n const iconRender = typeof icon === 'string' ? <Icon type={icon} /> : icon;\n\n const childStyle = (child: React.ReactElement) => {\n return Object.assign({}, child && child.props ? child.props.style : {}, {\n transitionDuration: '300ms',\n });\n };\n function getInstance(status: TransitionStatus, instance: any) {\n if (!instance) {\n return;\n }\n if (status === 'exited' || status === 'exiting') {\n instance.style.height = '1px';\n }\n if (status === 'entered' || status === 'entering') {\n instance.style.height = `${instance.scrollHeight}px`;\n }\n }\n return (\n <div className={cls} {...resetProps}>\n <div className={`${prefixCls}-header`} onClick={onItemClick}>\n {showArrow && iconRender}\n <span className={`${prefixCls}-title`}>{header}</span>\n {extra && <div className={`${prefixCls}-extra`}>{extra}</div>}\n </div>\n <CSSTransition in={isActive} unmountOnExit={false} timeout={300} classNames={`${prefixCls}-panel`}>\n {(status: TransitionStatus) =>\n React.cloneElement(<div>{children}</div>, {\n className: `${prefixCls}-panel`,\n style: childStyle(children as React.ReactElement),\n ref: (e: any) => getInstance(status, e),\n })\n }\n </CSSTransition>\n </div>\n );\n}\n","import Collapse from './Collapse';\n\nexport * from './Collapse';\nexport * from './Panel';\n\nexport default Collapse;\n","import React from 'react';\nimport copy from '@uiw/copy-to-clipboard';\nimport { IProps, HTMLSpanProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface CopyToClipboardProps extends IProps, Omit<HTMLSpanProps, 'onClick'> {\n text?: string;\n onClick?: (text: string, isCopy: boolean, event: React.MouseEvent<HTMLElement>) => void;\n}\n\nexport default function CopyToClipboard<T>(props: CopyToClipboardProps & T) {\n const {\n prefixCls = 'w-copy-to-clipboard',\n className,\n text = '',\n children,\n onClick = () => null,\n ...resetProps\n } = props;\n function handleClick(e: React.MouseEvent<HTMLElement>) {\n if (!text) {\n return onClick('', false, e);\n }\n copy(text, (isCopy: boolean) => {\n onClick(text, isCopy, e);\n });\n }\n const otherProps = {\n ...resetProps,\n className: [prefixCls, className].filter(Boolean).join(' ').trim(),\n onClick: handleClick,\n };\n return (\n <span {...otherProps}>\n <span className={`${prefixCls}-select`}>{text}</span>\n {children}\n </span>\n );\n}\n","import React, { useEffect, useState } from 'react';\nimport Input, { InputProps } from '@uiw/react-input';\nimport Popover, { PopoverProps } from '@uiw/react-popover';\nimport DatePicker, { DatePickerProps } from '@uiw/react-date-picker';\nimport Icon from '@uiw/react-icon';\nimport { IProps } from '@uiw/utils';\nimport formatter from '@uiw/formatter';\nimport './style/date-input-range.less';\n\nexport interface DateInputRangeProps<V> extends IProps, Omit<InputProps, 'onChange' | 'value'> {\n popoverProps?: PopoverProps;\n datePickerProps?: DatePickerProps;\n value?: Array<V>;\n format?: string;\n allowClear?: boolean;\n bodyStyle?: object;\n onChange?: (selectedDate?: Date, dateRange?: Array<Date | undefined>) => void;\n}\n\nexport function DateInputRange<V extends string | Date>(props: DateInputRangeProps<V>) {\n const {\n prefixCls = 'w-dateinputrange',\n bodyStyle = undefined,\n className,\n popoverProps,\n datePickerProps,\n allowClear = true,\n format = 'YYYY/MM/DD',\n onChange,\n value,\n ...inputProps\n } = props;\n\n const [dateRange, setDateRange] = useState<Array<Date | undefined>>([]);\n useEffect(() => {\n let valueTemp: Array<Date> = [];\n const propsValue = value;\n if (Array.isArray(propsValue) && !!propsValue?.length) {\n propsValue.forEach((date, index) => {\n valueTemp[index] = typeof propsValue[index] === 'string' ? new Date(date) : (date as Date);\n });\n }\n setDateRange(valueTemp);\n }, [JSON.stringify(value)]);\n\n function handleChange(cdate: Date | undefined, idx?: number) {\n const changeValue = [...dateRange];\n changeValue[idx!] = cdate;\n setDateRange(changeValue);\n onChange && onChange(cdate, changeValue);\n }\n\n return (\n <div\n className={[`${prefixCls}-contents`, `${prefixCls}-inner`].filter(Boolean).join(' ').trim()}\n style={{ width: 300, ...bodyStyle }}\n >\n <Popover\n trigger=\"focus\"\n placement=\"bottomLeft\"\n autoAdjustOverflow\n {...popoverProps}\n content={\n <DatePicker\n date={dateRange[0]}\n className={`${prefixCls}-popover`}\n {...datePickerProps}\n onChange={(selectedDate) => handleChange(selectedDate, 0)}\n />\n }\n >\n <Input\n placeholder=\"请选择日期\"\n readOnly\n {...(inputProps as InputProps)}\n // onChange={(v) => console.log('v', v)}\n value={dateRange[0] ? formatter(format, dateRange[0]) : ''}\n className={[prefixCls, className].filter(Boolean).join(' ').trim()}\n />\n </Popover>\n\n <Icon type=\"swap-right\" verticalAlign=\"baseline\" style={{ fontSize: 21, top: -1, margin: '0px 8px 0px 5px' }} />\n\n <Popover\n trigger=\"focus\"\n placement=\"bottomLeft\"\n autoAdjustOverflow\n {...popoverProps}\n content={\n <DatePicker\n date={dateRange[1]}\n className={`${prefixCls}-popover`}\n {...datePickerProps}\n onChange={(selectedDate) => handleChange(selectedDate, 1)}\n />\n }\n >\n <Input\n placeholder=\"请选择日期\"\n readOnly\n {...(inputProps as InputProps)}\n value={dateRange[1] ? formatter(format, dateRange[1]) : ''}\n // onChange={(v) => console.log('v2', v)}\n className={[prefixCls, className].filter(Boolean).join(' ').trim()}\n />\n </Popover>\n {allowClear && dateRange.length > 0 && (\n <Icon className={`${prefixCls}-close-btn`} color=\"#ccc\" onClick={() => setDateRange([])} type=\"close\" />\n )}\n </div>\n );\n}\n","import React, { useEffect, useState } from 'react';\nimport Input, { InputProps } from '@uiw/react-input';\nimport Popover, { PopoverProps } from '@uiw/react-popover';\nimport DatePicker, { DatePickerProps } from '@uiw/react-date-picker';\nimport Icon from '@uiw/react-icon';\nimport { IProps } from '@uiw/utils';\nimport formatter from '@uiw/formatter';\nexport * from './DateInputRange';\nimport './style/index.less';\n\nexport interface DateInputProps extends IProps, Omit<InputProps, 'onChange' | 'value'> {\n popoverProps?: PopoverProps;\n datePickerProps?: DatePickerProps;\n value?: Date | string;\n format?: string;\n allowClear?: boolean;\n onChange?: (selectedDate?: Date) => void;\n}\n\nexport default function DateInput(props: DateInputProps) {\n const {\n prefixCls = 'w-dateinput',\n className,\n popoverProps,\n datePickerProps,\n allowClear = true,\n format = 'YYYY/MM/DD',\n onChange,\n ...inputProps\n } = props;\n const [date, setDate] = useState(props.value);\n\n const value = date || '';\n inputProps.value = typeof value === 'string' ? value : formatter(format, value);\n\n useEffect(() => {\n if (props.value !== date) {\n setDate(props.value);\n }\n }, [props.value]);\n\n function handleChange(cdate?: Date) {\n setDate(cdate);\n onChange && onChange(cdate);\n }\n if (allowClear && inputProps.value) {\n inputProps.addonAfter = (\n <Icon className={`${prefixCls}-close-btn`} onClick={() => handleChange(undefined)} type=\"close\" />\n );\n }\n return (\n <Popover\n trigger=\"focus\"\n placement=\"bottomLeft\"\n autoAdjustOverflow\n {...popoverProps}\n content={\n <DatePicker\n date={(value && new Date(value)) || undefined}\n className={`${prefixCls}-popover`}\n {...datePickerProps}\n onChange={(selectedDate) => handleChange(selectedDate!)}\n />\n }\n >\n <Input\n placeholder=\"请选择日期\"\n readOnly\n {...(inputProps as InputProps)}\n className={[prefixCls, className].filter(Boolean).join(' ').trim()}\n />\n </Popover>\n );\n}\n","import React from 'react';\nimport { IProps } from '@uiw/utils';\n\nexport interface DescriptionsItemProps extends IProps {\n label?: React.ReactNode;\n children: React.ReactNode;\n span?: number;\n}\n\nconst DescriptionsItem: React.FC<DescriptionsItemProps> = ({ children }) => children as JSX.Element;\n\nexport default DescriptionsItem;\n","import React, { Fragment } from 'react';\nimport { IProps } from '@uiw/utils';\nimport { DescriptionsItemProps } from './DescriptionsItem';\nimport { RowProps } from './Row';\n\nexport interface CellProps\n extends Omit<RowProps, 'children'>,\n Omit<DescriptionsItemProps, 'children'>,\n React.HTMLAttributes<HTMLTableCellElement>,\n IProps {\n children?: React.ReactElement<DescriptionsItemProps> | React.ReactNode;\n tagName?: 'td' | 'th';\n /**\n * 是否为一行的最后一个\n */\n isLastCell?: boolean;\n}\n\nfunction Cell(props: CellProps = {}) {\n const {\n prefixCls,\n className,\n tagName: TagName = 'td',\n layout,\n bordered,\n label,\n isLastCell,\n colon,\n span,\n children,\n column,\n ...other\n } = props;\n\n const labelProps: React.HTMLAttributes<HTMLSpanElement> = {\n className: [\n prefixCls ? `${prefixCls}-item-label` : null,\n className,\n colon ? `${prefixCls}-item-colon` : null,\n !label ? `${prefixCls}-item-no-label` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim(),\n };\n if (layout === 'horizontal') {\n if (!bordered) {\n return (\n <TagName {...other} colSpan={span}>\n <span {...labelProps}>{label}</span>\n <span className={prefixCls ? `${prefixCls}-item-content` : ''}>{children}</span>\n </TagName>\n );\n }\n return (\n <Fragment>\n <th {...labelProps}>{label}</th>\n <TagName\n {...other}\n colSpan={span ? span * 2 - 1 : span}\n className={prefixCls ? `${prefixCls}-item-content` : ''}\n >\n {children}\n </TagName>\n </Fragment>\n );\n }\n return (\n <TagName colSpan={span} className={`${prefixCls}-item-${TagName === 'td' ? 'content' : 'label'}`}>\n {children}\n </TagName>\n );\n}\n\nexport default Cell;\n","import React, { Fragment } from 'react';\nimport { IProps } from '@uiw/utils';\nimport { DescriptionsItemProps } from './DescriptionsItem';\nimport Cell from './Cell';\n\nexport interface RowProps extends IProps {\n children?: React.ReactElement<DescriptionsItemProps>[];\n bordered?: boolean;\n layout?: 'horizontal' | 'vertical';\n colon?: boolean;\n column?: number;\n}\n\nexport default function Row(props: RowProps = {}) {\n const { prefixCls, layout, bordered, column, colon, children = [] } = props;\n function handleCell(isHead?: boolean) {\n return children.map((child, index) => (\n <Cell\n {...child.props}\n prefixCls={prefixCls}\n key={index}\n column={column}\n tagName={isHead ? 'th' : 'td'}\n isLastCell={children.length - 1 === index}\n layout={layout}\n colon={colon}\n bordered={bordered}\n >\n {isHead ? child.props.label : child.props.children}\n </Cell>\n ));\n }\n const cls = prefixCls ? `${prefixCls}-row` : '';\n return (\n <Fragment>\n {layout === 'vertical' && <tr className={cls}>{handleCell(true)}</tr>}\n <tr className={cls}>{handleCell()}</tr>\n </Fragment>\n );\n}\n","import React from 'react';\nimport { IProps } from '@uiw/utils';\nimport DescriptionsItem, { DescriptionsItemProps } from './DescriptionsItem';\nimport Row, { RowProps } from './Row';\nimport './style/index.less';\n\nexport * from './DescriptionsItem';\n\nexport interface DescriptionsProps extends IProps {\n column?: number;\n title?: React.ReactNode;\n children?: React.ReactNode;\n bordered?: boolean;\n colon?: boolean;\n size?: 'large' | 'small' | 'default';\n layout?: RowProps['layout'];\n}\n\nconst generateChildrenRows = (\n children: React.ReactElement<DescriptionsItemProps>[],\n column: number,\n): Array<React.ReactElement<DescriptionsItemProps>[]> => {\n const rows: React.ReactElement<DescriptionsItemProps>[][] = [];\n let columns: React.ReactElement<DescriptionsItemProps>[] | null = null;\n let leftSpans: number;\n\n children.forEach((node: React.ReactElement<DescriptionsItemProps>, index: number) => {\n let itemNode = node;\n\n if (!columns) {\n leftSpans = column;\n columns = [];\n rows.push(columns);\n }\n\n // Always set last span to align the end of Descriptions\n const lastItem = index === children.length - 1;\n if (lastItem) {\n itemNode = React.cloneElement(itemNode, {\n span: leftSpans,\n });\n }\n // Calculate left fill span\n const { span = 1 } = itemNode.props;\n columns.push(itemNode);\n leftSpans -= span;\n\n if (leftSpans <= 0) {\n columns = null;\n }\n });\n\n return rows;\n};\n\nfunction InternalDescriptions(props: DescriptionsProps, ref: React.ForwardedRef<HTMLDivElement>) {\n const {\n prefixCls = 'w-descriptions',\n className,\n title,\n bordered,\n column = 3,\n size,\n colon = true,\n children,\n layout = 'horizontal',\n ...other\n } = props;\n const cls = [\n prefixCls,\n className,\n prefixCls && layout ? `${prefixCls}-${layout}` : null,\n bordered ? `${prefixCls}-bordered` : null,\n size ? `${prefixCls}-${size}` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim();\n\n const cloneChildren = React.Children.toArray(children) as JSX.Element[];\n const childs: Array<React.ReactElement<DescriptionsItemProps>[]> = generateChildrenRows(cloneChildren, column!);\n\n return (\n <div className={cls} ref={ref}>\n <table {...other}>\n {title && <caption className={`${prefixCls}-title`}>{title}</caption>}\n <tbody>\n {childs.map((child, index) => (\n <Row key={index} prefixCls={prefixCls} bordered={bordered} colon={colon} column={column} layout={layout}>\n {child}\n </Row>\n ))}\n </tbody>\n </table>\n </div>\n );\n}\n\nconst Descriptions = React.forwardRef<HTMLDivElement, DescriptionsProps>(InternalDescriptions);\ntype Descriptions = typeof Descriptions & {\n Item: typeof DescriptionsItem;\n};\n\n(Descriptions as Descriptions).Item = DescriptionsItem;\n\nexport default Descriptions as Descriptions;\n","import React from 'react';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface DividerProps extends IProps, HTMLDivProps {\n dashed?: boolean;\n type?: 'horizontal' | 'vertical';\n align?: 'left' | 'right' | 'center';\n}\n\nexport default React.forwardRef<HTMLDivElement, DividerProps>((props, ref) => {\n const {\n prefixCls = 'w-divider',\n className,\n children,\n dashed = false,\n type = 'horizontal',\n align = 'center',\n ...restProps\n } = props;\n const cls = [\n className,\n prefixCls,\n prefixCls && type ? `${prefixCls}-${type}` : null,\n prefixCls && align ? `${prefixCls}-${align}` : null,\n children ? `${prefixCls}-with-text` : null,\n !!dashed ? `${prefixCls}-dashed` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim();\n return (\n <div className={cls} {...restProps} ref={ref}>\n {children && <span className={`${prefixCls}-inner-text`}>{children}</span>}\n </div>\n );\n});\n","import React, { useMemo } from 'react';\nimport Overlay, { OverlayProps } from '@uiw/react-overlay';\nimport Icon, { IconProps } from '@uiw/react-icon';\nimport Button from '@uiw/react-button';\nimport { HTMLDivProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface DrawerProps extends OverlayProps {\n footer?: React.ReactNode;\n icon?: IconProps['type'];\n title?: React.ReactNode;\n bodyProps?: HTMLDivProps;\n placement?: 'top' | 'right' | 'bottom' | 'left';\n size?: number;\n isCloseButtonShown?: boolean;\n onClose?: (e: React.MouseEvent<HTMLElement, MouseEvent>) => void;\n}\n\nexport default (props: DrawerProps = {}) => {\n const {\n prefixCls = 'w-drawer',\n className,\n style,\n placement = 'right',\n size = 260,\n title,\n footer,\n icon,\n isCloseButtonShown = true,\n bodyProps,\n timeout = 300,\n isOpen = false,\n maskClosable = true,\n ...overlayProps\n } = props;\n const cls = [className, prefixCls, placement].filter(Boolean).join(' ').trim();\n const bodyCls = [bodyProps ? bodyProps.className : null, prefixCls ? `${prefixCls}-body-inner` : null]\n .filter(Boolean)\n .join(' ')\n .trim();\n const styl = {\n ...style,\n [/^(top|bottom)$/.test(placement!) ? 'height' : 'width']: size,\n };\n const footerView = useMemo(() => (footer ? <div className={`${prefixCls}-footer`}>{footer}</div> : null), [footer]);\n const iconView = useMemo(() => (icon ? <Icon type={icon} /> : null), [icon]);\n const titleView = useMemo(() => (title ? <h4>{title}</h4> : null), [title]);\n return (\n <Overlay className={cls} timeout={timeout} isOpen={isOpen} maskClosable={maskClosable} {...overlayProps}>\n <div className={`${prefixCls}-wrapper`} style={styl}>\n {(title || icon) && (\n <div className={`${prefixCls}-header`}>\n {iconView}\n {titleView}\n {title && isCloseButtonShown && <Button basic onClick={props.onClose} icon=\"close\" type=\"light\" />}\n </div>\n )}\n <div className={`${prefixCls}-body`}>\n <div {...bodyProps} className={bodyCls}>\n {props.children}\n </div>\n </div>\n {footerView}\n </div>\n </Overlay>\n );\n};\n","import React from 'react';\nimport OverlayTrigger, { OverlayTriggerProps } from '@uiw/react-overlay-trigger';\nimport { IProps } from '@uiw/utils';\nimport { useMemo } from 'react';\n\nexport interface DropdownProps extends IProps, OverlayTriggerProps {\n menu?: React.ReactNode;\n}\n\nexport default function Dropdown(props: DropdownProps) {\n const { prefixCls = 'w-dropdown', placement = 'bottomLeft', className, menu, children, disabled, ...other } = props;\n\n const cls = useMemo(() => [prefixCls, className].filter(Boolean).join(' ').trim(), [prefixCls, className]);\n\n return (\n <OverlayTrigger\n isOutside\n autoAdjustOverflow\n className={cls}\n disabled={disabled}\n placement={placement}\n {...other}\n overlay={menu}\n >\n {React.cloneElement(children, Object.assign({}, children.props))}\n </OverlayTrigger>\n );\n}\n","import React from 'react';\nimport './style/index.less';\n\nexport interface EmptyProps extends React.HTMLAttributes<HTMLDivElement> {\n prefixCls?: string;\n icon?: React.ReactNode;\n size?: number | string;\n iconProps?: React.SVGProps<SVGSVGElement>;\n /** 自定义描述内容 */\n description?: React.ReactNode;\n}\n\nconst Empty = (props: EmptyProps) => {\n const {\n prefixCls = 'w-empty',\n className,\n icon,\n iconProps,\n size = 64,\n description = '暂无数据',\n children,\n ...other\n } = props;\n\n const cls = [prefixCls, className].filter(Boolean).join(' ').trim();\n return (\n <div className={cls} {...other}>\n <div className={`${prefixCls}-icon`}>\n {icon ? (\n icon\n ) : (\n <svg viewBox=\"0 0 1024 1024\" width={size} height={size} {...iconProps}>\n <path d=\"M20.48 860.16a491.52 102.4 0 1 0 983.04 0 491.52 102.4 0 1 0-983.04 0Z\" fill=\"#F5F5F5\" />\n <path d=\"M225.28 409.6l573.44-8.06912 112.78336 183.296H102.4z\" fill=\"#C4C5C7\" />\n <path\n d=\"M266.24 61.44h491.52a40.96 40.96 0 0 1 40.96 40.96v532.48a40.96 40.96 0 0 1-40.96 40.96H266.24a40.96 40.96 0 0 1-40.96-40.96V102.4a40.96 40.96 0 0 1 40.96-40.96z\"\n fill=\"#F5F5F7\"\n />\n <path\n d=\"M348.16 143.36h327.68a40.96 40.96 0 0 1 40.96 40.96v122.88a40.96 40.96 0 0 1-40.96 40.96H348.16a40.96 40.96 0 0 1-40.96-40.96V184.32a40.96 40.96 0 0 1 40.96-40.96zM327.68 409.6h368.64a20.48 20.48 0 0 1 0 40.96H327.68a20.48 20.48 0 0 1 0-40.96zM327.68 491.52h368.64a20.48 20.48 0 0 1 0 40.96H327.68a20.48 20.48 0 0 1 0-40.96z\"\n fill=\"#EBECEC\"\n />\n <path\n d=\"M673.44384 607.58016v13.43488c0 25.14944-20.0704 45.52704-44.8512 45.52704H382.95552l-2.2528-0.06144c-23.7568-1.16736-42.63936-21.07392-42.63936-45.4656v-13.45536c0-12.55424-10.0352-22.7328-22.44608-22.7328H102.4v250.30656C102.4 860.2624 122.49088 880.64 147.29216 880.64h719.31904c24.7808 0 44.89216-20.3776 44.89216-45.50656V584.82688H695.88992c-12.3904 0-22.44608 10.17856-22.44608 22.7328z\"\n fill=\"#E0E0E0\"\n />\n </svg>\n )}\n </div>\n {description && <div className={`${prefixCls}-description`}>{description}</div>}\n {children && <div className={`${prefixCls}-footer`}>{children}</div>}\n </div>\n );\n};\n\nexport default Empty;\n","import React from 'react';\nimport Input, { InputProps } from '@uiw/react-input';\nimport { FileInputProps } from './';\n\nexport interface InputUploadProps extends FileInputProps, InputProps {}\n\nexport default React.forwardRef<HTMLInputElement, InputUploadProps>((props, ref) => {\n const { className, dataLabel = 'Browse', prefixCls = 'w-fileinput', ...other } = props;\n const cls = [prefixCls, className].filter(Boolean).join(' ').trim();\n return <Input ref={ref} data-label={dataLabel} className={cls} {...other} type=\"file\" />;\n});\n","import React from 'react';\nimport Icon from '@uiw/react-icon';\nimport { FileInputListProps } from './';\nimport './style/index.less';\n\nconst Picture = (props: FileInputListProps) => {\n const {\n className,\n prefixCls = 'w-fileinput-list',\n dataList = [],\n uploadType,\n size = 'middle',\n shape = 'round',\n readonly,\n children,\n showFileIcon = {\n showPreviewIcon: true,\n showRemoveIcon: true,\n },\n onPreview,\n onAdd,\n onRemove,\n } = props;\n\n const cls = [prefixCls, `${prefixCls}-size-${size}`, `${prefixCls}-shape-${shape}`, className]\n .filter(Boolean)\n .join(' ')\n .trim();\n\n return (\n <div className={cls}>\n {children &&\n !readonly &&\n React.isValidElement(children) &&\n React.cloneElement(children, {\n onClick: onAdd,\n })}\n <div>\n {dataList.map((item, index) => (\n <div className={`${prefixCls}-${uploadType}`} key={index}>\n {uploadType === 'picture' && (\n <div className={`${prefixCls}-info ${prefixCls}-${uploadType}-info`}>\n <img src={item['dataURL']} alt=\"\" />\n {showFileIcon?.showPreviewIcon && (\n <div className={`${prefixCls}-actions`}>\n <span className={`${prefixCls}-actions-search`} onClick={() => onPreview?.(item)}>\n <Icon type=\"search\" style={{ color: '#fff', fontSize: 16 }} />\n </span>\n </div>\n )}\n </div>\n )}\n <div className={`${prefixCls}-${uploadType}-text`}>{item.name}</div>\n {showFileIcon?.showRemoveIcon && (\n <div className={`${prefixCls}-${uploadType}-icon`} onClick={() => onRemove?.(index)}>\n <Icon type=\"delete\" style={{ color: '#999' }} />\n </div>\n )}\n </div>\n ))}\n </div>\n </div>\n );\n};\n\nexport default Picture;\n","import React from 'react';\nimport Icon from '@uiw/react-icon';\nimport { FileInputListProps } from './';\nimport './style/index.less';\n\nconst Card = (props: FileInputListProps) => {\n const {\n className,\n prefixCls = 'w-fileinput-card',\n dataList = [],\n maxNumber = 3,\n shape = 'round',\n size = 'middle',\n readonly,\n children,\n showFileIcon = {\n showPreviewIcon: true,\n showRemoveIcon: true,\n },\n onAdd,\n onPreview,\n onRemove,\n } = props;\n const cls = [prefixCls, `${prefixCls}-size-${size}`, `${prefixCls}-shape-${shape}`, className]\n .filter(Boolean)\n .join(' ')\n .trim();\n\n const isAction = showFileIcon.showPreviewIcon || showFileIcon.showRemoveIcon ? true : false;\n\n return (\n <div className={cls}>\n {dataList.map((item, index) => (\n <div className={`${prefixCls}-box`} key={index}>\n <div className={`${prefixCls}-box-info`}>\n <img src={item['dataURL']} alt=\"\" />\n </div>\n\n <div className={isAction ? `${prefixCls}-actions` : ''}>\n {showFileIcon?.showPreviewIcon && (\n <span className={`${prefixCls}-actions-remove`} onClick={() => onPreview?.(item)}>\n <Icon type=\"search\" style={{ color: '#fff', fontSize: 16 }} />\n </span>\n )}\n {showFileIcon?.showRemoveIcon && (\n <span className={`${prefixCls}-actions-remove`} onClick={() => onRemove?.(index)}>\n <Icon type=\"delete\" style={{ color: '#fff', fontSize: 16 }} />\n </span>\n )}\n </div>\n </div>\n ))}\n {maxNumber > dataList.length && !readonly && (\n <div className={`${prefixCls}-box ${prefixCls}-btn`} onClick={onAdd}>\n {children}\n </div>\n )}\n </div>\n );\n};\n\nexport default Card;\n","import { FileInputValue } from './';\n\nexport const openFileDialog = (inputRef: any): void => {\n if (inputRef.current) inputRef.current.click();\n};\n\nexport const getAcceptTypeString = (accept?: Array<string>) => {\n return accept && accept.length > 0 ? accept.map((item) => `.${item}`).join(', ') : 'image/*';\n};\n\nexport const getBase64 = (file: File): Promise<string> => {\n const reader = new FileReader();\n return new Promise((resolve) => {\n reader.addEventListener('load', () => resolve(String(reader.result)));\n reader.readAsDataURL(file);\n });\n};\n\nexport const getListFiles = (files: FileList, dataURLKey: string): Promise<FileInputValue[]> => {\n const promiseFiles: Array<Promise<string>> = [];\n for (let i = 0; i < files.length; i += 1) {\n promiseFiles.push(getBase64(files[i]));\n }\n return Promise.all(promiseFiles).then((fileListBase64: Array<string>) => {\n const fileList: FileInputValue[] = fileListBase64.map((base64, index) => ({\n [dataURLKey]: base64,\n file: files[index],\n name: files[index].name,\n }));\n return fileList;\n });\n};\n\nexport const isUploadType = (type: string) => {\n return ['picture', 'text', 'card'].includes(type);\n};\n","import React, { useRef, useCallback, useEffect, useState } from 'react';\nimport List from './List';\nimport Card from './Card';\nimport { FileInputValue, FileInputListProps } from './';\nimport { FileInputUploadProps } from './types';\nimport { openFileDialog, getListFiles } from './utils';\n\nexport const FileList = (props: FileInputUploadProps) => {\n const { uploadType, value = [], multiple = false, maxNumber = 3, onChange } = props;\n const inputRef = useRef<HTMLInputElement>(null);\n const inValue: FileInputValue[] = value || [];\n const [fileList, setFileList] = useState<FileInputValue[]>([]);\n\n useEffect(() => {\n setFileList(inValue);\n }, []);\n\n const handleClickInput = useCallback(() => openFileDialog(inputRef), [inputRef]);\n\n const onFileUpload = useCallback((): void => {\n if (inputRef.current) inputRef.current.value = '';\n handleClickInput();\n }, [handleClickInput]);\n\n const onInputChange = async (e: React.ChangeEvent<HTMLInputElement>) => {\n const files = e.target.files;\n if (!files) return;\n const updatedFileList = await getListFiles(files, 'dataURL');\n let updatedList = [...fileList, ...updatedFileList];\n if (maxNumber < updatedList.length) {\n updatedList = updatedList.slice(0, maxNumber);\n }\n setFileList(updatedList);\n onChange?.(updatedList);\n };\n\n const onRemove = (index: number) => {\n const updatedList = [...fileList];\n updatedList.splice(index, 1);\n setFileList(updatedList);\n onChange?.(updatedList);\n };\n\n let Comp: ((props: FileInputListProps) => JSX.Element) | undefined;\n\n if (uploadType === 'card') {\n Comp = Card;\n }\n if (uploadType === 'picture' || uploadType === 'text') {\n Comp = List;\n }\n\n return (\n <React.Fragment>\n <input type=\"file\" ref={inputRef} multiple={multiple} style={{ display: 'none' }} onChange={onInputChange} />\n {Comp && (\n <Comp {...props} maxNumber={maxNumber || 3} dataList={fileList} onAdd={onFileUpload} onRemove={onRemove} />\n )}\n </React.Fragment>\n );\n};\n\nexport default FileList;\n","import React from 'react';\nimport Input from './Input';\nimport FileList from './FileList';\nimport { isUploadType } from './utils';\nimport { InputProps } from '@uiw/react-input';\nimport { UploadType, FileInputBaseProps, FileInputUploadProps, FileInputShowIconProps } from './types';\nimport './style/index.less';\nexport interface FileInputValue {\n dataURL?: string;\n file?: File;\n name?: string;\n [key: string]: any;\n}\nexport interface FileInputProps extends FileInputBaseProps, InputProps {\n dataLabel?: string;\n}\nexport interface FileInputListProps extends FileInputUploadProps {\n shape?: 'circle' | 'round';\n size?: 'large' | 'middle' | 'small';\n showFileIcon?: FileInputShowIconProps;\n dataList: FileInputValue[];\n onAdd?: () => void;\n onRemove?: (index: number) => void;\n}\n\ninterface Props {\n uploadType?: UploadType;\n [key: string]: any;\n}\n\nfunction Upload(props: Props) {\n const { uploadType = 'input' } = props;\n\n if (uploadType === 'input') {\n return <Input {...props} />;\n }\n\n if (isUploadType(uploadType)) {\n return <FileList {...props} />;\n }\n return null;\n}\n\nexport default Upload;\n","import React from 'react';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\nimport './style/col.less';\n\nexport interface ColProps extends IProps, HTMLDivProps {\n fixed?: boolean;\n span?: number | string;\n grow?: number | string;\n align?: 'top' | 'middle' | 'bottom' | 'baseline';\n}\n\nexport function Col(props: ColProps = {}) {\n const { prefixCls = 'w-col', className, fixed, span, grow, align, ...other } = props;\n const cls = [\n prefixCls,\n className,\n span ? `${prefixCls}-${span}` : null,\n fixed ? `${prefixCls}-fixed` : null,\n align ? `${prefixCls}-align-${align}` : null,\n fixed ? `${prefixCls}-grow-${grow}` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim();\n return (\n <div className={cls} {...other}>\n {props.children}\n </div>\n );\n}\n","import React from 'react';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\nimport './style/row.less';\n\nexport interface RowProps extends IProps, HTMLDivProps {\n fixed?: boolean;\n gutter?: number;\n justify?: 'flex-start' | 'flex-end' | 'center' | 'space-between' | 'space-around' | 'space-evenly';\n align?: 'top' | 'middle' | 'bottom' | 'baseline';\n}\n\nexport function Row(props: RowProps = {}) {\n const { prefixCls = 'w-row', className, gutter = 0, justify, align, ...other } = props;\n const cls = [\n prefixCls,\n className,\n align ? `${prefixCls}-align-${align}` : null,\n justify ? `${prefixCls}-justify-${justify}` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim();\n const gutterStyl = !gutter ? {} : { paddingLeft: gutter / 2, paddingRight: gutter / 2 };\n return (\n <div {...other} className={cls}>\n {React.Children.toArray(props.children).map((child) => {\n if (!React.isValidElement(child)) return child;\n return React.cloneElement(\n child,\n Object.assign({}, child.props, {\n style: { ...child.props.style, ...gutterStyl },\n }),\n );\n })}\n </div>\n );\n}\n","import React, { CSSProperties } from 'react';\nimport { Col, Row } from '@uiw/react-grid';\nimport { IProps, HTMLInputProps } from '@uiw/utils';\nimport { FormFieldsProps } from './Form';\nimport './style/form-item.less';\n\nexport interface FormItemProps<T> extends IProps, HTMLInputProps {\n inline?: boolean;\n hasError?: boolean;\n label?: React.ReactNode;\n required?: boolean;\n labelFor?: string;\n labelClassName?: string;\n help?: React.ReactNode;\n labelStyle?: CSSProperties;\n initialValue?: string | number | T;\n validator?: FormFieldsProps<T>['validator'];\n}\n\nexport default class FormItem<T> extends React.PureComponent<FormItemProps<T>> {\n public static defaultProps = {\n prefixCls: 'w-form-item',\n };\n render() {\n const {\n prefixCls,\n className,\n required,\n style,\n label,\n labelFor,\n labelClassName,\n labelStyle,\n help,\n inline,\n initialValue,\n validator,\n hasError,\n ...otherProps\n } = this.props;\n\n const cls = [prefixCls, className, hasError ? `${prefixCls}-error` : null].filter(Boolean).join(' ').trim();\n const labelCls = ['w-form-label', labelClassName].filter(Boolean).join(' ').trim();\n if (inline) {\n return (\n <div className={cls} style={style} {...otherProps}>\n <Row>\n <Col fixed className={labelCls}>\n {required && <label style={{ color: 'red' }}>*</label>}\n <label style={labelStyle} htmlFor={labelFor}>\n {label}\n </label>\n </Col>\n <Col className=\"w-form-row\">{this.props.children}</Col>\n </Row>\n {help && (\n <Row>\n <Col className=\"w-form-help\">{help}</Col>\n </Row>\n )}\n </div>\n );\n }\n return (\n <div className={cls} style={style} {...otherProps}>\n {label && (\n <React.Fragment>\n {required && <label style={{ color: 'red' }}>*</label>}\n <label className={labelCls} style={labelStyle} htmlFor={labelFor}>\n {label}\n </label>\n </React.Fragment>\n )}\n <Col className=\"w-form-row\">{this.props.children}</Col>\n {help && <div className=\"w-form-help\">{help}</div>}\n </div>\n );\n }\n}\n","import React, { useState, useImperativeHandle, useMemo } from 'react';\nimport { IProps } from '@uiw/utils';\nimport FormItem, { FormItemProps } from './FormItem';\nimport './style/form.less';\n\nexport interface FormProps<T> extends IProps, Omit<React.FormHTMLAttributes<HTMLFormElement>, 'onChange' | 'onSubmit'> {\n prefixCls?: string;\n fields?: Record<string, FormFieldsProps<T>>;\n onSubmit?: (state: FormSubmitProps, event: React.FormEvent) => any;\n afterSubmit?: (result: FormAfterSubmitProps) => any;\n onChange?: (state: FormState) => void;\n onSubmitError?: (evn: any) => any;\n resetOnSubmit?: boolean;\n children?: (handle: FormChildrenProps) => JSX.Element | JSX.Element | undefined;\n}\n\nexport interface FormState {\n submitting: boolean;\n initial: Record<string, any>;\n current: FormState['initial'];\n errors: Record<string, any>;\n}\n\nexport interface FormFieldsProps<T> extends FormItemProps<T> {\n name?: string;\n children?: React.ReactNode;\n help?: React.ReactNode;\n labelFor?: string;\n inline?: boolean;\n checked?: boolean;\n initialValue?: string | number | T;\n required?: boolean;\n validator?: (currentValue: any) => any;\n}\n\nexport interface FormSubmitProps {\n initial: FormState['initial'];\n current: FormState['current'];\n}\n\nexport interface FormAfterSubmitProps {\n state: FormState;\n response: any;\n reset: () => void;\n}\n\nexport interface FormChildrenProps {\n fields: Record<string, React.ReactElement>;\n resetForm: () => void;\n canSubmit: () => boolean;\n state: FormState;\n}\n\nexport type FormElementProps = {\n id?: string;\n name?: string;\n value?: string | boolean;\n checked?: boolean;\n onChange?: (env: React.BaseSyntheticEvent<HTMLInputElement>, list?: string[]) => void;\n};\n\nexport type FormRefType = Record<'onSubmit' | 'resetForm' | 'getFieldValues' | 'setFields', Function>;\n\nfunction newFormState<T>(\n fields: FormProps<T>['fields'],\n cb: (porps: FormFieldsProps<T>) => {\n initialValue: FormFieldsProps<T>['initialValue'];\n currentValue: FormFieldsProps<T>['initialValue'];\n },\n): FormState {\n const state: FormState = {\n initial: {},\n current: {},\n submitting: false,\n errors: {},\n };\n for (const name in fields) {\n const props = fields[name];\n if (!props) continue;\n const { initialValue, currentValue } = cb({ ...props, name });\n state.initial[name] = Array.isArray(initialValue) ? [...initialValue] : initialValue;\n state.current[name] = currentValue;\n }\n return state;\n}\n\nfunction newInitialValue<T>(value: FormFieldsProps<T>['initialValue']) {\n return value === null || value === undefined ? '' : value;\n}\n\nconst isPromise = (promise: Promise<any>) => promise && typeof promise.then === 'function';\n\nfunction Form<T>(\n {\n prefixCls = 'w-form',\n className,\n fields,\n children,\n resetOnSubmit,\n onSubmitError,\n onChange,\n onSubmit,\n afterSubmit,\n ...others\n }: FormProps<T>,\n ref: React.ForwardedRef<FormRefType | undefined>, //| React.RefObject<FormRefType>,\n) {\n const initData = useMemo(\n () =>\n newFormState(fields, ({ initialValue }) => {\n initialValue = newInitialValue(initialValue);\n return { initialValue, currentValue: initialValue };\n }),\n [],\n );\n const [data, setData] = useState<FormState>(initData);\n\n useImperativeHandle(\n ref,\n () => ({\n onSubmit: handleSubmit,\n resetForm: handleReset,\n getFieldValues: () => data.current,\n getError: () => data.errors,\n setFields: setFields,\n setFieldValue: setFieldValue,\n }),\n [data],\n );\n\n const formUnits: FormChildrenProps['fields'] = {};\n for (const name in fields) {\n const props = fields[name];\n if (!props) continue;\n const error = data.errors[name];\n if (typeof props.initialValue === 'boolean') {\n props.checked = props.initialValue;\n }\n const childField: FormFieldsProps<T> = controlField({\n ...props,\n name,\n });\n const help = error || props.help;\n const labelFor = props.labelFor;\n formUnits[name] = (\n <FormItem\n {...{\n ...props,\n key: name,\n children: childField,\n help,\n labelFor,\n state: data,\n name,\n hasError: !!error,\n }}\n />\n );\n }\n\n function setFields(fields: FormState['current']) {\n const tempData = { ...data, current: fields };\n setData(tempData);\n }\n\n function setFieldValue<V>(fieldName: string, value: V) {\n const tempData = { ...data, current: { ...data.current, [fieldName]: value } };\n setData(tempData);\n }\n\n function handleChange(\n name: string,\n validator: FormFieldsProps<T>['validator'],\n element?: React.ReactElement,\n cb?: (env: React.BaseSyntheticEvent<HTMLInputElement>) => void,\n ) {\n return (env: React.BaseSyntheticEvent<HTMLInputElement>, list?: string[]) => {\n let value = env && env.target && 'value' in env.target ? env.target.value : env;\n // 控件 Checkbox.Group 多选值的处理\n value = list || value;\n // 控件 Checkbox 值的处理\n if (!list && element && env && env.target && /(radio)/.test(env.target.type)) {\n // 控件 Switch/Radio/Checkbox 值的处理\n value = env.target.value ? env.target.value : env.target.checked;\n }\n if (!list && element && env && env.target && /(checkbox)/.test(env.target.type)) {\n // 控件 Switch/Radio/Checkbox 值的处理\n value = env.target.checked;\n }\n const nextState = {\n current: { ...data.current, [name]: value },\n } as FormState;\n const error = validator && validator(value);\n if (!error) {\n nextState.errors = { ...data.errors };\n delete nextState.errors[name];\n }\n if (env && env.persist && typeof env.persist === 'function') env.persist();\n setData({ ...data, ...nextState });\n if (cb) {\n cb(env);\n }\n onChange && onChange({ ...data, ...nextState });\n };\n }\n\n function handleSubmit(e: React.FormEvent) {\n e && e.preventDefault();\n const { initial, current } = data;\n setData({ ...data, submitting: true });\n const nextState = { submitting: false } as FormState;\n const onError = (evn: unknown) =>\n setData({\n ...data,\n ...nextState,\n errors: (onSubmitError && onSubmitError(evn)) || {},\n });\n const onSuccess = (response: any) => {\n if (resetOnSubmit) {\n nextState.current = initial;\n }\n setData({ ...data, ...nextState, errors: {} });\n afterSubmit && afterSubmit({ state: data, response, reset: handleReset });\n };\n try {\n const afterSubmitPromise = onSubmit ? onSubmit({ initial, current }, e) : undefined;\n if (afterSubmitPromise && isPromise(afterSubmitPromise)) {\n return afterSubmitPromise.then(onSuccess).catch(onError);\n } else {\n return onSuccess(afterSubmitPromise);\n }\n } catch (evn) {\n onError(evn);\n }\n }\n\n function canSubmit() {\n const { submitting, current = {} } = data;\n let passesValidators = true;\n for (const name in fields) {\n if (Object.prototype.hasOwnProperty.call(fields, name)) {\n const props: FormFieldsProps<T> = fields[name];\n if (!props) continue;\n if (props.validator && props.validator(current[name])) {\n passesValidators = false;\n break;\n }\n }\n }\n return !submitting && passesValidators;\n }\n\n function handleReset() {\n let { initial } = data;\n const initials = { ...initial };\n Object.entries(initials).map(([key, value]) => {\n if (Array.isArray(value)) {\n initials[key] = [...value];\n }\n });\n setData({ ...data, initial, current: initials, errors: {} });\n }\n\n function controlField({\n children,\n validator,\n name,\n help,\n label,\n labelFor,\n labelClassName,\n labelStyle,\n inline,\n initialValue,\n ...other\n }: FormFieldsProps<T>) {\n const element =\n typeof children !== 'function'\n ? children\n : children({\n onChange: handleChange(name!, validator),\n onSubmit: handleSubmit,\n canSubmit: canSubmit,\n });\n if (!element || React.Children.count(element) !== 1 || !name) return element;\n const props = {\n name: element.props.name || name,\n ...other,\n } as FormElementProps;\n const hasCurrentValue = Object.prototype.hasOwnProperty.call(data.current, name);\n props.id = element.props.id;\n props.value = hasCurrentValue ? data.current && data.current[name] : props.value;\n // : element.props.value;\n\n const type = element.props.type;\n // console.log('type', element)\n if (type === 'checkbox' || type === 'switch' || typeof props.value === 'boolean') {\n props.checked = !!props.value;\n delete props.value;\n }\n props.onChange = handleChange(name, validator, element, element.props.onChange) as FormElementProps['onChange'];\n return React.cloneElement(element, props as FormElementProps);\n }\n\n return (\n <form\n {...{\n ...others,\n className: [prefixCls, className].filter(Boolean).join(' ').trim(),\n onSubmit: handleSubmit,\n }}\n >\n <fieldset {...{ disabled: data.submitting }}>\n {typeof children === 'function'\n ? children({\n fields: formUnits,\n state: data,\n resetForm: handleReset,\n canSubmit: canSubmit,\n })\n : children}\n </fieldset>\n </form>\n );\n}\n\nexport default React.forwardRef<FormRefType | undefined, FormProps<{}>>(Form);\n","import Form from './Form';\n\nexport * from './Form';\nexport * from './FormItem';\nexport { default as FormItem } from './FormItem';\n\nexport default Form;\n","import React, { Fragment } from 'react';\nimport { IProps } from '@uiw/utils';\n\nexport type TagType = React.ComponentType | keyof JSX.IntrinsicElements;\n\nexport interface ListItemProps<Tag extends TagType> extends IProps, React.HTMLProps<Tag> {\n disabled?: boolean;\n active?: boolean;\n extra?: React.ReactNode;\n href?: string;\n tagName?: Tag;\n}\n\nexport const ListItem = React.forwardRef(\n <Tag extends TagType = 'div'>(props: ListItemProps<Tag>, ref: React.Ref<React.HTMLProps<Tag>>) => {\n const {\n prefixCls = 'w-list-item',\n className,\n children,\n extra,\n tagName = 'div',\n active = false,\n ...resetProps\n } = props;\n const cls = [prefixCls, className, props.disabled ? 'w-disabled' : null, active ? 'w-active' : null]\n .filter(Boolean)\n .join(' ')\n .trim();\n const TagName = props.href && typeof tagName === 'string' ? 'a' : tagName;\n return React.createElement(\n TagName,\n {\n ...resetProps,\n className: cls,\n ref,\n } as any,\n !extra || resetProps.href ? (\n children\n ) : (\n <Fragment>\n <div className={`${prefixCls}-main`}>{children}</div>\n <div className={`${prefixCls}-extra`}>{extra}</div>\n </Fragment>\n ),\n );\n },\n);\n\nListItem.displayName = 'List.Item';\n","import React from 'react';\nimport { IProps, HTMLDivProps, noop } from '@uiw/utils';\nimport { ListItem } from './Item';\nimport './style/index.less';\n\nexport * from './Item';\n\nexport interface ListProps<T> extends IProps, HTMLDivProps {\n bordered?: boolean;\n striped?: boolean;\n noHover?: boolean;\n active?: boolean;\n header?: React.ReactNode;\n footer?: React.ReactNode;\n size?: 'small' | 'default' | 'large';\n renderItem?: (item: any, idx: number) => React.ReactNode;\n dataSource?: T[];\n}\n\nfunction InternalList<T>(props: ListProps<T>, ref: React.ForwardedRef<HTMLDivElement>) {\n const {\n prefixCls = 'w-list',\n bordered = true,\n striped = false,\n noHover = false,\n active = false,\n size = 'default',\n renderItem = noop,\n className,\n children,\n header,\n footer,\n dataSource = [],\n ...resetProps\n } = props;\n let items: React.ReactNode;\n if (dataSource && dataSource.length > 0) {\n items = dataSource.map((item: any, index: number) => renderItem!(item, index));\n } else {\n items = children;\n }\n let childrenList = React.Children.map(\n items,\n (child: React.ReactNode, index) =>\n React.isValidElement(child) &&\n React.cloneElement(child, {\n key: index,\n }),\n );\n const classString = [\n prefixCls,\n className,\n striped ? `${prefixCls}-striped` : null,\n noHover ? `${prefixCls}-no-hover` : null,\n active ? `${prefixCls}-active` : null,\n bordered ? `${prefixCls}-bordered` : null,\n size && size !== 'default' ? `${prefixCls}-size-${size}` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim();\n return (\n <div className={classString} {...resetProps} ref={ref}>\n {header && <div className={`${prefixCls}-header`}>{header}</div>}\n {childrenList}\n {footer && <div className={`${prefixCls}-footer`}>{footer}</div>}\n </div>\n );\n}\n\nconst List = React.forwardRef<HTMLDivElement, ListProps<any>>(InternalList);\ntype List = typeof List & {\n Item: typeof ListItem;\n};\n\n(List as List).Item = ListItem;\n\nexport default List as List;\n","import React, { useMemo } from 'react';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface LoaderProps extends IProps, HTMLDivProps {\n size?: 'small' | 'default' | 'large';\n loading?: boolean;\n fullscreen?: boolean;\n color?: string;\n bgColor?: string;\n vertical?: boolean;\n tip?: React.ReactNode;\n indicator?: React.ReactNode;\n children?: any | React.ReactNode;\n}\n\nexport default (props: LoaderProps = {}) => {\n const {\n prefixCls = 'w-loader',\n className,\n size = 'default',\n loading = true,\n tip,\n vertical,\n color,\n bgColor,\n children,\n indicator,\n fullscreen = false,\n ...otherProps\n } = props;\n const cls = [prefixCls, className, size ? `${prefixCls}-${size}` : null].filter(Boolean).join(' ').trim();\n\n const indicatorView = useMemo(\n () => (\n <svg viewBox=\"25 25 50 50\">\n <circle cx=\"50\" cy=\"50\" r=\"20\" fill=\"none\" strokeWidth=\"5\" strokeMiterlimit=\"10\" />\n </svg>\n ),\n [],\n );\n\n const tipsView = useMemo(\n () => (\n <div\n className={[`${prefixCls}-tips`, fullscreen ? `${prefixCls}-fullscreen` : null]\n .filter(Boolean)\n .join(' ')\n .trim()}\n style={{ color, backgroundColor: bgColor }}\n >\n <div className={`${prefixCls}-tips-nested`}>\n {indicator || indicatorView}\n {tip && (\n <div\n className={[`${prefixCls}-text`, vertical ? `${prefixCls}-vertical` : null]\n .filter(Boolean)\n .join(' ')\n .trim()}\n >\n {tip}\n </div>\n )}\n </div>\n </div>\n ),\n [fullscreen, bgColor, prefixCls, vertical, tip],\n );\n\n return (\n <div className={cls} {...otherProps}>\n {(loading || fullscreen) && tipsView}\n {children &&\n React.cloneElement(\n children,\n Object.assign({}, children.props, {\n className: [`${prefixCls}-warp`, loading ? `${prefixCls}-blur` : null].filter(Boolean).join(' ').trim(),\n }),\n )}\n </div>\n );\n};\n","import React, { Fragment } from 'react';\nimport Icon, { IconProps } from '@uiw/react-icon';\nimport { IProps } from '@uiw/utils';\nimport './style/item.less';\n\nconst disabledProps = {\n href: undefined,\n onClick: undefined,\n onMouseDown: undefined,\n onMouseEnter: undefined,\n onMouseLeave: undefined,\n tabIndex: -1,\n};\n\nexport type TagType = React.ComponentType | keyof JSX.IntrinsicElements;\n\nexport interface MenuItemProps<Tag extends TagType> extends IProps, React.HTMLProps<Tag> {\n text?: React.ReactNode;\n addonAfter?: React.ReactNode;\n tagName?: Tag;\n multiline?: boolean;\n isSubMenuItem?: boolean;\n disabled?: boolean;\n active?: boolean;\n icon?: IconProps['type'];\n children?: React.ReactNode;\n}\n\nfunction Internal<Tag extends TagType = 'a'>(props: MenuItemProps<Tag>, ref: React.Ref<React.HTMLProps<Tag>>) {\n const {\n prefixCls = 'w-menu-item',\n className,\n tagName: TagName = 'a',\n children,\n disabled = false,\n multiline = false,\n icon,\n text,\n active = false,\n addonAfter,\n isSubMenuItem,\n ...htmlProps\n } = props;\n const anchorCls = [prefixCls, active ? 'active' : null, disabled ? 'w-disabled' : null, className]\n .filter(Boolean)\n .join(' ')\n .trim();\n\n const tagComp = React.createElement(\n TagName,\n {\n ...htmlProps,\n ...(disabled ? disabledProps : {}),\n className: anchorCls,\n ref,\n } as any,\n <Fragment>\n <Icon className={`${prefixCls}-icon`} type={icon} />\n <div\n className={[prefixCls && `${prefixCls}-text`, !multiline && `${prefixCls}-multiline`]\n .filter(Boolean)\n .join(' ')\n .trim()}\n >\n {text}\n </div>\n {addonAfter}\n </Fragment>,\n );\n if (isSubMenuItem) {\n return tagComp;\n }\n return <li> {tagComp} </li>;\n}\n\nexport const MenuItem = React.forwardRef(Internal);\n\nMenuItem.displayName = 'uiw.MenuItem';\n","import React from 'react';\nimport { IProps, HTMLLiProps } from '@uiw/utils';\n\nexport interface MenuDividerProps extends IProps, Omit<HTMLLiProps, 'title'> {\n title?: React.ReactNode;\n}\n\nexport const MenuDivider = React.forwardRef<HTMLLIElement, MenuDividerProps>((props, ref) => {\n const { prefixCls = 'w-menu-divider', className, title, ...htmlProps } = props;\n const cls = [prefixCls, className].filter(Boolean).join(' ').trim();\n if (!title) {\n return <li {...htmlProps} ref={ref} className={cls} />;\n }\n return (\n <li {...htmlProps} ref={ref} className={cls} data-menu=\"divider\">\n <strong>{title}</strong>\n </li>\n );\n});\n\nMenuDivider.displayName = 'uiw.MenuDivider';\n","import React, { useMemo, useState } from 'react';\nimport { CSSTransitionProps } from 'react-transition-group/CSSTransition';\nimport OverlayTrigger, { OverlayTriggerProps, OverlayTriggerRef } from '@uiw/react-overlay-trigger';\nimport Icon from '@uiw/react-icon';\nimport { IProps } from '@uiw/utils';\nimport { MenuItem, MenuItemProps, TagType } from './MenuItem';\nimport Menu, { MenuProps } from './Menu';\nimport './style/submenu.less';\n\nexport interface SubMenuProps<T extends TagType> extends IProps, MenuItemProps<T> {\n overlayProps?: OverlayTriggerProps;\n collapse?: boolean;\n disabled?: boolean;\n inlineCollapsed?: boolean;\n inlineIndent?: number;\n}\n\nfunction checkedMenuItem(node?: HTMLElement) {\n let isCheck = false;\n if (node) {\n // eslint-disable-next-line\n do {\n if (!node.dataset.menu) {\n isCheck = true;\n }\n if (node.dataset.menu && /^(subitem|divider)$/.test(node.dataset.menu)) {\n isCheck = false;\n }\n } while (!node.dataset.menu && (node = node.parentNode as HTMLElement));\n }\n return isCheck;\n}\n\nfunction IconView({ prefixCls, collapse, isOpen }: { prefixCls?: string; collapse?: boolean; isOpen: boolean }) {\n return useMemo(\n () => (\n <Icon\n type=\"caret-right\"\n className={[\n prefixCls ? `${prefixCls}-collapse-icon` : null,\n !collapse && isOpen ? 'w-open' : null,\n !collapse && !isOpen ? 'w-close' : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim()}\n />\n ),\n [prefixCls, collapse, isOpen],\n );\n}\nexport const SubMenu = React.forwardRef(function <Tag extends TagType = 'a'>(\n props: SubMenuProps<Tag>,\n ref: React.Ref<HTMLLIElement>,\n) {\n const {\n prefixCls = 'w-menu-subitem',\n className,\n disabled,\n overlayProps = {},\n children,\n collapse = false,\n inlineIndent,\n inlineCollapsed,\n ...other\n } = props;\n const overlayTriggerProps = {} as OverlayTriggerProps & CSSTransitionProps;\n const menuProps: MenuProps = {\n bordered: true,\n children,\n inlineIndent,\n className: [prefixCls ? `${prefixCls}-overlay` : null].filter(Boolean).join(' ').trim(),\n };\n const popupRef = React.useRef<OverlayTriggerRef>(null);\n const [isOpen, setIsOpen] = useState(false);\n useMemo(() => {\n setIsOpen(false);\n }, [collapse]);\n\n function onClick(e: React.MouseEvent<HTMLUListElement, MouseEvent>) {\n const target = e.currentTarget;\n const related = (e.relatedTarget || e.nativeEvent.target) as HTMLElement;\n if (target.children.length < 1) return;\n if (checkedMenuItem(related)) {\n if (popupRef.current) {\n popupRef.current!.hide();\n }\n }\n }\n function onExit(node: HTMLElement) {\n node.style.height = `${node.scrollHeight}px`;\n setIsOpen(false);\n }\n function onExiting(node: HTMLElement) {\n node.style.height = '0px';\n }\n function onEnter(node: HTMLElement) {\n node.style.height = '1px';\n setIsOpen(true);\n }\n function onEntering(node: HTMLElement) {\n node.style.height = `${node.scrollHeight}px`;\n }\n function onEntered(node: HTMLElement) {\n node.style.height = 'initial';\n }\n\n if (!collapse) {\n delete menuProps.onClick;\n menuProps.bordered = false;\n overlayTriggerProps.className = `${prefixCls}-collapse`;\n overlayTriggerProps.appear = false;\n overlayTriggerProps.isOutside = true;\n overlayTriggerProps.isClickOutside = false;\n overlayTriggerProps.unmountOnExit = false;\n overlayTriggerProps.trigger = 'click';\n overlayTriggerProps.transitionName = `${prefixCls}`;\n overlayTriggerProps.onExit = onExit;\n overlayTriggerProps.onExiting = onExiting;\n overlayTriggerProps.onEnter = onEnter;\n overlayTriggerProps.onEntered = onEntered;\n overlayTriggerProps.onEntering = onEntering;\n } else {\n overlayTriggerProps.className = `${prefixCls}-popup`;\n overlayTriggerProps.trigger = 'hover';\n overlayTriggerProps.usePortal = true;\n menuProps.onClick = onClick;\n }\n return (\n <li data-menu=\"subitem\" ref={ref}>\n <OverlayTrigger\n placement=\"rightTop\"\n autoAdjustOverflow\n disabled={disabled}\n isOpen={isOpen}\n usePortal={false}\n isOutside\n {...overlayTriggerProps}\n {...overlayProps}\n ref={popupRef}\n overlay={<Menu {...menuProps} style={!collapse ? { paddingLeft: inlineIndent } : {}} />}\n >\n <MenuItem\n {...other}\n ref={null}\n disabled={disabled}\n isSubMenuItem\n addonAfter={<IconView collapse={collapse} prefixCls={prefixCls} isOpen={isOpen} />}\n className={[\n prefixCls ? `${prefixCls}-title` : null,\n !collapse ? `${prefixCls}-collapse-title` : null,\n className,\n ]\n .filter(Boolean)\n .join(' ')\n .trim()}\n />\n </OverlayTrigger>\n </li>\n );\n});\n\nSubMenu.displayName = 'uiw.SubMenu';\n","import React, { useMemo } from 'react';\nimport { IProps, HTMLUlProps } from '@uiw/utils';\nimport { MenuItem } from './MenuItem';\nimport { MenuDivider } from './Divider';\nimport { SubMenu } from './SubMenu';\nimport './style/menu.less';\n\nexport interface MenuProps extends IProps, HTMLUlProps {\n /** 主题颜色 */\n theme?: 'light' | 'dark';\n /**\n * 垂直是否收起菜单\n * Default: `false`\n */\n inlineCollapsed?: boolean;\n /**\n * 菜单缩进宽度 Default: `10`\n */\n inlineIndent?: number;\n bordered?: boolean;\n}\n\nconst Menu = React.forwardRef<HTMLUListElement, MenuProps>((props, ref) => {\n const {\n prefixCls = 'w-menu',\n className,\n children,\n bordered,\n theme = 'light',\n inlineIndent = 10,\n inlineCollapsed,\n ...htmlProps\n } = props;\n const cls = useMemo(\n () =>\n [\n prefixCls,\n bordered ? 'w-bordered' : null,\n inlineCollapsed ? `${prefixCls}-inline-collapsed` : null,\n theme ? `${prefixCls}-${theme}` : null,\n className,\n ]\n .filter(Boolean)\n .join(' ')\n .trim(),\n [prefixCls, bordered, inlineCollapsed, theme, className],\n );\n\n return (\n <ul {...htmlProps} ref={ref} className={cls} data-menu=\"menu\">\n {React.Children.map(children, (child: React.ReactNode, key) => {\n if (!React.isValidElement(child)) return child;\n const props: { inlineIndent?: number; inlineCollapsed?: boolean } = {};\n // Sub Menu\n if (child.props.children && child.type === (SubMenu as any)) {\n props.inlineIndent = inlineIndent;\n }\n return React.cloneElement(child, Object.assign({ ...props }, child.props, { key: `${key}` }));\n })}\n </ul>\n );\n});\n\nMenu.displayName = 'uiw.Menu';\n\ntype Menu = typeof Menu & {\n Item: typeof MenuItem;\n SubMenu: typeof SubMenu;\n Divider: typeof MenuDivider;\n};\n\n(Menu as Menu).Item = MenuItem;\n(Menu as Menu).SubMenu = SubMenu;\n(Menu as Menu).Divider = MenuDivider;\n\nexport default Menu as Menu;\n","import Menu from './Menu';\n\nexport * from './Menu';\nexport * from './MenuItem';\nexport * from './SubMenu';\nexport * from './Divider';\n\nexport default Menu;\n","import React from 'react';\nimport { CSSTransition } from 'react-transition-group';\nimport Icon, { IconProps } from '@uiw/react-icon';\nimport Button from '@uiw/react-button';\nimport './style/index.less';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\n\nexport interface MessageProps extends IProps, Omit<HTMLDivProps, 'title'> {\n title?: React.ReactNode;\n icon?: IconProps['type'];\n type?: 'success' | 'warning' | 'info' | 'error';\n description?: React.ReactNode;\n showIcon?: boolean;\n isCloseButtonShown?: boolean;\n rounded?: boolean;\n onClose?: (e: React.MouseEvent<HTMLButtonElement>) => void;\n}\n\nexport interface IMessageState {\n isOpen: boolean;\n}\n\nexport default class Message extends React.Component<MessageProps, IMessageState> {\n public static defaultProps: MessageProps = {\n prefixCls: 'w-message',\n rounded: true,\n isCloseButtonShown: false,\n };\n constructor(props: MessageProps) {\n super(props);\n this.state = {\n isOpen: true,\n };\n }\n handleClosed = (e: React.MouseEvent<HTMLButtonElement>) => {\n const { onClose } = this.props;\n this.setState({ isOpen: false });\n onClose && onClose(e);\n };\n renderIcon = () => {\n const { type, showIcon } = this.props;\n let icon = this.props.icon;\n if (!icon && showIcon) {\n switch (type) {\n case 'success':\n icon = 'circle-check';\n break;\n case 'warning':\n icon = 'warning';\n break;\n case 'info':\n icon = 'information';\n break;\n case 'error':\n icon = 'circle-close';\n break;\n default:\n break;\n }\n }\n return icon;\n };\n render() {\n const {\n prefixCls,\n className,\n type,\n title,\n description,\n showIcon,\n icon,\n rounded,\n isCloseButtonShown,\n ...elementProps\n } = this.props;\n const children = description || this.props.children;\n const cls = [\n prefixCls,\n className,\n `${prefixCls}-${type}`,\n rounded ? `${prefixCls}-rounded` : null,\n showIcon ? `${prefixCls}-icon` : null,\n showIcon ? `${prefixCls}${title ? '-title' : ''}${children ? '-description' : ''}` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim();\n const Child = (\n <div className={cls} {...elementProps}>\n {isCloseButtonShown && <Button basic onClick={this.handleClosed} icon=\"close\" type=\"light\" />}\n {showIcon && <Icon type={this.renderIcon()} />}\n <span className={`${prefixCls}-title`}>{title}</span>\n <span className={`${prefixCls}-description`}>{children}</span>\n </div>\n );\n if (!isCloseButtonShown) {\n return Child;\n }\n return (\n <CSSTransition in={this.state.isOpen} unmountOnExit timeout={300} classNames={prefixCls}>\n {Child}\n </CSSTransition>\n );\n }\n}\n","import React, { useEffect, useMemo, useState } from 'react';\nimport Input, { InputProps } from '@uiw/react-input';\nimport Popover, { PopoverProps } from '@uiw/react-popover';\nimport { IProps } from '@uiw/utils';\nimport Button from '@uiw/react-button';\nimport formatter from '@uiw/formatter';\nimport { DatePickerMonth, DatePickerYear, DatePickerCaption, DatePickerCaptionProps } from '@uiw/react-date-picker';\nimport './style/index.less';\n\nexport interface MonthPickerProps extends IProps, Omit<InputProps, 'value' | 'onChange'> {\n popoverProps?: PopoverProps;\n pickerCaptionProps?: DatePickerCaptionProps;\n value?: Date | string;\n format?: string;\n monthLabel?: string[];\n allowClear?: boolean;\n onChange?: (date?: Date, formatDate?: string) => void;\n}\n\nconst MONTH_LABEL = [\n '一月',\n '二月',\n '三月',\n '四月',\n '五月',\n '六月',\n '七月',\n '八月',\n '九月',\n '十月',\n '十一月',\n '十二月',\n];\n\nexport default function MonthPicker(props: MonthPickerProps) {\n const {\n prefixCls = 'w-monthpicker',\n format = 'YYYY/MM',\n onChange = () => {},\n className,\n popoverProps,\n pickerCaptionProps = {},\n allowClear = true,\n monthLabel = MONTH_LABEL,\n ...inputProps\n } = props;\n\n const [isOpen, setIsOpen] = useState(false);\n const [panelDate, setPanelDate] = useState(new Date());\n const [type, setType] = useState('month');\n const [date, setDate] = useState(props.value);\n\n useEffect(() => setDate(props.value), [props.value]);\n\n inputProps.value = useMemo(\n () => (typeof date === 'string' ? date : date ? formatter(format, date) : ''),\n [format, date],\n );\n\n if (allowClear && inputProps.value) {\n inputProps.addonAfter = (\n <Button\n className={`${prefixCls}-close-btn`}\n icon=\"close\"\n onClick={() => {\n setDate('');\n onChange && onChange();\n }}\n size={inputProps.size}\n basic\n type=\"light\"\n />\n );\n }\n\n function handleSelectedDate(type: 'setMonth' | 'setFullYear', num: number, paging?: boolean) {\n const curPanelDate = new Date(new Date(panelDate)[type](num));\n if (!paging) {\n setType('month');\n }\n const curDate = formatter(format, new Date(curPanelDate));\n setDate(curDate);\n setPanelDate(curPanelDate);\n onChange && onChange(curPanelDate, curDate);\n if (type === 'setMonth') {\n setIsOpen(false);\n }\n }\n\n return (\n <Popover\n trigger=\"focus\"\n placement=\"bottomLeft\"\n autoAdjustOverflow\n isOpen={isOpen}\n {...popoverProps}\n onVisibleChange={(open) => setIsOpen(open)}\n content={\n <div className={`${prefixCls}-popover`}>\n <DatePickerCaption\n panelDate={panelDate}\n monthLabel={monthLabel}\n {...pickerCaptionProps}\n onSelected={(captionType) => {\n if (/^(month|year)$/.test(captionType as string)) {\n setType(captionType);\n } else {\n const year = new Date(panelDate).getFullYear();\n const curPanelDate = new Date(new Date(panelDate).setFullYear(type === 'next' ? year + 1 : year - 1));\n setPanelDate(curPanelDate);\n }\n }}\n />\n {type === 'month' && (\n <DatePickerMonth\n panelDate={panelDate}\n monthLabel={monthLabel}\n onSelected={(month, paging) => handleSelectedDate('setMonth', month, paging)}\n />\n )}\n {type === 'year' && (\n <DatePickerYear\n panelDate={panelDate}\n onSelected={(year, paging) => handleSelectedDate('setFullYear', year, paging)}\n />\n )}\n </div>\n }\n >\n <Input\n placeholder=\"请输入日期\"\n readOnly\n {...(inputProps as any)}\n className={[prefixCls, className].filter(Boolean).join(' ').trim()}\n />\n </Popover>\n );\n}\n","import React from 'react';\nimport Alert, { AlertProps } from '@uiw/react-alert';\nimport { IProps } from '@uiw/utils';\nimport { NotificationCreateProps } from './index';\n\nexport type Placement = 'topLeft' | 'topRight' | 'bottomLeft' | 'bottomRight';\n\nexport interface ContainerProps extends IProps {\n placement?: Placement;\n}\nexport interface ContainerState {\n placement?: Placement;\n notifys: ContainerNotifys;\n}\n\nexport type ContainerNotifys = {\n [placement: string]: {\n [key: string]: NotificationCreateProps;\n };\n};\n\nconst notifys: ContainerNotifys = {};\nconst timer: { [key: string]: any } = {};\n\nexport default class Container extends React.Component<ContainerProps, ContainerState> {\n public static defaultProps: ContainerProps = {\n prefixCls: 'w-notify',\n placement: 'topRight',\n };\n public state: ContainerState = {\n notifys: {},\n };\n public create(props: NotificationCreateProps) {\n const { placement, key } = props;\n if (!notifys[placement as Placement]) {\n notifys[placement as Placement] = {};\n }\n props.isOpen = false;\n notifys[placement as Placement][key as string] = props;\n if (props.duration) {\n timer[key as string] = setTimeout(() => {\n this.closed(key as string, placement);\n }, props.duration);\n }\n this.setState(\n {\n notifys,\n placement,\n },\n () => {\n notifys[placement as Placement][key as string].isOpen = true;\n this.setState({ notifys });\n },\n );\n }\n public closed(key: string, placement?: Placement) {\n if (!key || !placement || !notifys[placement][key]) {\n return;\n }\n notifys[placement][key].isOpen = false;\n const props: NotificationCreateProps = notifys[placement][key];\n this.setState({ notifys }, () => {\n clearTimeout(timer[key]);\n delete timer[key];\n delete notifys[placement][key];\n if (props && props.willUnmount) {\n props.willUnmount(props, notifys);\n }\n });\n }\n render() {\n const { prefixCls } = this.props;\n const { placement } = this.state;\n return (\n <React.Fragment>\n {placement &&\n Object.keys(this.state.notifys[placement]).map((key) => {\n const { description, isOpen, ...alertProps } = this.state.notifys[placement][key];\n if (alertProps.type === 'open') {\n delete alertProps.type;\n }\n return (\n <Alert\n className={prefixCls}\n key={key}\n useButton={false}\n width={320}\n {...(alertProps as AlertProps)}\n usePortal={false}\n hasBackdrop={false}\n isOpen={isOpen}\n content={description}\n />\n );\n })}\n </React.Fragment>\n );\n }\n}\n","import React from 'react';\nimport ReactDOM from 'react-dom';\nimport { AlertProps } from '@uiw/react-alert';\nimport { randomid } from '@uiw/utils';\nimport Container, { Placement, ContainerNotifys } from './Container';\nimport './style/index.less';\n\nexport interface NotificationCreateProps extends Omit<AlertProps, 'type'> {\n placement?: Placement;\n description?: React.ReactNode;\n type?: 'primary' | 'danger' | 'open' | 'success' | 'warning' | 'info' | 'error';\n duration?: number;\n key?: string;\n willUnmount?: (props: NotificationCreateProps, notifys: ContainerNotifys) => void;\n}\n\nexport type Notifys = { [key: string]: any };\nexport type NotifysDom = { [key: string]: HTMLDivElement };\n\nconst notifys: Notifys = {};\nconst notifysDom: NotifysDom = {};\n\nexport interface NotificationProps {\n (props: NotificationCreateProps, type: NotificationCreateProps['type']): void;\n [key: string]: () => void;\n}\n\nfunction NotificationCreate(props: NotificationCreateProps, type: NotificationCreateProps['type'] = 'open') {\n if (!props.placement) {\n props.placement = 'topRight';\n }\n props.type = type as NotificationCreateProps['type'];\n if (!props.icon && props.icon !== null) {\n switch (props.type) {\n case 'success':\n props.icon = 'circle-check';\n break;\n case 'warning':\n props.icon = 'warning';\n break;\n case 'info':\n props.icon = 'information';\n break;\n case 'error':\n props.icon = 'circle-close';\n break;\n default:\n break;\n }\n }\n switch (props.type) {\n case 'info':\n props.type = 'primary';\n break;\n case 'error':\n props.type = 'danger';\n break;\n default:\n break;\n }\n\n if (props.placement && !notifys[props.placement]) {\n const div = document.createElement('div');\n document.body.appendChild(div);\n div.className = ['w-notify-warpper', props.placement].filter(Boolean).join(' ').trim();\n notifysDom[props.placement] = div;\n notifys[props.placement] = ReactDOM.render(<Container />, div);\n }\n\n if (props.duration !== null) {\n props.duration = (props.duration || 4.5) * 1000;\n }\n\n if (notifys[props.placement]) {\n notifys[props.placement].create({\n ...props,\n duration: props.duration,\n key: randomid(),\n willUnmount(nprops: any, notifysChild: ContainerNotifys) {\n if (!nprops) return;\n nprops.onClose && nprops.onClose();\n const keys = Object.keys(notifysChild[props.placement as Placement]);\n if (keys.length === 0 && notifys[props.placement as Placement]) {\n delete notifys[props.placement as Placement];\n if (notifysDom[props.placement as Placement]) {\n document.body.removeChild(notifysDom[props.placement as Placement]);\n }\n }\n },\n });\n }\n}\n\n['open', 'success', 'warning', 'info', 'error'].forEach((type) => {\n (NotificationCreate as NotificationProps)[type] = (options: NotificationCreateProps = {}) => {\n return NotificationCreate(options, type as NotificationCreateProps['type']);\n };\n});\n\nexport interface NotificationApi {\n open(option: NotificationCreateProps): void;\n success(option: NotificationCreateProps): void;\n warning(option: NotificationCreateProps): void;\n info(option: NotificationCreateProps): void;\n error(option: NotificationCreateProps): void;\n}\n\nexport default NotificationCreate as unknown as NotificationApi;\n","/**\n * Returns a random text\n */\nexport function randomid(): string {\n return parseInt(String(Math.random() * 1e15), 10).toString(36);\n}\n","import React from 'react';\n\nexport default React.forwardRef<HTMLOptionElement, React.InputHTMLAttributes<HTMLOptionElement>>((props, ref) => (\n <option {...props} ref={ref} />\n));\n","import React from 'react';\n\nexport default React.forwardRef<HTMLOptGroupElement, React.InputHTMLAttributes<HTMLOptGroupElement>>((props, ref) => (\n <optgroup {...props} ref={ref} />\n));\n","import React from 'react';\nimport { IProps } from '@uiw/utils';\nimport Option from './Option';\nimport Group from './Group';\nimport './style/index.less';\n\nexport interface SelectProps extends IProps, Omit<React.SelectHTMLAttributes<HTMLSelectElement>, 'size'> {\n size?: 'large' | 'default' | 'small';\n}\n\nconst Select = React.forwardRef<HTMLSelectElement, SelectProps>((props, ref) => {\n const { prefixCls = 'w-select', className, size = 'default', ...other } = props;\n return (\n <select\n {...other}\n ref={ref}\n className={[prefixCls, className, size ? `${prefixCls}-${size}` : null].filter(Boolean).join(' ').trim()}\n />\n );\n});\n\ntype Select = typeof Select & {\n Option: typeof Option;\n Group: typeof Group;\n};\n\n(Select as Select).Option = Option;\n(Select as Select).Group = Group;\n\nexport default Select as Select;\n","import React, { useEffect, useMemo, useState } from 'react';\nimport Select from '@uiw/react-select';\nimport { IProps, HTMLUlProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface PaginationProps extends IProps, Omit<HTMLUlProps, 'onChange'> {\n prefixCls?: string;\n alignment?: 'left' | 'center' | 'right';\n size?: 'default' | 'small';\n pageSizeOptions?: number[];\n total?: number;\n pageSize?: number;\n divider?: boolean;\n current?: number;\n onChange?: (current: number, total: number, pageSize: number) => void;\n onShowSizeChange?: (current: number, pageSize: number) => void;\n}\n\nexport interface PaginationState {\n current: number;\n}\n\nexport interface PaginationItemSourceData {\n type?: string;\n disabled?: boolean;\n active?: boolean;\n label?: number | string;\n goto?: number;\n}\n\nexport default function Pagination(props: PaginationProps) {\n const {\n className,\n style,\n prefixCls = 'w-pagination',\n alignment = 'left',\n size = 'default',\n total = 0,\n pageSize = 10, // The number of pages displayed.\n pageSizeOptions = [],\n current: currentNumber = 1,\n onChange = () => null,\n onShowSizeChange,\n divider,\n ...other\n } = props;\n\n const [current, setCurrent] = useState(currentNumber);\n useEffect(() => setCurrent(currentNumber), [currentNumber]);\n\n const cls = [prefixCls, className, divider ? 'divider' : null, size].filter(Boolean).join(' ').trim();\n\n const initPageSoure = useMemo(() => {\n const data: PaginationItemSourceData[] = [{ type: 'prev', disabled: current === 1 }];\n const count = Math.ceil(total / pageSize);\n const itemCount = count <= 5 ? count : 5;\n let num = 0;\n let basic = 0;\n if (current > 3 && count > 5) {\n data.push({ label: 1 });\n }\n if (current > 4 && count > 6) {\n data.push({ type: 'jumpPrev', label: '•••', goto: 5 });\n }\n while (num < itemCount) {\n num += 1;\n if (current > 3 && count > 5) {\n basic = current - 3;\n }\n let label = num + basic;\n if (count - current === 0 && count > 5) {\n label -= 2;\n }\n if (count - current === 1 && count > 5) {\n label -= 1;\n }\n if (label <= count) {\n data.push({ label, active: current === label });\n }\n }\n if (current + 3 < count && count > 6) {\n data.push({ type: 'jumpNext', label: '•••', goto: 5 });\n }\n if (current + 2 < count && count > 5) {\n data.push({ label: count });\n }\n data.push({ type: 'next', disabled: current === count });\n return data;\n // return [\n // { type: 'prev', disabled: true },\n // { type: 'jumpPrev', label: '•••', goto: 5 },\n // { label: 1 },\n // { label: 2, active: true },\n // { label: 3 },\n // { label: 4 },\n // { type: 'jumpPrev', label: '•••', goto: 5 },\n // { type: 'next' },\n // ];\n }, [current, total, pageSize]);\n\n function handleClick(item: PaginationItemSourceData) {\n if (item.active || item.disabled) {\n return;\n }\n const count = Math.ceil(total / pageSize);\n const state = {} as PaginationState;\n if (item.label) {\n state.current = item.label as number;\n }\n if (item.type === 'prev') {\n state.current = current - 1 > 0 ? current - 1 : 1;\n }\n if (item.type === 'next') {\n state.current = current + 1 <= count ? current + 1 : count;\n }\n if (/^(jumpPrev|jumpNext)/.test(item.type as string) && item.goto) {\n state.current = item.type === 'jumpPrev' ? current - item.goto : current + item.goto;\n if (state.current > count) {\n state.current = count;\n }\n if (state.current < 1) {\n state.current = 1;\n }\n }\n\n setCurrent(state.current);\n onChange && onChange(state.current, total as number, pageSize as number);\n }\n\n const onSizeChange: React.ChangeEventHandler<HTMLSelectElement> = (e) => {\n const sizeCount: number = Number(e.target.value);\n const count = Math.ceil(total / sizeCount);\n const newCurrent: number = current > count ? count : current;\n onShowSizeChange && onShowSizeChange(newCurrent, sizeCount);\n };\n\n return (\n <ul className={cls} style={{ ...style, textAlign: alignment }} {...other}>\n {initPageSoure.map((item: PaginationItemSourceData, idx) => {\n // eslint-disable-next-line jsx-a11y/anchor-is-valid\n let label = <a>{item.label}</a>;\n if (/^(prev|next)$/.test(item.type as string)) {\n // eslint-disable-next-line jsx-a11y/anchor-is-valid\n label = <a className={`arrow ${item.type}`} />;\n }\n return (\n <li\n className={[item.active ? 'active' : null, item.disabled ? 'disabled' : null]\n .filter(Boolean)\n .join(' ')\n .trim()}\n onClick={() => handleClick(item)}\n key={idx}\n >\n {label}\n </li>\n );\n })}\n {pageSizeOptions.length > 0 && (\n <li className={`${prefixCls}-options`}>\n <Select size={size} defaultValue={pageSize} onChange={onSizeChange}>\n {pageSizeOptions.map((item: number, index: number) => (\n <Select.Option value={item} key={index}>\n {item}条/页\n </Select.Option>\n ))}\n </Select>\n </li>\n )}\n </ul>\n );\n}\n","import React, { useEffect, useState } from 'react';\nimport { IProps, noop } from '@uiw/utils';\nimport Input, { InputProps } from '@uiw/react-input';\nimport './style/input.less';\n\nexport interface PinCodeProps extends IProps {\n value?: string[];\n disabled?: boolean;\n onChange?: (value: string[]) => void;\n onBlur?: InputProps['onBlur'];\n onFocus?: InputProps['onFocus'];\n autoFocus?: boolean;\n size?: InputProps['size'];\n placeholder?: string;\n}\n\nfunction InternalPinCode(props: PinCodeProps = {}, ref: React.ForwardedRef<HTMLDivElement>) {\n const {\n prefixCls = 'w-pin-code',\n placeholder = '○',\n value = [],\n autoFocus,\n className,\n size = 'default',\n style,\n disabled,\n onChange = noop,\n onBlur = noop,\n onFocus = noop,\n ...otherProps\n } = props;\n const [input] = useState<{\n [key: string]: HTMLInputElement;\n }>({});\n const [placehold, setPlacehold] = useState(placeholder);\n const [values, setValues] = useState(value);\n const cls = [prefixCls, className, size ? `${prefixCls}-${size}` : null, disabled ? 'disabled' : null]\n .filter(Boolean)\n .join(' ')\n .trim();\n\n function handleChange(e: React.ChangeEvent<HTMLInputElement>, idx: number) {\n let val = e.target.value;\n val = val.charAt(val.length - 1);\n const arr = [...values];\n if (Number(val) > -1 && val) {\n e.currentTarget.value = val;\n arr[idx] = val;\n if (input[idx + 1]) {\n input[idx + 1].focus();\n }\n setValues(arr);\n } else if (!val) {\n arr[idx] = '';\n setValues(arr);\n }\n }\n function handleKeyDown(e: React.KeyboardEvent<HTMLInputElement>, idx: number) {\n let val = e.currentTarget.value;\n const key = e.key.toLocaleLowerCase();\n if (!val && input[idx - 1] && /(backspace|delete)/.test(key)) {\n input[idx - 1].focus();\n }\n }\n useEffect(() => {\n if (values !== value) {\n onChange(values);\n }\n }, [values]);\n\n function handleBlur(event: React.FocusEvent<HTMLInputElement>) {\n setPlacehold(placeholder);\n onBlur(event);\n }\n function handleFocus(event: React.FocusEvent<HTMLInputElement>) {\n setPlacehold('');\n onFocus(event);\n }\n\n return (\n <div className={cls} style={style} {...otherProps} ref={ref}>\n {[...values].map((val, key) => {\n const inpProps: InputProps = {\n min: 0,\n type: 'text',\n inputMode: 'numeric',\n autoComplete: 'off',\n value: val,\n onChange: (e) => handleChange(e, key),\n onKeyDown: (e) => handleKeyDown(e, key),\n onBlur: (e) => handleBlur(e),\n onFocus: (e) => handleFocus(e),\n className: `${prefixCls}-inner`,\n placeholder: placehold,\n disabled,\n size,\n };\n if (autoFocus && key === 0) {\n inpProps.autoFocus = true;\n }\n const child = (\n <Input\n ref={(instance) => {\n if (instance) {\n input[key] = instance;\n }\n }}\n {...inpProps}\n key={key}\n />\n );\n return child;\n })}\n </div>\n );\n}\n\nexport default React.forwardRef<HTMLDivElement, PinCodeProps>(InternalPinCode);\n","import React from 'react';\nimport Icon, { IconProps } from '@uiw/react-icon';\n\nexport function IconProgress<T>(props: { type: IconProps<T>['type'] }): JSX.Element {\n return <Icon type={props.type} />;\n}\n","import React from 'react';\nimport { IconProps } from '@uiw/react-icon';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\nimport { IconProgress } from './utils';\nimport './style/index.less';\nimport './style/circle.less';\n\nexport type Status = 'success' | 'active' | 'exception';\nexport interface ProgressCircleProps<T> extends IProps, HTMLDivProps {\n type?: IconProps<T>['type'];\n status?: Status;\n showText?: boolean; // 是否显示进度条文字内容\n percent?: number; // 百分比(必填)\n width?: number; // 圆圈进度条画布宽度\n strokeWidth?: number; // 进度条大小设置\n format?: (percent: number) => React.ReactNode;\n}\n\nexport default class Circle<T> extends React.Component<ProgressCircleProps<T>> {\n public static defaultProps: ProgressCircleProps<{}> = {\n prefixCls: 'w-progress',\n showText: true,\n percent: 0, // 百分比(必填)\n width: 126, // 圆圈进度条画布宽度\n strokeWidth: 6, // 进度条大小设置\n };\n relativeStrokeWidth(type: 'track' | 'bg' | undefined, elm: SVGPathElement) {\n const { strokeWidth, percent } = this.props;\n if (elm && elm.parentNode) {\n const { width } = (elm.parentNode as SVGAElement).getBoundingClientRect();\n const _strokeWidth: string = (((strokeWidth as number) / width) * 100).toFixed(1);\n const radius = parseInt((50 - parseFloat(_strokeWidth) / 2).toString(), 10);\n elm.setAttribute('stroke-width', _strokeWidth);\n elm.setAttribute(\n 'd',\n `M 50 50 m 0 -${radius} a ${radius} ${radius} 0 1 1 0 ${radius * 2} a ${radius} ${radius} 0 1 1 0 -${\n radius * 2\n }`,\n );\n if (type === 'track') {\n // 计算周长\n const perimeter = 2 * Math.PI * radius;\n elm.setAttribute(\n 'style',\n `stroke-dasharray:${perimeter}px,${perimeter}px;stroke-dashoffset:${\n (1 - (percent as number) / 100) * perimeter\n }px;transition: stroke-dashoffset 0.6s ease 0s, stroke 0.6s ease;`,\n );\n }\n }\n }\n render() {\n const { prefixCls, style, type, className, showText, percent, format, strokeWidth, width, status, ...resetProps } =\n this.props;\n const cls = [\n prefixCls,\n className,\n `${prefixCls}-circle`,\n showText ? `${prefixCls}-show-text` : null,\n status ? `${prefixCls}-status-${status}` : null,\n parseInt((percent as number).toString(), 10) >= 100 ? `${prefixCls}-status-success` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim();\n let progressInfo;\n const progressStatus =\n parseInt((percent as number).toString(), 10) >= 100 && !('status' in this.props) ? 'success' : status;\n if (showText) {\n let percentView: React.ReactNode = `${percent}%`;\n if (progressStatus === 'exception') {\n percentView = <IconProgress type=\"close\" />;\n } else if (progressStatus === 'success') {\n percentView = <IconProgress type=\"check\" />;\n }\n progressInfo = (\n <span className={`${prefixCls}-text`} style={{ fontSize: (width as number) * 0.16 + 6 }}>\n {format ? format(percent as number) : percentView}\n </span>\n );\n }\n return (\n <div className={cls} style={style} {...resetProps}>\n <svg viewBox=\"0 0 100 100\" width={`${width}`}>\n <path ref={this.relativeStrokeWidth.bind(this, 'bg')} className={`${prefixCls}-trail`} fill=\"none\" />\n <path\n ref={this.relativeStrokeWidth.bind(this, 'track')}\n strokeLinecap=\"round\"\n className={`${prefixCls}-stroke`}\n fill=\"none\"\n />\n </svg>\n {progressInfo}\n </div>\n );\n }\n}\n","import React from 'react';\nimport { IconProgress } from './utils';\nimport { ProgressCircleProps } from './Circle';\nimport './style/index.less';\nimport './style/line.less';\n\nexport interface ProgressLineProp<T> extends ProgressCircleProps<T> {}\n\nexport default class Line<T> extends React.Component<ProgressLineProp<T>> {\n public static defaultProps: ProgressLineProp<{}> = {\n prefixCls: 'w-progress',\n showText: true, // 是否显示进度条文字内容\n percent: 0, // 百分比(必填)\n width: 126, // 圆圈进度条画布宽度\n strokeWidth: 6, // 进度条大小设置\n };\n render() {\n const { prefixCls, style, className, showText, percent, format, strokeWidth, width, status, ...resetProps } =\n this.props;\n const cls = [\n prefixCls,\n className,\n `${prefixCls}-line`,\n showText ? `${prefixCls}-show-text` : null,\n status ? `${prefixCls}-status-${status}` : null,\n parseInt((percent as number).toString(), 10) >= 100 ? `${prefixCls}-status-success` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim();\n let progressInfo;\n if (showText) {\n const progressStatus =\n parseInt((percent as number).toString(), 10) >= 100 && !('status' in this.props) ? 'success' : status;\n let percentView: React.ReactNode = `${percent}%`;\n if (progressStatus === 'exception') {\n percentView = <IconProgress type=\"circle-close\" />;\n } else if (progressStatus === 'success') {\n percentView = <IconProgress type=\"circle-check\" />;\n }\n progressInfo = <span className={`${prefixCls}-text`}>{format ? format(percent as number) : percentView}</span>;\n }\n const percentStyle = {\n width: `${percent}%`,\n height: strokeWidth,\n };\n return (\n <div className={cls} style={style} {...resetProps}>\n <div className={`${prefixCls}-bar`}>\n <div className={`${prefixCls}-inner`}>\n <div className={`${prefixCls}-bg`} style={percentStyle} />\n </div>\n </div>\n {progressInfo}\n </div>\n );\n }\n}\n","import Circle from './Circle';\nimport Line from './Line';\n\nexport * from './Circle';\nexport * from './Line';\n\nexport default {\n Line,\n Circle,\n};\n","import React, { useState, useMemo } from 'react';\nimport { IProps, HTMLDivProps, HTMLSpanProps, noop } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface RateProps extends IProps, Omit<HTMLDivProps, 'onChange'> {\n value?: number;\n readOnly?: boolean;\n allowHalf?: boolean;\n count?: number;\n color?: string;\n disabled?: boolean;\n character?: React.ReactNode;\n onChange?: (key: number) => void;\n onHoverChange?: (key: number) => void;\n}\n\nexport default function Rate(props: RateProps = {}) {\n const {\n prefixCls = 'w-rate',\n count = 5,\n value: defValue = 0,\n className,\n allowHalf,\n character = '★',\n readOnly = false,\n disabled,\n onChange = noop,\n onHoverChange = noop,\n color,\n ...other\n } = props;\n const [value, setValue] = useState(defValue);\n const [hoverCount, setHoverCount] = useState(-1);\n const cls = [prefixCls, className, disabled ? 'disabled' : null].filter(Boolean).join(' ').trim();\n const [prevValue, setPrevValue] = useState<number>();\n if (defValue !== prevValue) {\n setPrevValue(defValue);\n }\n\n useMemo(() => {\n if (value !== prevValue) {\n setValue(defValue);\n }\n }, [prevValue]);\n\n function onMouseLeave() {\n setHoverCount(-1);\n }\n\n function getValue(e: React.MouseEvent<HTMLElement>, key: number) {\n e.persist();\n let currentValue = key;\n const isLeft =\n e.clientX - e.currentTarget.getBoundingClientRect().left <= e.currentTarget.getBoundingClientRect().width / 2;\n if (allowHalf) {\n e.persist();\n currentValue = isLeft ? key + 0.5 : key + 1;\n } else {\n currentValue = key + 1;\n }\n return currentValue;\n }\n\n function onMouseMove(e: React.MouseEvent<HTMLElement>, key: number) {\n const currentValue = getValue(e, key);\n if (hoverCount !== currentValue) {\n setHoverCount(currentValue);\n onHoverChange(currentValue);\n }\n }\n function onClick(e: React.MouseEvent<HTMLElement>, key: number) {\n if (readOnly) return;\n const currentValue = getValue(e, key);\n setValue(currentValue);\n onChange(currentValue);\n }\n return (\n <div {...other} className={cls} onMouseLeave={() => onMouseLeave()}>\n {[...Array(count)].map((_, idx) => {\n const halfon =\n (value <= idx + 0.5 && Math.ceil(value) - 1 === idx && hoverCount === -1) || hoverCount === idx + 0.5;\n const activeCls = [\n `${prefixCls}-hight`,\n idx + 1 <= value && hoverCount === -1 ? 'star-on' : null,\n idx + 1 <= hoverCount ? 'hover-on' : null,\n halfon ? 'half-on' : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim();\n const props: HTMLSpanProps = {};\n if (!readOnly) {\n props.onClick = (e) => onClick(e, idx);\n props.onMouseMove = (e) => onMouseMove(e, idx);\n }\n return (\n <span key={idx} {...props}>\n <span style={{ color }} className={activeCls}>\n {character}\n </span>\n <span className={`${prefixCls}-bg`}>{character}</span>\n </span>\n );\n })}\n </div>\n );\n}\n","import React, { useMemo } from 'react';\nimport { IProps, HTMLSpanProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface TagProps extends IProps, Omit<HTMLSpanProps, 'title'> {\n color?: string;\n disabled?: boolean;\n visible?: boolean;\n bordered?: boolean;\n light?: boolean;\n closable?: boolean;\n title?: React.ReactNode;\n onClose?: (e: React.MouseEvent<SVGSVGElement, MouseEvent>) => void;\n}\n\nexport default (props: TagProps = {}) => {\n const {\n prefixCls = 'w-tag',\n className,\n style,\n title = '',\n children,\n visible = true,\n color = '#6E6E6E',\n disabled = false,\n bordered = true,\n closable,\n light = false,\n onClose,\n ...other\n } = props;\n const cls = [prefixCls, className, light ? `${prefixCls}-light` : null, disabled ? 'disabled' : null]\n .filter(Boolean)\n .join(' ')\n .trim();\n const styl: React.CSSProperties = { ...style };\n if (!light) {\n styl.color = '#fff';\n styl.backgroundColor = color;\n } else {\n styl.color = color;\n styl.borderColor = color;\n if (bordered && light) {\n styl.boxShadow = `inset 0 0 0 1px ${color}`;\n }\n }\n if (!visible) {\n return null;\n }\n\n return (\n <span className={cls} style={styl} {...other}>\n {title || children}\n {closable ? (\n <svg onClick={onClose} className={`${prefixCls}-close`} width=\"15\" height=\"15\" viewBox=\"0 0 16 16\">\n <path d=\"M9.41 8l2.29-2.29c.19-.18.3-.43.3-.71a1.003 1.003 0 0 0-1.71-.71L8 6.59l-2.29-2.3a1.003 1.003 0 0 0-1.42 1.42L6.59 8 4.3 10.29c-.19.18-.3.43-.3.71a1.003 1.003 0 0 0 1.71.71L8 9.41l2.29 2.29c.18.19.43.3.71.3a1.003 1.003 0 0 0 .71-1.71L9.41 8z\" />\n </svg>\n ) : null}\n </span>\n );\n};\n","import React, { useMemo } from 'react';\nimport Dropdown, { DropdownProps } from '@uiw/react-dropdown';\nimport Icon from '@uiw/react-icon';\nimport Menu from '@uiw/react-menu';\nimport Input from '@uiw/react-input';\nimport Tag, { TagProps } from '@uiw/react-tag';\nimport { IProps } from '@uiw/utils';\nimport { useState } from 'react';\nimport { useRef } from 'react';\nimport { useEffect } from 'react';\nimport './style/index.less';\n\ntype ValueType = string | number;\nexport interface SearchSelectProps extends IProps, DropdownProps {\n mode?: 'single' | 'multiple';\n size?: 'large' | 'default' | 'small';\n maxTagCount?: number;\n labelInValue?: boolean;\n loading?: boolean;\n showSearch?: boolean;\n allowClear?: boolean;\n defaultValue?: ValueType | Array<ValueType>;\n tagProps?: TagProps;\n value?: ValueType | Array<ValueType>;\n option: SearchSelectOptionData[];\n onSelect?: (value: ValueType | Array<ValueType> | Array<SearchSelectOptionData>) => void;\n onSearch?: (value: string) => void;\n onChange?: (value: ValueType | Array<ValueType> | Array<SearchSelectOptionData>) => void;\n}\n\nexport interface SearchSelectOptionData {\n label: string;\n value: string | number;\n [keyName: string]: any;\n}\n\nexport default function SearchSelect(props: SearchSelectProps) {\n const {\n allowClear = false,\n disabled = false,\n size = 'default',\n maxTagCount,\n option = [],\n loading = false,\n labelInValue = false,\n prefixCls = 'w-search-select',\n className,\n mode = 'single',\n style,\n isOpen,\n value,\n defaultValue,\n showSearch,\n tagProps = {},\n placeholder,\n onSearch,\n onChange,\n onSelect,\n ...others\n } = props;\n\n const cls = [prefixCls, className].filter(Boolean).join(' ').trim();\n const isMultiple = useMemo(() => mode === 'multiple', [mode]);\n const [innerIsOpen, setInnerIsOpen] = useState(false);\n const [selectedValue, setSelectedValue] = useState<Array<SearchSelectOptionData>>([]);\n const [selectedLabel, setSelectedLabel] = useState('');\n const [selectIconType, setSelectIconType] = useState('');\n const omitTagCount = useMemo(\n () => (maxTagCount && selectedValue.length > maxTagCount ? selectedValue.length - maxTagCount : 0),\n [selectedValue.length],\n );\n const divRef = useRef<HTMLDivElement>(null);\n\n const valueRef = useRef<Array<SearchSelectOptionData>>();\n valueRef.current = useMemo(() => selectedValue, [selectedValue]);\n\n useEffect(() => {\n if (value === undefined && defaultValue !== undefined) {\n selectedValueChange(defaultValue);\n }\n }, []);\n\n useEffect(() => {\n if (value !== undefined) {\n selectedValueChange(value!);\n }\n }, [JSON.stringify(value)]);\n\n const getSelectOption = (option: Array<SearchSelectOptionData>, value: ValueType) => {\n const findResult = option.find((item) => item.value === value);\n return findResult;\n };\n\n function selectedValueChange(\n changeValue: ValueType | Array<ValueType> | SearchSelectOptionData | Array<SearchSelectOptionData>,\n ) {\n let opts: Array<SearchSelectOptionData> = [];\n\n if (labelInValue) {\n if (Array.isArray(changeValue)) {\n opts = changeValue as Array<SearchSelectOptionData>;\n } else {\n opts.push(changeValue as SearchSelectOptionData);\n }\n } else {\n if (Array.isArray(changeValue)) {\n opts = changeValue.map((v) => getSelectOption(option, v as ValueType)!).filter((m) => !!m);\n } else {\n const findResult = getSelectOption(option, changeValue as ValueType);\n if (findResult) {\n setSelectedLabel(findResult.label);\n opts.push(findResult);\n }\n }\n }\n setSelectedValue(opts);\n }\n\n function removeSelectItem(index: number) {\n const selectedValue = valueRef.current as SearchSelectOptionData[];\n selectedValue.splice(index, 1);\n const values = [...selectedValue];\n return values;\n }\n\n function handleItemClick(item: SearchSelectOptionData) {\n setInnerIsOpen(false);\n const values = [item];\n setSelectedLabel(item.label);\n const resultValue = item.value;\n handleChange(resultValue, values);\n }\n\n function handleItemsClick(index: number, item?: SearchSelectOptionData) {\n let values: SearchSelectOptionData[] = index !== -1 ? removeSelectItem(index) : [...selectedValue, item!];\n const resultValue = values.map((item) => item.value);\n handleChange(resultValue, values);\n }\n\n function handleChange(resultValue: ValueType | Array<ValueType>, values: SearchSelectOptionData[]) {\n onSelect && onSelect(resultValue);\n handleSelectChange(resultValue, values); // 支持form组件\n\n value === undefined && setSelectedValue(values); // 如果受控于父组件则不需要内部维护状态\n }\n\n // 渲染icon\n function renderSelectIcon(type: string) {\n let selectIconType;\n if (type === 'enter' && allowClear && selectedValue) {\n console.log(123);\n selectIconType = 'close';\n } else {\n selectIconType = '';\n }\n setSelectIconType(selectIconType);\n }\n // handle change\n function handleInputChange(e: React.ChangeEvent<HTMLInputElement>) {\n const value = e.target.value;\n setInnerIsOpen(!!value);\n setSelectedLabel(value);\n setSelectIconType(showSearch && value ? 'loading' : '');\n showSearch && onSearch && onSearch(value);\n // handleSelectChange(value);\n }\n // 清除选中的值\n function resetSelectedValue() {\n setInnerIsOpen(false);\n setSelectedValue([]);\n setSelectedLabel('');\n setSelectIconType('');\n handleSelectChange('', []);\n }\n function handleSelectChange(value: ValueType | Array<ValueType>, options: Array<SearchSelectOptionData>) {\n if (!onChange) return;\n\n onChange(labelInValue ? options : value);\n }\n\n function inputKeyDown(e: any) {\n if (isMultiple && selectedValue.length > 0 && !selectedLabel && e.keyCode === 8) {\n handleItemsClick(selectedValue.length - 1);\n }\n }\n\n return (\n <Dropdown\n className={cls}\n trigger=\"focus\"\n style={{ marginTop: 5 }}\n disabled={option && option.length > 0 ? false : true}\n {...others}\n onVisibleChange={(open) => {\n if (!open && isMultiple) setSelectedLabel('');\n setInnerIsOpen(open);\n }}\n isOpen={innerIsOpen}\n menu={\n <Menu\n bordered\n style={{\n minHeight: 25,\n maxHeight: 280,\n minWidth: 200,\n overflowY: 'scroll',\n width: divRef.current ? divRef.current.offsetWidth : 'auto',\n }}\n >\n {!option || option.length === 0 ? (\n <div style={{ color: '#c7c7c7', fontSize: 12 }}>{loading ? '正在加载数据...' : '没有数据'}</div>\n ) : (\n option.map((item) => {\n const index = selectedValue.findIndex((finds) => finds.value === item.value);\n return (\n <Menu.Item\n active={index !== -1}\n key={index}\n text={item.label}\n onClick={() => (isMultiple ? handleItemsClick(index, item) : handleItemClick(item))}\n />\n );\n })\n )}\n </Menu>\n }\n >\n <div\n ref={divRef}\n onMouseOver={() => renderSelectIcon('enter')}\n onMouseLeave={() => renderSelectIcon('leave')}\n style={{ width: '100%', maxWidth: 'none', ...style }}\n >\n {isMultiple ? (\n <div className={`${prefixCls}-inner`}>\n <div style={{ display: 'flex', flexFlow: 'wrap' }}>\n {isMultiple &&\n selectedValue.slice(0, maxTagCount).map((item, index) => {\n return (\n <Tag\n style={{ height: 20, margin: 1, display: 'flex', alignItems: 'center', ...tagProps.style }}\n className={`${prefixCls}-tag`}\n key={index}\n color=\"#393E48\"\n {...tagProps}\n closable\n onClose={() => handleItemsClick(index, item)}\n >\n {item.label}\n </Tag>\n );\n })}\n {!!omitTagCount && (\n <Tag style={{ height: 20, margin: 1, display: 'flex', alignItems: 'center' }} disabled={true}>\n +{omitTagCount} …{' '}\n </Tag>\n )}\n <Input\n style={{ flex: 1 }}\n className={`${prefixCls}-input-contents`}\n readOnly={!showSearch}\n size={size}\n disabled={disabled}\n onKeyDown={inputKeyDown}\n onChange={handleInputChange}\n value={selectedLabel}\n placeholder={selectedValue.length ? '' : placeholder}\n />\n </div>\n {(selectIconType === 'close' || (selectIconType === 'loading' && loading)) && (\n <Icon type={selectIconType} spin={loading && selectIconType === 'loading'} onClick={resetSelectedValue} />\n )}\n </div>\n ) : (\n <Input\n readOnly={!showSearch}\n size={size}\n disabled={disabled}\n onChange={handleInputChange}\n value={selectedLabel}\n placeholder={placeholder}\n addonAfter={\n (selectIconType === 'close' || (selectIconType === 'loading' && loading)) && (\n <Icon\n type={selectIconType}\n spin={loading && selectIconType === 'loading'}\n onClick={resetSelectedValue}\n />\n )\n }\n />\n )}\n </div>\n </Dropdown>\n );\n}\n","import React, { useEffect, useRef, useState } from 'react';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\nimport Step, { StepProps } from './Step';\n\nexport interface StepsProps<T> extends IProps, HTMLDivProps {\n status?: StepProps['status'];\n progressDot?: StepProps['progressDot'];\n direction?: 'horizontal' | 'vertical';\n /**\n * 指定当前步骤,从 `0` 开始记数。\n */\n current?: number;\n}\n\nfunction InternalSteps<T>(props: StepsProps<T>) {\n const {\n prefixCls = 'w-steps',\n style = {},\n className,\n children,\n current,\n status = 'process',\n progressDot = false,\n direction = 'horizontal',\n ...resetProps\n } = props;\n\n const warpRef = useRef<HTMLDivElement>(null);\n const [lastStepOffsetWidth, setLastStepOffsetWidth] = useState(0);\n const filteredChildren = React.Children.toArray(children).filter((c) => !!c);\n const lastIndex = filteredChildren.length - 1; // 最后一个节点的索引数字\n const classString = [prefixCls, `${prefixCls}-${direction}`, !!progressDot ? `${prefixCls}-dot` : null]\n .filter(Boolean)\n .join(' ')\n .trim();\n\n useEffect(() => calcStepOffsetWidth());\n\n // 计算每一步的宽度\n function calcStepOffsetWidth() {\n const domNode = warpRef.current;\n if (domNode && domNode.lastChild) {\n const width = ((domNode.lastChild as HTMLElement).offsetWidth || 0) + 1;\n if (width === lastStepOffsetWidth || Math.abs(width - lastStepOffsetWidth) <= 3) {\n return;\n }\n setLastStepOffsetWidth(width);\n }\n }\n\n return (\n <div className={classString} style={style} {...resetProps} ref={warpRef}>\n {React.Children.map(children, (child: any, index) => {\n const childProps = {\n stepNumber: `${index + 1}`,\n prefixCls,\n progressDot,\n ...child.props,\n };\n if (index !== lastIndex && direction !== 'vertical') {\n childProps.itemWidth = `${100 / lastIndex}%`;\n childProps.adjustMarginRight = -Math.round(lastStepOffsetWidth / lastIndex + 1);\n }\n\n if (progressDot && direction !== 'vertical') {\n childProps.itemWidth = `${100 / filteredChildren.length}%`;\n childProps.adjustMarginRight = 0;\n }\n // 错误前面\n if (status === 'error' && index === (current as number) - 1) {\n childProps.className = `${prefixCls}-next-error`;\n }\n if (!child.props.status) {\n if (index === current!) {\n childProps.status = status;\n } else if (index < (current as number)) {\n childProps.status = 'finish';\n } else {\n childProps.status = 'wait';\n }\n }\n return React.cloneElement(child, childProps);\n })}\n </div>\n );\n}\n\ntype Steps = typeof InternalSteps & {\n Step: typeof Step;\n};\n\n(InternalSteps as Steps).Step = Step;\n\nexport default InternalSteps as Steps;\n","import React, { CSSProperties } from 'react';\nimport Icon, { IconProps, IconsName } from '@uiw/react-icon';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface StepProps extends IProps, Omit<HTMLDivProps, 'title'> {\n title?: React.ReactNode;\n description?: React.ReactNode;\n status?: 'wait' | 'process' | 'finish' | 'error' | 'success';\n progressDot?: boolean;\n itemWidth?: number;\n stepNumber?: string;\n adjustMarginRight?: number;\n icon?: IconProps['type'];\n}\n\nexport default function Step(props: StepProps) {\n const {\n prefixCls = 'w-steps',\n className,\n style,\n status,\n itemWidth,\n icon,\n adjustMarginRight,\n stepNumber,\n title,\n description,\n progressDot,\n ...restProps\n } = props;\n const classString = [\n `${prefixCls}-item`,\n `${prefixCls}-item-${status}`,\n className,\n icon ? `${prefixCls}-custom` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim();\n const stepItemStyle: CSSProperties = { ...style };\n const stepItemDotStyle: CSSProperties = {};\n if (itemWidth) {\n stepItemStyle.width = itemWidth;\n }\n if (adjustMarginRight) {\n stepItemStyle.marginRight = adjustMarginRight;\n if (progressDot) {\n stepItemDotStyle.paddingRight = Math.abs(adjustMarginRight);\n }\n }\n let iconNode = null;\n if (progressDot) {\n iconNode = <span className={`${prefixCls}-dot`} />;\n } else if (icon && typeof icon !== 'string') {\n iconNode = <span className={`${prefixCls}-icon`}>{icon}</span>;\n } else if ((icon && typeof icon === 'string') || status === 'finish' || status === 'error') {\n iconNode = (\n <Icon\n type={\n [\n icon && typeof icon === 'string' ? `${icon}` : null,\n !icon && status === 'finish' ? 'check' : null,\n !icon && status === 'error' ? 'close' : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim() as IconsName | null\n }\n />\n );\n } else {\n iconNode = <span className={`${prefixCls}-icon`}>{stepNumber}</span>;\n }\n return (\n <div {...restProps} className={classString} style={stepItemStyle}>\n <div className={`${prefixCls}-item-tail`} style={stepItemDotStyle}>\n <i style={{ paddingRight: '100%' }} />\n </div>\n <div className={`${prefixCls}-item-head`}>\n <div className={[`${prefixCls}-item-inner`, !!icon && 'is-icon'].filter(Boolean).join(' ').trim()}>\n {iconNode}\n </div>\n </div>\n <div className={`${prefixCls}-item-main`}>\n <div className={`${prefixCls}-item-title`}>{title}</div>\n {description && <div className={`${prefixCls}-item-description`}>{description}</div>}\n </div>\n </div>\n );\n}\n","import Steps from './Steps';\n\nexport * from './Steps';\nexport * from './Step';\n\nexport default Steps;\n","import React from 'react';\nimport { HTMLDivProps } from '@uiw/utils';\nimport { SliderProps, SliderMarks } from './index';\n\ninterface TooltipProps extends HTMLDivProps {\n prefixCls: string;\n data: number[];\n step: number;\n min: number;\n vertical: boolean;\n marks: SliderProps['marks'];\n markRender: (stepValue: number, mark?: SliderMarks) => React.ReactNode;\n}\n\nexport default function Dots(props: TooltipProps) {\n const { prefixCls, data, step, min, vertical, marks, markRender } = props;\n return (\n <div className={`${prefixCls}-dots`}>\n {data.map((val, idx) => {\n const stepValue = idx * step + min;\n return (\n <div\n key={idx}\n style={{\n [vertical ? 'top' : 'left']: `${val}%`,\n }}\n className={[`${prefixCls}-mark`, marks && marks !== true && !marks[stepValue] ? 'no-marks' : null]\n .filter(Boolean)\n .join(' ')\n .trim()}\n >\n {marks === true && markRender && markRender(stepValue)}\n {marks !== true && marks && marks[stepValue] && markRender && markRender(stepValue, marks[stepValue])}\n </div>\n );\n })}\n </div>\n );\n}\n","import React, { useEffect, useState } from 'react';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\nimport Dots from './Dots';\nimport './style/index.less';\n\nexport type SliderMarks = {\n style?: React.CSSProperties;\n label?: React.ReactNode;\n};\n\nexport interface SliderProps extends IProps, Omit<HTMLDivProps, 'onChange'> {\n value?: number | number[];\n min?: number;\n max?: number;\n marks?: boolean | Record<number, SliderMarks>;\n dots?: boolean;\n range?: boolean;\n vertical?: boolean;\n step?: number;\n disabled?: boolean;\n tooltip?: boolean;\n progress?: boolean | string;\n renderMarks?: (value: number) => JSX.Element;\n onChange?: (value: number | number[]) => void;\n onClick?: (e: React.MouseEvent<HTMLElement>) => void;\n}\n\nexport default function Slider(props: SliderProps) {\n const {\n prefixCls = 'w-slider',\n value = 0,\n min = 0,\n max = 100,\n dots = false,\n step = 1,\n disabled = false,\n progress = true,\n tooltip = false,\n className,\n marks,\n renderMarks,\n vertical,\n onChange,\n ...other\n } = props;\n\n const bar = React.useRef<HTMLDivElement>(null);\n const slider = React.useRef<HTMLDivElement>(null);\n const indexBar = React.useRef<number>();\n const startX = React.useRef<number>();\n const curValue = React.useRef<number | number[]>();\n const barWidth = React.useRef<number>();\n const barOffsetLeft = React.useRef<number>();\n const move = React.useRef<boolean>();\n const [arrValue, setArrValue] = useState(Array.isArray(value) ? value : [value]);\n\n useEffect(() => setArrValue(Array.isArray(value) ? value : [value]), [value]);\n\n other.onClick = (evn: React.MouseEvent<HTMLElement>) => {\n if (move.current !== undefined) {\n return;\n }\n const markOffset = slider.current!.getBoundingClientRect();\n const vals = getWidthToValue(evn[vertical ? 'clientY' : 'clientX'] - markOffset[vertical ? 'y' : 'x']);\n const curr = getRangeValue(vals);\n handleChange(curr);\n };\n\n function getRangeValue(val: number | number[]) {\n if (!Array.isArray(value)) {\n return Array.isArray(val) ? val : [val];\n }\n const newData = [...arrValue];\n const val1 = newData[0];\n const val2 = newData[1];\n if ((val1 < val2 && val1 > val) || (val1 > val2 && val1 < val)) {\n newData[0] = val as number;\n }\n if ((val1 < val2 && val2 < val) || (val1 > val2 && val2 > val)) {\n newData[1] = val as number;\n }\n\n if (val1 > val && val2 < val) {\n const half = val2 + (val1 - val2) / 2;\n if (half >= val) {\n newData[1] = val as number;\n }\n if (half < val) {\n newData[0] = val as number;\n }\n }\n if (val2 > val && val1 < val) {\n const half = val1 + (val2 - val1) / 2;\n if (half >= val) {\n newData[0] = val as number;\n }\n if (half < val) {\n newData[1] = val as number;\n }\n }\n return newData;\n }\n\n function handleChange(val: number[]) {\n setArrValue([...val]);\n onChange && onChange(arrValue.length === 1 ? val[0] : val);\n }\n\n function getWidthToValue(width: number) {\n const equal = (max - min) / step;\n let percent = 0;\n if (slider.current) {\n percent = (width / slider.current[vertical ? 'clientHeight' : 'clientWidth']) * 100;\n }\n\n if (percent <= 0) {\n percent = 0;\n }\n if (percent >= 100) {\n percent = 100;\n }\n\n const num = equal * (percent / 100) + 0.5;\n const numFloor = Math.floor(num);\n const vals = numFloor * step + min;\n return vals;\n }\n\n function onHandleBtnDown(idx: number, env: React.MouseEvent<HTMLElement>) {\n if (disabled) {\n return;\n }\n indexBar.current = idx;\n move.current = true;\n startX.current = env[vertical ? 'clientY' : 'clientX'];\n if (bar.current) {\n barWidth.current = bar.current[vertical ? 'clientHeight' : 'clientWidth'];\n barOffsetLeft.current = bar.current[vertical ? 'offsetTop' : 'offsetLeft'];\n }\n const vals = [...arrValue];\n if (Array.isArray(value)) {\n barWidth.current =\n (indexBar.current === 1 && vals[1] > vals[0]) || (indexBar.current !== 1 && vals[0] > vals[1])\n ? barWidth.current! + barOffsetLeft.current!\n : barOffsetLeft.current;\n }\n window.addEventListener('mousemove', onDragging);\n window.addEventListener('mouseup', onDragEnd);\n }\n function onDragging(env: MouseEvent | React.MouseEvent<HTMLButtonElement, MouseEvent>) {\n if (!move.current) {\n return;\n }\n const vals = [...arrValue];\n const valueToWidth = getWidthToValue(env[vertical ? 'clientY' : 'clientX'] - startX.current! + barWidth.current!);\n if (valueToWidth !== curValue.current) {\n vals[indexBar.current!] = valueToWidth;\n const barStyl = getStyle(vals);\n if (bar.current) {\n bar.current.style[vertical ? 'top' : 'left'] = barStyl.left;\n bar.current.style[vertical ? 'bottom' : 'right'] = barStyl.right;\n }\n handleChange(vals);\n curValue.current = valueToWidth;\n }\n }\n function onDragEnd() {\n move.current = undefined;\n window.removeEventListener('mousemove', onDragging, false);\n window.removeEventListener('mouseup', onDragEnd, false);\n }\n\n const stepArray = () => {\n const equal = (max - min) / step;\n const stepWidth = (100 * step) / (max - min);\n const result = [0];\n for (let i = 1; i < equal; i += 1) {\n result.push(i * stepWidth);\n }\n result.push(100);\n return result;\n };\n function getValueToPercent(vals: number) {\n return ((vals - min) * 100) / (max - min);\n }\n\n function getStyle(val?: number[]) {\n val = val || arrValue;\n const barStyl = { left: '0%', right: '100%' };\n if (!Array.isArray(value)) {\n barStyl.right = `${100 - getValueToPercent(val[0])}%`;\n } else {\n const leftValue = val[0] > val[1] ? val[1] : val[0];\n const rightValue = val[0] > val[1] ? val[0] : val[1];\n barStyl.left = `${getValueToPercent(leftValue)}%`;\n barStyl.right = `${100 - getValueToPercent(rightValue)}%`;\n }\n return barStyl;\n }\n\n function getLabelValue(val: number) {\n if (marks && marks !== true && marks[val] && marks[val].label) {\n return marks[val].label;\n } else if (marks && marks !== true && marks[val] && typeof marks[val] === 'string') {\n return marks[val];\n } else if (renderMarks && typeof renderMarks === 'function' && renderMarks(val)) {\n return renderMarks(val);\n }\n return val;\n }\n\n const barStyl = getStyle();\n if (disabled) {\n delete other.onClick;\n }\n return (\n <div\n ref={slider}\n className={[\n prefixCls,\n className,\n disabled ? 'disabled' : null,\n marks ? `${prefixCls}-with-marks` : null,\n vertical ? `${prefixCls}-vertical` : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim()}\n {...other}\n >\n <div\n ref={bar}\n className={`${prefixCls}-bar`}\n style={{\n [vertical ? 'top' : 'left']: barStyl.left,\n [vertical ? 'bottom' : 'right']: barStyl.right,\n ...(progress !== true ? { backgroundColor: progress || 'initial' } : {}),\n }}\n />\n {[...arrValue].map((item, idx) => {\n const lleftPostion = getValueToPercent(item);\n return (\n <div\n key={idx}\n className={`${prefixCls}-handle`}\n onMouseDown={(evn) => onHandleBtnDown(idx, evn)}\n style={{ [vertical ? 'top' : 'left']: `${lleftPostion}%` }}\n >\n {(tooltip || tooltip === false) && (\n <div className={[`${prefixCls}-tooltip`, tooltip ? 'open' : null].filter(Boolean).join(' ').trim()}>\n {getLabelValue(item)}\n </div>\n )}\n </div>\n );\n })}\n {dots && (\n <Dots\n prefixCls={prefixCls}\n min={min}\n step={step}\n marks={marks}\n vertical={!!vertical}\n data={stepArray()}\n markRender={(stepValue, mark = {}) => {\n if (!mark) {\n return <div> {getLabelValue(stepValue)} </div>;\n }\n const other = typeof mark === 'object' ? mark : {};\n delete other.label;\n return <div {...other}> {getLabelValue(stepValue)} </div>;\n }}\n />\n )}\n </div>\n );\n}\n","import React from 'react';\nimport { RadioAbstract, RadioAbstractProps } from '@uiw/react-radio';\nimport './style/index.less';\n\nexport interface SwitchProps extends RadioAbstractProps {}\n\nexport default React.forwardRef<HTMLInputElement, SwitchProps>((props, ref) => {\n const { prefixCls = 'w-switch', ...other } = props;\n return <RadioAbstract prefixCls={prefixCls} {...{ ...other, type: 'checkbox' }} ref={ref} />;\n});\n","import React from 'react';\nimport { IProps, noop } from '@uiw/utils';\nimport { TableProps, TableColumns } from './';\nimport './style/index.less';\n\nexport interface TheadProps extends IProps {\n data?: TableProps['data'][];\n onCellHead?: TableProps['onCellHead'];\n}\n\nexport default (props: TheadProps & React.HTMLAttributes<HTMLTableSectionElement> = {}) => {\n const { prefixCls = 'w-table', className, data = [], onCellHead = noop, ...other } = props;\n return (\n <thead className={[prefixCls, className].filter(Boolean).join(' ').trim()} {...other}>\n {data &&\n data.length > 0 &&\n data.map((tds?: TableColumns[], rowNum?: number) => (\n <tr key={rowNum}>\n {(tds || []).map((item, colNum) => {\n const { title, key, render, children, ellipsis, ...thProps } = item;\n const titleNode: TableColumns['title'] =\n typeof title === 'function' ? title(item, colNum, rowNum!) : title;\n if (thProps.colSpan === 0) {\n return null;\n }\n if (ellipsis) {\n thProps.className = `${thProps.className || ''} ${prefixCls}-ellipsis`;\n }\n return (\n <th key={colNum} onClick={(evn) => onCellHead(item, colNum, rowNum!, evn)} {...thProps}>\n {titleNode}\n </th>\n );\n })}\n </tr>\n ))}\n </thead>\n );\n};\n","import { TableColumns } from './';\n\n/**\n * Get colspan number\n * @param {Array} date\n */\nfunction getColspanNum(data: TableColumns[] = [], num = 1) {\n let childs: TableColumns[] = [];\n for (let i = 0; i < data.length; i += 1) {\n if (data[i].children) {\n childs = childs.concat(data[i].children || []);\n }\n }\n if (childs && childs.length > 0) {\n num = getColspanNum(childs, num + 1);\n }\n return num;\n}\n\n/**\n * Get rowspan number\n * @param {Array} date\n */\nfunction getRowspanNum(data: TableColumns[] = [], child = []) {\n let childs: TableColumns[] = [];\n for (let i = 0; i < data.length; i += 1) {\n if (!data[i].children) {\n childs.push(data[i]);\n } else if (data[i].children && data[i].children!.length > 0) {\n childs = childs.concat(getRowspanNum(data[i].children, child));\n }\n }\n return childs;\n}\n\nexport interface ILevelItems {\n header: TableColumns[][];\n ellipsis?: Record<string, boolean>;\n render: {\n [key: string]: any;\n };\n}\n\n/**\n * JSON Array => Array\n * @param {Array} date\n */\nexport const getLevelItems = (data: TableColumns[], result?: ILevelItems): ILevelItems => {\n if (!result) {\n result = { header: [], render: {} };\n }\n if (result && !result.header) {\n result.header = [];\n }\n if (result && !result.render) {\n result.render = {};\n }\n let child: TableColumns[] = [];\n const levelTop: TableColumns[] = [];\n for (let i = 0; i < data.length; i += 1) {\n if (data[i].render && data[i].key) {\n result.render[data[i].key as string] = data[i].render;\n }\n if (data[i].ellipsis && data[i].key) {\n if (!result.ellipsis) result.ellipsis = {};\n result.ellipsis[data[i].key!] = true;\n }\n if (result.header.length === 0) {\n // Calculation rowspan\n if (data[i].children && data[i].children && data[i].children!.length > 0) {\n data[i].colSpan = getRowspanNum(data[i].children as TableColumns[]).length;\n }\n levelTop.push(data[i]);\n }\n if (data[i] && data[i].children) {\n child = child.concat(\n data[i].children!.map((item: TableColumns) => {\n // Calculation rowspan\n if (item.children && item.children.length > 0) {\n item.colSpan = getRowspanNum(item.children).length;\n }\n return item;\n }),\n );\n }\n }\n // level 1\n if (result.header.length === 0) {\n const num = getColspanNum(levelTop);\n result.header.push(\n levelTop.map((item) => {\n if (num === 1) return item;\n if (!item.children || (item.children && item.children.length === 0)) {\n item.rowSpan = num;\n }\n return item;\n }),\n );\n }\n if (child && child.length > 0) {\n const num = getColspanNum(child);\n result.header.push(\n child.map((item: TableColumns) => {\n if (num === 1) return item;\n if (!item.children || (item.children && item.children.length === 0)) {\n item.rowSpan = num;\n }\n return item;\n }),\n );\n result = getLevelItems(child, result);\n }\n return result;\n};\n\n/**\n * Get all columns keys\n * @param {Array} data\n */\nexport const getAllColumnsKeys = (data: TableColumns[], keys: any[] = []): string[] => {\n for (let i = 0; i < data.length; i += 1) {\n if (data[i].children) {\n keys = keys.concat(getAllColumnsKeys(data[i].children || []));\n } else if (data[i].key) {\n keys.push(data[i].key);\n }\n }\n return keys;\n};\n","import React from 'react';\nimport { IProps, HTMLDivProps, noop } from '@uiw/utils';\nimport Thead from './Thead';\nimport { getLevelItems, getAllColumnsKeys } from './util';\nimport './style/index.less';\n\nexport type TableColumns = {\n title?: string | ((data: TableColumns, rowNum: number, colNum: number) => JSX.Element) | JSX.Element;\n key?: string;\n width?: number;\n colSpan?: number;\n children?: TableColumns[];\n ellipsis?: boolean;\n render?: (\n text: string,\n keyName: string,\n rowData: { [key: string]: any },\n rowNumber: number,\n columnNumber: number,\n ) => void;\n style?: React.CSSProperties;\n [key: string]: any;\n};\n\nexport interface TableProps extends IProps, Omit<HTMLDivProps, 'title'> {\n prefixCls?: string;\n columns?: TableColumns[];\n data?: Record<string, string | number | JSX.Element | boolean>[];\n title?: React.ReactNode;\n footer?: React.ReactNode;\n bordered?: boolean;\n empty?: React.ReactNode;\n onCell?: (\n data: { [key: string]: any },\n options: ICellOptions,\n evn: React.MouseEvent<HTMLTableCellElement>,\n ) => void | React.ReactNode;\n onCellHead?: (\n data: TableColumns,\n rowNum: number,\n colNum: number,\n evn: React.MouseEvent<HTMLTableCellElement>,\n ) => void;\n}\n\nexport interface ICellOptions {\n rowNum: number;\n colNum: number;\n keyName: string;\n}\n\nexport default (props: TableProps = {}) => {\n const {\n prefixCls = 'w-table',\n className,\n columns = [],\n data = [],\n title,\n footer,\n bordered,\n onCell = noop,\n onCellHead = noop,\n empty,\n children,\n ...other\n } = props;\n\n const cls = [prefixCls, className, bordered ? `${prefixCls}-bordered` : null].filter(Boolean).join(' ').trim();\n const { header, render, ellipsis } = getLevelItems(columns);\n const keys = getAllColumnsKeys(columns);\n return (\n <div className={cls} {...other}>\n <table style={ellipsis ? { tableLayout: 'fixed' } : {}}>\n {title && <caption>{title}</caption>}\n {columns && columns.length > 0 && <Thead onCellHead={onCellHead} data={header} />}\n {data && data.length > 0 && (\n <tbody>\n {data.map((trData, rowNum) => (\n <tr key={rowNum}>\n {keys.map((keyName, colNum) => {\n let objs: React.TdHTMLAttributes<HTMLTableDataCellElement> = {\n children: trData[keyName],\n };\n if (render[keyName]) {\n const child = render[keyName](trData[keyName], keyName, trData, rowNum, colNum);\n if (React.isValidElement(child)) {\n objs.children = child;\n } else {\n if (child.props) {\n objs = { ...child.props, children: objs.children };\n if (child.props.rowSpan === 0 || child.props.colSpan === 0) return null;\n }\n if (child.children) {\n objs.children = child.children;\n }\n }\n }\n if (ellipsis && ellipsis[keyName]) {\n objs.className = `${prefixCls}-ellipsis`;\n }\n return (\n <td {...objs} key={colNum} onClick={(evn) => onCell(trData, { rowNum, colNum, keyName }, evn)} />\n );\n })}\n </tr>\n ))}\n </tbody>\n )}\n {data && data.length === 0 && empty && (\n <tbody>\n <tr>\n <td colSpan={columns.length} style={{ position: 'relative', left: 0 }}>\n {empty}\n </td>\n </tr>\n </tbody>\n )}\n {props.children}\n </table>\n {footer && <div className={`${prefixCls}-footer`}>{footer}</div>}\n </div>\n );\n};\n","import React, { useEffect, useState, useRef } from 'react';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\nimport Pane from './Pane';\nimport './style/index.less';\n\nexport * from './Pane';\n\nTabs.Pane = Pane;\n\nexport interface TabsProps extends IProps, HTMLDivProps {\n prefixCls?: string;\n activeKey?: string;\n type?: 'default' | 'line' | 'card';\n children?: React.ReactNode;\n onTabClick?: (key: string, item: React.ReactElement, e: React.MouseEvent) => void;\n}\n\nexport default function Tabs(props: TabsProps) {\n const {\n prefixCls = 'w-tabs',\n className,\n children,\n type = 'default',\n activeKey: _,\n onTabClick,\n ...elementProps\n } = props;\n const [activeKey, setActiveKey] = useState(props.activeKey);\n const [slideStyle, setSlideStyle] = useState({ width: 0, left: 0 });\n const activeItem = useRef<HTMLDivElement | undefined>();\n const cls = [prefixCls, className, type ? `${prefixCls}-${type}` : null].filter(Boolean).join(' ').trim();\n\n useEffect(() => setActiveKey(props.activeKey), [props.activeKey]);\n useEffect(() => calcSlideStyle(), [activeKey]);\n\n function calcSlideStyle() {\n if (activeItem.current && type === 'line') {\n setSlideStyle({\n width: activeItem.current.clientWidth,\n left: activeItem.current.offsetLeft,\n });\n }\n }\n\n return (\n <div className={cls} {...elementProps}>\n <div className={`${prefixCls}-bar`}>\n <div className={`${prefixCls}-nav`}>\n {React.Children.map(children as React.ReactElement[], (item: React.ReactElement, key: number) => {\n if (!item) {\n return null;\n }\n const divProps: HTMLDivProps = {\n className: [\n `${prefixCls}-item`,\n item.key === activeKey ? 'active' : null,\n item.props.disabled ? 'disabled' : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim(),\n children: item.props.label,\n };\n if (!item.props.disabled) {\n divProps.onClick = (e: React.MouseEvent) => {\n setActiveKey(item.key as string);\n onTabClick && onTabClick(item.key as string, item, e);\n calcSlideStyle();\n };\n }\n return (\n <div\n key={key}\n ref={(node) => {\n if (node && item.key === activeKey) {\n activeItem.current = node;\n }\n }}\n {...divProps}\n />\n );\n })}\n </div>\n <div style={slideStyle} className={`${prefixCls}-slide`} />\n </div>\n {React.Children.map(children, (item: any) => {\n if (!item || activeKey !== item.key) {\n return null;\n }\n return React.cloneElement(item, Object.assign({}, item.props, {}));\n })}\n </div>\n );\n}\n","import React from 'react';\nimport { IProps, HTMLDivProps } from '@uiw/utils';\n\nexport interface TabsPaneProps extends IProps, HTMLDivProps {\n label?: React.ReactNode;\n disabled?: boolean;\n}\n\nexport default (props: TabsPaneProps = {}) => {\n const { prefixCls = 'w-tabs-pane', className, label: _, ...resetProps } = props;\n return <div className={[prefixCls, className].filter(Boolean).join(' ').trim()} {...resetProps} />;\n};\n","import React from 'react';\nimport { IProps, HTMLTextProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface TextareaProps extends IProps, HTMLTextProps {}\n\nexport default React.forwardRef<HTMLTextAreaElement, TextareaProps>((props, ref) => {\n const { prefixCls = 'w-textarea', className, ...restProps } = props;\n return (\n <textarea className={[prefixCls, className].filter(Boolean).join(' ').trim()} {...restProps} ref={ref}>\n {props.children}\n </textarea>\n );\n});\n","import React from 'react';\nimport OverlayTrigger, { OverlayTriggerProps } from '@uiw/react-overlay-trigger';\nimport { IProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface TooltipProps extends IProps, OverlayTriggerProps {\n visibleArrow?: boolean;\n content?: React.ReactNode;\n}\n\nexport default (props: TooltipProps = {}) => {\n const {\n prefixCls = 'w-tooltip',\n className,\n placement = 'top',\n isOpen = false,\n trigger,\n delay,\n usePortal = true,\n visibleArrow = true,\n onVisibleChange,\n ...other\n } = props;\n const cls = [prefixCls, className, !visibleArrow ? 'no-arrow' : null].filter(Boolean).join(' ').trim();\n return (\n <OverlayTrigger\n usePortal={usePortal}\n isOpen={isOpen}\n trigger={trigger}\n delay={delay}\n onVisibleChange={onVisibleChange}\n placement={placement}\n {...other}\n overlay={\n <div className={cls}>\n {visibleArrow && <div className={`${prefixCls}-arrow`} />}\n <div className={`${prefixCls}-inner`}>{props.content}</div>\n </div>\n }\n >\n {typeof props.children === 'object' ? props.children : <span>{props.children}</span>}\n </OverlayTrigger>\n );\n};\n","import React, { useCallback, useMemo } from 'react';\nimport { CSSTransition } from 'react-transition-group';\nimport Icon, { IconProps } from '@uiw/react-icon';\nimport { IProps, noop } from '@uiw/utils';\nimport { TreeData, TreeProps, getChildKeys } from './';\n\ninterface TreeNodeIconProps {\n isOpen: boolean;\n noChild: boolean;\n openKeys: TreeNodeProps['openKeys'];\n selectedKeys: TreeNodeProps['selectedKeys'];\n}\n\ninterface TreeNodeProps<T = (data: TreeData, props: TreeNodeIconProps) => IconProps['type']> extends IProps {\n data: TreeData[];\n level: number;\n parent?: TreeData;\n icon?: T;\n iconAnimation?: boolean;\n isSelected?: boolean;\n renderTitle?: TreeProps['renderTitle'];\n\n openKeys?: TreeData['key'][];\n selectedKeys?: TreeData['key'][];\n\n onItemClick?: (item: TreeData, evn: React.MouseEvent<HTMLElement>) => void;\n onItemSelected?: (item: TreeData, evn: React.MouseEvent<HTMLElement>) => void;\n}\n\nconst Label = ({ label }: { label: React.ReactNode }) => useMemo(() => <span>{label}</span>, [label]);\n\nexport default function TreeNode<T>(props: TreeNodeProps<T>) {\n const {\n prefixCls,\n renderTitle,\n icon,\n iconAnimation,\n isSelected,\n openKeys,\n selectedKeys,\n\n data,\n level,\n parent,\n\n onItemClick = noop,\n onItemSelected = noop,\n ...other\n } = props;\n let isOpen = false;\n\n if (parent && parent.key) {\n isOpen = !!(openKeys && openKeys.indexOf(parent.key) > -1);\n }\n const onExit = useCallback((node: HTMLElement) => {\n node.style.height = `${node.scrollHeight}px`;\n }, []);\n const onExiting = useCallback((node: HTMLElement) => {\n node.style.height = '1px';\n }, []);\n const onEnter = useCallback((node: HTMLElement, isAppearing: boolean) => {\n node.style.height = '1px';\n }, []);\n const onEntering = useCallback((node: HTMLElement, isAppearing: boolean) => {\n node.style.height = `${node.scrollHeight}px`;\n }, []);\n const onEntered = useCallback((node: HTMLElement, isAppearing: boolean) => {\n node.style.height = 'initial';\n }, []);\n return (\n <CSSTransition\n classNames={prefixCls}\n in={isOpen}\n timeout={200}\n onExit={onExit}\n onExiting={onExiting}\n onEnter={onEnter}\n onEntered={onEntered}\n onEntering={onEntering}\n >\n <ul\n className={[\n level !== 1 && isOpen ? [`${prefixCls}-open`] : null,\n level !== 1 && !isOpen ? [`${prefixCls}-close`] : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim()}\n >\n {data.map((item, idx: number) => {\n item.parent = parent;\n const selected = !!(selectedKeys && selectedKeys.indexOf(item.key) > -1);\n const noChild = !item.children;\n const itemIsOpen = openKeys && openKeys.indexOf(item.key) > -1 && !!item.children;\n const iconItem =\n typeof icon === 'function'\n ? icon(item, {\n isOpen: !!itemIsOpen,\n noChild,\n openKeys,\n selectedKeys,\n })\n : icon;\n const childKeys = noChild ? [] : getChildKeys(item.children);\n const checkedKeys = selectedKeys ? selectedKeys.filter((key) => childKeys.indexOf(key) > -1) : [];\n const isHalfChecked = checkedKeys.length > 0 && childKeys.length !== checkedKeys.length;\n return (\n <li key={idx} style={{ display: item.hideNode ? 'none' : 'block' }}>\n <div className={`${prefixCls}-label`}>\n <span className={`${prefixCls}-switcher`} onClick={(evn) => onItemClick(item, evn)}>\n <Icon\n type={iconItem || 'caret-right'}\n className={[\n typeof icon === 'function' ? `${prefixCls}-switcher-noop` : null,\n noChild ? 'no-child' : null,\n !iconAnimation ? 'no-animation' : null,\n itemIsOpen ? 'open' : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim()}\n />\n </span>\n <div\n onClick={(evn) => onItemSelected(item, evn)}\n className={[\n `${prefixCls}-title`,\n selected && isSelected ? 'selected' : null,\n item.disabled ? 'disabled' : null,\n ]\n .filter(Boolean)\n .join(' ')\n .trim()}\n >\n {renderTitle ? (\n renderTitle(item, {\n selected,\n noChild,\n openKeys,\n isHalfChecked,\n selectedKeys,\n })\n ) : (\n <Label label={item.label} />\n )}\n </div>\n </div>\n {item.children && (\n <TreeNode\n {...other}\n {...{\n prefixCls,\n icon,\n iconAnimation,\n isSelected,\n openKeys,\n selectedKeys,\n onItemClick,\n onItemSelected,\n renderTitle,\n }}\n prefixCls={prefixCls}\n data={item.children}\n level={level + 1}\n parent={item}\n />\n )}\n </li>\n );\n })}\n </ul>\n </CSSTransition>\n );\n}\n","import React, { useEffect, useState } from 'react';\nimport { IconProps } from '@uiw/react-icon';\nimport { IProps, HTMLDivProps, noop } from '@uiw/utils';\nimport TreeNode from './TreeNode';\nimport './style/index.less';\n\nexport type TreeRenderTitleNode = {\n selected?: boolean;\n noChild?: boolean;\n isHalfChecked?: boolean;\n openKeys?: TreeProps['openKeys'];\n selectedKeys?: TreeProps['selectedKeys'];\n};\n\nexport interface TreeProps extends IProps, Omit<HTMLDivProps, 'onChange'> {\n icon?: IconProps['type'];\n data?: TreeData[];\n openKeys?: TreeData['key'][];\n selectedKeys?: TreeData['key'][];\n defaultExpandAll?: boolean;\n /**\n * 是否自动展开父节点\n */\n autoExpandParent?: boolean;\n /**\n * 是否展示连接线\n */\n showLine?: boolean;\n iconAnimation?: boolean;\n isSelected?: boolean;\n /**\n * 子节点受父节点控制设置 `true`,需要配合 `multiple` 参数使用。\n */\n checkStrictly?: boolean;\n /**\n * 支持点选多个节点\n */\n multiple?: boolean;\n renderTitle?: (item: TreeData, node: TreeRenderTitleNode) => React.ReactElement;\n onExpand?: (key: TreeData['key'], expanded: boolean, item: TreeData, evn: React.MouseEvent<HTMLElement>) => void;\n onSelected?: (\n keys: TreeData['key'][],\n key: TreeData['key'],\n selected: boolean,\n item: TreeData,\n evn: React.MouseEvent<HTMLElement>,\n ) => void;\n onChange?: (keys: (string | number | undefined)[]) => void;\n value?: TreeData['key'][];\n}\n\nexport interface TreeData {\n label?: React.ReactNode;\n children?: TreeData[];\n hideNode?: boolean;\n key?: string | number;\n [keyName: string]: any;\n}\n\n/**\n * a contains b\n * @param {Array} a\n * @param {Array} b\n */\nconst isContained = (a: any[], b: any[]) => {\n if (!(a instanceof Array) || !(b instanceof Array)) return false;\n if (a.length < b.length) return false;\n const aStr = a.toString();\n for (let i = 0, len = b.length; i < len; i += 1) {\n if (aStr.indexOf(b[i]) === -1) return false;\n }\n return true;\n};\n\nexport const getChildKeys = (\n childs: TreeData[] = [],\n result: TreeData['key'][] = [],\n depth?: number,\n): TreeData['key'][] => {\n childs.forEach((item) => {\n result.push(item.key as string | number);\n if (typeof depth === 'number' && !(depth - 1)) return;\n\n if (item.children && item.children.length > 0) {\n result = result.concat(getChildKeys(item.children, undefined, depth ? depth - 1 : undefined));\n }\n });\n return result;\n};\n\nconst getParentKeys = (childs: TreeData = {}, result: TreeData['key'][] = []) => {\n if (childs.key) {\n result.push(childs.key);\n }\n if (childs.parent) {\n result = getParentKeys(childs.parent, result);\n }\n return result;\n};\n\nconst getParentSelectKeys = (\n childs: TreeData = {},\n selectedKeys: TreeData['key'][] = [],\n result: TreeData['key'][] = [],\n) => {\n if (childs.key && childs.children && isContained(selectedKeys, getChildKeys(childs.children, undefined, 1))) {\n result.push(childs.key);\n if (childs.parent && !childs.parent.parent) {\n if (isContained(selectedKeys, getChildKeys(childs.children))) {\n selectedKeys = selectedKeys.concat(result);\n }\n if (isContained(selectedKeys, getChildKeys(childs.parent.children))) {\n result.push(childs.parent.key);\n }\n }\n }\n if (childs.parent) {\n result = getParentSelectKeys(childs.parent, selectedKeys, result);\n }\n return result;\n};\n\nexport default function Tree(props: TreeProps) {\n const {\n prefixCls = 'w-tree',\n icon = 'caret-right',\n data = [],\n openKeys = [],\n selectedKeys = [],\n defaultExpandAll = false,\n showLine = false,\n iconAnimation = true,\n isSelected = true,\n checkStrictly = false,\n multiple = false,\n onExpand = noop,\n onSelected = noop,\n\n className,\n autoExpandParent = true,\n renderTitle,\n onChange,\n ...elementProps\n } = props;\n\n const [curOpenKeys, setCurOpenKeys] = useState(openKeys);\n const [curSelectedKeys, setCurSelectedKeys] = useState(props.value || selectedKeys);\n\n useEffect(() => {\n setCurSelectedKeys(props.selectedKeys || []);\n }, [JSON.stringify(props.selectedKeys)]);\n useEffect(() => {\n setCurSelectedKeys(props.value || []);\n }, [JSON.stringify(props.value)]);\n // useEffect(() => setCurOpenKeys(openKeys), [openKeys]);\n // useEffect(() => setCurSelectedKeys(selectedKeys), [selectedKeys]);\n\n useEffect(() => {\n let arrOpenKeys: TreeData['key'][] = [...curOpenKeys];\n if (defaultExpandAll) {\n arrOpenKeys = getChildKeys(data);\n } else if (autoExpandParent) {\n arrOpenKeys.push(...getChildKeys(data || [], undefined, 1));\n }\n setCurOpenKeys(arrOpenKeys);\n }, []);\n\n const cls = [className, prefixCls, showLine ? `${prefixCls}-line` : null].filter(Boolean).join(' ').trim();\n\n function onItemClick(item: TreeData, evn: React.MouseEvent<HTMLElement>) {\n if (!item.children) {\n return;\n }\n // const { onExpand } = this.props;\n // const { openKeys } = this.state;\n let currentKeys = [...(curOpenKeys as TreeData['key'][])];\n const key = currentKeys.find((v) => v === item.key);\n const cls = evn.currentTarget.className.replace(/(\\s)open/g, '');\n let expanded = false;\n if (!key && item.key) {\n currentKeys.push(item.key);\n evn.currentTarget.className = [cls, 'open'].filter(Boolean).join(' ').trim();\n expanded = true;\n } else {\n currentKeys = currentKeys.filter((v) => v !== item.key);\n evn.currentTarget.className = cls;\n }\n setCurOpenKeys(currentKeys);\n onExpand && onExpand(item.key, expanded, item, evn);\n }\n function onItemSelected(item: TreeData, evn: React.MouseEvent<HTMLElement>) {\n // const { onSelected, multiple, checkStrictly } = this.props;\n let selKeys = [...(curSelectedKeys as TreeData['key'][])];\n const findKey = selKeys.find((v) => v === item.key);\n let selected = false;\n if (!findKey) {\n selected = true;\n selKeys.push(item.key);\n } else {\n selKeys = selKeys.filter((v) => v !== item.key);\n }\n if (checkStrictly) {\n if (!findKey) {\n selKeys = selKeys.concat(getChildKeys(item.children).filter((val) => selKeys.indexOf(val) === -1));\n selKeys = selKeys.concat(getParentSelectKeys(item, selKeys));\n selKeys = Array.from(new Set(selKeys)); // Remove duplicates.\n } else {\n selKeys = selKeys.filter((val) => getChildKeys(item.children).indexOf(val) === -1);\n selKeys = selKeys.filter((val) => getParentKeys(item.parent).indexOf(val) === -1);\n }\n }\n if (!multiple) {\n selKeys = !findKey ? [item.key] : [];\n }\n setCurSelectedKeys(selKeys);\n onSelected && onSelected(selKeys, item.key, selected, item, evn);\n onChange?.(selKeys);\n }\n return (\n <div className={cls} {...elementProps}>\n <TreeNode\n {...{\n icon,\n iconAnimation,\n isSelected,\n openKeys: curOpenKeys,\n selectedKeys: curSelectedKeys,\n prefixCls,\n renderTitle,\n }}\n onItemClick={onItemClick}\n onItemSelected={onItemSelected}\n data={data}\n level={1}\n />\n </div>\n );\n}\n","import React, { Fragment } from 'react';\nimport Tree, { TreeProps, TreeRenderTitleNode, TreeData } from '@uiw/react-tree';\nimport Checkbox, { CheckboxProps } from '@uiw/react-checkbox';\nimport './style/index.less';\n\nexport interface TreeCheckedProps extends TreeProps {}\n\nexport default function TreeChecked({ prefixCls = 'w-treechecked', ...props }: TreeCheckedProps): JSX.Element {\n props.className = [prefixCls, props.className].filter(Boolean).join(' ').trim();\n props.checkStrictly = true;\n props.isSelected = false;\n props.multiple = true;\n return (\n <Tree\n renderTitle={(item: TreeData, node: TreeRenderTitleNode) => {\n const checkedProps: CheckboxProps = {};\n if (node.isHalfChecked) {\n checkedProps.indeterminate = true;\n }\n if (node.selected) {\n checkedProps.checked = true;\n } else {\n checkedProps.checked = false;\n }\n return (\n <Fragment>\n <Checkbox className={`${prefixCls}-checked`} {...checkedProps} />\n {item.label && <span>{item.label}</span>}\n </Fragment>\n );\n }}\n {...props}\n />\n );\n}\n","import React, { useMemo, useState, useRef, useEffect, ReactElement } from 'react';\nimport Dropdown, { DropdownProps } from '@uiw/react-dropdown';\nimport Icon from '@uiw/react-icon';\nimport Input from '@uiw/react-input';\nimport Tag from '@uiw/react-tag';\nimport Card from '@uiw/react-card';\nimport Empty from '@uiw/react-empty';\nimport { IProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface DropContent<V> {\n values: Array<V>;\n onSelected?: (selectedAll: Array<V>, selectd: V, isChecked: boolean) => void;\n options?: Array<any>;\n}\n\nexport interface SearchTagInputOption {\n label: string;\n key: string | number;\n}\n\nexport interface SearchTagInputProps<V> extends IProps, DropdownProps, DropContent<V> {\n allowClear?: boolean;\n content: ReactElement<DropContent<V>>;\n size?: 'large' | 'default' | 'small';\n onChange: (selectedAll: Array<V>, selectd: V, isChecked: boolean) => void;\n onSearch?: (seachValue: string) => void;\n // mode?: 'single' | 'multiple';\n loading?: boolean;\n placeholder?: string;\n emptyOption?: boolean | React.ReactNode;\n}\n\nfunction SearchTagInput<V extends SearchTagInputOption>(props: SearchTagInputProps<V>) {\n const {\n prefixCls = 'w-search-tree',\n mode = 'single',\n size = 'default',\n disabled = false,\n allowClear = false,\n loading = false,\n className,\n style,\n placeholder,\n\n content,\n options,\n values,\n onChange,\n onSearch,\n emptyOption,\n ...others\n } = props;\n\n const cls = [prefixCls, className].filter(Boolean).join(' ').trim();\n // const isMultiple = useMemo(() => mode === 'multiple', [mode]);\n const [innerIsOpen, setInnerIsOpen] = useState(false);\n const [selectedOption, setSelectedOption] = useState<Array<V>>(values);\n const optionRef = useRef<Array<V>>();\n const [searchValue, searchValueSet] = useState<string>('');\n optionRef.current = useMemo(() => selectedOption, [selectedOption]);\n const [selectIconType, setSelectIconType] = useState('');\n const inputRef = useRef<HTMLInputElement>(null);\n\n useEffect(() => {\n setSelectedOption(values);\n }, [JSON.stringify(values)]);\n\n function renderSelectIcon(type: string) {\n const selectIconType = type === 'enter' && allowClear && (!!selectedOption.length || searchValue) ? 'close' : '';\n setSelectIconType(selectIconType);\n }\n\n const handleSelectChange = (selectedAll: Array<V>, selectd?: V, isChecked: boolean = true) => {\n setSelectedOption(selectedAll);\n\n onChange && onChange(selectedAll, selectd!, isChecked);\n };\n\n const removeSelectItem = (index: number) => {\n const selectedOption = optionRef.current as Array<V>;\n const curreentItem = selectedOption[index];\n selectedOption.splice(index, 1);\n handleSelectChange([...selectedOption], curreentItem, false);\n };\n\n function handleInputChange(value: string) {\n searchValueSet(value);\n onSearch?.(value);\n setSelectIconType(value ? 'loading' : '');\n }\n\n // 清除选中的值\n function resetSelectedValue(e: any) {\n e.stopPropagation();\n setInnerIsOpen(false);\n setSelectedOption([]);\n handleInputChange('');\n handleSelectChange([]);\n }\n\n function inputKeyDown(e: any) {\n if (selectedOption.length > 0 && !searchValue && e.keyCode === 8) {\n removeSelectItem(selectedOption.length - 1);\n }\n }\n\n const newContent = useMemo(() => {\n if (emptyOption) {\n return typeof emptyOption === 'boolean' ? <Empty style={{ minWidth: 200, width: style?.width }} /> : emptyOption;\n }\n\n const newProps = {\n ...content.props,\n onSelected: handleSelectChange,\n values: selectedOption,\n options,\n };\n return React.cloneElement(content as JSX.Element, newProps);\n }, [JSON.parse(JSON.stringify(selectedOption)), options, emptyOption]);\n\n return (\n <Dropdown\n className={cls}\n trigger=\"focus\"\n {...others}\n isOpen={innerIsOpen}\n menu={<Card bodyStyle={emptyOption === true ? { padding: 0 } : undefined}>{newContent}</Card>}\n >\n <div\n onMouseOver={() => renderSelectIcon('enter')}\n onMouseLeave={() => renderSelectIcon('leave')}\n onClick={() => inputRef.current?.focus()}\n style={{ minWidth: 200, maxWidth: 'none', ...style }}\n >\n <div className={`${prefixCls}-inner`}>\n <div style={{ display: 'flex', flexFlow: 'wrap' }}>\n {selectedOption.map((item, index) => {\n return (\n <Tag\n style={{ height: 20, margin: 1, display: 'flex', alignItems: 'center' }}\n className={`${prefixCls}-tag`}\n key={index}\n closable\n color=\"#393E48\"\n onClose={(e) => {\n e.stopPropagation();\n removeSelectItem(index);\n }}\n >\n {item.label}\n </Tag>\n );\n })}\n <Input\n ref={inputRef}\n style={{ flex: 1, minWidth: 30 }}\n className={`${prefixCls}-input-contents`}\n size={size}\n disabled={disabled}\n onKeyDown={inputKeyDown}\n onChange={(e: React.ChangeEvent<HTMLInputElement>) => handleInputChange(e.target.value)}\n value={searchValue}\n placeholder={selectedOption.length ? '' : placeholder}\n />\n </div>\n <span style={{ height: 25 }} className={`${prefixCls}-close-tag-contents`}>\n {(selectIconType === 'close' || (selectIconType === 'loading' && loading)) && (\n <Icon type={selectIconType} spin={loading && selectIconType === 'loading'} onClick={resetSelectedValue} />\n )}\n </span>\n </div>\n </div>\n </Dropdown>\n );\n}\n\nexport default SearchTagInput;\n","import React, { useState, useEffect } from 'react';\nimport SearchTagInput, { DropContent, SearchTagInputOption } from './SearchTagInput';\nimport Tree, { TreeData, TreeProps } from '@uiw/react-tree';\nimport TreeChecked, { TreeCheckedProps } from '@uiw/react-tree-checked';\n\ntype SelectOtpion = Record<string, string>;\n\n// type TreeCheckedsProps = TreeCheckedProps & Partial<DropContent<SearchTagInputOption>>\nfunction TreeCheckeds<V extends SearchTagInputOption>(\n props: Omit<TreeCheckedProps, 'onSelected'> & Partial<DropContent<V>>,\n) {\n const [selectOption, selectOptionSet] = useState<SelectOtpion>({});\n const [keys, keysSet] = useState<Array<string | number>>([]);\n\n useEffect(() => {\n let selectOption: SelectOtpion = {};\n const keys = props.values?.map((opt) => {\n selectOption[opt.key] = opt.label;\n return opt.key;\n });\n selectOptionSet(selectOption);\n keysSet(keys || []);\n }, [props.values]);\n\n const onSelected = (_1: any, _2: any, isChecked: boolean, evn: TreeData) => {\n const curSelectOption: SelectOtpion = getOptionsRecursion([evn], selectOption, isChecked);\n const option = Object.entries(curSelectOption).map(([key, label]) => ({ key, label } as V));\n props.onSelected?.(option, { key: evn.key, label: evn.label as string } as V, isChecked);\n };\n\n const getOptionsRecursion = (childrens: TreeData[], selectOption: SelectOtpion, isAdd: boolean) => {\n const addOrDel = (key: string | number, label: string, isAdd: boolean) => {\n if (isAdd) {\n selectOption[key] = label;\n } else {\n delete selectOption[key!];\n }\n };\n const iteratorParent = (child: TreeData) => {\n // 向上迭代\n if (child.parent) {\n const selectCount = child.parent.children.filter((child: TreeData) => !selectOption[child.key!]).length;\n addOrDel(child.parent.key, child.parent.label, selectCount === 0);\n iteratorParent(child.parent);\n }\n };\n\n childrens.forEach((child: TreeData) => {\n if (!!child.children?.length) {\n selectOption = getOptionsRecursion(child.children, selectOption, isAdd);\n }\n addOrDel(child.key!, child.label?.toString()!, isAdd);\n iteratorParent(child);\n });\n return selectOption;\n };\n\n return (\n <TreeChecked defaultExpandAll={true} {...props} data={props.options} selectedKeys={keys} onSelected={onSelected} />\n );\n}\n\nfunction SingeTree<V extends SearchTagInputOption>(props: Omit<TreeProps, 'onSelected'> & Partial<DropContent<V>>) {\n const [keys, keysSet] = useState<Array<string | number>>([]);\n\n useEffect(() => {\n const keys: Array<string | number> = [];\n if (props.values?.length) keys[0] = props.values[0].key;\n keysSet(keys);\n }, [props.values]);\n\n const onSelected = (_1: any, _2: any, isChecked: boolean, evn: TreeData) => {\n const { key, label } = evn;\n const cur = { key, label } as V;\n props.onSelected?.([cur], cur, isChecked);\n };\n\n return (\n <Tree\n defaultExpandAll={true}\n {...props}\n multiple={false}\n data={props.options}\n selectedKeys={keys}\n onSelected={onSelected}\n />\n );\n}\n\nexport interface SearchTreeProps<V> {\n onChange?: (selectd: V, selectedAll: Array<V>, isChecked: boolean) => void;\n onSearch?: (seachValue: string) => void;\n value?: Array<V>;\n options?: TreeData[];\n treeProps?: Omit<TreeCheckedProps, 'onSelected'> & Partial<DropContent<V>>;\n emptyOption?: React.ReactNode;\n multiple?: boolean;\n}\n\nfunction SearchTree<V extends SearchTagInputOption>(props: SearchTreeProps<V>) {\n const {\n onChange,\n onSearch,\n multiple = true,\n options = [],\n value = [],\n emptyOption = !options.length,\n treeProps,\n ...other\n } = props;\n const [selectedValues, selectedValuesSet] = useState<Array<V>>(Array.isArray(value) ? value : [value]);\n const [selectedOptions, selectedOptionSet] = useState<Array<TreeData>>(options);\n const [isEmpty, isEmptySet] = useState(emptyOption);\n\n useEffect(() => {\n selectedValuesSet(Array.isArray(value) ? value : []);\n }, [JSON.stringify(value)]);\n\n const selectedChange = (resultValue: Array<V>, cur: V, isChecked: boolean) => {\n selectedValuesSet(resultValue);\n onChange?.(cur, resultValue, isChecked);\n };\n\n // 防抖\n const debounce = (fn: Function, ms: number) => {\n let timeoutId: NodeJS.Timeout;\n return (searchValue: string) => {\n onSearch?.(searchValue);\n clearTimeout(timeoutId);\n timeoutId = setTimeout(() => {\n fn(searchValue);\n }, ms);\n };\n };\n\n const selectedSearch = (searchValue: string) => {\n const hiddenNodeForSeach = (childrens: TreeData[], parentIsHide: boolean = true) => {\n childrens.forEach((child: TreeData) => {\n const isHide = !(child.label as string).includes(searchValue.trim()) && parentIsHide;\n if (!!child.children?.length) {\n hiddenNodeForSeach(child.children, isHide);\n const find = child.children.find((item) => !item.hideNode);\n child.hideNode = isHide && !find;\n } else {\n child.hideNode = isHide;\n }\n });\n };\n hiddenNodeForSeach(options);\n selectedOptionSet([...options]);\n\n let isEmpt = true;\n options.forEach((opt) => (isEmpt = isEmpt && !!opt.hideNode));\n isEmptySet(isEmpt);\n };\n\n return (\n <SearchTagInput\n {...other}\n emptyOption={isEmpty}\n onSearch={debounce(selectedSearch, 600)}\n onChange={selectedChange}\n values={selectedValues}\n options={selectedOptions}\n content={multiple ? <TreeCheckeds {...treeProps} /> : <SingeTree {...treeProps} />}\n />\n );\n}\n\nexport default SearchTree;\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n// expose the modules object (__webpack_modules__)\n__webpack_require__.m = __webpack_modules__;\n\n","var deferred = [];\n__webpack_require__.O = function(result, chunkIds, fn, priority) {\n\tif(chunkIds) {\n\t\tpriority = priority || 0;\n\t\tfor(var i = deferred.length; i > 0 && deferred[i - 1][2] > priority; i--) deferred[i] = deferred[i - 1];\n\t\tdeferred[i] = [chunkIds, fn, priority];\n\t\treturn;\n\t}\n\tvar notFulfilled = Infinity;\n\tfor (var i = 0; i < deferred.length; i++) {\n\t\tvar chunkIds = deferred[i][0];\n\t\tvar fn = deferred[i][1];\n\t\tvar priority = deferred[i][2];\n\t\tvar fulfilled = true;\n\t\tfor (var j = 0; j < chunkIds.length; j++) {\n\t\t\tif ((priority & 1 === 0 || notFulfilled >= priority) && Object.keys(__webpack_require__.O).every(function(key) { return __webpack_require__.O[key](chunkIds[j]); })) {\n\t\t\t\tchunkIds.splice(j--, 1);\n\t\t\t} else {\n\t\t\t\tfulfilled = false;\n\t\t\t\tif(priority < notFulfilled) notFulfilled = priority;\n\t\t\t}\n\t\t}\n\t\tif(fulfilled) {\n\t\t\tdeferred.splice(i--, 1)\n\t\t\tvar r = fn();\n\t\t\tif (r !== undefined) result = r;\n\t\t}\n\t}\n\treturn result;\n};","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = function(module) {\n\tvar getter = module && module.__esModule ?\n\t\tfunction() { return module['default']; } :\n\t\tfunction() { return module; };\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = function(exports, definition) {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.f = {};\n// This file contains only the entry chunk.\n// The chunk loading function for additional chunks\n__webpack_require__.e = function(chunkId) {\n\treturn Promise.all(Object.keys(__webpack_require__.f).reduce(function(promises, key) {\n\t\t__webpack_require__.f[key](chunkId, promises);\n\t\treturn promises;\n\t}, []));\n};","// This function allow to reference async chunks\n__webpack_require__.u = function(chunkId) {\n\t// return url for filenames based on template\n\treturn \"static/js/\" + ({\"889\":\"vendors-prismjs\",\"6554\":\"vendors-code-preview\",\"6982\":\"vendors-standalone\"}[chunkId] || chunkId) + \".\" + {\"200\":\"d5a57a0b\",\"207\":\"891adb65\",\"226\":\"6a30fefc\",\"280\":\"2c6a39d1\",\"455\":\"c6373db5\",\"486\":\"fc977627\",\"492\":\"47ca7cbf\",\"581\":\"90621994\",\"627\":\"acb355d3\",\"745\":\"3a86c62c\",\"747\":\"7519f1c0\",\"751\":\"0807c32c\",\"766\":\"3b400825\",\"889\":\"b53bdc3b\",\"922\":\"b1f148e3\",\"1016\":\"a3866702\",\"1127\":\"d65f8357\",\"1151\":\"3c560b1f\",\"1181\":\"04f18676\",\"1358\":\"e579baca\",\"1689\":\"2762e851\",\"1756\":\"87f583cc\",\"1773\":\"70bc3c86\",\"1892\":\"13ea195f\",\"1971\":\"d746cb8b\",\"2078\":\"53137233\",\"2092\":\"2f66702a\",\"2208\":\"bfb04965\",\"2326\":\"5b5e6089\",\"2448\":\"1d46904a\",\"2456\":\"624e63f5\",\"2476\":\"7945e2f2\",\"2618\":\"a4b0094e\",\"2679\":\"0780e749\",\"2692\":\"db178ecc\",\"2739\":\"8ae3d250\",\"2795\":\"45c184a0\",\"2848\":\"d0299bbe\",\"2855\":\"0ddb3b84\",\"2867\":\"45b7bbad\",\"2926\":\"f11fdc77\",\"2937\":\"72c1a9c5\",\"3151\":\"59d27efa\",\"3153\":\"c354b3d5\",\"3257\":\"5693b5c1\",\"3259\":\"80ff41ab\",\"3261\":\"d4120c57\",\"3410\":\"d5d0af47\",\"3450\":\"bb5e6340\",\"3561\":\"6f3572f1\",\"3769\":\"535a1903\",\"3811\":\"ac38cada\",\"3882\":\"ba7ab665\",\"3931\":\"088517c5\",\"3972\":\"219adba7\",\"4036\":\"412a4652\",\"4045\":\"30975813\",\"4234\":\"2822529c\",\"4255\":\"2391ca41\",\"4781\":\"ce661c8a\",\"4877\":\"ea4e48af\",\"4960\":\"4b52fbe5\",\"5001\":\"3abadda3\",\"5080\":\"676201d3\",\"5146\":\"76b73d7f\",\"5253\":\"7a8716a8\",\"5329\":\"2f1635b0\",\"5364\":\"b95913d0\",\"5374\":\"49733922\",\"5407\":\"5c016d0c\",\"5468\":\"ea87a4b5\",\"5475\":\"f586f3b0\",\"5523\":\"66c3ed7c\",\"5576\":\"33ea816b\",\"5609\":\"b7130b71\",\"5630\":\"ddc66a16\",\"5821\":\"41b747c6\",\"5930\":\"65ea3787\",\"6019\":\"add10037\",\"6036\":\"289c2eb8\",\"6216\":\"180d7a17\",\"6221\":\"01a2779e\",\"6315\":\"4b82eca4\",\"6319\":\"b4316107\",\"6421\":\"27b4c645\",\"6436\":\"f9f8d420\",\"6536\":\"6aaaba5b\",\"6554\":\"fdba0f1f\",\"6566\":\"511e95c6\",\"6623\":\"cf061c3e\",\"6659\":\"6790167d\",\"6660\":\"cd859a1a\",\"6869\":\"38330ca9\",\"6878\":\"c6cec0d9\",\"6889\":\"ed8f240c\",\"6956\":\"373c91a3\",\"6982\":\"da956558\",\"7079\":\"3aa94426\",\"7213\":\"d5ae367d\",\"7217\":\"1be488ae\",\"7266\":\"bba9c51f\",\"7313\":\"18ac2eb2\",\"7491\":\"b2911100\",\"7664\":\"f92b74f7\",\"7712\":\"3d195b56\",\"7763\":\"444dce16\",\"7858\":\"2b64eed2\",\"7861\":\"757503f5\",\"7898\":\"7ad51028\",\"8131\":\"d3fab736\",\"8200\":\"9471041e\",\"8312\":\"58a5729e\",\"8398\":\"cc6aa9ea\",\"8471\":\"4345a110\",\"8488\":\"148bfa75\",\"8586\":\"9d605493\",\"8709\":\"44b46cf7\",\"8747\":\"04252521\",\"8768\":\"2b6b6aab\",\"8804\":\"bea2a7b0\",\"8849\":\"d5dd1a61\",\"8913\":\"18615c75\",\"8915\":\"82c6b45a\",\"9057\":\"b21f426b\",\"9126\":\"732f4d56\",\"9137\":\"f4e2b7b0\",\"9147\":\"d6a507a2\",\"9188\":\"636af533\",\"9200\":\"0a1f7353\",\"9331\":\"f7b559cf\",\"9421\":\"15a9391f\",\"9429\":\"3b8debbf\",\"9574\":\"cc6ec2a4\",\"9636\":\"004d3c49\",\"9762\":\"d3f5bf16\",\"9767\":\"eb2c6ae6\",\"9777\":\"40075961\",\"9820\":\"1374775d\",\"9836\":\"8cd96a11\",\"9871\":\"a375a870\",\"9900\":\"2d8ffaaf\",\"9961\":\"3712fbe4\"}[chunkId] + \".chunk.js\";\n};","// This function allow to reference async chunks\n__webpack_require__.miniCssF = function(chunkId) {\n\t// return url for filenames based on template\n\treturn \"static/css/\" + chunkId + \".\" + {\"200\":\"cc97fb71\",\"226\":\"cc97fb71\",\"280\":\"cc97fb71\",\"455\":\"cc97fb71\",\"492\":\"cc97fb71\",\"581\":\"cc97fb71\",\"627\":\"cc97fb71\",\"751\":\"cc97fb71\",\"1181\":\"cc97fb71\",\"1689\":\"cc97fb71\",\"1773\":\"cc97fb71\",\"2092\":\"cc97fb71\",\"2208\":\"cc97fb71\",\"2326\":\"cc97fb71\",\"2476\":\"cc97fb71\",\"2618\":\"cc97fb71\",\"2739\":\"cc97fb71\",\"2848\":\"cc97fb71\",\"2855\":\"cc97fb71\",\"2867\":\"cc97fb71\",\"2937\":\"cc97fb71\",\"3153\":\"cc97fb71\",\"3410\":\"cc97fb71\",\"3882\":\"cc97fb71\",\"3972\":\"cc97fb71\",\"4045\":\"cc97fb71\",\"4234\":\"cc97fb71\",\"4255\":\"cc97fb71\",\"4877\":\"6e864cd4\",\"4960\":\"cc97fb71\",\"5001\":\"cc97fb71\",\"5080\":\"cc97fb71\",\"5329\":\"cc97fb71\",\"5374\":\"cc97fb71\",\"5407\":\"cc97fb71\",\"5475\":\"cc97fb71\",\"5523\":\"cc97fb71\",\"5576\":\"cc97fb71\",\"5609\":\"cc97fb71\",\"5630\":\"cc97fb71\",\"6216\":\"cc97fb71\",\"6221\":\"cc97fb71\",\"6315\":\"cc97fb71\",\"6319\":\"cc97fb71\",\"6421\":\"cc97fb71\",\"6436\":\"cc97fb71\",\"6623\":\"cc97fb71\",\"6660\":\"cc97fb71\",\"6889\":\"cc97fb71\",\"6956\":\"cc97fb71\",\"7213\":\"cc97fb71\",\"7491\":\"cc97fb71\",\"7712\":\"cc97fb71\",\"7858\":\"cc97fb71\",\"7898\":\"cc97fb71\",\"8131\":\"cc97fb71\",\"8200\":\"cc97fb71\",\"8471\":\"cc97fb71\",\"8804\":\"cc97fb71\",\"8913\":\"2fc8f29c\",\"9126\":\"cc97fb71\",\"9200\":\"14abaeb3\",\"9331\":\"cc97fb71\",\"9421\":\"cc97fb71\",\"9574\":\"cc97fb71\",\"9636\":\"cc97fb71\",\"9762\":\"cc97fb71\",\"9767\":\"cc97fb71\",\"9777\":\"cc97fb71\",\"9871\":\"cc97fb71\"}[chunkId] + \".chunk.css\";\n};","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","__webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }","var inProgress = {};\nvar dataWebpackPrefix = \"website:\";\n// loadScript function to load a script via script tag\n__webpack_require__.l = function(url, done, key, chunkId) {\n\tif(inProgress[url]) { inProgress[url].push(done); return; }\n\tvar script, needAttach;\n\tif(key !== undefined) {\n\t\tvar scripts = document.getElementsByTagName(\"script\");\n\t\tfor(var i = 0; i < scripts.length; i++) {\n\t\t\tvar s = scripts[i];\n\t\t\tif(s.getAttribute(\"src\") == url || s.getAttribute(\"data-webpack\") == dataWebpackPrefix + key) { script = s; break; }\n\t\t}\n\t}\n\tif(!script) {\n\t\tneedAttach = true;\n\t\tscript = document.createElement('script');\n\n\t\tscript.charset = 'utf-8';\n\t\tscript.timeout = 120;\n\t\tif (__webpack_require__.nc) {\n\t\t\tscript.setAttribute(\"nonce\", __webpack_require__.nc);\n\t\t}\n\t\tscript.setAttribute(\"data-webpack\", dataWebpackPrefix + key);\n\t\tscript.src = url;\n\t}\n\tinProgress[url] = [done];\n\tvar onScriptComplete = function(prev, event) {\n\t\t// avoid mem leaks in IE.\n\t\tscript.onerror = script.onload = null;\n\t\tclearTimeout(timeout);\n\t\tvar doneFns = inProgress[url];\n\t\tdelete inProgress[url];\n\t\tscript.parentNode && script.parentNode.removeChild(script);\n\t\tdoneFns && doneFns.forEach(function(fn) { return fn(event); });\n\t\tif(prev) return prev(event);\n\t}\n\t;\n\tvar timeout = setTimeout(onScriptComplete.bind(null, undefined, { type: 'timeout', target: script }), 120000);\n\tscript.onerror = onScriptComplete.bind(null, script.onerror);\n\tscript.onload = onScriptComplete.bind(null, script.onload);\n\tneedAttach && document.head.appendChild(script);\n};","// define __esModule on exports\n__webpack_require__.r = function(exports) {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","__webpack_require__.p = \"./\";","var createStylesheet = function(chunkId, fullhref, resolve, reject) {\n\tvar linkTag = document.createElement(\"link\");\n\n\tlinkTag.rel = \"stylesheet\";\n\tlinkTag.type = \"text/css\";\n\tvar onLinkComplete = function(event) {\n\t\t// avoid mem leaks.\n\t\tlinkTag.onerror = linkTag.onload = null;\n\t\tif (event.type === 'load') {\n\t\t\tresolve();\n\t\t} else {\n\t\t\tvar errorType = event && (event.type === 'load' ? 'missing' : event.type);\n\t\t\tvar realHref = event && event.target && event.target.href || fullhref;\n\t\t\tvar err = new Error(\"Loading CSS chunk \" + chunkId + \" failed.\\n(\" + realHref + \")\");\n\t\t\terr.code = \"CSS_CHUNK_LOAD_FAILED\";\n\t\t\terr.type = errorType;\n\t\t\terr.request = realHref;\n\t\t\tlinkTag.parentNode.removeChild(linkTag)\n\t\t\treject(err);\n\t\t}\n\t}\n\tlinkTag.onerror = linkTag.onload = onLinkComplete;\n\tlinkTag.href = fullhref;\n\n\tdocument.head.appendChild(linkTag);\n\treturn linkTag;\n};\nvar findStylesheet = function(href, fullhref) {\n\tvar existingLinkTags = document.getElementsByTagName(\"link\");\n\tfor(var i = 0; i < existingLinkTags.length; i++) {\n\t\tvar tag = existingLinkTags[i];\n\t\tvar dataHref = tag.getAttribute(\"data-href\") || tag.getAttribute(\"href\");\n\t\tif(tag.rel === \"stylesheet\" && (dataHref === href || dataHref === fullhref)) return tag;\n\t}\n\tvar existingStyleTags = document.getElementsByTagName(\"style\");\n\tfor(var i = 0; i < existingStyleTags.length; i++) {\n\t\tvar tag = existingStyleTags[i];\n\t\tvar dataHref = tag.getAttribute(\"data-href\");\n\t\tif(dataHref === href || dataHref === fullhref) return tag;\n\t}\n};\nvar loadStylesheet = function(chunkId) {\n\treturn new Promise(function(resolve, reject) {\n\t\tvar href = __webpack_require__.miniCssF(chunkId);\n\t\tvar fullhref = __webpack_require__.p + href;\n\t\tif(findStylesheet(href, fullhref)) return resolve();\n\t\tcreateStylesheet(chunkId, fullhref, resolve, reject);\n\t});\n}\n// object to store loaded CSS chunks\nvar installedCssChunks = {\n\t179: 0\n};\n\n__webpack_require__.f.miniCss = function(chunkId, promises) {\n\tvar cssChunks = {\"200\":1,\"226\":1,\"280\":1,\"455\":1,\"492\":1,\"581\":1,\"627\":1,\"751\":1,\"1181\":1,\"1689\":1,\"1773\":1,\"2092\":1,\"2208\":1,\"2326\":1,\"2476\":1,\"2618\":1,\"2739\":1,\"2848\":1,\"2855\":1,\"2867\":1,\"2937\":1,\"3153\":1,\"3410\":1,\"3882\":1,\"3972\":1,\"4045\":1,\"4234\":1,\"4255\":1,\"4877\":1,\"4960\":1,\"5001\":1,\"5080\":1,\"5329\":1,\"5374\":1,\"5407\":1,\"5475\":1,\"5523\":1,\"5576\":1,\"5609\":1,\"5630\":1,\"6216\":1,\"6221\":1,\"6315\":1,\"6319\":1,\"6421\":1,\"6436\":1,\"6623\":1,\"6660\":1,\"6889\":1,\"6956\":1,\"7213\":1,\"7491\":1,\"7712\":1,\"7858\":1,\"7898\":1,\"8131\":1,\"8200\":1,\"8471\":1,\"8804\":1,\"8913\":1,\"9126\":1,\"9200\":1,\"9331\":1,\"9421\":1,\"9574\":1,\"9636\":1,\"9762\":1,\"9767\":1,\"9777\":1,\"9871\":1};\n\tif(installedCssChunks[chunkId]) promises.push(installedCssChunks[chunkId]);\n\telse if(installedCssChunks[chunkId] !== 0 && cssChunks[chunkId]) {\n\t\tpromises.push(installedCssChunks[chunkId] = loadStylesheet(chunkId).then(function() {\n\t\t\tinstalledCssChunks[chunkId] = 0;\n\t\t}, function(e) {\n\t\t\tdelete installedCssChunks[chunkId];\n\t\t\tthrow e;\n\t\t}));\n\t}\n};\n\n// no hmr","// no baseURI\n\n// object to store loaded and loading chunks\n// undefined = chunk not loaded, null = chunk preloaded/prefetched\n// [resolve, reject, Promise] = chunk loading, 0 = chunk loaded\nvar installedChunks = {\n\t179: 0\n};\n\n__webpack_require__.f.j = function(chunkId, promises) {\n\t\t// JSONP chunk loading for javascript\n\t\tvar installedChunkData = __webpack_require__.o(installedChunks, chunkId) ? installedChunks[chunkId] : undefined;\n\t\tif(installedChunkData !== 0) { // 0 means \"already installed\".\n\n\t\t\t// a Promise means \"currently loading\".\n\t\t\tif(installedChunkData) {\n\t\t\t\tpromises.push(installedChunkData[2]);\n\t\t\t} else {\n\t\t\t\tif(true) { // all chunks have JS\n\t\t\t\t\t// setup Promise in chunk cache\n\t\t\t\t\tvar promise = new Promise(function(resolve, reject) { installedChunkData = installedChunks[chunkId] = [resolve, reject]; });\n\t\t\t\t\tpromises.push(installedChunkData[2] = promise);\n\n\t\t\t\t\t// start chunk loading\n\t\t\t\t\tvar url = __webpack_require__.p + __webpack_require__.u(chunkId);\n\t\t\t\t\t// create error before stack unwound to get useful stacktrace later\n\t\t\t\t\tvar error = new Error();\n\t\t\t\t\tvar loadingEnded = function(event) {\n\t\t\t\t\t\tif(__webpack_require__.o(installedChunks, chunkId)) {\n\t\t\t\t\t\t\tinstalledChunkData = installedChunks[chunkId];\n\t\t\t\t\t\t\tif(installedChunkData !== 0) installedChunks[chunkId] = undefined;\n\t\t\t\t\t\t\tif(installedChunkData) {\n\t\t\t\t\t\t\t\tvar errorType = event && (event.type === 'load' ? 'missing' : event.type);\n\t\t\t\t\t\t\t\tvar realSrc = event && event.target && event.target.src;\n\t\t\t\t\t\t\t\terror.message = 'Loading chunk ' + chunkId + ' failed.\\n(' + errorType + ': ' + realSrc + ')';\n\t\t\t\t\t\t\t\terror.name = 'ChunkLoadError';\n\t\t\t\t\t\t\t\terror.type = errorType;\n\t\t\t\t\t\t\t\terror.request = realSrc;\n\t\t\t\t\t\t\t\tinstalledChunkData[1](error);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t};\n\t\t\t\t\t__webpack_require__.l(url, loadingEnded, \"chunk-\" + chunkId, chunkId);\n\t\t\t\t} else installedChunks[chunkId] = 0;\n\t\t\t}\n\t\t}\n};\n\n// no prefetching\n\n// no preloaded\n\n// no HMR\n\n// no HMR manifest\n\n__webpack_require__.O.j = function(chunkId) { return installedChunks[chunkId] === 0; };\n\n// install a JSONP callback for chunk loading\nvar webpackJsonpCallback = function(parentChunkLoadingFunction, data) {\n\tvar chunkIds = data[0];\n\tvar moreModules = data[1];\n\tvar runtime = data[2];\n\t// add \"moreModules\" to the modules object,\n\t// then flag all \"chunkIds\" as loaded and fire callback\n\tvar moduleId, chunkId, i = 0;\n\tif(chunkIds.some(function(id) { return installedChunks[id] !== 0; })) {\n\t\tfor(moduleId in moreModules) {\n\t\t\tif(__webpack_require__.o(moreModules, moduleId)) {\n\t\t\t\t__webpack_require__.m[moduleId] = moreModules[moduleId];\n\t\t\t}\n\t\t}\n\t\tif(runtime) var result = runtime(__webpack_require__);\n\t}\n\tif(parentChunkLoadingFunction) parentChunkLoadingFunction(data);\n\tfor(;i < chunkIds.length; i++) {\n\t\tchunkId = chunkIds[i];\n\t\tif(__webpack_require__.o(installedChunks, chunkId) && installedChunks[chunkId]) {\n\t\t\tinstalledChunks[chunkId][0]();\n\t\t}\n\t\tinstalledChunks[chunkId] = 0;\n\t}\n\treturn __webpack_require__.O(result);\n}\n\nvar chunkLoadingGlobal = self[\"webpackChunkwebsite\"] = self[\"webpackChunkwebsite\"] || [];\nchunkLoadingGlobal.forEach(webpackJsonpCallback.bind(null, 0));\nchunkLoadingGlobal.push = webpackJsonpCallback.bind(null, chunkLoadingGlobal.push.bind(chunkLoadingGlobal));","// startup\n// Load entry module and return exports\n// This entry module depends on other loaded chunks and execution need to be delayed\nvar __webpack_exports__ = __webpack_require__.O(undefined, [9896,5183], function() { return __webpack_require__(52744); })\n__webpack_exports__ = __webpack_require__.O(__webpack_exports__);\n"],"names":["dark","viewBox","width","height","version","stroke","strokeWidth","fill","fillRule","d","light","NoMatch","to","De","tip","indicator","type","spin","style","verticalAlign","Options","props","useMemo","value","onChange","e","target","isV1","split","window","location","href","currentVersion","pkg","versionList","data","firstVersion","unshift","className","styles","defaultValue","map","idx","home","component","github","issue","gitee","plugin","SiderMenu","useLocation","menu","find","item","RegExp","path","test","pathname","children","nav","icon","name","divider","replace","initialState","layout","reducer","state","action","ThemeContext","React","dispatch","rx","x","y","fillOpacity","menutop","china","id","transform","xlinkHref","Nav","useContext","Fragment","filter","Boolean","join","trim","logo","Object","keys","includes","usePortal","placement","content","whiteSpace","activeStyle","color","isActive","undefined","rel","onClick","Header","Layout","Sider","Content","Components","siderMenu","offsetTop","zIndex","display","alignItems","padding","position","left","top","bottom","overflow","paddingLeft","lineHeight","flexDirection","justifyContent","backgroundColor","Loadable","Component","Suspense","fallback","Home","lazy","Extensions","GuideQuickStart","GuideImport","GuideCreateReactApp","GuideKKT","GuideDocs","GuideVscode","GuideRecommendation","Overview","Colors","Alert","AutoLink","ResetCss","Avatar","Affix","Calendar","Checkbox","CopyToClipboard","Collapse","Card","Descriptions","Loader","Icon","Divider","Drawer","DatePicker","DateInput","Dropdown","Badge","Progress","Pagination","PinCode","Input","Button","Radio","Select","SearchSelect","Split","Switch","Slider","Grid","Form","FileInput","Breadcrumb","List","Notify","Tree","TreeChecked","SearchTree","Tag","Tabs","Tooltip","Table","TimePicker","Rate","Overlay","BackTop","Portal","OverlayTrigger","Popover","Message","MonthPicker","Textarea","Modal","Formatter","Steps","Menu","Empty","routes","element","index","App","useRoutes","Provider","useReducer","ReactDOM","document","getElementById","noop","getScroll","method","isWindow","ret","documentElement","getOffset","elemRect","getBoundingClientRect","targetRect","getTargetRect","scrollTop","scrollLeft","docElem","body","clientTop","clientLeft","getDefaultTarget","constructor","placeholderStyle","affixStyle","box","events","eventHandlers","timeout","getInstance","node","updatePosition","bind","componentDidMount","this","setTimeout","setTargetEventListeners","componentWillUnmount","clearEventListeners","clearTimeout","offsetBottom","offsetParent","elemSize","clientWidth","clientHeight","offsetMode","elemOffset","setPlaceholderStyle","setAffixStyle","affixed","setState","forEach","eventName","addEventListener","handler","removeEventListener","render","prefixCls","resetProps","cls","_jsx","ref","defaultProps","canUseDOM","createElement","container","defaultNode","useRef","containerRef","useEffect","current","removeChild","appendChild","isOpen","maskClosable","backdropProps","portalProps","hasBackdrop","unmountOnExit","transitionName","onOpening","onOpened","onClosing","onClosed","onClose","dialogProps","otherProps","useState","setIsOpen","visible","setVisible","overlay","overlayWillClose","classList","add","decoratedChild","cloneElement","tabIndex","handleBackdropMouseDown","onMouseDown","remove","TransitionGroupComp","CSSTransition","classNames","in","onEntering","onEntered","onExiting","onExited","status","_jsxs","tagName","TagName","others","svg","svgPaths","i","propps","disabled","active","loading","block","basic","htmlType","size","child","useButton","autoFocus","title","cancelText","cancelButtonProps","confirmButtonProps","confirmText","maxWidth","minWidth","isCloseButtonShown","onCancel","onConfirm","bodyStyle","other","setLoading","handleCancel","_handleCancel","_handleConfirm","handleConfirm","delimiter","text","word","match","url","_createElement","key","startsWith","shape","src","alt","onError","isImgExist","setIsImgExist","evn","getScrollTop","fixed","speed","showBelow","clickable","topShowBelow","percent","setPercent","setCurrent","onScroll","Math","round","scrollHeight","innerHeight","getScrollPercent","scrollToTop","step","start","timer","setInterval","scrollTo","clearInterval","scrollToAnimate","max","dot","processing","count","supProps","warpperProps","separator","isElm","assign","Item","vertical","context","parentNode","isDOM","HTMLElement","nodeType","nodeName","contains","compareDocumentPosition","getBordersSize","axis","sideA","sideB","parseFloat","isIE11","isBrowser","MSInputMethodContext","documentMode","isIE10","navigator","userAgent","isIE","getSize","html","computedStyle","parseInt","rect","right","offsets","result","sizes","getComputedStyle","getWindowSizes","ownerDocument","horizScrollbar","offsetWidth","vertScrollbar","offsetHeight","offsetLeft","property","css","defaultView","getStyleComputedProperty","getOuterSizes","scrollWidth","getStyle","options","triggerDom","trigger","popupDom","popup","autoAdjustOverflow","sty","winSizeHeight","winSizeWidth","innerWidth","normalizeDelay","delay","show","hide","isOutside","isClickOutside","onVisibleChange","onEnter","triggerRef","popupRef","timeoutRef","hoverStateRef","overlayStyl","setOverlayStyl","useImperativeHandle","overlayProps","triggerProps","handleClickOutside","handleResize","styls","popNode","childNode","clearTimeouts","length","timeoutId","handleShow","handle","push","handleHide","handleMouseOverOut","relatedNative","currentTarget","related","relatedTarget","nativeEvent","onFocus","onMouseOver","onMouseEnter","onMouseOut","onMouseLeave","isAppearing","renderArrow","visibleArrow","preIcon","addonAfter","inputRef","addonRef","input","paddingRight","computedInputPadding","autoComplete","TimePickerPanel","date","hideDisabled","onSelected","disableds","getDisabledItem","num","Date","Array","_","liProps","currentDate","handleClick","currentCount","tag","dataset","Number","getItemInstance","TimePickerTime","precision","TimePanel","format","popoverProps","allowClear","disabledHours","disabledMinutes","disabledSeconds","inputProps","setDate","timeProps","inputValue","formatter","datePickerTime","_props","dataStr","placeholder","readOnly","classnames","obj","keyName","DayRect","selectedDate","col","today","panelDate","disabledDate","renderDay","onSelectDay","end","prev","selected","next","isNaN","getTime","isValidDate","year","getFullYear","month","getMonth","week","getDay","toDateString","lastDay","getDate","day","cellDate","divProps","cellMonth","WEEKTITLE","WEEKDAY","DatePickerDay","weekday","weekTitle","weekdayLabel","row","curDate","DatePickerMonth","monthLabel","selectedMonth","DatePickerYear","panelNum","activeYear","setActiveYear","selectedYear","setFullYear","handleSelected","arg","arguments","DatePickerCaption","todayButton","renderMonth","MONTH_LABEL","onPanelChange","showTime","setType","selectDate","setSelectDate","selectPanelDate","setSelectPanelDate","curType","setMonth","onSelectedDate","paging","dateSource","RenderDay","dayData","arr","label","_objectWithoutPropertiesLoose","titleFormat","todayLabel","onPaging","setPanelDate","handlePaging","titleLable","btngroup","propsNext","extra","footer","bordered","noHover","bodyClassName","RadioAbstract","checked","prChecked","setChecked","prevChecked","setPrevChecked","persist","CheckboxGroup","valueRef","childs","isArray","include","val","InternalCheckbox","indeterminate","Group","toArray","activeKey","currentActiveKey","InternalCollapse","accordion","showArrow","propsActiveKey","setActiveKey","String","indexOf","childProps","onItemClick","splice","Panel","header","iconRender","transitionDuration","instance","copy","isCopy","DateInputRange","datePickerProps","dateRange","setDateRange","handleChange","cdate","changeValue","valueTemp","propsValue","JSON","stringify","fontSize","margin","colon","span","labelProps","colSpan","Row","column","handleCell","isHead","Cell","isLastCell","InternalDescriptions","leftSpans","rows","columns","itemNode","generateChildrenRows","DescriptionsItem","dashed","align","restProps","bodyProps","bodyCls","styl","footerView","iconView","titleView","iconProps","description","dataLabel","dataList","uploadType","readonly","showFileIcon","showPreviewIcon","showRemoveIcon","onPreview","onAdd","onRemove","maxNumber","isAction","getBase64","file","reader","FileReader","Promise","resolve","readAsDataURL","getListFiles","files","dataURLKey","promiseFiles","all","then","fileListBase64","base64","multiple","inValue","fileList","setFileList","Comp","handleClickInput","useCallback","click","openFileDialog","onFileUpload","onInputChange","updatedFileList","updatedList","slice","FileList","Col","grow","gutter","justify","gutterStyl","FormItem","required","labelFor","labelClassName","labelStyle","help","inline","hasError","labelCls","htmlFor","fields","resetOnSubmit","onSubmitError","onSubmit","afterSubmit","initData","cb","initial","submitting","errors","initialValue","currentValue","newFormState","setData","handleSubmit","resetForm","handleReset","getFieldValues","getError","setFields","setFieldValue","formUnits","error","childField","controlField","tempData","fieldName","validator","env","list","nextState","preventDefault","promise","onSuccess","response","reset","afterSubmitPromise","catch","canSubmit","passesValidators","prototype","hasOwnProperty","call","initials","entries","hasCurrentValue","ListItem","displayName","InternalList","items","striped","renderItem","dataSource","childrenList","classString","bgColor","fullscreen","indicatorView","cx","cy","r","strokeMiterlimit","tipsView","disabledProps","Internal","multiline","isSubMenuItem","htmlProps","anchorCls","tagComp","MenuItem","MenuDivider","IconView","collapse","SubMenu","inlineIndent","overlayTriggerProps","menuProps","isCheck","checkedMenuItem","appear","onExit","theme","inlineCollapsed","handleClosed","renderIcon","showIcon","rounded","elementProps","Child","pickerCaptionProps","handleSelectedDate","curPanelDate","open","captionType","notifys","Container","create","duration","closed","willUnmount","alertProps","notifysDom","NotificationCreate","div","random","toString","nprops","notifysChild","Option","alignment","total","pageSize","pageSizeOptions","currentNumber","onShowSizeChange","initPageSoure","ceil","itemCount","goto","textAlign","sizeCount","InternalPinCode","onBlur","placehold","setPlacehold","values","setValues","handleBlur","event","handleFocus","inpProps","min","inputMode","charAt","focus","onKeyDown","toLocaleLowerCase","handleKeyDown","IconProgress","Circle","relativeStrokeWidth","elm","_strokeWidth","toFixed","radius","setAttribute","perimeter","PI","progressInfo","showText","progressStatus","percentView","strokeLinecap","Line","percentStyle","defValue","allowHalf","character","onHoverChange","setValue","hoverCount","setHoverCount","prevValue","setPrevValue","getValue","isLeft","clientX","halfon","activeCls","onMouseMove","closable","borderColor","boxShadow","maxTagCount","option","labelInValue","mode","showSearch","tagProps","onSearch","onSelect","isMultiple","innerIsOpen","setInnerIsOpen","selectedValue","setSelectedValue","selectedLabel","setSelectedLabel","selectIconType","setSelectIconType","omitTagCount","divRef","selectedValueChange","getSelectOption","findResult","opts","v","m","handleItemsClick","removeSelectItem","resultValue","handleSelectChange","renderSelectIcon","console","log","handleInputChange","resetSelectedValue","marginTop","minHeight","maxHeight","overflowY","findIndex","finds","handleItemClick","flexFlow","flex","keyCode","InternalSteps","progressDot","direction","warpRef","lastStepOffsetWidth","setLastStepOffsetWidth","filteredChildren","c","lastIndex","domNode","lastChild","abs","calcStepOffsetWidth","stepNumber","itemWidth","adjustMarginRight","Step","stepItemStyle","stepItemDotStyle","marginRight","iconNode","Dots","marks","markRender","stepValue","dots","progress","tooltip","renderMarks","bar","slider","indexBar","startX","curValue","barWidth","barOffsetLeft","move","arrValue","setArrValue","getWidthToValue","equal","floor","onDragging","vals","valueToWidth","barStyl","onDragEnd","markOffset","newData","val1","val2","half","getRangeValue","getValueToPercent","leftValue","rightValue","getLabelValue","lleftPostion","onHandleBtnDown","stepWidth","stepArray","mark","onCellHead","tds","rowNum","colNum","ellipsis","thProps","titleNode","getColspanNum","concat","getRowspanNum","getLevelItems","levelTop","rowSpan","getAllColumnsKeys","onCell","empty","tableLayout","Thead","trData","objs","onTabClick","slideStyle","setSlideStyle","activeItem","calcSlideStyle","Pane","Label","TreeNode","renderTitle","iconAnimation","isSelected","openKeys","selectedKeys","level","parent","onItemSelected","noChild","itemIsOpen","iconItem","childKeys","getChildKeys","checkedKeys","isHalfChecked","hideNode","isContained","a","b","aStr","len","depth","getParentKeys","getParentSelectKeys","defaultExpandAll","showLine","checkStrictly","onExpand","autoExpandParent","curOpenKeys","setCurOpenKeys","curSelectedKeys","setCurSelectedKeys","arrOpenKeys","currentKeys","expanded","selKeys","findKey","from","Set","checkedProps","emptyOption","selectedOption","setSelectedOption","optionRef","searchValue","searchValueSet","selectedAll","selectd","isChecked","curreentItem","newContent","newProps","parse","_inputRef$current","stopPropagation","TreeCheckeds","selectOption","selectOptionSet","keysSet","_props$values","opt","getOptionsRecursion","childrens","isAdd","addOrDel","iteratorParent","selectCount","_child$children","_child$label","_1","_2","curSelectOption","SingeTree","_props$values2","cur","treeProps","selectedValues","selectedValuesSet","selectedOptions","selectedOptionSet","isEmpty","isEmptySet","SearchTagInput","fn","ms","debounce","hiddenNodeForSeach","parentIsHide","isHide","_child$children2","isEmpt","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","exports","module","__webpack_modules__","deferred","O","chunkIds","priority","notFulfilled","Infinity","fulfilled","j","every","n","getter","__esModule","definition","o","defineProperty","enumerable","get","f","chunkId","reduce","promises","u","miniCssF","g","globalThis","Function","prop","inProgress","dataWebpackPrefix","l","done","script","needAttach","scripts","getElementsByTagName","s","getAttribute","charset","nc","onScriptComplete","onerror","onload","doneFns","head","Symbol","toStringTag","p","loadStylesheet","reject","fullhref","existingLinkTags","dataHref","existingStyleTags","findStylesheet","linkTag","errorType","realHref","err","Error","code","request","createStylesheet","installedCssChunks","miniCss","installedChunks","installedChunkData","realSrc","message","webpackJsonpCallback","parentChunkLoadingFunction","moreModules","runtime","some","chunkLoadingGlobal","self","__webpack_exports__"],"sourceRoot":""}