{"mappings":";AACaA,IC2BAC,ECjBPC,ECRFC,EAgGSC,GC+ETC,EAWAC,EAEEC,EA0BAC,EC/LFC,EAkJEC,EACAC,EC3KKC,ENUEC,EAAgC,CAAA,EAChCC,EAAY,CAAA,EACZC,GACZ,oECbYC,EAAUC,MAAMD,QAStB,SAASE,EAAOC,EAAKC,EAAAA,CAE3B,QAASR,KAAKQ,EAAOD,EAAIP,CAAAA,EAAKQ,EAAMR,CAAAA,EACpC,OAA6BO,CAC7B,CAAA,SAQeE,GAAWC,EAAAA,CAC1B,IAAIC,EAAaD,EAAKC,WAClBA,GAAYA,EAAWC,YAAYF,CAAAA,CACvC,CEZM,SAASG,GAAcC,EAAMN,EAAOO,EAAAA,CAC1C,IACCC,EACAC,EACAjB,EAHGkB,EAAkB,CAAA,EAItB,IAAKlB,KAAKQ,EACLR,GAAK,MAAOgB,EAAMR,EAAMR,CAAAA,EACnBA,GAAK,MAAOiB,EAAMT,EAAMR,CAAAA,EAC5BkB,EAAgBlB,CAAAA,EAAKQ,EAAMR,CAAAA,EAUjC,GAPImB,UAAUC,OAAS,IACtBF,EAAgBH,SACfI,UAAUC,OAAS,EAAI/B,EAAMgC,KAAKF,UAAW,CAAA,EAAKJ,GAKjC,OAARD,GAAQ,YAAcA,EAAKQ,cAAgB,KACrD,IAAKtB,KAAKc,EAAKQ,aACVJ,EAAgBlB,CAAAA,IADNsB,SAEbJ,EAAgBlB,CAAAA,EAAKc,EAAKQ,aAAatB,CAAAA,GAK1C,OAAOuB,EAAYT,EAAMI,EAAiBF,EAAKC,EAAK,IAAA,CACpD,CAceM,SAAAA,EAAYT,EAAMN,EAAOQ,EAAKC,EAAKO,EAAAA,CAIlD,IAAMC,EAAQ,CACbX,KAAAA,EACAN,MAAAA,EACAQ,IAAAA,EACAC,IAAAA,EACAS,IAAW,KACXC,GAAS,KACTC,IAAQ,EACRC,IAAM,KAKNC,IAAAA,OACAC,IAAY,KACZC,YAAAA,OACAC,IAAWT,GAAAA,EAAqBjC,EAChC2C,IAAAA,GACAC,IAAQ,CAAA,EAMT,OAFIX,GAAY,MAAQlC,EAAQmC,OAAS,MAAMnC,EAAQmC,MAAMA,CAAAA,EAEtDA,CACP,CAAA,SAEeW,IAAAA,CACf,MAAO,CAAEC,QAAS,IAAA,CAClB,CAEeC,SAAAA,EAAS9B,EAAAA,CACxB,OAAOA,EAAMO,QACb,CC/EewB,SAAAA,EAAc/B,EAAOgC,EAAAA,CACpCC,KAAKjC,MAAQA,EACbiC,KAAKD,QAAUA,CACf,CA0EM,SAASE,EAAcjB,EAAOkB,EAAAA,CACpC,GAAIA,GAAc,KAEjB,OAAOlB,EAAAE,GACJe,EAAcjB,EAAeA,GAAAA,EAAAA,IAAe,CAAA,EAC5C,KAIJ,QADImB,EACGD,EAAalB,EAAAC,IAAgBN,OAAQuB,IAG3C,IAFAC,EAAUnB,EAAAC,IAAgBiB,CAAAA,IAEX,MAAQC,EAAAf,KAAgB,KAItC,OAAOe,EACPf,IAQF,OAA4B,OAAdJ,EAAMX,MAAQ,WAAa4B,EAAcjB,CAAAA,EAAS,IAChE,CA2CD,SAASoB,GAAwBpB,EAAAA,CAAjC,IAGWzB,EACJ8C,EAHN,IAAKrB,EAAQA,EAAHE,KAAqB,MAAQF,EAAKM,KAAe,KAAM,CAEhE,IADAN,EAAKI,IAAQJ,EAAKM,IAAYgB,KAAO,KAC5B/C,EAAI,EAAGA,EAAIyB,EAAKC,IAAWN,OAAQpB,IAE3C,IADI8C,EAAQrB,EAAAC,IAAgB1B,CAAAA,IACf,MAAQ8C,EAAAjB,KAAc,KAAM,CACxCJ,EAAKI,IAAQJ,EAAKM,IAAYgB,KAAOD,EAArCjB,IACA,KACA,CAGF,OAAOgB,GAAwBpB,CAAAA,CAC/B,CACD,CAAA,SA4BeuB,EAAcC,EAAAA,EAAAA,CAE1BA,EAADnB,MACCmB,EAAAnB,IAAAA,KACDrC,EAAcyD,KAAKD,CAAAA,GAAAA,CAClBE,EAAAA,OACFzD,IAAiBJ,EAAQ8D,sBAEzB1D,EAAeJ,EAAQ8D,oBACNzD,GAAOwD,CAAAA,CAEzB,CASD,SAASA,GAAAA,CAAT,IACKF,EAMEI,EAzGkBC,EAOjBC,EANHC,EACHC,EACAC,EACAC,EAmGD,IAHAlE,EAAcmE,KAAKhE,CAAAA,EAGXqD,EAAIxD,EAAcoE,MAAAA,GACrBZ,EAAAA,MACCI,EAAoB5D,EAAc2B,OAlGjCmC,EAAAA,OALNE,GADGD,GADoBF,EA0GNL,GAAAA,KAxGXpB,IACN6B,EAAc,CAAA,EACdC,EAAW,CAAA,EAERL,EAAAA,OACGC,EAAWjD,EAAO,CAAA,EAAIkD,CAAAA,GAC5BvB,IAAqBuB,EAAAvB,IAAqB,EACtC3C,EAAQmC,OAAOnC,EAAQmC,MAAM8B,CAAAA,EAEjCO,EACCR,EADGS,IAEHR,EACAC,EACAF,EACAA,IAAAA,EAAAA,IAAqBU,aJzII,GI0IzBR,EAAAA,IAAiC,CAACC,CAAAA,EAAU,KAC5CC,EACAD,GAAiBf,EAAcc,CAAAA,EAAYC,CAAAA,EJ5IlB,GI6ItBD,EAAArB,KACHwB,CAAAA,EAGDJ,EAAQtB,IAAauB,EAArBvB,IACAsB,EAAA5B,GAAAD,IAA2B6B,EAA3BrB,GAAAA,EAA8CqB,EAC9CU,GAAWP,EAAaH,EAAUI,CAAAA,EAE9BJ,EAAQ1B,KAAS4B,GACpBZ,GAAwBU,CAAAA,GA8EpB9D,EAAc2B,OAASiC,GAI1B5D,EAAcmE,KAAKhE,CAAAA,GAItBuD,EAAAA,IAAyB,CACzB,CAAA,SGlNee,GACfC,EACAC,EACAC,EACAC,EACAC,EACAC,EACAC,EACAf,EACAD,EACAiB,EACAf,EAAAA,CAAAA,IAEI3D,EAEHwD,EAEAmB,EAEAC,EAEAC,EAKGC,EAAeR,GAAkBA,EAAnB5C,KAAgDxB,EAE9D6E,EAAoBX,EAAahD,OAMrC,IAJAiD,EAAAvC,IAA0B2B,EAC1BuB,GAA0BX,EAAgBD,EAAcU,CAAAA,EACxDrB,EAASY,EAATvC,IAEK9B,EAAI,EAAGA,EAAI+E,EAAmB/E,KAClC2E,EAAaN,EAAA3C,IAAyB1B,CAAAA,IAEvB,MACO,OAAd2E,GAAc,WACA,OAAdA,GAAc,aAQrBnB,EADGmB,EAAAzC,MACHsB,GAAWvD,EAEA6E,EAAYH,EAADzC,GAAAA,GAAuBjC,EAI9C0E,EAAUzC,IAAUlC,EAGpB8D,EACCK,EACAQ,EACAnB,EACAe,EACAC,EACAC,EACAf,EACAD,EACAiB,EACAf,CAAAA,EAIDiB,EAASD,EAAH9C,IACF8C,EAAW1D,KAAOuC,EAASvC,KAAO0D,EAAW1D,MAC5CuC,EAASvC,KACZgE,EAASzB,EAASvC,IAAK,KAAM0D,CAAAA,EAE9BhB,EAAST,KACRyB,EAAW1D,IACX0D,EAAA5C,KAAyB6C,EACzBD,CAAAA,GAIEE,GAAiB,MAAQD,GAAU,OACtCC,EAAgBD,GP1GS,MO8GzBD,EAAAxC,KACAqB,EAAA9B,MAAuBiD,EAFxBjD,KAKK+B,GAAAA,CAAWA,EAAOyB,cACrBzB,EAASf,EAAcc,CAAAA,GAExBC,EAAS0B,GAAOR,EAAYlB,EAAQU,CAAAA,GAEV,OAAnBQ,EAAW7D,MAAQ,YAC1B6D,EAAU7C,MADQhB,OAMlB2C,EAASkB,EAAH7C,IACI8C,IACVnB,EAASmB,EAAOQ,aAQjBT,EAAAA,IAAAA,OAGAA,EAAAA,KAAAA,SAaDN,EAAAvC,IAA0B2B,EAC1BY,EAAAxC,IAAsBgD,CACtB,CAOD,SAASG,GAA0BX,EAAgBD,EAAcU,EAAAA,CAAjE,IAEK9E,EAEA2E,EAEAnB,EA8DG6B,EAmCAC,EA/FDP,EAAoBX,EAAahD,OACnCmE,EAAoBT,EAAY1D,OACnCoE,EAAuBD,EAEpBE,EAAO,EAGX,IADApB,EAAA3C,IAA2B,CAAA,EACtB1B,EAAI,EAAGA,EAAI+E,EAAmB/E,IAqD5BqF,EAAcrF,EAAIyF,GA3CvBd,EAAaN,EAAA3C,IAAyB1B,CAAAA,GAPvC2E,EAAaP,EAAapE,CAAAA,IAGX,MACO,OAAd2E,GAAc,WACA,OAAdA,GAAc,WAEsB,KAMtB,OAAdA,GAAc,UACA,OAAdA,GAAc,UAEA,OAAdA,GAAc,UACrBA,EAAW3C,aAAe0D,OAEiBnE,EAC1C,KACAoD,EACA,KACA,KACA,IAAA,EAESvE,EAAQuE,CAAAA,EACyBpD,EAC1Ce,EACA,CAAEvB,SAAU4D,CAAAA,EACZ,KACA,KACA,IAAA,EAESA,EAAW3C,cAFpB,QAEiD2C,EAAAA,IAAoB,EAK3BpD,EAC1CoD,EAAW7D,KACX6D,EAAWnE,MACXmE,EAAW3D,IACX2D,EAAW1D,IAAM0D,EAAW1D,IAAM,KAClC0D,EALqD1C,GAAAA,EAQX0C,IAM1B,MA6BlBA,EAAAA,GAAqBN,EACrBM,EAAAA,IAAoBN,EAAAA,IAAwB,EAEtCiB,EAAgBK,GACrBhB,EACAG,EACAO,EACAG,CAAAA,EAMDb,EAAUzC,IAAUoD,EAEpB9B,EAAW,KACP8B,IADO,KAGVE,KADAhC,EAAWsB,EAAYQ,CAAAA,KAGtB9B,EAAQrB,KPtRW,SO6RFqB,GAAY,MAAQA,EAAQvB,MAAe,MAGzDqD,GAH0CrD,IAI7CwD,IAI6B,OAAnBd,EAAW7D,MAAQ,aAC7B6D,EAAUxC,KPxSc,QO0SfmD,IAAkBD,IACxBC,IAAkBD,EAAc,EACnCI,IACUH,EAAgBD,EACtBG,EAAuBT,EAAoBM,EAC9CI,GAAQH,EAAgBD,EAExBI,IAESH,EAAgBD,EACtBC,GAAiBD,EAAc,IAClCI,EAAOH,EAAgBD,GAGxBI,EAAO,EAKJH,IAAkBtF,EAAIyF,IACzBd,EAAAxC,KP9TwB,UOwOzBqB,EAAWsB,EAAYO,CAAAA,IAGtB7B,EAASxC,KAAO,MAChBwC,EAAAA,KP1OmB,SO2OlBA,EAAArB,OAEGqB,EAAQ3B,KAASwC,EAAjBvC,MACHuC,EAAAvC,IAA0BY,EAAcc,CAAAA,GAGzCoC,EAAQpC,EAAUA,EAAAA,EAAU,EAW5BsB,EAAYO,CAAAA,EAAe,KAC3BG,KAwEH,GAAIA,EACH,IAAKxF,EAAI,EAAGA,EAAIuF,EAAmBvF,KAClCwD,EAAWsB,EAAY9E,CAAAA,IACP,MPxUI,SOwUKwD,EAAArB,OACpBqB,EAAQ3B,KAASwC,EAAjBvC,MACHuC,EAAAvC,IAA0BY,EAAcc,CAAAA,GAGzCoC,EAAQpC,EAAUA,CAAAA,EAIrB,CAQD,SAAS2B,GAAOU,EAAapC,EAAQU,EAAAA,CAArC,IAIMpD,EACKf,EAFV,GAA+B,OAApB6F,EAAY/E,MAAQ,WAAY,CAE1C,IADIC,EAAW8E,EAAHnE,IACH1B,EAAI,EAAGe,GAAYf,EAAIe,EAASK,OAAQpB,IAC5Ce,EAASf,CAAAA,IAKZe,EAASf,CAAAA,EAAT2B,GAAsBkE,EACtBpC,EAAS0B,GAAOpE,EAASf,CAAAA,EAAIyD,EAAQU,CAAAA,GAIvC,OAAOV,CACP,CAAUoC,EAAAA,KAAoBpC,IAC9BU,EAAU2B,aAAaD,EAAvBhE,IAAyC4B,GAAU,IAAA,EACnDA,EAASoC,EAAHhE,KAGP,GACC4B,EAASA,GAAUA,EAAO2B,kBAClB3B,GAAU,MAAQA,EAAOsC,WAAa,GAE/C,OAAOtC,CACP,CAQM,SAASuC,GAAajF,EAAUkF,EAAAA,CAUtC,OATAA,EAAMA,GAAO,CAAA,EACTlF,GAAY,MAA2B,OAAZA,GAAY,YAChCX,EAAQW,CAAAA,EAClBA,EAASmF,KAAK,SAAApD,EAAAA,CACbkD,GAAalD,EAAOmD,CAAAA,CACpB,CAAA,EAEDA,EAAI/C,KAAKnC,CAAAA,GAEHkF,CACP,CASD,SAASN,GACRhB,EACAG,EACAO,EACAG,EAAAA,CAJD,IAMOxE,EAAM2D,EAAW3D,IACjBF,EAAO6D,EAAW7D,KACpBqF,EAAId,EAAc,EAClBe,EAAIf,EAAc,EAClB7B,EAAWsB,EAAYO,CAAAA,EAc3B,GACC7B,IAAa,MACZA,GACAxC,GAAOwC,EAASxC,KAChBF,IAAS0C,EAAS1C,MP5aE,SO6anB0C,EAAArB,KAEF,OAAOkD,EACD,GAXNG,GACChC,GAAY,MPtaQ,SOsaCA,EAAAA,KAAmC,EAAI,GAW7D,KAAO2C,GAAK,GAAKC,EAAItB,EAAY1D,QAAQ,CACxC,GAAI+E,GAAK,EAAG,CAEX,IADA3C,EAAWsB,EAAYqB,CAAAA,IPnbJ,SOsbjB3C,EAAArB,MACDnB,GAAOwC,EAASxC,KAChBF,IAAS0C,EAAS1C,KAElB,OAAOqF,EAERA,GACA,CAED,GAAIC,EAAItB,EAAY1D,OAAQ,CAE3B,IADAoC,EAAWsB,EAAYsB,CAAAA,IPhcJ,SOmcjB5C,EAAQrB,MACTnB,GAAOwC,EAASxC,KAChBF,IAAS0C,EAAS1C,KAElB,OAAOsF,EAERA,GACA,CACD,CAGF,MAAA,EACA,CFndD,SAASC,EAASC,EAAOtF,EAAKuF,EAAAA,CACzBvF,EAAI,CAAA,IAAO,IACdsF,EAAME,YAAYxF,EAAKuF,GAAgB,EAAKA,EAE5CD,EAAMtF,CAAAA,EADIuF,GAAS,KACN,GACa,OAATA,GAAS,UAAYpG,GAAmBsG,KAAKzF,CAAAA,EACjDuF,EAEAA,EAAQ,IAEtB,CAuBeC,SAAAA,EAAYE,EAAKC,EAAMJ,EAAOK,EAAUpC,EAAAA,CACvD,IAAIqC,EAEJC,EAAG,GAAIH,IAAS,QACf,GAAoB,OAATJ,GAAS,SACnBG,EAAIJ,MAAMS,QAAUR,MACd,CAKN,GAJuB,OAAZK,GAAY,WACtBF,EAAIJ,MAAMS,QAAUH,EAAW,IAG5BA,EACH,IAAKD,KAAQC,EACNL,GAASI,KAAQJ,GACtBF,EAASK,EAAIJ,MAAOK,EAAM,EAAA,EAK7B,GAAIJ,EACH,IAAKI,KAAQJ,EACPK,GAAYL,EAAMI,CAAAA,IAAUC,EAASD,CAAAA,GACzCN,EAASK,EAAIJ,MAAOK,EAAMJ,EAAMI,CAAAA,CAAAA,CAInC,SAGOA,EAAK,CAAA,IAAO,KAAOA,EAAK,CAAA,IAAO,IACvCE,EACCF,KAAUA,EAAOA,EAAKK,QAAQ,8BAA+B,IAAA,GAQ7DL,EAJAA,EAAKM,YAAAA,IAAiBP,GACtBC,IAAS,cACTA,IAAS,YAEFA,EAAKM,YAAAA,EAAc5H,MAAM,CAAA,EACrBsH,EAAKtH,MAAM,CAAA,EAElBqH,EAALQ,IAAqBR,EAAGQ,EAAc,CAAjB,GACrBR,EAAGQ,EAAYP,EAAOE,CAAAA,EAAcN,EAEhCA,EACEK,EAQJL,EAAMY,EAAYP,EAASO,GAP3BZ,EAAMY,EAAYtH,EAClB6G,EAAIU,iBACHT,EACAE,EAAa9G,EAAoBD,EACjC+G,CAAAA,GAMFH,EAAIW,oBACHV,EACAE,EAAa9G,EAAoBD,EACjC+G,CAAAA,MAGI,CACN,GAAIrC,GAAa,6BAIhBmC,EAAOA,EAAKK,QAAQ,cAAe,GAAA,EAAKA,QAAQ,SAAU,GAAA,UAE1DL,GAAQ,SACRA,GAAQ,UACRA,GAAQ,QACRA,GAAQ,QACRA,GAAQ,QAGRA,GAAQ,YACRA,GAAQ,YACRA,GAAQ,WACRA,GAAQ,WACRA,GAAQ,QACRA,KAAQD,EAER,GAAA,CACCA,EAAIC,CAAAA,EAAQJ,GAAgB,GAE5B,MAAMO,CAAAA,MACEQ,CAAAA,CAUU,OAATf,GAAS,aAETA,GAAS,MAASA,IAAlBA,IAAqCI,EAAK,CAAA,IAAO,IAG3DD,EAAIa,gBAAgBZ,CAAAA,EAFpBD,EAAIc,aAAab,EAAMJ,CAAAA,EAIxB,CACD,CAOD,SAASkB,EAAiBZ,EAAAA,CAMzB,OAAO,SAAUS,EAAAA,CAChB,GAAI7E,KAAiByE,EAAA,CACpB,IAAMQ,EAAejF,KAAAyE,EAAgBI,EAAExG,KAAO+F,CAAAA,EAC9C,GAAIS,EAAEK,GAAe,KACpBL,EAAEK,EAAc9H,YAKNyH,EAAEK,EAAcD,EAAaP,EACvC,OAED,OAAOO,EAAapI,EAAQsI,MAAQtI,EAAQsI,MAAMN,CAAAA,EAAKA,CAAAA,CACvD,CACD,CACD,CG3IM,SAASxD,EACfK,EACAZ,EACAC,EACAe,EACAC,EACAC,EACAf,EACAD,EACAiB,EACAf,EAAAA,CAVM,IAaFkE,EAkBE5E,EAAG6E,EAAOC,EAAUC,EAAUC,EAAUC,EACxCC,EAKAC,EACAC,EAuGOrI,EA4BPsI,EACHC,EASSvI,EA6BNoE,EAlMLoE,EAAUjF,EAASzC,KAIpB,GAAIyC,EAASvB,cAAb,OAAwC,OAAA,KR9CX,IQiDzBwB,EAAArB,MACHuC,EAAAA,CAAAA,ERpD0B,GQoDTlB,EAAQrB,KAEzBsC,EAAoB,CADpBhB,EAASF,EAAQ1B,IAAQ2B,EAAhB3B,GAAAA,IAILgG,EAAMvI,EAAXsC,MAA2BiG,EAAItE,CAAAA,EAE/BkF,EAAO,GAAsB,OAAXD,GAAW,WAC5B,GAAA,CAgEC,GA9DIL,EAAW5E,EAAS/C,MAKpB4H,GADJP,EAAMW,EAAQE,cACQnE,EAAcsD,EAApC9F,GAAAA,EACIsG,EAAmBR,EACpBO,EACCA,EAAS5H,MAAM+F,MACfsB,EAAAA,GACDtD,EAGCf,EAAJzB,IAECmG,GADAjF,EAAIM,EAAAxB,IAAsByB,EAAtBzB,KACwBJ,GAAwBsB,EACpD0F,KAEI,cAAeH,GAAWA,EAAQI,UAAUC,OAE/CtF,EAAQxB,IAAckB,EAAI,IAAIuF,EAAQL,EAAUE,CAAAA,GAGhD9E,EAAAxB,IAAsBkB,EAAI,IAAIV,EAC7B4F,EACAE,CAAAA,EAEDpF,EAAEjB,YAAcwG,EAChBvF,EAAE4F,OAASC,IAERV,GAAUA,EAASW,IAAI9F,CAAAA,EAE3BA,EAAEzC,MAAQ2H,EACLlF,EAAE+F,QAAO/F,EAAE+F,MAAQ,CAAV,GACd/F,EAAET,QAAU6F,EACZpF,EAACgG,IAAkB1E,EACnBuD,EAAQ7E,EAAAA,IAAAA,GACRA,EAAAiG,IAAqB,CAAA,EACrBjG,EAAAkG,IAAoB,CAAA,GAIjBlG,EAAAmG,KAAgB,OACnBnG,EAACmG,IAAcnG,EAAE+F,OAGdR,EAAQa,0BAA4B,OACnCpG,EAAAmG,KAAgBnG,EAAE+F,QACrB/F,EAACmG,IAAc9I,EAAO,CAAA,EAAI2C,EAAAA,GAAAA,GAG3B3C,EACC2C,EACAuF,IAAAA,EAAQa,yBAAyBlB,EAAUlF,EAFtCmG,GAAAA,CAAAA,GAMPrB,EAAW9E,EAAEzC,MACbwH,EAAW/E,EAAE+F,MACb/F,EAAAhB,IAAWsB,EAGPuE,EAEFU,EAAQa,0BAA4B,MACpCpG,EAAEqG,oBAAsB,MAExBrG,EAAEqG,mBAAAA,EAGCrG,EAAEsG,mBAAqB,MAC1BtG,EAACiG,IAAkBhG,KAAKD,EAAEsG,iBAAAA,MAErB,CASN,GAPCf,EAAQa,0BAA4B,MACpClB,IAAaJ,GACb9E,EAAEuG,2BAA6B,MAE/BvG,EAAEuG,0BAA0BrB,EAAUE,CAAAA,EAAAA,CAIrCpF,EAADpB,MACEoB,EAAEwG,uBAAyB,MAC5BxG,EAAEwG,sBACDtB,EACAlF,EAFDmG,IAGCf,CAAAA,IAJEoB,IAMHlG,EAAAtB,MAAuBuB,EAAvBvB,KACA,CAkBD,IAhBIsB,EAAAtB,MAAuBuB,EAAvBvB,MAKHgB,EAAEzC,MAAQ2H,EACVlF,EAAE+F,MAAQ/F,EACVA,IAAAA,EAAAnB,IAAAA,IAGDyB,EAAA1B,IAAgB2B,EAAhB3B,IACA0B,EAAQ7B,IAAa8B,EAArB9B,IACA6B,EAAQ7B,IAAWgI,QAAQ,SAAAjI,EAAAA,CACtBA,IAAOA,EAAAE,GAAgB4B,EAC3B,CAAA,EAEQvD,EAAI,EAAGA,EAAIiD,EAAAkG,IAAkB/H,OAAQpB,IAC7CiD,EAACiG,IAAkBhG,KAAKD,EAACkG,IAAiBnJ,CAAAA,CAAAA,EAE3CiD,EAAAkG,IAAoB,CAAA,EAEhBlG,EAAAiG,IAAmB9H,QACtBsC,EAAYR,KAAKD,CAAAA,EAGlB,MAAMwF,CACN,CAEGxF,EAAE0G,qBAAuB,MAC5B1G,EAAE0G,oBAAoBxB,EAAUlF,EAAcoF,IAAAA,CAAAA,EAG3CpF,EAAE2G,oBAAsB,MAC3B3G,EAAAiG,IAAmBhG,KAAK,UAAA,CACvBD,EAAE2G,mBAAmB7B,EAAUC,EAAUC,CAAAA,CACzC,CAAA,CAEF,CASD,GAPAhF,EAAET,QAAU6F,EACZpF,EAAEzC,MAAQ2H,EACVlF,EAAAc,IAAeI,EACflB,EAAApB,IAAAA,GAEIyG,EAAahJ,EAAjBuK,IACCtB,EAAQ,EACL,cAAeC,GAAWA,EAAQI,UAAUC,OAAQ,CAQvD,IAPA5F,EAAE+F,MAAQ/F,EACVA,IAAAA,EAAAA,IAAAA,GAEIqF,GAAYA,EAAW/E,CAAAA,EAE3BsE,EAAM5E,EAAE4F,OAAO5F,EAAEzC,MAAOyC,EAAE+F,MAAO/F,EAAET,OAAAA,EAE1BxC,EAAI,EAAGA,EAAIiD,EAACkG,IAAiB/H,OAAQpB,IAC7CiD,EAACiG,IAAkBhG,KAAKD,EAAAkG,IAAkBnJ,CAAAA,CAAAA,EAE3CiD,EAAAkG,IAAoB,CAAA,CACpB,KACA,IACClG,EAAAnB,IAAAA,GACIwG,GAAYA,EAAW/E,CAAAA,EAE3BsE,EAAM5E,EAAE4F,OAAO5F,EAAEzC,MAAOyC,EAAE+F,MAAO/F,EAAET,OAAAA,EAGnCS,EAAE+F,MAAQ/F,EAAVmG,UACQnG,EAACnB,KAAAA,EAAayG,EAAQ,IAIhCtF,EAAE+F,MAAQ/F,EAAVmG,IAEInG,EAAE6G,iBAAmB,OACxBvF,EAAgBjE,EAAOA,EAAO,CAAD,EAAKiE,CAAAA,EAAgBtB,EAAE6G,gBAAAA,CAAAA,GAGhDhC,GAAS7E,EAAE8G,yBAA2B,OAC1C9B,EAAWhF,EAAE8G,wBAAwBhC,EAAUC,CAAAA,GAOhD9D,GACCC,EACA/D,EAJGgE,EADHyD,GAAO,MAAQA,EAAI/G,OAASwB,GAAYuF,EAAI7G,KAAO,KACZ6G,EAAIrH,MAAMO,SAAW8G,CAAAA,EAIpCzD,EAAe,CAACA,CAAAA,EACxCb,EACAC,EACAe,EACAC,EACAC,EACAf,EACAD,EACAiB,EACAf,CAAAA,EAGDV,EAAEF,KAAOQ,EAGTA,IAAAA,EAAApB,KAAAA,KAEIc,EAAAA,IAAmB7B,QACtBsC,EAAYR,KAAKD,CAAAA,EAGdiF,IACHjF,EAAAA,IAAkBA,EAAAtB,GAAyB,KAkB5C,OAhBQ2F,EAAAA,CACR/D,EAAQtB,IAAa,KAEjByC,GAAeD,GAAqB,MACvClB,EAAQ1B,IAAQ4B,EAChBF,EAAApB,KAAmBuC,EAChBtF,IRhRqB,GQkRxBqF,EAAkBA,EAAkBuF,QAAQvG,CAAAA,CAAAA,EAAW,OAIvDF,EAAA1B,IAAgB2B,EAAhB3B,IACA0B,EAAQ7B,IAAa8B,EACrB9B,KACDpC,EAAOuC,IAAayF,EAAG/D,EAAUC,CAAAA,CACjC,MAEDiB,GAAqB,MACrBlB,EAAAtB,MAAuBuB,EAAvBvB,KAEAsB,EAAA7B,IAAqB8B,EAArB9B,IACA6B,EAAQ1B,IAAQ2B,EAChB3B,KACA0B,EAAQ1B,IAAQoI,GACfzG,EAD+B3B,IAE/B0B,EACAC,EACAe,EACAC,EACAC,EACAf,EACAgB,EACAf,CAAAA,GAIGkE,EAAMvI,EAAQ4K,SAASrC,EAAItE,CAAAA,CAChC,CAAA,SAOeU,GAAWP,EAAayG,EAAMxG,EAAAA,CAC7CwG,EAAIrI,IAAAA,OAEJ,QAAS9B,EAAI,EAAGA,EAAI2D,EAASvC,OAAQpB,IACpCiF,EAAStB,EAAS3D,CAAAA,EAAI2D,EAAAA,EAAW3D,CAAAA,EAAI2D,EAAAA,EAAW3D,CAAAA,CAAAA,EAG7CV,EAAiBA,KAAAA,EAAAyC,IAAgBoI,EAAMzG,CAAAA,EAE3CA,EAAYwC,KAAK,SAAAjD,EAAAA,CAChB,GAAA,CAECS,EAAcT,EAAdiG,IACAjG,EAAAiG,IAAqB,CAAA,EACrBxF,EAAYwC,KAAK,SAAAkE,EAAAA,CAEhBA,EAAG/I,KAAK4B,CAAAA,CACR,CAAA,CAGD,OAFQqE,EAAAA,CACRhI,EAAAuC,IAAoByF,EAAGrE,EAAvBhB,GAAAA,CACA,CACD,CAAA,CACD,CAiBD,SAASgI,GACRvD,EACAnD,EACAC,EACAe,EACAC,EACAC,EACAf,EACAgB,EACAf,EAAAA,CATD,IAeK3D,EAEAqK,EAEAC,EAEAC,EACAhE,EACAiE,EACAC,EAbA1C,EAAWvE,EAAShD,MACpB2H,EAAW5E,EAAS/C,MACpBuF,EAAkCxC,EAASzC,KAmB/C,GALIiF,IAAa,MAAOvB,EAAY,6BAC3BuB,IAAa,OACrBvB,EAAY,qCACHA,IAAWA,EAAY,gCAE7BC,GAAqB,MACxB,IAAKzE,EAAI,EAAGA,EAAIyE,EAAkBrD,OAAQpB,IAMzC,IALAuG,EAAQ9B,EAAkBzE,CAAAA,IAOzB,iBAAkBuG,GAAAA,CAAAA,CAAYR,IAC7BA,EAAWQ,EAAMmE,YAAc3E,EAAWQ,EAAMR,WAAa,GAC7D,CACDW,EAAMH,EACN9B,EAAkBzE,CAAAA,EAAK,KACvB,KACA,EAIH,GAAI0G,GAAO,KAAM,CAChB,GAAIX,IAAa,KAChB,OAAO4E,SAASC,eAAezC,CAAAA,EAGhCzB,EAAMiE,SAASE,gBACdrG,EACAuB,EACAoC,EAAS2C,IAAM3C,CAAAA,EAIhB1D,EAAoB,KAGpBC,EAAAA,EACA,CAED,GAAIqB,IAAa,KAEZgC,IAAaI,GAAczD,GAAegC,EAAIqE,OAAS5C,IAC1DzB,EAAIqE,KAAO5C,OAEN,CASN,GAPA1D,EAAoBA,GAAqBpF,EAAMgC,KAAKqF,EAAIsE,UAAAA,EAExDjD,EAAWvE,EAAShD,OAASP,EAAAA,CAKxByE,GAAeD,GAAqB,KAExC,IADAsD,EAAW,CAAX,EACK/H,EAAI,EAAGA,EAAI0G,EAAIuE,WAAW7J,OAAQpB,IAEtC+H,GADAxB,EAAQG,EAAIuE,WAAWjL,CAAAA,GACR2G,IAAAA,EAAQJ,EAAMA,MAI/B,IAAKvG,KAAK+H,EAET,GADAxB,EAAQwB,EAAS/H,CAAAA,EACbA,GAAK,YACEA,GAAAA,GAAK,0BACfsK,EAAU/D,UACAvG,IAAM,OAANA,EAAiBA,KAAKmI,GAAW,CAC3C,GACEnI,GAAK,SAAW,iBAAkBmI,GAClCnI,GAAK,WAAa,mBAAoBmI,EAEvC,SAED3B,EAAYE,EAAK1G,EAAG,KAAMuG,EAAO/B,CAAAA,CACjC,EAKF,IAAKxE,KAAKmI,EACT5B,EAAQ4B,EAASnI,CAAAA,EACbA,GAAK,WACRuK,EAAchE,EACJvG,GAAK,0BACfqK,EAAU9D,EACAvG,GAAK,QACfwK,EAAajE,EACHvG,GAAK,UACfyK,EAAUlE,EAEVvG,IAAM,OACJ0E,GAA+B,OAAT6B,GAAS,YACjCwB,EAAS/H,CAAAA,IAAOuG,GAEhBC,EAAYE,EAAK1G,EAAGuG,EAAOwB,EAAS/H,CAAAA,EAAIwE,CAAAA,EAK1C,GAAI6F,EAGD3F,GACC4F,IACAD,EAAAA,SAAmBC,EACnBD,QAAAA,EAAAa,SAAmBxE,EAAIyE,aAEzBzE,EAAIyE,UAAYd,EAAAA,QAGjB9G,EAAA7B,IAAqB,CAAA,UAEjB4I,IAAS5D,EAAIyE,UAAY,IAE7BjH,GACCwC,EACAtG,EAAQmK,CAAAA,EAAeA,EAAc,CAACA,CAAAA,EACtChH,EACAC,EACAe,EACAwB,IAAa,gBACV,+BACAvB,EACHC,EACAf,EACAe,EACGA,EAAkB,CAAA,EAClBjB,EAAA9B,KAAsBgB,EAAcc,EAAU,CAAA,EACjDkB,EACAf,CAAAA,EAIGc,GAAqB,KACxB,IAAKzE,EAAIyE,EAAkBrD,OAAQpB,KAC9ByE,EAAkBzE,CAAAA,GAAM,MAAMS,GAAWgE,EAAkBzE,CAAAA,CAAAA,EAM7D0E,IACJ1E,EAAI,QAEHwK,IAFG,SAOFA,IAAe9D,EAAI1G,CAAAA,GAClB+F,IAAa,YAAbA,CAA4ByE,GAI5BzE,IAAa,UAAYyE,IAAezC,EAAS/H,CAAAA,IAEnDwG,EAAYE,EAAK1G,EAAGwK,EAAYzC,EAAS/H,CAAAA,EAAIwE,CAAAA,EAG9CxE,EAAI,UACAyK,IADA,QACyBA,IAAY/D,EAAI1G,CAAAA,GAC5CwG,EAAYE,EAAK1G,EAAGyK,EAAS1C,EAAS/H,CAAAA,EAAIwE,CAAAA,EAG5C,CAED,OAAOkC,CACP,CAQezB,SAAAA,EAAShE,EAAKsF,EAAO9E,EAAAA,CACpC,GAAA,CACmB,OAAPR,GAAO,WAAYA,EAAIsF,CAAAA,EAC7BtF,EAAIoB,QAAUkE,CAGnB,OAFQe,EAAAA,CACRhI,EAAOuC,IAAayF,EAAG7F,CAAAA,CACvB,CACD,CASM,SAASmE,EAAQnE,EAAOoE,EAAauF,EAAAA,CAArC,IACFC,EAsBMrL,EAbV,GARIV,EAAQsG,SAAStG,EAAQsG,QAAQnE,CAAAA,GAEhC4J,EAAI5J,EAAMR,OACToK,EAAEhJ,SAAWgJ,EAAEhJ,UAAYZ,EAAhCI,KACCoD,EAASoG,EAAG,KAAMxF,CAAAA,IAIfwF,EAAI5J,EAALM,MAA0B,KAAM,CACnC,GAAIsJ,EAAEC,qBACL,GAAA,CACCD,EAAEC,qBAAAA,CAGF,OAFQhE,EAAAA,CACRhI,EAAAuC,IAAoByF,EAAGzB,CAAAA,CACvB,CAGFwF,EAAEtI,KAAOsI,EAACtH,IAAc,IACxB,CAED,GAAKsH,EAAI5J,EAAHC,IACL,IAAS1B,EAAI,EAAGA,EAAIqL,EAAEjK,OAAQpB,IACzBqL,EAAErL,CAAAA,GACL4F,EACCyF,EAAErL,CAAAA,EACF6F,EACAuF,GAAmC,OAAd3J,EAAMX,MAAQ,UAARA,EAM1BsK,GAAc3J,EAAAI,KAAc,MAChCpB,GAAWgB,EAADI,GAAAA,EAKXJ,EAAAM,IAAmBN,EAAKE,GAAWF,EAAAI,IAAaJ,EAAKK,IAAAA,MACrD,CAGD,SAASgH,GAAStI,EAAOwI,EAAOxG,EAAAA,CAC/B,OAAOC,KAAKT,YAAYxB,EAAOgC,CAAAA,CAC/B,CC7lBeqG,SAAAA,GAAOpH,EAAO0C,EAAWoH,EAAAA,CAAzB1C,IAMXnE,EAOAlB,EAQAE,EACHC,EArBGrE,EAAeA,IAAAA,EAAAqC,GAAcF,EAAO0C,CAAAA,EAYpCX,GAPAkB,EAAoC,OAAf6G,GAAe,YAQrC,KACCA,GAAeA,EAAhB7J,KAA0CyC,EAF7CzC,IAQIgC,EAAc,CAAA,EACjBC,EAAW,CAAA,EACZG,EACCK,EAPD1C,GAAAA,CAAWiD,GAAe6G,GAAgBpH,GAAlCzC,IACPb,GAAcyB,EAAU,KAAM,CAACb,CAAAA,CAAAA,EAU/B+B,GAAYvD,EACZA,EACAkE,EAAUH,aAAAA,CACTU,GAAe6G,EACb,CAACA,CAAAA,EACD/H,EACA,KACAW,EAAUqH,WACVnM,EAAMgC,KAAK8C,EAAU6G,UAAAA,EACrB,KACHtH,EAAAA,CACCgB,GAAe6G,EACbA,EACA/H,EACAA,EACAW,IAAAA,EAAUqH,WACb9G,EACAf,CAAAA,EAIDM,GAAWP,EAAajC,EAAOkC,CAAAA,CAC/B,CAOM,SAAS8H,GAAQhK,EAAO0C,EAAAA,CAC9B0E,GAAOpH,EAAO0C,EAAWsH,EAAAA,CACzB,CAAA,SC5DeC,GAAajK,EAAOjB,EAAOO,EAAAA,CAAAA,IAEzCC,EACAC,EACAjB,EAEGsB,EALAJ,EAAkBZ,EAAO,CAAD,EAAKmB,EAAMjB,KAAAA,EAWvC,IAAKR,KAJDyB,EAAMX,MAAQW,EAAMX,KAAKQ,eAC5BA,EAAeG,EAAMX,KAAKQ,cAGjBd,EACLR,GAAK,MAAOgB,EAAMR,EAAMR,CAAAA,EACnBA,GAAK,MAAOiB,EAAMT,EAAMR,CAAAA,EAEhCkB,EAAgBlB,CAAAA,EADRQ,EAAMR,CAAAA,IACEA,QADkBsB,IAApBtB,OACOsB,EAAatB,CAAAA,EAEbQ,EAAMR,CAAAA,EAS7B,OALImB,UAAUC,OAAS,IACtBF,EAAgBH,SACfI,UAAUC,OAAS,EAAI/B,EAAMgC,KAAKF,UAAW,CAAA,EAAKJ,GAG7CQ,EACNE,EAAMX,KACNI,EACAF,GAAOS,EAAMT,IACbC,GAAOQ,EAAMR,IACb,IAAA,CAED,CJ1Ce0K,SAAAA,GAAcC,EAAcC,EAAAA,CAG3C,IAAMrJ,EAAU,CACfT,IAHD8J,EAAY,OAAS7L,IAIpB2B,GAAeiK,EAEfE,SAJe,SAINtL,EAAOuL,EAAAA,CAIf,OAAOvL,EAAMO,SAASgL,CAAAA,CACtB,EAEDC,SAAAA,SAASxL,EAAAA,CAAAA,IAGHyL,EACAC,EAsCL,OAzCKzJ,KAAKqH,kBAELmC,EAAO,CAAA,GACPC,EAAM,CAAV,GACIL,CAAAA,EAAapJ,KAEjBA,KAAKqH,gBAAkB,UAAA,CAAA,OAAMoC,CAAN,EAEvBzJ,KAAKgH,sBAAwB,SAAU0C,EAAAA,CAClC1J,KAAKjC,MAAM+F,QAAU4F,EAAO5F,OAe/B0F,EAAK/F,KAAK,SAAAjD,EAAAA,CACTA,EAACpB,IAAAA,GACDmB,EAAcC,CAAAA,CACd,CAAA,CAEF,EAEDR,KAAKsG,IAAM,SAAA9F,EAAAA,CACVgJ,EAAK/I,KAAKD,CAAAA,EACV,IAAImJ,EAAMnJ,EAAEqI,qBACZrI,EAAEqI,qBAAuB,UAAA,CACxBW,EAAKI,OAAOJ,EAAKjC,QAAQ/G,CAAAA,EAAI,CAAA,EACzBmJ,GAAKA,EAAI/K,KAAK4B,CAAAA,CAClB,CACD,GAGKzC,EAAMO,QACb,CAAA,EASF,OAAQyB,EAAQwJ,SAAuBxJ,GAAAA,EAAQsJ,SAASpD,YACvDlG,CACD,CL5CYnD,EAAQa,EAAUb,MCjBzBC,EAAU,CACfuC,ISHM,SAAqByK,EAAO7K,EAAO+B,EAAU+I,EAAAA,CAQnD,QANIjJ,EAEHkJ,EAEAC,EAEOhL,EAAQA,EAAhBE,IACC,IAAK2B,EAAY7B,EAAHM,MAAAA,CAAyBuB,EAAD3B,GACrC,GAAA,CAcC,IAbA6K,EAAOlJ,EAAUtB,cAELwK,EAAKE,0BAA4B,OAC5CpJ,EAAUqJ,SAASH,EAAKE,yBAAyBJ,CAAAA,CAAAA,EACjDG,EAAUnJ,EAAHxB,KAGJwB,EAAUsJ,mBAAqB,OAClCtJ,EAAUsJ,kBAAkBN,EAAOC,GAAa,CAAhD,CAAA,EACAE,EAAUnJ,EACVxB,KAGG2K,EACH,OAAQnJ,EAASqF,IAAiBrF,CAInC,OAFQgE,EAAAA,CACRgF,EAAQhF,CACR,CAIH,MAAMgF,CACN,CAAA,ERxCG/M,EAAU,EAgGDC,GAAiB,SAAAiC,EAAAA,CAC7BA,OAAAA,GAAS,MAAQA,EAAMO,aAAe6K,IADJ,ECxEnCtK,EAAcqG,UAAU+D,SAAW,SAAUG,EAAQC,EAAAA,CAEpD,IAAIC,EAEHA,EADGvK,KAAA2G,KAAmB,MAAQ3G,KAAA2G,MAAoB3G,KAAKuG,MACnDvG,KAAH2G,IAEG3G,KAAA2G,IAAkB9I,EAAO,CAAD,EAAKmC,KAAKuG,KAAAA,EAGlB,OAAV8D,GAAU,aAGpBA,EAASA,EAAOxM,EAAO,CAAA,EAAI0M,CAAAA,EAAIvK,KAAKjC,KAAAA,GAGjCsM,GACHxM,EAAO0M,EAAGF,CAAAA,EAIPA,GAAU,MAEVrK,KAAJR,MACK8K,GACHtK,KAAA0G,IAAqBjG,KAAK6J,CAAAA,EAE3B/J,EAAcP,IAAAA,EAEf,EAQDF,EAAcqG,UAAUqE,YAAc,SAAUF,EAAAA,CAC3CtK,KAAAA,MAIHA,KAAAZ,IAAAA,GACIkL,GAAUtK,KAAAyG,IAAsBhG,KAAK6J,CAAAA,EACzC/J,EAAcP,IAAAA,EAEf,EAYDF,EAAcqG,UAAUC,OAASvG,EA8F7B7C,EAAgB,CAAA,EAadE,EACa,OAAXuN,SAAW,WACfA,QAAQtE,UAAUuE,KAAKC,KAAKF,QAAQG,QAAAA,CAAAA,EACpCC,WAuBE1N,EAAY,SAAC2N,EAAGC,EAAAA,CAAMD,OAAAA,EAAAtL,IAAAL,IAAkB4L,EAA5BvL,IAAAL,GAAA,EAuBlBuB,EAAO0G,IAAkB,ECtNrBhK,EAAa,EAkJXC,EAAa2H,EAAAA,EAAiB,EAC9B1H,EAAoB0H,EAAAA,EAAiB,EC3KhCzH,EAAI","names":["MODE_HYDRATE","slice","options","vnodeId","isValidElement","rerenderQueue","prevDebounce","defer","depthSort","eventClock","eventProxy","eventProxyCapture","i","EMPTY_OBJ","EMPTY_ARR","IS_NON_DIMENSIONAL","isArray","Array","assign","obj","props","removeNode","node","parentNode","removeChild","createElement","type","children","key","ref","normalizedProps","arguments","length","call","defaultProps","createVNode","original","vnode","__k","__","__b","__e","__d","__c","constructor","__v","__i","__u","createRef","current","Fragment","BaseComponent","context","this","getDomSibling","childIndex","sibling","updateParentDomPointers","child","base","enqueueRender","c","push","process","debounceRendering","renderQueueLength","component","newVNode","oldVNode","oldDom","commitQueue","refQueue","sort","shift","diff","__P","namespaceURI","commitRoot","diffChildren","parentDom","renderResult","newParentVNode","oldParentVNode","globalContext","namespace","excessDomChildren","isHydrating","childVNode","newDom","firstChildDom","oldChildren","newChildrenLength","constructNewChildrenArray","applyRef","isConnected","insert","nextSibling","skewedIndex","matchingIndex","oldChildrenLength","remainingOldChildren","skew","String","findMatchingIndex","unmount","parentVNode","insertBefore","nodeType","toChildArray","out","some","x","y","setStyle","style","value","setProperty","test","dom","name","oldValue","useCapture","o","cssText","replace","toLowerCase","l","_attached","addEventListener","removeEventListener","e","removeAttribute","setAttribute","createEventProxy","eventHandler","_dispatched","event","tmp","isNew","oldProps","oldState","snapshot","clearProcessingException","newProps","provider","componentContext","renderHook","count","newType","outer","contextType","__E","prototype","render","doRender","sub","state","__n","__h","_sb","__s","getDerivedStateFromProps","componentWillMount","componentDidMount","componentWillReceiveProps","shouldComponentUpdate","forEach","componentWillUpdate","componentDidUpdate","__r","getChildContext","getSnapshotBeforeUpdate","indexOf","diffElementNodes","diffed","root","cb","newHtml","oldHtml","newChildren","inputValue","checked","localName","document","createTextNode","createElementNS","is","data","childNodes","attributes","__html","innerHTML","skipRemove","r","componentWillUnmount","replaceNode","firstChild","hydrate","cloneElement","createContext","defaultValue","contextId","Consumer","contextValue","Provider","subs","ctx","_props","old","splice","error","errorInfo","ctor","handled","getDerivedStateFromError","setState","componentDidCatch","undefined","update","callback","s","forceUpdate","Promise","then","bind","resolve","setTimeout","a","b"],"sourceRoot":"/","sources":["../esmd/npm/preact@10.22.0/node_modules/.pnpm/preact@10.22.0/node_modules/preact/src/constants.js","../esmd/npm/preact@10.22.0/node_modules/.pnpm/preact@10.22.0/node_modules/preact/src/util.js","../esmd/npm/preact@10.22.0/node_modules/.pnpm/preact@10.22.0/node_modules/preact/src/options.js","../esmd/npm/preact@10.22.0/node_modules/.pnpm/preact@10.22.0/node_modules/preact/src/create-element.js","../esmd/npm/preact@10.22.0/node_modules/.pnpm/preact@10.22.0/node_modules/preact/src/component.js","../esmd/npm/preact@10.22.0/node_modules/.pnpm/preact@10.22.0/node_modules/preact/src/diff/props.js","../esmd/npm/preact@10.22.0/node_modules/.pnpm/preact@10.22.0/node_modules/preact/src/create-context.js","../esmd/npm/preact@10.22.0/node_modules/.pnpm/preact@10.22.0/node_modules/preact/src/diff/children.js","../esmd/npm/preact@10.22.0/node_modules/.pnpm/preact@10.22.0/node_modules/preact/src/diff/index.js","../esmd/npm/preact@10.22.0/node_modules/.pnpm/preact@10.22.0/node_modules/preact/src/render.js","../esmd/npm/preact@10.22.0/node_modules/.pnpm/preact@10.22.0/node_modules/preact/src/clone-element.js","../esmd/npm/preact@10.22.0/node_modules/.pnpm/preact@10.22.0/node_modules/preact/src/diff/catch-error.js"],"sourcesContent":["/** Normal hydration that attaches to a DOM tree but does not diff it. */\nexport const MODE_HYDRATE = 1 \u003c\u003c 5;\n/** Signifies this VNode suspended on the previous render */\nexport const MODE_SUSPENDED = 1 \u003c\u003c 7;\n/** Indicates that this node needs to be inserted while patching children */\nexport const INSERT_VNODE = 1 \u003c\u003c 16;\n/** Indicates a VNode has been matched with another VNode in the diff */\nexport const MATCHED = 1 \u003c\u003c 17;\n\n/** Reset all mode flags */\nexport const RESET_MODE = ~(MODE_HYDRATE | MODE_SUSPENDED);\n\nexport const EMPTY_OBJ = /** @type {any} */ ({});\nexport const EMPTY_ARR = [];\nexport const IS_NON_DIMENSIONAL =\n\t/acit|ex(?:s|g|n|p|$)|rph|grid|ows|mnc|ntw|ine[ch]|zoo|^ord|itera/i;\n","import { EMPTY_ARR } from './constants';\n\nexport const isArray = Array.isArray;\n\n/**\n * Assign properties from `props` to `obj`\n * @template O, P The obj and props types\n * @param {O} obj The object to copy properties to\n * @param {P} props The object to copy properties from\n * @returns {O \u0026 P}\n */\nexport function assign(obj, props) {\n\t// @ts-expect-error We change the type of `obj` to be `O \u0026 P`\n\tfor (let i in props) obj[i] = props[i];\n\treturn /** @type {O \u0026 P} */ (obj);\n}\n\n/**\n * Remove a child node from its parent if attached. This is a workaround for\n * IE11 which doesn't support `Element.prototype.remove()`. Using this function\n * is smaller than including a dedicated polyfill.\n * @param {preact.ContainerNode} node The node to remove\n */\nexport function removeNode(node) {\n\tlet parentNode = node.parentNode;\n\tif (parentNode) parentNode.removeChild(node);\n}\n\nexport const slice = EMPTY_ARR.slice;\n","import { _catchError } from './diff/catch-error';\n\n/**\n * The `option` object can potentially contain callback functions\n * that are called during various stages of our renderer. This is the\n * foundation on which all our addons like `preact/debug`, `preact/compat`,\n * and `preact/hooks` are based on. See the `Options` type in `internal.d.ts`\n * for a full list of available option hooks (most editors/IDEs allow you to\n * ctrl+click or cmd+click on mac the type definition below).\n * @type {Options}\n */\nconst options = {\n\t_catchError\n};\n\nexport default options;\n","import { slice } from './util';\nimport options from './options';\n\nlet vnodeId = 0;\n\n/**\n * Create an virtual node (used for JSX)\n * @param {VNode[\"type\"]} type The node name or Component constructor for this\n * virtual node\n * @param {object | null | undefined} [props] The properties of the virtual node\n * @param {Array\u003cimport('.').ComponentChildren\u003e} [children] The children of the\n * virtual node\n * @returns {VNode}\n */\nexport function createElement(type, props, children) {\n\tlet normalizedProps = {},\n\t\tkey,\n\t\tref,\n\t\ti;\n\tfor (i in props) {\n\t\tif (i == 'key') key = props[i];\n\t\telse if (i == 'ref') ref = props[i];\n\t\telse normalizedProps[i] = props[i];\n\t}\n\n\tif (arguments.length \u003e 2) {\n\t\tnormalizedProps.children =\n\t\t\targuments.length \u003e 3 ? slice.call(arguments, 2) : children;\n\t}\n\n\t// If a Component VNode, check for and apply defaultProps\n\t// Note: type may be undefined in development, must never error here.\n\tif (typeof type == 'function' \u0026\u0026 type.defaultProps != null) {\n\t\tfor (i in type.defaultProps) {\n\t\t\tif (normalizedProps[i] === undefined) {\n\t\t\t\tnormalizedProps[i] = type.defaultProps[i];\n\t\t\t}\n\t\t}\n\t}\n\n\treturn createVNode(type, normalizedProps, key, ref, null);\n}\n\n/**\n * Create a VNode (used internally by Preact)\n * @param {VNode[\"type\"]} type The node name or Component\n * Constructor for this virtual node\n * @param {object | string | number | null} props The properties of this virtual node.\n * If this virtual node represents a text node, this is the text of the node (string or number).\n * @param {string | number | null} key The key for this virtual node, used when\n * diffing it against its children\n * @param {VNode[\"ref\"]} ref The ref property that will\n * receive a reference to its created child\n * @returns {VNode}\n */\nexport function createVNode(type, props, key, ref, original) {\n\t// V8 seems to be better at detecting type shapes if the object is allocated from the same call site\n\t// Do not inline into createElement and coerceToVNode!\n\t/** @type {VNode} */\n\tconst vnode = {\n\t\ttype,\n\t\tprops,\n\t\tkey,\n\t\tref,\n\t\t_children: null,\n\t\t_parent: null,\n\t\t_depth: 0,\n\t\t_dom: null,\n\t\t// _nextDom must be initialized to undefined b/c it will eventually\n\t\t// be set to dom.nextSibling which can return `null` and it is important\n\t\t// to be able to distinguish between an uninitialized _nextDom and\n\t\t// a _nextDom that has been set to `null`\n\t\t_nextDom: undefined,\n\t\t_component: null,\n\t\tconstructor: undefined,\n\t\t_original: original == null ? ++vnodeId : original,\n\t\t_index: -1,\n\t\t_flags: 0\n\t};\n\n\t// Only invoke the vnode hook if this was *not* a direct copy:\n\tif (original == null \u0026\u0026 options.vnode != null) options.vnode(vnode);\n\n\treturn vnode;\n}\n\nexport function createRef() {\n\treturn { current: null };\n}\n\nexport function Fragment(props) {\n\treturn props.children;\n}\n\n/**\n * Check if a the argument is a valid Preact VNode.\n * @param {*} vnode\n * @returns {vnode is VNode}\n */\nexport const isValidElement = vnode =\u003e\n\tvnode != null \u0026\u0026 vnode.constructor == undefined;\n","import { assign } from './util';\nimport { diff, commitRoot } from './diff/index';\nimport options from './options';\nimport { Fragment } from './create-element';\nimport { MODE_HYDRATE } from './constants';\n\n/**\n * Base Component class. Provides `setState()` and `forceUpdate()`, which\n * trigger rendering\n * @param {object} props The initial component props\n * @param {object} context The initial context from parent components'\n * getChildContext\n */\nexport function BaseComponent(props, context) {\n\tthis.props = props;\n\tthis.context = context;\n}\n\n/**\n * Update component state and schedule a re-render.\n * @this {Component}\n * @param {object | ((s: object, p: object) =\u003e object)} update A hash of state\n * properties to update with new values or a function that given the current\n * state and props returns a new partial state\n * @param {() =\u003e void} [callback] A function to be called once component state is\n * updated\n */\nBaseComponent.prototype.setState = function (update, callback) {\n\t// only clone state when copying to nextState the first time.\n\tlet s;\n\tif (this._nextState != null \u0026\u0026 this._nextState !== this.state) {\n\t\ts = this._nextState;\n\t} else {\n\t\ts = this._nextState = assign({}, this.state);\n\t}\n\n\tif (typeof update == 'function') {\n\t\t// Some libraries like `immer` mark the current state as readonly,\n\t\t// preventing us from mutating it, so we need to clone it. See #2716\n\t\tupdate = update(assign({}, s), this.props);\n\t}\n\n\tif (update) {\n\t\tassign(s, update);\n\t}\n\n\t// Skip update if updater function returned null\n\tif (update == null) return;\n\n\tif (this._vnode) {\n\t\tif (callback) {\n\t\t\tthis._stateCallbacks.push(callback);\n\t\t}\n\t\tenqueueRender(this);\n\t}\n};\n\n/**\n * Immediately perform a synchronous re-render of the component\n * @this {Component}\n * @param {() =\u003e void} [callback] A function to be called after component is\n * re-rendered\n */\nBaseComponent.prototype.forceUpdate = function (callback) {\n\tif (this._vnode) {\n\t\t// Set render mode so that we can differentiate where the render request\n\t\t// is coming from. We need this because forceUpdate should never call\n\t\t// shouldComponentUpdate\n\t\tthis._force = true;\n\t\tif (callback) this._renderCallbacks.push(callback);\n\t\tenqueueRender(this);\n\t}\n};\n\n/**\n * Accepts `props` and `state`, and returns a new Virtual DOM tree to build.\n * Virtual DOM is generally constructed via [JSX](http://jasonformat.com/wtf-is-jsx).\n * @param {object} props Props (eg: JSX attributes) received from parent\n * element/component\n * @param {object} state The component's current state\n * @param {object} context Context object, as returned by the nearest\n * ancestor's `getChildContext()`\n * @returns {ComponentChildren | void}\n */\nBaseComponent.prototype.render = Fragment;\n\n/**\n * @param {VNode} vnode\n * @param {number | null} [childIndex]\n */\nexport function getDomSibling(vnode, childIndex) {\n\tif (childIndex == null) {\n\t\t// Use childIndex==null as a signal to resume the search from the vnode's sibling\n\t\treturn vnode._parent\n\t\t\t? getDomSibling(vnode._parent, vnode._index + 1)\n\t\t\t: null;\n\t}\n\n\tlet sibling;\n\tfor (; childIndex \u003c vnode._children.length; childIndex++) {\n\t\tsibling = vnode._children[childIndex];\n\n\t\tif (sibling != null \u0026\u0026 sibling._dom != null) {\n\t\t\t// Since updateParentDomPointers keeps _dom pointer correct,\n\t\t\t// we can rely on _dom to tell us if this subtree contains a\n\t\t\t// rendered DOM node, and what the first rendered DOM node is\n\t\t\treturn sibling._dom;\n\t\t}\n\t}\n\n\t// If we get here, we have not found a DOM node in this vnode's children.\n\t// We must resume from this vnode's sibling (in it's parent _children array)\n\t// Only climb up and search the parent if we aren't searching through a DOM\n\t// VNode (meaning we reached the DOM parent of the original vnode that began\n\t// the search)\n\treturn typeof vnode.type == 'function' ? getDomSibling(vnode) : null;\n}\n\n/**\n * Trigger in-place re-rendering of a component.\n * @param {Component} component The component to rerender\n */\nfunction renderComponent(component) {\n\tlet oldVNode = component._vnode,\n\t\toldDom = oldVNode._dom,\n\t\tcommitQueue = [],\n\t\trefQueue = [];\n\n\tif (component._parentDom) {\n\t\tconst newVNode = assign({}, oldVNode);\n\t\tnewVNode._original = oldVNode._original + 1;\n\t\tif (options.vnode) options.vnode(newVNode);\n\n\t\tdiff(\n\t\t\tcomponent._parentDom,\n\t\t\tnewVNode,\n\t\t\toldVNode,\n\t\t\tcomponent._globalContext,\n\t\t\tcomponent._parentDom.namespaceURI,\n\t\t\toldVNode._flags \u0026 MODE_HYDRATE ? [oldDom] : null,\n\t\t\tcommitQueue,\n\t\t\toldDom == null ? getDomSibling(oldVNode) : oldDom,\n\t\t\t!!(oldVNode._flags \u0026 MODE_HYDRATE),\n\t\t\trefQueue\n\t\t);\n\n\t\tnewVNode._original = oldVNode._original;\n\t\tnewVNode._parent._children[newVNode._index] = newVNode;\n\t\tcommitRoot(commitQueue, newVNode, refQueue);\n\n\t\tif (newVNode._dom != oldDom) {\n\t\t\tupdateParentDomPointers(newVNode);\n\t\t}\n\t}\n}\n\n/**\n * @param {VNode} vnode\n */\nfunction updateParentDomPointers(vnode) {\n\tif ((vnode = vnode._parent) != null \u0026\u0026 vnode._component != null) {\n\t\tvnode._dom = vnode._component.base = null;\n\t\tfor (let i = 0; i \u003c vnode._children.length; i++) {\n\t\t\tlet child = vnode._children[i];\n\t\t\tif (child != null \u0026\u0026 child._dom != null) {\n\t\t\t\tvnode._dom = vnode._component.base = child._dom;\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\n\t\treturn updateParentDomPointers(vnode);\n\t}\n}\n\n/**\n * The render queue\n * @type {Array\u003cComponent\u003e}\n */\nlet rerenderQueue = [];\n\n/*\n * The value of `Component.debounce` must asynchronously invoke the passed in callback. It is\n * important that contributors to Preact can consistently reason about what calls to `setState`, etc.\n * do, and when their effects will be applied. See the links below for some further reading on designing\n * asynchronous APIs.\n * * [Designing APIs for Asynchrony](https://blog.izs.me/2013/08/designing-apis-for-asynchrony)\n * * [Callbacks synchronous and asynchronous](https://blog.ometer.com/2011/07/24/callbacks-synchronous-and-asynchronous/)\n */\n\nlet prevDebounce;\n\nconst defer =\n\ttypeof Promise == 'function'\n\t\t? Promise.prototype.then.bind(Promise.resolve())\n\t\t: setTimeout;\n\n/**\n * Enqueue a rerender of a component\n * @param {Component} c The component to rerender\n */\nexport function enqueueRender(c) {\n\tif (\n\t\t(!c._dirty \u0026\u0026\n\t\t\t(c._dirty = true) \u0026\u0026\n\t\t\trerenderQueue.push(c) \u0026\u0026\n\t\t\t!process._rerenderCount++) ||\n\t\tprevDebounce !== options.debounceRendering\n\t) {\n\t\tprevDebounce = options.debounceRendering;\n\t\t(prevDebounce || defer)(process);\n\t}\n}\n\n/**\n * @param {Component} a\n * @param {Component} b\n */\nconst depthSort = (a, b) =\u003e a._vnode._depth - b._vnode._depth;\n\n/** Flush the render queue by rerendering all queued components */\nfunction process() {\n\tlet c;\n\trerenderQueue.sort(depthSort);\n\t// Don't update `renderCount` yet. Keep its value non-zero to prevent unnecessary\n\t// process() calls from getting scheduled while `queue` is still being consumed.\n\twhile ((c = rerenderQueue.shift())) {\n\t\tif (c._dirty) {\n\t\t\tlet renderQueueLength = rerenderQueue.length;\n\t\t\trenderComponent(c);\n\t\t\tif (rerenderQueue.length \u003e renderQueueLength) {\n\t\t\t\t// When i.e. rerendering a provider additional new items can be injected, we want to\n\t\t\t\t// keep the order from top to bottom with those new items so we can handle them in a\n\t\t\t\t// single pass\n\t\t\t\trerenderQueue.sort(depthSort);\n\t\t\t}\n\t\t}\n\t}\n\tprocess._rerenderCount = 0;\n}\n\nprocess._rerenderCount = 0;\n","import { IS_NON_DIMENSIONAL } from '../constants';\nimport options from '../options';\n\nfunction setStyle(style, key, value) {\n\tif (key[0] === '-') {\n\t\tstyle.setProperty(key, value == null ? '' : value);\n\t} else if (value == null) {\n\t\tstyle[key] = '';\n\t} else if (typeof value != 'number' || IS_NON_DIMENSIONAL.test(key)) {\n\t\tstyle[key] = value;\n\t} else {\n\t\tstyle[key] = value + 'px';\n\t}\n}\n\n// A logical clock to solve issues like https://github.com/preactjs/preact/issues/3927.\n// When the DOM performs an event it leaves micro-ticks in between bubbling up which means that\n// an event can trigger on a newly reated DOM-node while the event bubbles up.\n//\n// Originally inspired by Vue\n// (https://github.com/vuejs/core/blob/caeb8a68811a1b0f79/packages/runtime-dom/src/modules/events.ts#L90-L101),\n// but modified to use a logical clock instead of Date.now() in case event handlers get attached\n// and events get dispatched during the same millisecond.\n//\n// The clock is incremented after each new event dispatch. This allows 1 000 000 new events\n// per second for over 280 years before the value reaches Number.MAX_SAFE_INTEGER (2**53 - 1).\nlet eventClock = 0;\n\n/**\n * Set a property value on a DOM node\n * @param {PreactElement} dom The DOM node to modify\n * @param {string} name The name of the property to set\n * @param {*} value The value to set the property to\n * @param {*} oldValue The old value the property had\n * @param {string} namespace Whether or not this DOM node is an SVG node or not\n */\nexport function setProperty(dom, name, value, oldValue, namespace) {\n\tlet useCapture;\n\n\to: if (name === 'style') {\n\t\tif (typeof value == 'string') {\n\t\t\tdom.style.cssText = value;\n\t\t} else {\n\t\t\tif (typeof oldValue == 'string') {\n\t\t\t\tdom.style.cssText = oldValue = '';\n\t\t\t}\n\n\t\t\tif (oldValue) {\n\t\t\t\tfor (name in oldValue) {\n\t\t\t\t\tif (!(value \u0026\u0026 name in value)) {\n\t\t\t\t\t\tsetStyle(dom.style, name, '');\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (value) {\n\t\t\t\tfor (name in value) {\n\t\t\t\t\tif (!oldValue || value[name] !== oldValue[name]) {\n\t\t\t\t\t\tsetStyle(dom.style, name, value[name]);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\t// Benchmark for comparison: https://esbench.com/bench/574c954bdb965b9a00965ac6\n\telse if (name[0] === 'o' \u0026\u0026 name[1] === 'n') {\n\t\tuseCapture =\n\t\t\tname !== (name = name.replace(/(PointerCapture)$|Capture$/i, '$1'));\n\n\t\t// Infer correct casing for DOM built-in events:\n\t\tif (\n\t\t\tname.toLowerCase() in dom ||\n\t\t\tname === 'onFocusOut' ||\n\t\t\tname === 'onFocusIn'\n\t\t)\n\t\t\tname = name.toLowerCase().slice(2);\n\t\telse name = name.slice(2);\n\n\t\tif (!dom._listeners) dom._listeners = {};\n\t\tdom._listeners[name + useCapture] = value;\n\n\t\tif (value) {\n\t\t\tif (!oldValue) {\n\t\t\t\tvalue._attached = eventClock;\n\t\t\t\tdom.addEventListener(\n\t\t\t\t\tname,\n\t\t\t\t\tuseCapture ? eventProxyCapture : eventProxy,\n\t\t\t\t\tuseCapture\n\t\t\t\t);\n\t\t\t} else {\n\t\t\t\tvalue._attached = oldValue._attached;\n\t\t\t}\n\t\t} else {\n\t\t\tdom.removeEventListener(\n\t\t\t\tname,\n\t\t\t\tuseCapture ? eventProxyCapture : eventProxy,\n\t\t\t\tuseCapture\n\t\t\t);\n\t\t}\n\t} else {\n\t\tif (namespace == 'http://www.w3.org/2000/svg') {\n\t\t\t// Normalize incorrect prop usage for SVG:\n\t\t\t// - xlink:href / xlinkHref --\u003e href (xlink:href was removed from SVG and isn't needed)\n\t\t\t// - className --\u003e class\n\t\t\tname = name.replace(/xlink(H|:h)/, 'h').replace(/sName$/, 's');\n\t\t} else if (\n\t\t\tname != 'width' \u0026\u0026\n\t\t\tname != 'height' \u0026\u0026\n\t\t\tname != 'href' \u0026\u0026\n\t\t\tname != 'list' \u0026\u0026\n\t\t\tname != 'form' \u0026\u0026\n\t\t\t// Default value in browsers is `-1` and an empty string is\n\t\t\t// cast to `0` instead\n\t\t\tname != 'tabIndex' \u0026\u0026\n\t\t\tname != 'download' \u0026\u0026\n\t\t\tname != 'rowSpan' \u0026\u0026\n\t\t\tname != 'colSpan' \u0026\u0026\n\t\t\tname != 'role' \u0026\u0026\n\t\t\tname in dom\n\t\t) {\n\t\t\ttry {\n\t\t\t\tdom[name] = value == null ? '' : value;\n\t\t\t\t// labelled break is 1b smaller here than a return statement (sorry)\n\t\t\t\tbreak o;\n\t\t\t} catch (e) {}\n\t\t}\n\n\t\t// aria- and data- attributes have no boolean representation.\n\t\t// A `false` value is different from the attribute not being\n\t\t// present, so we can't remove it. For non-boolean aria\n\t\t// attributes we could treat false as a removal, but the\n\t\t// amount of exceptions would cost too many bytes. On top of\n\t\t// that other frameworks generally stringify `false`.\n\n\t\tif (typeof value == 'function') {\n\t\t\t// never serialize functions as attribute values\n\t\t} else if (value != null \u0026\u0026 (value !== false || name[4] === '-')) {\n\t\t\tdom.setAttribute(name, value);\n\t\t} else {\n\t\t\tdom.removeAttribute(name);\n\t\t}\n\t}\n}\n\n/**\n * Create an event proxy function.\n * @param {boolean} useCapture Is the event handler for the capture phase.\n * @private\n */\nfunction createEventProxy(useCapture) {\n\t/**\n\t * Proxy an event to hooked event handlers\n\t * @param {PreactEvent} e The event object from the browser\n\t * @private\n\t */\n\treturn function (e) {\n\t\tif (this._listeners) {\n\t\t\tconst eventHandler = this._listeners[e.type + useCapture];\n\t\t\tif (e._dispatched == null) {\n\t\t\t\te._dispatched = eventClock++;\n\n\t\t\t\t// When `e._dispatched` is smaller than the time when the targeted event\n\t\t\t\t// handler was attached we know we have bubbled up to an element that was added\n\t\t\t\t// during patching the DOM.\n\t\t\t} else if (e._dispatched \u003c eventHandler._attached) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\treturn eventHandler(options.event ? options.event(e) : e);\n\t\t}\n\t};\n}\n\nconst eventProxy = createEventProxy(false);\nconst eventProxyCapture = createEventProxy(true);\n","import { enqueueRender } from './component';\n\nexport let i = 0;\n\nexport function createContext(defaultValue, contextId) {\n\tcontextId = '__cC' + i++;\n\n\tconst context = {\n\t\t_id: contextId,\n\t\t_defaultValue: defaultValue,\n\t\t/** @type {FunctionComponent} */\n\t\tConsumer(props, contextValue) {\n\t\t\t// return props.children(\n\t\t\t// \tcontext[contextId] ? context[contextId].props.value : defaultValue\n\t\t\t// );\n\t\t\treturn props.children(contextValue);\n\t\t},\n\t\t/** @type {FunctionComponent} */\n\t\tProvider(props) {\n\t\t\tif (!this.getChildContext) {\n\t\t\t\t/** @type {Component[]} */\n\t\t\t\tlet subs = [];\n\t\t\t\tlet ctx = {};\n\t\t\t\tctx[contextId] = this;\n\n\t\t\t\tthis.getChildContext = () =\u003e ctx;\n\n\t\t\t\tthis.shouldComponentUpdate = function (_props) {\n\t\t\t\t\tif (this.props.value !== _props.value) {\n\t\t\t\t\t\t// I think the forced value propagation here was only needed when `options.debounceRendering` was being bypassed:\n\t\t\t\t\t\t// https://github.com/preactjs/preact/commit/4d339fb803bea09e9f198abf38ca1bf8ea4b7771#diff-54682ce380935a717e41b8bfc54737f6R358\n\t\t\t\t\t\t// In those cases though, even with the value corrected, we're double-rendering all nodes.\n\t\t\t\t\t\t// It might be better to just tell folks not to use force-sync mode.\n\t\t\t\t\t\t// Currently, using `useContext()` in a class component will overwrite its `this.context` value.\n\t\t\t\t\t\t// subs.some(c =\u003e {\n\t\t\t\t\t\t// \tc.context = _props.value;\n\t\t\t\t\t\t// \tenqueueRender(c);\n\t\t\t\t\t\t// });\n\n\t\t\t\t\t\t// subs.some(c =\u003e {\n\t\t\t\t\t\t// \tc.context[contextId] = _props.value;\n\t\t\t\t\t\t// \tenqueueRender(c);\n\t\t\t\t\t\t// });\n\t\t\t\t\t\tsubs.some(c =\u003e {\n\t\t\t\t\t\t\tc._force = true;\n\t\t\t\t\t\t\tenqueueRender(c);\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\t\t\t\t};\n\n\t\t\t\tthis.sub = c =\u003e {\n\t\t\t\t\tsubs.push(c);\n\t\t\t\t\tlet old = c.componentWillUnmount;\n\t\t\t\t\tc.componentWillUnmount = () =\u003e {\n\t\t\t\t\t\tsubs.splice(subs.indexOf(c), 1);\n\t\t\t\t\t\tif (old) old.call(c);\n\t\t\t\t\t};\n\t\t\t\t};\n\t\t\t}\n\n\t\t\treturn props.children;\n\t\t}\n\t};\n\n\t// Devtools needs access to the context object when it\n\t// encounters a Provider. This is necessary to support\n\t// setting `displayName` on the context object instead\n\t// of on the component itself. See:\n\t// https://reactjs.org/docs/context.html#contextdisplayname\n\n\treturn (context.Provider._contextRef = context.Consumer.contextType =\n\t\tcontext);\n}\n","import { diff, unmount, applyRef } from './index';\nimport { createVNode, Fragment } from '../create-element';\nimport { EMPTY_OBJ, EMPTY_ARR, INSERT_VNODE, MATCHED } from '../constants';\nimport { isArray } from '../util';\nimport { getDomSibling } from '../component';\n\n/**\n * Diff the children of a virtual node\n * @param {PreactElement} parentDom The DOM element whose children are being\n * diffed\n * @param {ComponentChildren[]} renderResult\n * @param {VNode} newParentVNode The new virtual node whose children should be\n * diff'ed against oldParentVNode\n * @param {VNode} oldParentVNode The old virtual node whose children should be\n * diff'ed against newParentVNode\n * @param {object} globalContext The current context object - modified by\n * getChildContext\n * @param {string} namespace Current namespace of the DOM node (HTML, SVG, or MathML)\n * @param {Array\u003cPreactElement\u003e} excessDomChildren\n * @param {Array\u003cComponent\u003e} commitQueue List of components which have callbacks\n * to invoke in commitRoot\n * @param {PreactElement} oldDom The current attached DOM element any new dom\n * elements should be placed around. Likely `null` on first render (except when\n * hydrating). Can be a sibling DOM element when diffing Fragments that have\n * siblings. In most cases, it starts out as `oldChildren[0]._dom`.\n * @param {boolean} isHydrating Whether or not we are in hydration\n * @param {any[]} refQueue an array of elements needed to invoke refs\n */\nexport function diffChildren(\n\tparentDom,\n\trenderResult,\n\tnewParentVNode,\n\toldParentVNode,\n\tglobalContext,\n\tnamespace,\n\texcessDomChildren,\n\tcommitQueue,\n\toldDom,\n\tisHydrating,\n\trefQueue\n) {\n\tlet i,\n\t\t/** @type {VNode} */\n\t\toldVNode,\n\t\t/** @type {VNode} */\n\t\tchildVNode,\n\t\t/** @type {PreactElement} */\n\t\tnewDom,\n\t\t/** @type {PreactElement} */\n\t\tfirstChildDom;\n\n\t// This is a compression of oldParentVNode!=null \u0026\u0026 oldParentVNode != EMPTY_OBJ \u0026\u0026 oldParentVNode._children || EMPTY_ARR\n\t// as EMPTY_OBJ._children should be `undefined`.\n\t/** @type {VNode[]} */\n\tlet oldChildren = (oldParentVNode \u0026\u0026 oldParentVNode._children) || EMPTY_ARR;\n\n\tlet newChildrenLength = renderResult.length;\n\n\tnewParentVNode._nextDom = oldDom;\n\tconstructNewChildrenArray(newParentVNode, renderResult, oldChildren);\n\toldDom = newParentVNode._nextDom;\n\n\tfor (i = 0; i \u003c newChildrenLength; i++) {\n\t\tchildVNode = newParentVNode._children[i];\n\t\tif (\n\t\t\tchildVNode == null ||\n\t\t\ttypeof childVNode == 'boolean' ||\n\t\t\ttypeof childVNode == 'function'\n\t\t) {\n\t\t\tcontinue;\n\t\t}\n\n\t\t// At this point, constructNewChildrenArray has assigned _index to be the\n\t\t// matchingIndex for this VNode's oldVNode (or -1 if there is no oldVNode).\n\t\tif (childVNode._index === -1) {\n\t\t\toldVNode = EMPTY_OBJ;\n\t\t} else {\n\t\t\toldVNode = oldChildren[childVNode._index] || EMPTY_OBJ;\n\t\t}\n\n\t\t// Update childVNode._index to its final index\n\t\tchildVNode._index = i;\n\n\t\t// Morph the old element into the new one, but don't append it to the dom yet\n\t\tdiff(\n\t\t\tparentDom,\n\t\t\tchildVNode,\n\t\t\toldVNode,\n\t\t\tglobalContext,\n\t\t\tnamespace,\n\t\t\texcessDomChildren,\n\t\t\tcommitQueue,\n\t\t\toldDom,\n\t\t\tisHydrating,\n\t\t\trefQueue\n\t\t);\n\n\t\t// Adjust DOM nodes\n\t\tnewDom = childVNode._dom;\n\t\tif (childVNode.ref \u0026\u0026 oldVNode.ref != childVNode.ref) {\n\t\t\tif (oldVNode.ref) {\n\t\t\t\tapplyRef(oldVNode.ref, null, childVNode);\n\t\t\t}\n\t\t\trefQueue.push(\n\t\t\t\tchildVNode.ref,\n\t\t\t\tchildVNode._component || newDom,\n\t\t\t\tchildVNode\n\t\t\t);\n\t\t}\n\n\t\tif (firstChildDom == null \u0026\u0026 newDom != null) {\n\t\t\tfirstChildDom = newDom;\n\t\t}\n\n\t\tif (\n\t\t\tchildVNode._flags \u0026 INSERT_VNODE ||\n\t\t\toldVNode._children === childVNode._children\n\t\t) {\n\t\t\t// @ts-expect-error olDom should be present on a DOM node\n\t\t\tif (oldDom \u0026\u0026 !oldDom.isConnected) {\n\t\t\t\toldDom = getDomSibling(oldVNode);\n\t\t\t}\n\t\t\toldDom = insert(childVNode, oldDom, parentDom);\n\t\t} else if (\n\t\t\ttypeof childVNode.type == 'function' \u0026\u0026\n\t\t\tchildVNode._nextDom !== undefined\n\t\t) {\n\t\t\t// Since Fragments or components that return Fragment like VNodes can\n\t\t\t// contain multiple DOM nodes as the same level, continue the diff from\n\t\t\t// the sibling of last DOM child of this child VNode\n\t\t\toldDom = childVNode._nextDom;\n\t\t} else if (newDom) {\n\t\t\toldDom = newDom.nextSibling;\n\t\t}\n\n\t\t// Eagerly cleanup _nextDom. We don't need to persist the value because it\n\t\t// is only used by `diffChildren` to determine where to resume the diff\n\t\t// after diffing Components and Fragments. Once we store it the nextDOM\n\t\t// local var, we can clean up the property. Also prevents us hanging on to\n\t\t// DOM nodes that may have been unmounted.\n\t\tchildVNode._nextDom = undefined;\n\n\t\t// Unset diffing flags\n\t\tchildVNode._flags \u0026= ~(INSERT_VNODE | MATCHED);\n\t}\n\n\t// TODO: With new child diffing algo, consider alt ways to diff Fragments.\n\t// Such as dropping oldDom and moving fragments in place\n\t//\n\t// Because the newParentVNode is Fragment-like, we need to set it's\n\t// _nextDom property to the nextSibling of its last child DOM node.\n\t//\n\t// `oldDom` contains the correct value here because if the last child\n\t// is a Fragment-like, then oldDom has already been set to that child's _nextDom.\n\t// If the last child is a DOM VNode, then oldDom will be set to that DOM\n\t// node's nextSibling.\n\tnewParentVNode._nextDom = oldDom;\n\tnewParentVNode._dom = firstChildDom;\n}\n\n/**\n * @param {VNode} newParentVNode\n * @param {ComponentChildren[]} renderResult\n * @param {VNode[]} oldChildren\n */\nfunction constructNewChildrenArray(newParentVNode, renderResult, oldChildren) {\n\t/** @type {number} */\n\tlet i;\n\t/** @type {VNode} */\n\tlet childVNode;\n\t/** @type {VNode} */\n\tlet oldVNode;\n\n\tconst newChildrenLength = renderResult.length;\n\tlet oldChildrenLength = oldChildren.length,\n\t\tremainingOldChildren = oldChildrenLength;\n\n\tlet skew = 0;\n\n\tnewParentVNode._children = [];\n\tfor (i = 0; i \u003c newChildrenLength; i++) {\n\t\t// @ts-expect-error We are reusing the childVNode variable to hold both the\n\t\t// pre and post normalized childVNode\n\t\tchildVNode = renderResult[i];\n\n\t\tif (\n\t\t\tchildVNode == null ||\n\t\t\ttypeof childVNode == 'boolean' ||\n\t\t\ttypeof childVNode == 'function'\n\t\t) {\n\t\t\tchildVNode = newParentVNode._children[i] = null;\n\t\t}\n\t\t// If this newVNode is being reused (e.g. \u003cdiv\u003e{reuse}{reuse}\u003c/div\u003e) in the same diff,\n\t\t// or we are rendering a component (e.g. setState) copy the oldVNodes so it can have\n\t\t// it's own DOM \u0026 etc. pointers\n\t\telse if (\n\t\t\ttypeof childVNode == 'string' ||\n\t\t\ttypeof childVNode == 'number' ||\n\t\t\t// eslint-disable-next-line valid-typeof\n\t\t\ttypeof childVNode == 'bigint' ||\n\t\t\tchildVNode.constructor == String\n\t\t) {\n\t\t\tchildVNode = newParentVNode._children[i] = createVNode(\n\t\t\t\tnull,\n\t\t\t\tchildVNode,\n\t\t\t\tnull,\n\t\t\t\tnull,\n\t\t\t\tnull\n\t\t\t);\n\t\t} else if (isArray(childVNode)) {\n\t\t\tchildVNode = newParentVNode._children[i] = createVNode(\n\t\t\t\tFragment,\n\t\t\t\t{ children: childVNode },\n\t\t\t\tnull,\n\t\t\t\tnull,\n\t\t\t\tnull\n\t\t\t);\n\t\t} else if (childVNode.constructor === undefined \u0026\u0026 childVNode._depth \u003e 0) {\n\t\t\t// VNode is already in use, clone it. This can happen in the following\n\t\t\t// scenario:\n\t\t\t//   const reuse = \u003cdiv /\u003e\n\t\t\t//   \u003cdiv\u003e{reuse}\u003cspan /\u003e{reuse}\u003c/div\u003e\n\t\t\tchildVNode = newParentVNode._children[i] = createVNode(\n\t\t\t\tchildVNode.type,\n\t\t\t\tchildVNode.props,\n\t\t\t\tchildVNode.key,\n\t\t\t\tchildVNode.ref ? childVNode.ref : null,\n\t\t\t\tchildVNode._original\n\t\t\t);\n\t\t} else {\n\t\t\tchildVNode = newParentVNode._children[i] = childVNode;\n\t\t}\n\n\t\tconst skewedIndex = i + skew;\n\n\t\t// Handle unmounting null placeholders, i.e. VNode =\u003e null in unkeyed children\n\t\tif (childVNode == null) {\n\t\t\toldVNode = oldChildren[skewedIndex];\n\t\t\tif (\n\t\t\t\toldVNode \u0026\u0026\n\t\t\t\toldVNode.key == null \u0026\u0026\n\t\t\t\toldVNode._dom \u0026\u0026\n\t\t\t\t(oldVNode._flags \u0026 MATCHED) === 0\n\t\t\t) {\n\t\t\t\tif (oldVNode._dom == newParentVNode._nextDom) {\n\t\t\t\t\tnewParentVNode._nextDom = getDomSibling(oldVNode);\n\t\t\t\t}\n\n\t\t\t\tunmount(oldVNode, oldVNode, false);\n\n\t\t\t\t// Explicitly nullify this position in oldChildren instead of just\n\t\t\t\t// setting `_match=true` to prevent other routines (e.g.\n\t\t\t\t// `findMatchingIndex` or `getDomSibling`) from thinking VNodes or DOM\n\t\t\t\t// nodes in this position are still available to be used in diffing when\n\t\t\t\t// they have actually already been unmounted. For example, by only\n\t\t\t\t// setting `_match=true` here, the unmounting loop later would attempt\n\t\t\t\t// to unmount this VNode again seeing `_match==true`.  Further,\n\t\t\t\t// getDomSibling doesn't know about _match and so would incorrectly\n\t\t\t\t// assume DOM nodes in this subtree are mounted and usable.\n\t\t\t\toldChildren[skewedIndex] = null;\n\t\t\t\tremainingOldChildren--;\n\t\t\t}\n\t\t\tcontinue;\n\t\t}\n\n\t\tchildVNode._parent = newParentVNode;\n\t\tchildVNode._depth = newParentVNode._depth + 1;\n\n\t\tconst matchingIndex = findMatchingIndex(\n\t\t\tchildVNode,\n\t\t\toldChildren,\n\t\t\tskewedIndex,\n\t\t\tremainingOldChildren\n\t\t);\n\n\t\t// Temporarily store the matchingIndex on the _index property so we can pull\n\t\t// out the oldVNode in diffChildren. We'll override this to the VNode's\n\t\t// final index after using this property to get the oldVNode\n\t\tchildVNode._index = matchingIndex;\n\n\t\toldVNode = null;\n\t\tif (matchingIndex !== -1) {\n\t\t\toldVNode = oldChildren[matchingIndex];\n\t\t\tremainingOldChildren--;\n\t\t\tif (oldVNode) {\n\t\t\t\toldVNode._flags |= MATCHED;\n\t\t\t}\n\t\t}\n\n\t\t// Here, we define isMounting for the purposes of the skew diffing\n\t\t// algorithm. Nodes that are unsuspending are considered mounting and we detect\n\t\t// this by checking if oldVNode._original === null\n\t\tconst isMounting = oldVNode == null || oldVNode._original === null;\n\n\t\tif (isMounting) {\n\t\t\tif (matchingIndex == -1) {\n\t\t\t\tskew--;\n\t\t\t}\n\n\t\t\t// If we are mounting a DOM VNode, mark it for insertion\n\t\t\tif (typeof childVNode.type != 'function') {\n\t\t\t\tchildVNode._flags |= INSERT_VNODE;\n\t\t\t}\n\t\t} else if (matchingIndex !== skewedIndex) {\n\t\t\tif (matchingIndex === skewedIndex + 1) {\n\t\t\t\tskew++;\n\t\t\t} else if (matchingIndex \u003e skewedIndex) {\n\t\t\t\tif (remainingOldChildren \u003e newChildrenLength - skewedIndex) {\n\t\t\t\t\tskew += matchingIndex - skewedIndex;\n\t\t\t\t} else {\n\t\t\t\t\tskew--;\n\t\t\t\t}\n\t\t\t} else if (matchingIndex \u003c skewedIndex) {\n\t\t\t\tif (matchingIndex == skewedIndex - 1) {\n\t\t\t\t\tskew = matchingIndex - skewedIndex;\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tskew = 0;\n\t\t\t}\n\n\t\t\t// Move this VNode's DOM if the original index (matchingIndex) doesn't\n\t\t\t// match the new skew index (i + new skew)\n\t\t\tif (matchingIndex !== i + skew) {\n\t\t\t\tchildVNode._flags |= INSERT_VNODE;\n\t\t\t}\n\t\t}\n\t}\n\n\t// Remove remaining oldChildren if there are any. Loop forwards so that as we\n\t// unmount DOM from the beginning of the oldChildren, we can adjust oldDom to\n\t// point to the next child, which needs to be the first DOM node that won't be\n\t// unmounted.\n\tif (remainingOldChildren) {\n\t\tfor (i = 0; i \u003c oldChildrenLength; i++) {\n\t\t\toldVNode = oldChildren[i];\n\t\t\tif (oldVNode != null \u0026\u0026 (oldVNode._flags \u0026 MATCHED) === 0) {\n\t\t\t\tif (oldVNode._dom == newParentVNode._nextDom) {\n\t\t\t\t\tnewParentVNode._nextDom = getDomSibling(oldVNode);\n\t\t\t\t}\n\n\t\t\t\tunmount(oldVNode, oldVNode);\n\t\t\t}\n\t\t}\n\t}\n}\n\n/**\n * @param {VNode} parentVNode\n * @param {PreactElement} oldDom\n * @param {PreactElement} parentDom\n * @returns {PreactElement}\n */\nfunction insert(parentVNode, oldDom, parentDom) {\n\t// Note: VNodes in nested suspended trees may be missing _children.\n\n\tif (typeof parentVNode.type == 'function') {\n\t\tlet children = parentVNode._children;\n\t\tfor (let i = 0; children \u0026\u0026 i \u003c children.length; i++) {\n\t\t\tif (children[i]) {\n\t\t\t\t// If we enter this code path on sCU bailout, where we copy\n\t\t\t\t// oldVNode._children to newVNode._children, we need to update the old\n\t\t\t\t// children's _parent pointer to point to the newVNode (parentVNode\n\t\t\t\t// here).\n\t\t\t\tchildren[i]._parent = parentVNode;\n\t\t\t\toldDom = insert(children[i], oldDom, parentDom);\n\t\t\t}\n\t\t}\n\n\t\treturn oldDom;\n\t} else if (parentVNode._dom != oldDom) {\n\t\tparentDom.insertBefore(parentVNode._dom, oldDom || null);\n\t\toldDom = parentVNode._dom;\n\t}\n\n\tdo {\n\t\toldDom = oldDom \u0026\u0026 oldDom.nextSibling;\n\t} while (oldDom != null \u0026\u0026 oldDom.nodeType === 8);\n\n\treturn oldDom;\n}\n\n/**\n * Flatten and loop through the children of a virtual node\n * @param {ComponentChildren} children The unflattened children of a virtual\n * node\n * @returns {VNode[]}\n */\nexport function toChildArray(children, out) {\n\tout = out || [];\n\tif (children == null || typeof children == 'boolean') {\n\t} else if (isArray(children)) {\n\t\tchildren.some(child =\u003e {\n\t\t\ttoChildArray(child, out);\n\t\t});\n\t} else {\n\t\tout.push(children);\n\t}\n\treturn out;\n}\n\n/**\n * @param {VNode} childVNode\n * @param {VNode[]} oldChildren\n * @param {number} skewedIndex\n * @param {number} remainingOldChildren\n * @returns {number}\n */\nfunction findMatchingIndex(\n\tchildVNode,\n\toldChildren,\n\tskewedIndex,\n\tremainingOldChildren\n) {\n\tconst key = childVNode.key;\n\tconst type = childVNode.type;\n\tlet x = skewedIndex - 1;\n\tlet y = skewedIndex + 1;\n\tlet oldVNode = oldChildren[skewedIndex];\n\n\t// We only need to perform a search if there are more children\n\t// (remainingOldChildren) to search. However, if the oldVNode we just looked\n\t// at skewedIndex was not already used in this diff, then there must be at\n\t// least 1 other (so greater than 1) remainingOldChildren to attempt to match\n\t// against. So the following condition checks that ensuring\n\t// remainingOldChildren \u003e 1 if the oldVNode is not already used/matched. Else\n\t// if the oldVNode was null or matched, then there could needs to be at least\n\t// 1 (aka `remainingOldChildren \u003e 0`) children to find and compare against.\n\tlet shouldSearch =\n\t\tremainingOldChildren \u003e\n\t\t(oldVNode != null \u0026\u0026 (oldVNode._flags \u0026 MATCHED) === 0 ? 1 : 0);\n\n\tif (\n\t\toldVNode === null ||\n\t\t(oldVNode \u0026\u0026\n\t\t\tkey == oldVNode.key \u0026\u0026\n\t\t\ttype === oldVNode.type \u0026\u0026\n\t\t\t(oldVNode._flags \u0026 MATCHED) === 0)\n\t) {\n\t\treturn skewedIndex;\n\t} else if (shouldSearch) {\n\t\twhile (x \u003e= 0 || y \u003c oldChildren.length) {\n\t\t\tif (x \u003e= 0) {\n\t\t\t\toldVNode = oldChildren[x];\n\t\t\t\tif (\n\t\t\t\t\toldVNode \u0026\u0026\n\t\t\t\t\t(oldVNode._flags \u0026 MATCHED) === 0 \u0026\u0026\n\t\t\t\t\tkey == oldVNode.key \u0026\u0026\n\t\t\t\t\ttype === oldVNode.type\n\t\t\t\t) {\n\t\t\t\t\treturn x;\n\t\t\t\t}\n\t\t\t\tx--;\n\t\t\t}\n\n\t\t\tif (y \u003c oldChildren.length) {\n\t\t\t\toldVNode = oldChildren[y];\n\t\t\t\tif (\n\t\t\t\t\toldVNode \u0026\u0026\n\t\t\t\t\t(oldVNode._flags \u0026 MATCHED) === 0 \u0026\u0026\n\t\t\t\t\tkey == oldVNode.key \u0026\u0026\n\t\t\t\t\ttype === oldVNode.type\n\t\t\t\t) {\n\t\t\t\t\treturn y;\n\t\t\t\t}\n\t\t\t\ty++;\n\t\t\t}\n\t\t}\n\t}\n\n\treturn -1;\n}\n","import {\n\tEMPTY_OBJ,\n\tMODE_HYDRATE,\n\tMODE_SUSPENDED,\n\tRESET_MODE\n} from '../constants';\nimport { BaseComponent, getDomSibling } from '../component';\nimport { Fragment } from '../create-element';\nimport { diffChildren } from './children';\nimport { setProperty } from './props';\nimport { assign, isArray, removeNode, slice } from '../util';\nimport options from '../options';\n\n/**\n * Diff two virtual nodes and apply proper changes to the DOM\n * @param {PreactElement} parentDom The parent of the DOM element\n * @param {VNode} newVNode The new virtual node\n * @param {VNode} oldVNode The old virtual node\n * @param {object} globalContext The current context object. Modified by\n * getChildContext\n * @param {string} namespace Current namespace of the DOM node (HTML, SVG, or MathML)\n * @param {Array\u003cPreactElement\u003e} excessDomChildren\n * @param {Array\u003cComponent\u003e} commitQueue List of components which have callbacks\n * to invoke in commitRoot\n * @param {PreactElement} oldDom The current attached DOM element any new dom\n * elements should be placed around. Likely `null` on first render (except when\n * hydrating). Can be a sibling DOM element when diffing Fragments that have\n * siblings. In most cases, it starts out as `oldChildren[0]._dom`.\n * @param {boolean} isHydrating Whether or not we are in hydration\n * @param {any[]} refQueue an array of elements needed to invoke refs\n */\nexport function diff(\n\tparentDom,\n\tnewVNode,\n\toldVNode,\n\tglobalContext,\n\tnamespace,\n\texcessDomChildren,\n\tcommitQueue,\n\toldDom,\n\tisHydrating,\n\trefQueue\n) {\n\t/** @type {any} */\n\tlet tmp,\n\t\tnewType = newVNode.type;\n\n\t// When passing through createElement it assigns the object\n\t// constructor as undefined. This to prevent JSON-injection.\n\tif (newVNode.constructor !== undefined) return null;\n\n\t// If the previous diff bailed out, resume creating/hydrating.\n\tif (oldVNode._flags \u0026 MODE_SUSPENDED) {\n\t\tisHydrating = !!(oldVNode._flags \u0026 MODE_HYDRATE);\n\t\toldDom = newVNode._dom = oldVNode._dom;\n\t\texcessDomChildren = [oldDom];\n\t}\n\n\tif ((tmp = options._diff)) tmp(newVNode);\n\n\touter: if (typeof newType == 'function') {\n\t\ttry {\n\t\t\tlet c, isNew, oldProps, oldState, snapshot, clearProcessingException;\n\t\t\tlet newProps = newVNode.props;\n\n\t\t\t// Necessary for createContext api. Setting this property will pass\n\t\t\t// the context value as `this.context` just for this component.\n\t\t\ttmp = newType.contextType;\n\t\t\tlet provider = tmp \u0026\u0026 globalContext[tmp._id];\n\t\t\tlet componentContext = tmp\n\t\t\t\t? provider\n\t\t\t\t\t? provider.props.value\n\t\t\t\t\t: tmp._defaultValue\n\t\t\t\t: globalContext;\n\n\t\t\t// Get component and set it to `c`\n\t\t\tif (oldVNode._component) {\n\t\t\t\tc = newVNode._component = oldVNode._component;\n\t\t\t\tclearProcessingException = c._processingException = c._pendingError;\n\t\t\t} else {\n\t\t\t\t// Instantiate the new component\n\t\t\t\tif ('prototype' in newType \u0026\u0026 newType.prototype.render) {\n\t\t\t\t\t// @ts-expect-error The check above verifies that newType is suppose to be constructed\n\t\t\t\t\tnewVNode._component = c = new newType(newProps, componentContext); // eslint-disable-line new-cap\n\t\t\t\t} else {\n\t\t\t\t\t// @ts-expect-error Trust me, Component implements the interface we want\n\t\t\t\t\tnewVNode._component = c = new BaseComponent(\n\t\t\t\t\t\tnewProps,\n\t\t\t\t\t\tcomponentContext\n\t\t\t\t\t);\n\t\t\t\t\tc.constructor = newType;\n\t\t\t\t\tc.render = doRender;\n\t\t\t\t}\n\t\t\t\tif (provider) provider.sub(c);\n\n\t\t\t\tc.props = newProps;\n\t\t\t\tif (!c.state) c.state = {};\n\t\t\t\tc.context = componentContext;\n\t\t\t\tc._globalContext = globalContext;\n\t\t\t\tisNew = c._dirty = true;\n\t\t\t\tc._renderCallbacks = [];\n\t\t\t\tc._stateCallbacks = [];\n\t\t\t}\n\n\t\t\t// Invoke getDerivedStateFromProps\n\t\t\tif (c._nextState == null) {\n\t\t\t\tc._nextState = c.state;\n\t\t\t}\n\n\t\t\tif (newType.getDerivedStateFromProps != null) {\n\t\t\t\tif (c._nextState == c.state) {\n\t\t\t\t\tc._nextState = assign({}, c._nextState);\n\t\t\t\t}\n\n\t\t\t\tassign(\n\t\t\t\t\tc._nextState,\n\t\t\t\t\tnewType.getDerivedStateFromProps(newProps, c._nextState)\n\t\t\t\t);\n\t\t\t}\n\n\t\t\toldProps = c.props;\n\t\t\toldState = c.state;\n\t\t\tc._vnode = newVNode;\n\n\t\t\t// Invoke pre-render lifecycle methods\n\t\t\tif (isNew) {\n\t\t\t\tif (\n\t\t\t\t\tnewType.getDerivedStateFromProps == null \u0026\u0026\n\t\t\t\t\tc.componentWillMount != null\n\t\t\t\t) {\n\t\t\t\t\tc.componentWillMount();\n\t\t\t\t}\n\n\t\t\t\tif (c.componentDidMount != null) {\n\t\t\t\t\tc._renderCallbacks.push(c.componentDidMount);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tif (\n\t\t\t\t\tnewType.getDerivedStateFromProps == null \u0026\u0026\n\t\t\t\t\tnewProps !== oldProps \u0026\u0026\n\t\t\t\t\tc.componentWillReceiveProps != null\n\t\t\t\t) {\n\t\t\t\t\tc.componentWillReceiveProps(newProps, componentContext);\n\t\t\t\t}\n\n\t\t\t\tif (\n\t\t\t\t\t!c._force \u0026\u0026\n\t\t\t\t\t((c.shouldComponentUpdate != null \u0026\u0026\n\t\t\t\t\t\tc.shouldComponentUpdate(\n\t\t\t\t\t\t\tnewProps,\n\t\t\t\t\t\t\tc._nextState,\n\t\t\t\t\t\t\tcomponentContext\n\t\t\t\t\t\t) === false) ||\n\t\t\t\t\t\tnewVNode._original === oldVNode._original)\n\t\t\t\t) {\n\t\t\t\t\t// More info about this here: https://gist.github.com/JoviDeCroock/bec5f2ce93544d2e6070ef8e0036e4e8\n\t\t\t\t\tif (newVNode._original !== oldVNode._original) {\n\t\t\t\t\t\t// When we are dealing with a bail because of sCU we have to update\n\t\t\t\t\t\t// the props, state and dirty-state.\n\t\t\t\t\t\t// when we are dealing with strict-equality we don't as the child could still\n\t\t\t\t\t\t// be dirtied see #3883\n\t\t\t\t\t\tc.props = newProps;\n\t\t\t\t\t\tc.state = c._nextState;\n\t\t\t\t\t\tc._dirty = false;\n\t\t\t\t\t}\n\n\t\t\t\t\tnewVNode._dom = oldVNode._dom;\n\t\t\t\t\tnewVNode._children = oldVNode._children;\n\t\t\t\t\tnewVNode._children.forEach(vnode =\u003e {\n\t\t\t\t\t\tif (vnode) vnode._parent = newVNode;\n\t\t\t\t\t});\n\n\t\t\t\t\tfor (let i = 0; i \u003c c._stateCallbacks.length; i++) {\n\t\t\t\t\t\tc._renderCallbacks.push(c._stateCallbacks[i]);\n\t\t\t\t\t}\n\t\t\t\t\tc._stateCallbacks = [];\n\n\t\t\t\t\tif (c._renderCallbacks.length) {\n\t\t\t\t\t\tcommitQueue.push(c);\n\t\t\t\t\t}\n\n\t\t\t\t\tbreak outer;\n\t\t\t\t}\n\n\t\t\t\tif (c.componentWillUpdate != null) {\n\t\t\t\t\tc.componentWillUpdate(newProps, c._nextState, componentContext);\n\t\t\t\t}\n\n\t\t\t\tif (c.componentDidUpdate != null) {\n\t\t\t\t\tc._renderCallbacks.push(() =\u003e {\n\t\t\t\t\t\tc.componentDidUpdate(oldProps, oldState, snapshot);\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tc.context = componentContext;\n\t\t\tc.props = newProps;\n\t\t\tc._parentDom = parentDom;\n\t\t\tc._force = false;\n\n\t\t\tlet renderHook = options._render,\n\t\t\t\tcount = 0;\n\t\t\tif ('prototype' in newType \u0026\u0026 newType.prototype.render) {\n\t\t\t\tc.state = c._nextState;\n\t\t\t\tc._dirty = false;\n\n\t\t\t\tif (renderHook) renderHook(newVNode);\n\n\t\t\t\ttmp = c.render(c.props, c.state, c.context);\n\n\t\t\t\tfor (let i = 0; i \u003c c._stateCallbacks.length; i++) {\n\t\t\t\t\tc._renderCallbacks.push(c._stateCallbacks[i]);\n\t\t\t\t}\n\t\t\t\tc._stateCallbacks = [];\n\t\t\t} else {\n\t\t\t\tdo {\n\t\t\t\t\tc._dirty = false;\n\t\t\t\t\tif (renderHook) renderHook(newVNode);\n\n\t\t\t\t\ttmp = c.render(c.props, c.state, c.context);\n\n\t\t\t\t\t// Handle setState called in render, see #2553\n\t\t\t\t\tc.state = c._nextState;\n\t\t\t\t} while (c._dirty \u0026\u0026 ++count \u003c 25);\n\t\t\t}\n\n\t\t\t// Handle setState called in render, see #2553\n\t\t\tc.state = c._nextState;\n\n\t\t\tif (c.getChildContext != null) {\n\t\t\t\tglobalContext = assign(assign({}, globalContext), c.getChildContext());\n\t\t\t}\n\n\t\t\tif (!isNew \u0026\u0026 c.getSnapshotBeforeUpdate != null) {\n\t\t\t\tsnapshot = c.getSnapshotBeforeUpdate(oldProps, oldState);\n\t\t\t}\n\n\t\t\tlet isTopLevelFragment =\n\t\t\t\ttmp != null \u0026\u0026 tmp.type === Fragment \u0026\u0026 tmp.key == null;\n\t\t\tlet renderResult = isTopLevelFragment ? tmp.props.children : tmp;\n\n\t\t\tdiffChildren(\n\t\t\t\tparentDom,\n\t\t\t\tisArray(renderResult) ? renderResult : [renderResult],\n\t\t\t\tnewVNode,\n\t\t\t\toldVNode,\n\t\t\t\tglobalContext,\n\t\t\t\tnamespace,\n\t\t\t\texcessDomChildren,\n\t\t\t\tcommitQueue,\n\t\t\t\toldDom,\n\t\t\t\tisHydrating,\n\t\t\t\trefQueue\n\t\t\t);\n\n\t\t\tc.base = newVNode._dom;\n\n\t\t\t// We successfully rendered this VNode, unset any stored hydration/bailout state:\n\t\t\tnewVNode._flags \u0026= RESET_MODE;\n\n\t\t\tif (c._renderCallbacks.length) {\n\t\t\t\tcommitQueue.push(c);\n\t\t\t}\n\n\t\t\tif (clearProcessingException) {\n\t\t\t\tc._pendingError = c._processingException = null;\n\t\t\t}\n\t\t} catch (e) {\n\t\t\tnewVNode._original = null;\n\t\t\t// if hydrating or creating initial tree, bailout preserves DOM:\n\t\t\tif (isHydrating || excessDomChildren != null) {\n\t\t\t\tnewVNode._dom = oldDom;\n\t\t\t\tnewVNode._flags |= isHydrating\n\t\t\t\t\t? MODE_HYDRATE | MODE_SUSPENDED\n\t\t\t\t\t: MODE_HYDRATE;\n\t\t\t\texcessDomChildren[excessDomChildren.indexOf(oldDom)] = null;\n\t\t\t\t// ^ could possibly be simplified to:\n\t\t\t\t// excessDomChildren.length = 0;\n\t\t\t} else {\n\t\t\t\tnewVNode._dom = oldVNode._dom;\n\t\t\t\tnewVNode._children = oldVNode._children;\n\t\t\t}\n\t\t\toptions._catchError(e, newVNode, oldVNode);\n\t\t}\n\t} else if (\n\t\texcessDomChildren == null \u0026\u0026\n\t\tnewVNode._original === oldVNode._original\n\t) {\n\t\tnewVNode._children = oldVNode._children;\n\t\tnewVNode._dom = oldVNode._dom;\n\t} else {\n\t\tnewVNode._dom = diffElementNodes(\n\t\t\toldVNode._dom,\n\t\t\tnewVNode,\n\t\t\toldVNode,\n\t\t\tglobalContext,\n\t\t\tnamespace,\n\t\t\texcessDomChildren,\n\t\t\tcommitQueue,\n\t\t\tisHydrating,\n\t\t\trefQueue\n\t\t);\n\t}\n\n\tif ((tmp = options.diffed)) tmp(newVNode);\n}\n\n/**\n * @param {Array\u003cComponent\u003e} commitQueue List of components\n * which have callbacks to invoke in commitRoot\n * @param {VNode} root\n */\nexport function commitRoot(commitQueue, root, refQueue) {\n\troot._nextDom = undefined;\n\n\tfor (let i = 0; i \u003c refQueue.length; i++) {\n\t\tapplyRef(refQueue[i], refQueue[++i], refQueue[++i]);\n\t}\n\n\tif (options._commit) options._commit(root, commitQueue);\n\n\tcommitQueue.some(c =\u003e {\n\t\ttry {\n\t\t\t// @ts-expect-error Reuse the commitQueue variable here so the type changes\n\t\t\tcommitQueue = c._renderCallbacks;\n\t\t\tc._renderCallbacks = [];\n\t\t\tcommitQueue.some(cb =\u003e {\n\t\t\t\t// @ts-expect-error See above comment on commitQueue\n\t\t\t\tcb.call(c);\n\t\t\t});\n\t\t} catch (e) {\n\t\t\toptions._catchError(e, c._vnode);\n\t\t}\n\t});\n}\n\n/**\n * Diff two virtual nodes representing DOM element\n * @param {PreactElement} dom The DOM element representing the virtual nodes\n * being diffed\n * @param {VNode} newVNode The new virtual node\n * @param {VNode} oldVNode The old virtual node\n * @param {object} globalContext The current context object\n * @param {string} namespace Current namespace of the DOM node (HTML, SVG, or MathML)\n * @param {Array\u003cPreactElement\u003e} excessDomChildren\n * @param {Array\u003cComponent\u003e} commitQueue List of components which have callbacks\n * to invoke in commitRoot\n * @param {boolean} isHydrating Whether or not we are in hydration\n * @param {any[]} refQueue an array of elements needed to invoke refs\n * @returns {PreactElement}\n */\nfunction diffElementNodes(\n\tdom,\n\tnewVNode,\n\toldVNode,\n\tglobalContext,\n\tnamespace,\n\texcessDomChildren,\n\tcommitQueue,\n\tisHydrating,\n\trefQueue\n) {\n\tlet oldProps = oldVNode.props;\n\tlet newProps = newVNode.props;\n\tlet nodeType = /** @type {string} */ (newVNode.type);\n\t/** @type {any} */\n\tlet i;\n\t/** @type {{ __html?: string }} */\n\tlet newHtml;\n\t/** @type {{ __html?: string }} */\n\tlet oldHtml;\n\t/** @type {ComponentChildren} */\n\tlet newChildren;\n\tlet value;\n\tlet inputValue;\n\tlet checked;\n\n\t// Tracks entering and exiting namespaces when descending through the tree.\n\tif (nodeType === 'svg') namespace = 'http://www.w3.org/2000/svg';\n\telse if (nodeType === 'math')\n\t\tnamespace = 'http://www.w3.org/1998/Math/MathML';\n\telse if (!namespace) namespace = 'http://www.w3.org/1999/xhtml';\n\n\tif (excessDomChildren != null) {\n\t\tfor (i = 0; i \u003c excessDomChildren.length; i++) {\n\t\t\tvalue = excessDomChildren[i];\n\n\t\t\t// if newVNode matches an element in excessDomChildren or the `dom`\n\t\t\t// argument matches an element in excessDomChildren, remove it from\n\t\t\t// excessDomChildren so it isn't later removed in diffChildren\n\t\t\tif (\n\t\t\t\tvalue \u0026\u0026\n\t\t\t\t'setAttribute' in value === !!nodeType \u0026\u0026\n\t\t\t\t(nodeType ? value.localName === nodeType : value.nodeType === 3)\n\t\t\t) {\n\t\t\t\tdom = value;\n\t\t\t\texcessDomChildren[i] = null;\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t}\n\n\tif (dom == null) {\n\t\tif (nodeType === null) {\n\t\t\treturn document.createTextNode(newProps);\n\t\t}\n\n\t\tdom = document.createElementNS(\n\t\t\tnamespace,\n\t\t\tnodeType,\n\t\t\tnewProps.is \u0026\u0026 newProps\n\t\t);\n\n\t\t// we created a new parent, so none of the previously attached children can be reused:\n\t\texcessDomChildren = null;\n\t\t// we are creating a new node, so we can assume this is a new subtree (in\n\t\t// case we are hydrating), this deopts the hydrate\n\t\tisHydrating = false;\n\t}\n\n\tif (nodeType === null) {\n\t\t// During hydration, we still have to split merged text from SSR'd HTML.\n\t\tif (oldProps !== newProps \u0026\u0026 (!isHydrating || dom.data !== newProps)) {\n\t\t\tdom.data = newProps;\n\t\t}\n\t} else {\n\t\t// If excessDomChildren was not null, repopulate it with the current element's children:\n\t\texcessDomChildren = excessDomChildren \u0026\u0026 slice.call(dom.childNodes);\n\n\t\toldProps = oldVNode.props || EMPTY_OBJ;\n\n\t\t// If we are in a situation where we are not hydrating but are using\n\t\t// existing DOM (e.g. replaceNode) we should read the existing DOM\n\t\t// attributes to diff them\n\t\tif (!isHydrating \u0026\u0026 excessDomChildren != null) {\n\t\t\toldProps = {};\n\t\t\tfor (i = 0; i \u003c dom.attributes.length; i++) {\n\t\t\t\tvalue = dom.attributes[i];\n\t\t\t\toldProps[value.name] = value.value;\n\t\t\t}\n\t\t}\n\n\t\tfor (i in oldProps) {\n\t\t\tvalue = oldProps[i];\n\t\t\tif (i == 'children') {\n\t\t\t} else if (i == 'dangerouslySetInnerHTML') {\n\t\t\t\toldHtml = value;\n\t\t\t} else if (i !== 'key' \u0026\u0026 !(i in newProps)) {\n\t\t\t\tif (\n\t\t\t\t\t(i == 'value' \u0026\u0026 'defaultValue' in newProps) ||\n\t\t\t\t\t(i == 'checked' \u0026\u0026 'defaultChecked' in newProps)\n\t\t\t\t) {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\t\t\t\tsetProperty(dom, i, null, value, namespace);\n\t\t\t}\n\t\t}\n\n\t\t// During hydration, props are not diffed at all (including dangerouslySetInnerHTML)\n\t\t// @TODO we should warn in debug mode when props don't match here.\n\t\tfor (i in newProps) {\n\t\t\tvalue = newProps[i];\n\t\t\tif (i == 'children') {\n\t\t\t\tnewChildren = value;\n\t\t\t} else if (i == 'dangerouslySetInnerHTML') {\n\t\t\t\tnewHtml = value;\n\t\t\t} else if (i == 'value') {\n\t\t\t\tinputValue = value;\n\t\t\t} else if (i == 'checked') {\n\t\t\t\tchecked = value;\n\t\t\t} else if (\n\t\t\t\ti !== 'key' \u0026\u0026\n\t\t\t\t(!isHydrating || typeof value == 'function') \u0026\u0026\n\t\t\t\toldProps[i] !== value\n\t\t\t) {\n\t\t\t\tsetProperty(dom, i, value, oldProps[i], namespace);\n\t\t\t}\n\t\t}\n\n\t\t// If the new vnode didn't have dangerouslySetInnerHTML, diff its children\n\t\tif (newHtml) {\n\t\t\t// Avoid re-applying the same '__html' if it did not changed between re-render\n\t\t\tif (\n\t\t\t\t!isHydrating \u0026\u0026\n\t\t\t\t(!oldHtml ||\n\t\t\t\t\t(newHtml.__html !== oldHtml.__html \u0026\u0026\n\t\t\t\t\t\tnewHtml.__html !== dom.innerHTML))\n\t\t\t) {\n\t\t\t\tdom.innerHTML = newHtml.__html;\n\t\t\t}\n\n\t\t\tnewVNode._children = [];\n\t\t} else {\n\t\t\tif (oldHtml) dom.innerHTML = '';\n\n\t\t\tdiffChildren(\n\t\t\t\tdom,\n\t\t\t\tisArray(newChildren) ? newChildren : [newChildren],\n\t\t\t\tnewVNode,\n\t\t\t\toldVNode,\n\t\t\t\tglobalContext,\n\t\t\t\tnodeType === 'foreignObject'\n\t\t\t\t\t? 'http://www.w3.org/1999/xhtml'\n\t\t\t\t\t: namespace,\n\t\t\t\texcessDomChildren,\n\t\t\t\tcommitQueue,\n\t\t\t\texcessDomChildren\n\t\t\t\t\t? excessDomChildren[0]\n\t\t\t\t\t: oldVNode._children \u0026\u0026 getDomSibling(oldVNode, 0),\n\t\t\t\tisHydrating,\n\t\t\t\trefQueue\n\t\t\t);\n\n\t\t\t// Remove children that are not part of any vnode.\n\t\t\tif (excessDomChildren != null) {\n\t\t\t\tfor (i = excessDomChildren.length; i--; ) {\n\t\t\t\t\tif (excessDomChildren[i] != null) removeNode(excessDomChildren[i]);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t// As above, don't diff props during hydration\n\t\tif (!isHydrating) {\n\t\t\ti = 'value';\n\t\t\tif (\n\t\t\t\tinputValue !== undefined \u0026\u0026\n\t\t\t\t// #2756 For the \u003cprogress\u003e-element the initial value is 0,\n\t\t\t\t// despite the attribute not being present. When the attribute\n\t\t\t\t// is missing the progress bar is treated as indeterminate.\n\t\t\t\t// To fix that we'll always update it when it is 0 for progress elements\n\t\t\t\t(inputValue !== dom[i] ||\n\t\t\t\t\t(nodeType === 'progress' \u0026\u0026 !inputValue) ||\n\t\t\t\t\t// This is only for IE 11 to fix \u003cselect\u003e value not being updated.\n\t\t\t\t\t// To avoid a stale select value we need to set the option.value\n\t\t\t\t\t// again, which triggers IE11 to re-evaluate the select value\n\t\t\t\t\t(nodeType === 'option' \u0026\u0026 inputValue !== oldProps[i]))\n\t\t\t) {\n\t\t\t\tsetProperty(dom, i, inputValue, oldProps[i], namespace);\n\t\t\t}\n\n\t\t\ti = 'checked';\n\t\t\tif (checked !== undefined \u0026\u0026 checked !== dom[i]) {\n\t\t\t\tsetProperty(dom, i, checked, oldProps[i], namespace);\n\t\t\t}\n\t\t}\n\t}\n\n\treturn dom;\n}\n\n/**\n * Invoke or update a ref, depending on whether it is a function or object ref.\n * @param {Ref\u003cany\u003e} ref\n * @param {any} value\n * @param {VNode} vnode\n */\nexport function applyRef(ref, value, vnode) {\n\ttry {\n\t\tif (typeof ref == 'function') ref(value);\n\t\telse ref.current = value;\n\t} catch (e) {\n\t\toptions._catchError(e, vnode);\n\t}\n}\n\n/**\n * Unmount a virtual node from the tree and apply DOM changes\n * @param {VNode} vnode The virtual node to unmount\n * @param {VNode} parentVNode The parent of the VNode that initiated the unmount\n * @param {boolean} [skipRemove] Flag that indicates that a parent node of the\n * current element is already detached from the DOM.\n */\nexport function unmount(vnode, parentVNode, skipRemove) {\n\tlet r;\n\tif (options.unmount) options.unmount(vnode);\n\n\tif ((r = vnode.ref)) {\n\t\tif (!r.current || r.current === vnode._dom) {\n\t\t\tapplyRef(r, null, parentVNode);\n\t\t}\n\t}\n\n\tif ((r = vnode._component) != null) {\n\t\tif (r.componentWillUnmount) {\n\t\t\ttry {\n\t\t\t\tr.componentWillUnmount();\n\t\t\t} catch (e) {\n\t\t\t\toptions._catchError(e, parentVNode);\n\t\t\t}\n\t\t}\n\n\t\tr.base = r._parentDom = null;\n\t}\n\n\tif ((r = vnode._children)) {\n\t\tfor (let i = 0; i \u003c r.length; i++) {\n\t\t\tif (r[i]) {\n\t\t\t\tunmount(\n\t\t\t\t\tr[i],\n\t\t\t\t\tparentVNode,\n\t\t\t\t\tskipRemove || typeof vnode.type != 'function'\n\t\t\t\t);\n\t\t\t}\n\t\t}\n\t}\n\n\tif (!skipRemove \u0026\u0026 vnode._dom != null) {\n\t\tremoveNode(vnode._dom);\n\t}\n\n\t// Must be set to `undefined` to properly clean up `_nextDom`\n\t// for which `null` is a valid value. See comment in `create-element.js`\n\tvnode._component = vnode._parent = vnode._dom = vnode._nextDom = undefined;\n}\n\n/** The `.render()` method for a PFC backing instance. */\nfunction doRender(props, state, context) {\n\treturn this.constructor(props, context);\n}\n","import { EMPTY_OBJ } from './constants';\nimport { commitRoot, diff } from './diff/index';\nimport { createElement, Fragment } from './create-element';\nimport options from './options';\nimport { slice } from './util';\n\n/**\n * Render a Preact virtual node into a DOM element\n * @param {ComponentChild} vnode The virtual node to render\n * @param {PreactElement} parentDom The DOM element to render into\n * @param {PreactElement | object} [replaceNode] Optional: Attempt to re-use an\n * existing DOM tree rooted at `replaceNode`\n */\nexport function render(vnode, parentDom, replaceNode) {\n\tif (options._root) options._root(vnode, parentDom);\n\n\t// We abuse the `replaceNode` parameter in `hydrate()` to signal if we are in\n\t// hydration mode or not by passing the `hydrate` function instead of a DOM\n\t// element..\n\tlet isHydrating = typeof replaceNode == 'function';\n\n\t// To be able to support calling `render()` multiple times on the same\n\t// DOM node, we need to obtain a reference to the previous tree. We do\n\t// this by assigning a new `_children` property to DOM nodes which points\n\t// to the last rendered tree. By default this property is not present, which\n\t// means that we are mounting a new tree for the first time.\n\tlet oldVNode = isHydrating\n\t\t? null\n\t\t: (replaceNode \u0026\u0026 replaceNode._children) || parentDom._children;\n\n\tvnode = ((!isHydrating \u0026\u0026 replaceNode) || parentDom)._children =\n\t\tcreateElement(Fragment, null, [vnode]);\n\n\t// List of effects that need to be called after diffing.\n\tlet commitQueue = [],\n\t\trefQueue = [];\n\tdiff(\n\t\tparentDom,\n\t\t// Determine the new vnode tree and store it on the DOM element on\n\t\t// our custom `_children` property.\n\t\tvnode,\n\t\toldVNode || EMPTY_OBJ,\n\t\tEMPTY_OBJ,\n\t\tparentDom.namespaceURI,\n\t\t!isHydrating \u0026\u0026 replaceNode\n\t\t\t? [replaceNode]\n\t\t\t: oldVNode\n\t\t\t? null\n\t\t\t: parentDom.firstChild\n\t\t\t? slice.call(parentDom.childNodes)\n\t\t\t: null,\n\t\tcommitQueue,\n\t\t!isHydrating \u0026\u0026 replaceNode\n\t\t\t? replaceNode\n\t\t\t: oldVNode\n\t\t\t? oldVNode._dom\n\t\t\t: parentDom.firstChild,\n\t\tisHydrating,\n\t\trefQueue\n\t);\n\n\t// Flush all queued effects\n\tcommitRoot(commitQueue, vnode, refQueue);\n}\n\n/**\n * Update an existing DOM element with data from a Preact virtual node\n * @param {ComponentChild} vnode The virtual node to render\n * @param {PreactElement} parentDom The DOM element to update\n */\nexport function hydrate(vnode, parentDom) {\n\trender(vnode, parentDom, hydrate);\n}\n","import { assign, slice } from './util';\nimport { createVNode } from './create-element';\n\n/**\n * Clones the given VNode, optionally adding attributes/props and replacing its\n * children.\n * @param {VNode} vnode The virtual DOM element to clone\n * @param {object} props Attributes/props to add when cloning\n * @param {Array\u003cComponentChildren\u003e} rest Any additional arguments will be used\n * as replacement children.\n * @returns {VNode}\n */\nexport function cloneElement(vnode, props, children) {\n\tlet normalizedProps = assign({}, vnode.props),\n\t\tkey,\n\t\tref,\n\t\ti;\n\n\tlet defaultProps;\n\n\tif (vnode.type \u0026\u0026 vnode.type.defaultProps) {\n\t\tdefaultProps = vnode.type.defaultProps;\n\t}\n\n\tfor (i in props) {\n\t\tif (i == 'key') key = props[i];\n\t\telse if (i == 'ref') ref = props[i];\n\t\telse if (props[i] === undefined \u0026\u0026 defaultProps !== undefined) {\n\t\t\tnormalizedProps[i] = defaultProps[i];\n\t\t} else {\n\t\t\tnormalizedProps[i] = props[i];\n\t\t}\n\t}\n\n\tif (arguments.length \u003e 2) {\n\t\tnormalizedProps.children =\n\t\t\targuments.length \u003e 3 ? slice.call(arguments, 2) : children;\n\t}\n\n\treturn createVNode(\n\t\tvnode.type,\n\t\tnormalizedProps,\n\t\tkey || vnode.key,\n\t\tref || vnode.ref,\n\t\tnull\n\t);\n}\n","/**\n * Find the closest error boundary to a thrown error and call it\n * @param {object} error The thrown value\n * @param {VNode} vnode The vnode that threw the error that was caught (except\n * for unmounting when this parameter is the highest parent that was being\n * unmounted)\n * @param {VNode} [oldVNode]\n * @param {ErrorInfo} [errorInfo]\n */\nexport function _catchError(error, vnode, oldVNode, errorInfo) {\n\t/** @type {Component} */\n\tlet component,\n\t\t/** @type {ComponentType} */\n\t\tctor,\n\t\t/** @type {boolean} */\n\t\thandled;\n\n\tfor (; (vnode = vnode._parent); ) {\n\t\tif ((component = vnode._component) \u0026\u0026 !component._processingException) {\n\t\t\ttry {\n\t\t\t\tctor = component.constructor;\n\n\t\t\t\tif (ctor \u0026\u0026 ctor.getDerivedStateFromError != null) {\n\t\t\t\t\tcomponent.setState(ctor.getDerivedStateFromError(error));\n\t\t\t\t\thandled = component._dirty;\n\t\t\t\t}\n\n\t\t\t\tif (component.componentDidCatch != null) {\n\t\t\t\t\tcomponent.componentDidCatch(error, errorInfo || {});\n\t\t\t\t\thandled = component._dirty;\n\t\t\t\t}\n\n\t\t\t\t// This is an error boundary. Mark it as having bailed out, and whether it was mid-hydration.\n\t\t\t\tif (handled) {\n\t\t\t\t\treturn (component._pendingError = component);\n\t\t\t\t}\n\t\t\t} catch (e) {\n\t\t\t\terror = e;\n\t\t\t}\n\t\t}\n\t}\n\n\tthrow error;\n}\n"],"version":3}
