From 488094651511d2dc672148fdd69df9e0a6ef7be0 Mon Sep 17 00:00:00 2001 From: maddalax Date: Thu, 10 Oct 2024 17:00:20 -0500 Subject: [PATCH] hn clone --- examples/hackernews/.dockerignore | 11 ++ examples/hackernews/.gitignore | 6 + examples/hackernews/Dockerfile | 38 +++++ examples/hackernews/Taskfile.yml | 20 +++ examples/hackernews/assets.go | 13 ++ examples/hackernews/assets/css/input.css | 15 ++ .../assets/public/apple-touch-icon.png | Bin 0 -> 3429 bytes examples/hackernews/assets/public/favicon.ico | Bin 0 -> 5238 bytes .../assets/public/icon-192-maskable.png | Bin 0 -> 3732 bytes .../hackernews/assets/public/icon-192.png | Bin 0 -> 7032 bytes .../assets/public/icon-512-maskable.png | Bin 0 -> 14025 bytes .../hackernews/assets/public/icon-512.png | Bin 0 -> 23888 bytes examples/hackernews/assets_prod.go | 16 ++ examples/hackernews/components/badge.go | 14 ++ examples/hackernews/go.mod | 10 ++ examples/hackernews/go.sum | 18 +++ .../hackernews/internal/batch/parallel.go | 30 ++++ examples/hackernews/internal/embedded/os.go | 17 +++ .../hackernews/internal/httpjson/client.go | 115 +++++++++++++++ examples/hackernews/internal/news/news.go | 137 ++++++++++++++++++ examples/hackernews/internal/random.go | 13 ++ .../hackernews/internal/timeformat/time.go | 39 +++++ examples/hackernews/main.go | 30 ++++ examples/hackernews/pages/index.go | 21 +++ examples/hackernews/pages/root.go | 32 ++++ examples/hackernews/partials/comments.go | 84 +++++++++++ examples/hackernews/partials/sidebar.go | 126 ++++++++++++++++ examples/hackernews/partials/story.go | 79 ++++++++++ examples/hackernews/tailwind.config.js | 7 + framework/assets/dist/htmgo.js | 4 +- framework/assets/js/htmgo.ts | 16 ++ .../js/htmxextensions/trigger-children.ts | 18 ++- templates/starter/pages/root.go | 2 +- 33 files changed, 920 insertions(+), 11 deletions(-) create mode 100644 examples/hackernews/.dockerignore create mode 100644 examples/hackernews/.gitignore create mode 100644 examples/hackernews/Dockerfile create mode 100644 examples/hackernews/Taskfile.yml create mode 100644 examples/hackernews/assets.go create mode 100644 examples/hackernews/assets/css/input.css create mode 100644 examples/hackernews/assets/public/apple-touch-icon.png create mode 100644 examples/hackernews/assets/public/favicon.ico create mode 100644 examples/hackernews/assets/public/icon-192-maskable.png create mode 100644 examples/hackernews/assets/public/icon-192.png create mode 100644 examples/hackernews/assets/public/icon-512-maskable.png create mode 100644 examples/hackernews/assets/public/icon-512.png create mode 100644 examples/hackernews/assets_prod.go create mode 100644 examples/hackernews/components/badge.go create mode 100644 examples/hackernews/go.mod create mode 100644 examples/hackernews/go.sum create mode 100644 examples/hackernews/internal/batch/parallel.go create mode 100644 examples/hackernews/internal/embedded/os.go create mode 100644 examples/hackernews/internal/httpjson/client.go create mode 100644 examples/hackernews/internal/news/news.go create mode 100644 examples/hackernews/internal/random.go create mode 100644 examples/hackernews/internal/timeformat/time.go create mode 100644 examples/hackernews/main.go create mode 100644 examples/hackernews/pages/index.go create mode 100644 examples/hackernews/pages/root.go create mode 100644 examples/hackernews/partials/comments.go create mode 100644 examples/hackernews/partials/sidebar.go create mode 100644 examples/hackernews/partials/story.go create mode 100644 examples/hackernews/tailwind.config.js diff --git a/examples/hackernews/.dockerignore b/examples/hackernews/.dockerignore new file mode 100644 index 0000000..fb47686 --- /dev/null +++ b/examples/hackernews/.dockerignore @@ -0,0 +1,11 @@ +# Project exclude paths +/tmp/ +node_modules/ +dist/ +js/dist +js/node_modules +go.work +go.work.sum +.idea +!framework/assets/dist +__htmgo \ No newline at end of file diff --git a/examples/hackernews/.gitignore b/examples/hackernews/.gitignore new file mode 100644 index 0000000..3d6a979 --- /dev/null +++ b/examples/hackernews/.gitignore @@ -0,0 +1,6 @@ +/assets/dist +tmp +node_modules +.idea +__htmgo +dist \ No newline at end of file diff --git a/examples/hackernews/Dockerfile b/examples/hackernews/Dockerfile new file mode 100644 index 0000000..37c299d --- /dev/null +++ b/examples/hackernews/Dockerfile @@ -0,0 +1,38 @@ +# Stage 1: Build the Go binary +FROM golang:1.23-alpine AS builder + +RUN apk update +RUN apk add git +RUN apk add curl + +# Set the working directory inside the container +WORKDIR /app + +# Copy go.mod and go.sum files +COPY go.mod go.sum ./ + +# Download and cache the Go modules +RUN go mod download + +# Copy the source code into the container +COPY . . + +# Build the Go binary for Linux +RUN GOPRIVATE=github.com/maddalax GOPROXY=direct go run github.com/maddalax/htmgo/cli/htmgo@latest build + + +# Stage 2: Create the smallest possible image +FROM gcr.io/distroless/base-debian11 + +# Set the working directory inside the container +WORKDIR /app + +# Copy the Go binary from the builder stage +COPY --from=builder /app/dist . + +# Expose the necessary port (replace with your server port) +EXPOSE 3000 + + +# Command to run the binary +CMD ["./hackernews"] diff --git a/examples/hackernews/Taskfile.yml b/examples/hackernews/Taskfile.yml new file mode 100644 index 0000000..28f1902 --- /dev/null +++ b/examples/hackernews/Taskfile.yml @@ -0,0 +1,20 @@ +version: '3' + +tasks: + run: + cmds: + - htmgo run + silent: true + + build: + cmds: + - htmgo build + + docker: + cmds: + - docker build . + + watch: + cmds: + - htmgo watch + silent: true diff --git a/examples/hackernews/assets.go b/examples/hackernews/assets.go new file mode 100644 index 0000000..8104b98 --- /dev/null +++ b/examples/hackernews/assets.go @@ -0,0 +1,13 @@ +//go:build !prod +// +build !prod + +package main + +import ( + "hackernews/internal/embedded" + "io/fs" +) + +func GetStaticAssets() fs.FS { + return embedded.NewOsFs() +} diff --git a/examples/hackernews/assets/css/input.css b/examples/hackernews/assets/css/input.css new file mode 100644 index 0000000..404b710 --- /dev/null +++ b/examples/hackernews/assets/css/input.css @@ -0,0 +1,15 @@ +@tailwind base; +@tailwind components; +@tailwind utilities; + +@layer utilities { + /* Chrome, Safari and Opera */ + .no-scrollbar::-webkit-scrollbar { + display: none; + } + + .no-scrollbar { + -ms-overflow-style: none; /* IE and Edge */ + scrollbar-width: none; /* Firefox */ + } +} diff --git a/examples/hackernews/assets/public/apple-touch-icon.png b/examples/hackernews/assets/public/apple-touch-icon.png new file mode 100644 index 0000000000000000000000000000000000000000..d10e9fe56b9576167656a1270d4ab42bec72d659 GIT binary patch literal 3429 zcmeHK*H_cc7X5`#1VIp#UPMI!siJggL5e_t5ITt9M==NyK}w{GfE3|Fnv_VSNEhiK zB%*+H2)!E=A)$m8di~1uHi7E0F!3@00KlTJrwyZW z^&gy}r^Y+I^f##l@`mYZ0U!JL7paA|vz5M!kr5zH&CdX!s7CDY>ns9#*8O`|jMO~iuFIcM`+$DqYyYbERdYs=} zG@Cn2HOG@*am(sCU8YU4lC`n<5GSkiFgm4DCN(<0;*+7cW;6U2dl#+g)$>=`9yCDe z*SxKFdIVPOFVxtohIP8BWJYOV{o+!MCNMy1CZ{@Ue;$H_nO?k1t=WRfOd7$4& z#`VAe$hoRtbV&OP0A7m5vC5j-@BdEyX(8AxEm+*6uhX!=m@5JE9(-Wtf)W?GE@EnD z$6r%hWBQQdTwMAwAFCTbv>M)?rJNrg>6o1SRxkfb)IdijJL?yJqGdL20SuyT9-2+b@-uyScj;)b8vom%KhA>}tfmHQT^{z4g$k z2pn&Fp&(9x+>CYZ54OR2-7trb)RS|t$JaK(Gt}O{yr;vQ+xqe)<}fW@BBw#_+R(|v z0+K^!*CS$B%kV^ibJ|8*%i>R^Y}U`}$iQR5@*vQ z&^j@LY^&2C66f)(3j|1mHIHz6lO^nOP|&E)2FX&eY>%iSEEMIpl9_bZSSm|bb%n7Y z`3Fop{OsXCj!1XWY^2&x{;rOoAV!~5MLG48W`0*g-snQ3Y=0HBs)Htq z`-qlwr@c3Crk9t#;P#gdFmwC&WWGft>;-v^j)`TV!us?B~V9 zXUwLcQN)SU&E3hRH>bG!E_d(R9j+Eg<7kzWf%2Iq`+&L!s+1Q|OLwnjqqE1jS4CCa zDuhEVm_3cKebz9w=d#bHJz^x;%}0l$r?hQT$c}onn2TbhIJ|Qz;+(s0iPX#YkxqW4 zx50SRb7g(glmqe!KSLA;J0K8`5?(3sX5jC)z>ug`zP-gXrEEVfUTibjn(H8nqB_hS z?6+Fzpp_1?rTcaDHa&jwO+;OIA9qFp*<_1qL?~2*$IM5s(br~yM)u=SYaaj*n13K2 zy9F+u?`q^SFLP{X0!X6X`0>18`^f0Ic?(LBv5Gb`{zotCF^Tg(18 zX6nHn)!(yu3E~mN(rmVb5V}SI^LfSKN)TR9+tzhl_EQM1BeK}ft7F%;|3>C7&Hg4N zyT)@iu%K@tr<%bjiI0*@8QuVYcEC}peid!c_TMh9MP>+u?p$(;f@TdsTN+6f`?p;7 z@Rqq*+)dz$Y^bFmnRaeUF8pzdKzL z^7@`_FoIU&IX9VuDEi?bT>0r8|%N1B$=Y?cL?Qn%X3kE|=ul z(d+9`@j2cMT%Pmrvf0wel$qSnFkzQnV!PaZPS%A@;dHUBSRthC?eb1zi|d3>Vj$W~ z=n0H+)bw}>on=^7RtC-ZG{hxdgsVtg;>*a=CWpmH9Km>IWEV!8#TR$e2zHR#tA4FK zHoPut3hNNU_OI>sBPC1g{CPIlElWvMz#%+g>9v3q6LtVQWpQQuomO9V0VSp(X88vb zzRWukPDA2mywGwKi3??Pn`BKw zjz+`+UDUiQV6JIz>*(-;k)qbBK)1qb_vSHW0@XD>aI47Y!tGn~rd3vSzj;{ivlyPQ zOWZVA+xH!WZ&>;=Tkr09e#t&MNpYu)-c%V{0#!$yfBwWb9h{$emRbJGsSKnvWj$#& zQFJZ#u;NB>@fEMax61V2@q!WI1*6|*P*vBf#4g6}8YE!-E?v$jM`2kBicIAq$ziD$?)9^k02kLY4T}&>8nja#e}QpOd3` z*4(QfhVVZ+UeJu#Dr=|`wYLM7`fPlN%B+dTSy+uPsQG7=`=$Kjet@=LmhZUQwqkEeVZBB1ZepQx>oC%NWF zdmo=0@^$&na^HaJYV3|C9v`Sr*q-{Y?$I=W&1L4|UO1qU$)n&eX$oiEt|!5$e%Bc{#~f{N391h{sB|aM6Cb- literal 0 HcmV?d00001 diff --git a/examples/hackernews/assets/public/favicon.ico b/examples/hackernews/assets/public/favicon.ico new file mode 100644 index 0000000000000000000000000000000000000000..040cccf58ea179321b86f78b5f0a0817f1ec773a GIT binary patch literal 5238 zcmc&%TTc^F5MGTxz&GO?PsX3&laKxa5?VDrsPP_Skg8Epp+!_s6a+*B?}`GJic-7) zB8Vu0f{KVn1m!020|D?VOqU=FFKnXI9e|XbZK)i!~ZGZTTWi zTSj9-g8rZQtBALpc=W0fo8j(S%O?&OATMu&mKe zdP>qtnj0j7LmFfqw!yZd)Rh>62A?G_s?o4sOTFvGNAbC*3$0Is$VuPwznqMf;^%m` zBKz=0LHWmb;c{Ub?%pm!S4T6d$_kX69w!-R#Sd0pLiv>(lwHh1XL}Qx>Z;K4v6xbM9Jy;a*q_>sNeIh9UtF!AnVWu+_|1-rZ4yRAAQDaYk4Tv{GzEA4G+rkyzxG& z%g-x09iR2t2gPUnrpJEN_)C$Oxf8h=J5Y0{1eMovQJA$`$r=3T7$`o=T`lsd|He6! zcaf7Oe5d*%pJUaRwLtpO?`2~<^a>m*ML<#bnL!)#Fjqw{qI90=JUF4i7m%~ zaW5kKJ?njzwjGY{M41bEt~u13D?gK}8DHP`xybWq{SPrV*XV3>?qu2~_-~v=T}>I? zB}F*x+vdm@!`b3U-po(Fmk0WK0Zb7^o^UvX(zB_yHr2T{i!&y3|2hQy7g2RHAEkMz zXsEr7$%%3Ff9b)A)b(~g=x3^RPMxOpH9o4ulZO?`7T>#kf6Kn5_{@Is|IMqXs1M%4 zub*QW9_$zQv{}p)Z~8n}w$+>-lXKY~j0}Gh_T=3A&Q?rKg;8)K8SG#GmyZjI)T z=H75@bja!Y8J}ZdiyxYtL~r+Ne0bX?*30$9`7i4KE7w27T;Jyp8vCXM| z&C<46{l$i55@WqroXOr9-*#}0H`fO&eVj?(W=`~}HZt>pD{RUhIbQg(KPUXS^&i{= z#k2p4;Pdx}Nq){NZ@T}CcmK^Xi0AhQQkrtwK@C# F{tLVTip2l` literal 0 HcmV?d00001 diff --git a/examples/hackernews/assets/public/icon-192-maskable.png b/examples/hackernews/assets/public/icon-192-maskable.png new file mode 100644 index 0000000000000000000000000000000000000000..d4d6efb61bf6c212e3c466edca6256d9a3000e86 GIT binary patch literal 3732 zcmeHKX*kqf8~@LcC1qw(mLa<$yD*ZmWgD7ANVc+%BBrq<+t^}?kTuIBOO_&f2xBZ^ zlJS%+$)0&)8nVYcg}nc+>s>y)U*C`Khx^?3Iltd^?)y6DKKFGW(!~qrhYunT0swFr zV_{+o>dxQ7!v&7EQ~unbf)H%Yje*+tVk~fC;_Zm>!D4|^pv?n7lKcS9-xN@gpa1|z zF$CZMHRShNG4$VPXEDcr?B7J}*)w#|=`W0lk=<>`vTL}%U9ZS~B!h2u>Y9IiOMnW2 z6ZwrR8AFtnd>~$Vz(mGLF7>CisHySZ$(p0(si$PCPhtI}4q}i;C1W}B9~#EqeFo?6 z72`q@dc?RUh5b|N&(3z`hb(WkhX;m^hi{7d%{R54p51AmUEQf+wmm`#)ZeBpDJMWV z51C314>lvT;cJorL=ur=20+#Fqd8#^N$&sK|Lb#*oJbvFujCk^HHMXvLMaUC(dpVI z7l~uj@kGS~YJOkT^3Qn3dFQz8EbRm{ro#KTY=+Q0#e84HRS=}ZoRWZO@e@)6oCr*H z%SqSA0-V=4G&S)sD4ZD4Y$B@-0{+CiCsvFAXb>znxrYk`4i66Ypm_{|mANAsp9}$L z9R!)*%njk`M7u~I5d{Hl!*c>`@amhBtV}#OK!6K}V~B&k*g+%4yObd&vSmIim+QVD<1$K89M0M>#^KXu#Ds@8) z&yv>hnm7NJMCwZx*tVXqamoFZ)IKfHuBADgEjk+f<;xY_TZ@OZW&*DJp4QNaqxAGN z>`+T#NaU)m6`%P^Eff;m>1%df<5;S4v4ZEOf}BEqJTkx_Kiwcf@Lk~|;x%)pLpr)g zLpV_&w5L-n?W)qBUn?swSZ9uPz_8+4Q=84qnNshDs9E>w=aiudpN&dH!}pelAK696 zcNbxSL)lBCMfO7*XL&l4w13egv~+T#HQ0Uws?`IRAuvzR5eZudOND- zE_il^Iw;o3=juBfcXNGjnkZ{@vo+Sk7UX2%Iw8dGL5`m%D$U|7MNnB7}2| z82&3{kF|S6(;-+9DA1?jH+IM|yU9`|2G&`Hd7pRcGkTl(WO2-2t@JN!pW)BnqBTRhaI4O&j@|x_ z;9-9$h)}}GSVj2_*tQlXPP(wC=sfFW6 z`iY7}+sM}{dhwm?7`cHMC*(UyKzSfb15sfQKU^V4N9t{5IgVeT>zrybGK^xrObtiR zPEkV&R9srjMjJzdo2p19J*FD$+!p6yWwiaz+!ibUL#c>(za%lrYr|G1sIMr%7-@+hz0Ye|? zkA+9VyR5r7)aZ&Th_uiRTvf*xX0_h3JFQxatN_>7;nF*g;1#YkA^8c?5@k5-Z?N~s zFDzMOF)n|hezX{Ey>o83HO=*N*?CE~P;lsdrIdsr5clarWbn2f`X4F~-6cq-w@jvc}9F4$zzsl1I*^5Xc*Ujj5s-CrO zTxijCup$snx9zZm9G;buB{-kUtn?E5B%T%SKR&s@-LwZC znr~tukDtEWyj30e@khg(C$3=OXnm`2^CV%tze4|nikD5H3;@yTy+}%QRCiLkM6auO zbjT%o$ry-!!n-W==%Gx1YS{eEsJq(8sP|lu1m4RSUc4WT>2Uc3xRqVqE53Mx*dWd1IZB z>1+(PfOpS-W75~D&0VprCHnsIcKhLQ^bl$$^cA7}1$sISFKQ>i6<)zU%~VAM7Oxi# z$><*cz9=s{Ghc-2(|5(k<`+2EVcu}0yC@Jf>a8pZR=sDb!C7K@0wWh%+z6TaGa?ke z(PyaZdYIk56%Ne{{?uL$mn&_QOCFIsa`t~CvO|OT(X?tnF^Pw3ki& z6}1~RI>*$*cBj&^p+Pb>MYP~^{tLaTj~>cBHFZ?h3Ta9u-{71QZB&P{n#$xC52Y?GXdNX9aFXBWzUjQR<`$S z#n-PpOLsTSB09qHyl4lt4#f64#wqQ%zld0z5Cb`Pp>YwF7SQHwU1?&R($!$z47YOR@iF2hLi7G@g6v_`ne5`nK`}Vx97WW zt9xMLUW9VVaO`mA_a^MVnh(swg~PEg#r&dgf9)P)+fz>Yv4NtjmE?w3({b(xgApEh z6|(YmOOhj%5ke>#O}8h%tivtXvFxS2jBB1#j1*_bKVNY$eOe^CXbj}neQGj4ffdQL zru}7h1eRVUuVa0g_2n`QC#)NT;!VPumBYfjZqg&Kee#sJgr2k z(7Z~uHJz7UXG<8&u{nK$ z-ECyRf}Q#{?%5)O2z>B7cpoVRKyW64F7|04QT&qQ2ObEIq0GzA)ptPRR$f<$8Q3!- zGY(uH1?&1hT|ftum71%?K_dETT_pnC+05&;{T4`ER8KTb1=~{1|A+8jr_i|%w90=a U`U+xTzkh@n(+eiG#@FKh0jyU=3;+NC literal 0 HcmV?d00001 diff --git a/examples/hackernews/assets/public/icon-192.png b/examples/hackernews/assets/public/icon-192.png new file mode 100644 index 0000000000000000000000000000000000000000..f5334355c00b1ff31781f93b97b0efaa0e049d60 GIT binary patch literal 7032 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 x%cimilvfPSdV(Q_^}+tza4QzW{-_?Ogx> literal 0 HcmV?d00001 diff --git a/examples/hackernews/assets/public/icon-512-maskable.png b/examples/hackernews/assets/public/icon-512-maskable.png new file mode 100644 index 0000000000000000000000000000000000000000..db61f3dbc056f541e9b215d4be7ec22a8f436e38 GIT binary patch literal 14025 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 KG(KIojr>11q;Vnu literal 0 HcmV?d00001 diff --git a/examples/hackernews/assets/public/icon-512.png b/examples/hackernews/assets/public/icon-512.png new file mode 100644 index 0000000000000000000000000000000000000000..ba0665d887cf19d3a45122767f0d6609ccb1afbb GIT binary patch literal 23888 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 B&S(Gt literal 0 HcmV?d00001 diff --git a/examples/hackernews/assets_prod.go b/examples/hackernews/assets_prod.go new file mode 100644 index 0000000..f0598e1 --- /dev/null +++ b/examples/hackernews/assets_prod.go @@ -0,0 +1,16 @@ +//go:build prod +// +build prod + +package main + +import ( + "embed" + "io/fs" +) + +//go:embed assets/dist/* +var staticAssets embed.FS + +func GetStaticAssets() fs.FS { + return staticAssets +} diff --git a/examples/hackernews/components/badge.go b/examples/hackernews/components/badge.go new file mode 100644 index 0000000..dd97f60 --- /dev/null +++ b/examples/hackernews/components/badge.go @@ -0,0 +1,14 @@ +package components + +import "github.com/maddalax/htmgo/framework/h" + +func Badge(text string, active bool, children ...h.Ren) *h.Element { + return h.Button( + h.Text(text), + h.ClassX("font-semibold px-3 py-1 rounded-full cursor-pointer h-[32px]", h.ClassMap{ + "bg-rose-500 text-white": active, + "bg-neutral-300": !active, + }), + h.Children(children...), + ) +} diff --git a/examples/hackernews/go.mod b/examples/hackernews/go.mod new file mode 100644 index 0000000..ae1640a --- /dev/null +++ b/examples/hackernews/go.mod @@ -0,0 +1,10 @@ +module hackernews + +go 1.23.0 + +require ( + github.com/go-chi/chi/v5 v5.1.0 + github.com/maddalax/htmgo/framework v0.0.0-20241009153712-95f9b43395b7 +) + +require github.com/google/uuid v1.6.0 // indirect diff --git a/examples/hackernews/go.sum b/examples/hackernews/go.sum new file mode 100644 index 0000000..84d81a5 --- /dev/null +++ b/examples/hackernews/go.sum @@ -0,0 +1,18 @@ +github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c= +github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= +github.com/go-chi/chi/v5 v5.1.0 h1:acVI1TYaD+hhedDJ3r54HyA6sExp3HfXq7QWEEY/xMw= +github.com/go-chi/chi/v5 v5.1.0/go.mod h1:DslCQbL2OYiznFReuXYUmQ2hGd1aDpCnlMNITLSKoi8= +github.com/google/uuid v1.6.0 h1:NIvaJDMOsjHA8n1jAhLSgzrAzy1Hgr+hNrb57e+94F0= +github.com/google/uuid v1.6.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= +github.com/maddalax/htmgo/framework v0.0.0-20241009153712-95f9b43395b7 h1:KzbU4UIVDc+ppklnwEEAAGLXpED16hUoGbbx1qhN7eo= +github.com/maddalax/htmgo/framework v0.0.0-20241009153712-95f9b43395b7/go.mod h1:HYKI49Pb6oyY2opSJdTt145B1vWgfWIDohvlolynv80= +github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM= +github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= +github.com/puzpuzpuz/xsync/v3 v3.4.0 h1:DuVBAdXuGFHv8adVXjWWZ63pJq+NRXOWVXlKDBZ+mJ4= +github.com/puzpuzpuz/xsync/v3 v3.4.0/go.mod h1:VjzYrABPabuM4KyBh1Ftq6u8nhwY5tBPKP9jpmh0nnA= +github.com/stretchr/testify v1.9.0 h1:HtqpIVDClZ4nwg75+f6Lvsy/wHu+3BoSGCbBAcpTsTg= +github.com/stretchr/testify v1.9.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY= +golang.org/x/net v0.29.0 h1:5ORfpBpCs4HzDYoodCDBbwHzdR5UrLBZ3sOnUJmFoHo= +golang.org/x/net v0.29.0/go.mod h1:gLkgy8jTGERgjzMic6DS9+SP0ajcu6Xu3Orq/SpETg0= +gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA= +gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= diff --git a/examples/hackernews/internal/batch/parallel.go b/examples/hackernews/internal/batch/parallel.go new file mode 100644 index 0000000..6f03e5f --- /dev/null +++ b/examples/hackernews/internal/batch/parallel.go @@ -0,0 +1,30 @@ +package batch + +import ( + "sync" +) + +func ParallelProcess[T any, Z any](items []T, concurrency int, cb func(item T) Z) []Z { + if len(items) == 0 { + return []Z{} + } + if len(items) == 1 { + return []Z{cb(items[0])} + } + results := make([]Z, len(items)) + wg := sync.WaitGroup{} + sem := make(chan struct{}, concurrency) + for i, item := range items { + wg.Add(1) + sem <- struct{}{} + go func(item T) { + defer func() { + wg.Done() + <-sem + }() + results[i] = cb(item) + }(item) + } + wg.Wait() + return results +} diff --git a/examples/hackernews/internal/embedded/os.go b/examples/hackernews/internal/embedded/os.go new file mode 100644 index 0000000..ddfd55f --- /dev/null +++ b/examples/hackernews/internal/embedded/os.go @@ -0,0 +1,17 @@ +package embedded + +import ( + "io/fs" + "os" +) + +type OsFs struct { +} + +func (receiver OsFs) Open(name string) (fs.File, error) { + return os.Open(name) +} + +func NewOsFs() OsFs { + return OsFs{} +} diff --git a/examples/hackernews/internal/httpjson/client.go b/examples/hackernews/internal/httpjson/client.go new file mode 100644 index 0000000..4c1e5ce --- /dev/null +++ b/examples/hackernews/internal/httpjson/client.go @@ -0,0 +1,115 @@ +package httpjson + +import ( + "bytes" + "encoding/json" + "fmt" + "io" + "net/http" + "sync" + "time" +) + +var ( + client *http.Client + once sync.Once // Consider allowing configuration parameters for the singleton +) + +func getClient() *http.Client { + once.Do(func() { + client = &http.Client{ + Timeout: 10 * time.Second, + } + }) + return client +} + +func Get[T any](url string) (*T, error) { + client := getClient() + resp, err := client.Get(url) + if err != nil { + return nil, err + } + defer resp.Body.Close() + + if resp.StatusCode != http.StatusOK { + return nil, fmt.Errorf("unexpected status code: %d", resp.StatusCode) + } + + var result T + body, err := io.ReadAll(resp.Body) + if err != nil { + return nil, err + } + + if err := json.Unmarshal(body, &result); err != nil { + return nil, err + } + + return &result, nil +} + +func Post[T any](url string, data T) (*http.Response, error) { + client := getClient() + body, err := json.Marshal(data) + if err != nil { + return nil, err + } + + resp, err := client.Post(url, "application/json", bytes.NewBuffer(body)) + if err != nil { + return nil, err + } + + if resp.StatusCode != http.StatusCreated && resp.StatusCode != http.StatusOK { + return resp, fmt.Errorf("unexpected status code: %d", resp.StatusCode) + } + + return resp, nil +} + +func Patch[T any](url string, data T) error { + client := getClient() + body, err := json.Marshal(data) + if err != nil { + return err + } + + req, err := http.NewRequest(http.MethodPatch, url, bytes.NewBuffer(body)) + if err != nil { + return err + } + req.Header.Set("Content-Type", "application/json") + + resp, err := client.Do(req) + if err != nil { + return err + } + defer resp.Body.Close() + + if resp.StatusCode != http.StatusOK { + return fmt.Errorf("unexpected status code: %d", resp.StatusCode) + } + + return nil +} + +func Delete(url string) error { + client := getClient() + req, err := http.NewRequest(http.MethodDelete, url, nil) + if err != nil { + return err + } + + resp, err := client.Do(req) + if err != nil { + return err + } + defer resp.Body.Close() + + if resp.StatusCode != http.StatusOK { + return fmt.Errorf("unexpected status code: %d", resp.StatusCode) + } + + return nil +} diff --git a/examples/hackernews/internal/news/news.go b/examples/hackernews/internal/news/news.go new file mode 100644 index 0000000..a972e68 --- /dev/null +++ b/examples/hackernews/internal/news/news.go @@ -0,0 +1,137 @@ +package news + +import ( + "fmt" + "github.com/maddalax/htmgo/framework/h" + "hackernews/internal/batch" + "hackernews/internal/httpjson" + "hackernews/internal/timeformat" + "log/slog" + "strconv" + "time" +) + +const baseUrl = "https://hacker-news.firebaseio.com/v0/" + +func url(path string, qs *h.Qs) string { + return baseUrl + path + ".json?" + qs.ToString() +} + +type Category struct { + Name string + Path string +} + +var Categories = []Category{ + {"Top Stories", "topstories"}, + {"Best Stories", "beststories"}, + {"New Stories", "newstories"}, +} + +type Comment struct { + By string `json:"by"` + Text string `json:"text"` + TimeRaw int64 `json:"time"` + Time time.Time `json:"-"` + Type string `json:"type"` + Kids []int `json:"kids"` + Parent int `json:"parent"` + Id int `json:"id"` +} + +type Story struct { + Id int `json:"id"` + By string `json:"by"` + Text string `json:"text"` + Title string `json:"title"` + Type string `json:"type"` + Descendents int `json:"descendants"` + Score int `json:"score"` + Url string + TimeRaw int64 `json:"time"` + Time time.Time `json:"-"` + // comment ids + Kids []int +} + +type GetTopStoriesRequest struct { + Limit int + Page int +} + +func MustItemId(ctx *h.RequestContext) int { + raw := h.GetQueryParam(ctx, "item") + parsed, err := strconv.ParseInt(raw, 10, 64) + if err != nil { + return 0 + } + return int(parsed) +} + +func GetStories(category string, page int, limit int) []Story { + top, err := httpjson.Get[[]int](url(category, h.NewQs())) + if err != nil { + slog.Error("failed to load top stories", slog.String("err", err.Error())) + return make([]Story, 0) + } + ids := *top + start := page * limit + end := start + limit + return batch.ParallelProcess[int, Story]( + ids[start:end], + 50, + func(id int) Story { + story, err := GetStory(id) + if err != nil { + slog.Error("failed to load story", slog.Int("id", id), slog.String("err", err.Error())) + return Story{} + } + return *story + }, + ) +} + +func GetTopStories(page int, limit int) []Story { + return GetStories("topstories", page, limit) +} + +func GetBestStories(page int, limit int) []Story { + return GetStories("beststories", page, limit) +} + +func GetNewStories(page int, limit int) []Story { + return GetStories("newstories", page, limit) +} + +func GetComments(ids []int) []Comment { + return batch.ParallelProcess( + ids, + 50, + func(id int) Comment { + comment, err := GetComment(id) + if err != nil { + slog.Error("failed to load comment", slog.Int("id", id), slog.String("err", err.Error())) + return Comment{} + } + return *comment + }, + ) +} + +func GetComment(id int) (*Comment, error) { + c, err := httpjson.Get[Comment](url(fmt.Sprintf("item/%d", id), h.NewQs())) + if err != nil { + return nil, err + } + c.Time = timeformat.ParseUnix(c.TimeRaw) + return c, nil +} + +func GetStory(id int) (*Story, error) { + s, err := httpjson.Get[Story](url(fmt.Sprintf("item/%d", id), h.NewQs())) + if err != nil { + return nil, err + } + s.Time = timeformat.ParseUnix(s.TimeRaw) + return s, nil +} diff --git a/examples/hackernews/internal/random.go b/examples/hackernews/internal/random.go new file mode 100644 index 0000000..cdd5416 --- /dev/null +++ b/examples/hackernews/internal/random.go @@ -0,0 +1,13 @@ +package internal + +import "math/rand" + +var letters = []rune("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ") + +func RandSeq(n int) string { + b := make([]rune, n) + for i := range b { + b[i] = letters[rand.Intn(len(letters))] + } + return string(b) +} diff --git a/examples/hackernews/internal/timeformat/time.go b/examples/hackernews/internal/timeformat/time.go new file mode 100644 index 0000000..62af620 --- /dev/null +++ b/examples/hackernews/internal/timeformat/time.go @@ -0,0 +1,39 @@ +package timeformat + +import ( + "fmt" + "time" +) + +func ParseUnix(t int64) time.Time { + return time.UnixMilli(t * 1000) +} + +func RelativeTime(t time.Time) string { + now := time.Now() + diff := now.Sub(t) + + var pluralize = func(s string) string { + if s[0] == '1' { + return s[:len(s)-5] + " ago" + } + return s + } + + switch { + case diff < time.Minute: + return "just now" + case diff < time.Hour: + return pluralize(fmt.Sprintf("%d minutes ago", int(diff.Minutes()))) + case diff < time.Hour*24: + return pluralize(fmt.Sprintf("%d hours ago", int(diff.Hours()))) + case diff < time.Hour*24*7: + return pluralize(fmt.Sprintf("%d days ago", int(diff.Hours()/24))) + case diff < time.Hour*24*30: + return pluralize(fmt.Sprintf("%d weeks ago", int(diff.Hours()/(24*7)))) + case diff < time.Hour*24*365: + return pluralize(fmt.Sprintf("%d months ago", int(diff.Hours()/(24*30)))) + default: + return pluralize(fmt.Sprintf("%d years ago", int(diff.Hours()/(24*365)))) + } +} diff --git a/examples/hackernews/main.go b/examples/hackernews/main.go new file mode 100644 index 0000000..575e42c --- /dev/null +++ b/examples/hackernews/main.go @@ -0,0 +1,30 @@ +package main + +import ( + "github.com/maddalax/htmgo/framework/h" + "github.com/maddalax/htmgo/framework/service" + "hackernews/__htmgo" + "io/fs" + "net/http" +) + +func main() { + locator := service.NewLocator() + + h.Start(h.AppOpts{ + ServiceLocator: locator, + LiveReload: true, + Register: func(app *h.App) { + sub, err := fs.Sub(GetStaticAssets(), "assets/dist") + + if err != nil { + panic(err) + } + + http.FileServerFS(sub) + + app.Router.Handle("/public/*", http.StripPrefix("/public", http.FileServerFS(sub))) + __htmgo.Register(app.Router) + }, + }) +} diff --git a/examples/hackernews/pages/index.go b/examples/hackernews/pages/index.go new file mode 100644 index 0000000..b103599 --- /dev/null +++ b/examples/hackernews/pages/index.go @@ -0,0 +1,21 @@ +package pages + +import ( + "github.com/maddalax/htmgo/framework/h" + "hackernews/partials" +) + +func IndexPage(ctx *h.RequestContext) *h.Page { + return h.NewPage( + RootPage( + h.Div( + h.Class("flex gap-2 min-h-screen"), + partials.StorySidebar(ctx), + h.Main( + h.Class("flex justify-center items-start p-6 max-w-3xl min-w-3xl mx-auto"), + partials.Story(ctx), + ), + ), + ), + ) +} diff --git a/examples/hackernews/pages/root.go b/examples/hackernews/pages/root.go new file mode 100644 index 0000000..2c785ec --- /dev/null +++ b/examples/hackernews/pages/root.go @@ -0,0 +1,32 @@ +package pages + +import ( + "github.com/maddalax/htmgo/framework/h" +) + +func RootPage(children ...h.Ren) h.Ren { + return h.Html( + h.HxExtensions(h.BaseExtensions()), + h.Head( + h.Meta("viewport", "width=device-width, initial-scale=1"), + h.Link("/public/favicon.ico", "icon"), + h.Link("/public/apple-touch-icon.png", "apple-touch-icon"), + h.Meta("title", "htmgo template"), + h.Meta("charset", "utf-8"), + h.Meta("author", "htmgo"), + h.Meta("description", "this is a template"), + h.Meta("og:title", "htmgo template"), + h.Meta("og:url", "https://htmgo.dev"), + h.Link("canonical", "https://htmgo.dev"), + h.Meta("og:description", "this is a template"), + h.Link("/public/main.css", "stylesheet"), + h.Script("/public/htmgo.js"), + h.Script("/public/custom.js"), + ), + h.Body( + h.Div( + h.Fragment(children...), + ), + ), + ) +} diff --git a/examples/hackernews/partials/comments.go b/examples/hackernews/partials/comments.go new file mode 100644 index 0000000..14b39bd --- /dev/null +++ b/examples/hackernews/partials/comments.go @@ -0,0 +1,84 @@ +package partials + +import ( + "fmt" + "github.com/maddalax/htmgo/framework/h" + "hackernews/internal/batch" + "hackernews/internal/news" + "hackernews/internal/timeformat" + "strings" + "time" +) + +func StoryComments(ctx *h.RequestContext) *h.Partial { + return h.NewPartial( + h.Div( + h.Class("flex flex-col gap-3 prose max-w-none"), + CachedStoryComments(news.MustItemId(ctx)), + )) +} + +var CachedStoryComments = h.CachedPerKeyT[string, int](time.Minute*3, func(itemId int) (string, h.GetElementFunc) { + return fmt.Sprintf("story-comments-%d", itemId), func() *h.Element { + story, err := news.GetStory(itemId) + + if err != nil { + return h.Div( + h.Text("Failed to load story"), + ) + } + + comments := news.GetComments(story.Kids) + + // parallel process because each comment needs to load its children comments + items := batch.ParallelProcess[news.Comment, *h.Element](comments, 50, func(item news.Comment) *h.Element { + return Comment(item, 0) + }) + + return h.List(items, func(item *h.Element, index int) *h.Element { + return item + }) + } +}) + +func Comment(item news.Comment, nesting int) *h.Element { + if item.Text == "" { + return h.Empty() + } + + children := news.GetComments(item.Kids) + + return h.Div( + h.ClassX("block bg-white pb-2 pt-2", h.ClassMap{ + "border-b border-gray-200": nesting == 0, + "border-l border-gray-200": nesting > 0, + }), + h.If(nesting > 0, h.Attribute("style", fmt.Sprintf("margin-left: %dpx", (nesting-1)*15))), + h.Div( + h.If(nesting > 0, h.Class("pl-4")), + h.Div( + h.Class("flex gap-1 items-center"), + h.Div( + h.Class("font-bold text-rose-500"), + h.UnsafeRaw(item.By), + ), + h.Div( + h.Class("text-sm text-gray-600"), + h.UnsafeRaw("•"), + h.TextF(" %s", timeformat.RelativeTime(item.Time)), + ), + ), + h.Div( + h.Class("text-sm text-gray-600"), + h.UnsafeRaw(strings.TrimSpace(item.Text)), + ), + ), + h.If(len(children) > 0, h.List( + children, func(child news.Comment, index int) *h.Element { + return h.Div( + Comment(child, nesting+1), + ) + }, + )), + ) +} diff --git a/examples/hackernews/partials/sidebar.go b/examples/hackernews/partials/sidebar.go new file mode 100644 index 0000000..e68325b --- /dev/null +++ b/examples/hackernews/partials/sidebar.go @@ -0,0 +1,126 @@ +package partials + +import ( + "fmt" + "github.com/maddalax/htmgo/framework/h" + "github.com/maddalax/htmgo/framework/hx" + "hackernews/components" + "hackernews/internal/news" + "hackernews/internal/timeformat" + "time" +) + +// @lang js +var ScrollJs = ` + const scrollContainer = self; + let isDown = false; + let startX; + let scrollLeft; + + scrollContainer.addEventListener("mousedown", (e) => { + isDown = true; + scrollContainer.classList.add("active"); + startX = e.pageX - scrollContainer.offsetLeft; + scrollLeft = scrollContainer.scrollLeft; + }); + + scrollContainer.addEventListener("mouseleave", () => { + isDown = false; + scrollContainer.classList.remove("active"); + }); + + scrollContainer.addEventListener("mouseup", () => { + isDown = false; + scrollContainer.classList.remove("active"); + }); + + scrollContainer.addEventListener("mousemove", (e) => { + if (!isDown) return; + e.preventDefault(); + const x = e.pageX - scrollContainer.offsetLeft; + const walk = (x - startX) * 3; // Adjust scroll speed here + scrollContainer.scrollLeft = scrollLeft - walk; + }); +` + +func StorySidebar(ctx *h.RequestContext) *h.Partial { + category := h.GetQueryParam(ctx, "category") + if category == "" { + category = "topstories" + } + + body := h.Aside( + h.Id("story-sidebar"), + h.JoinExtensions(h.TriggerChildren()), + h.Class("sticky top-0 h-screen p-1 bg-gray-100 overflow-y-auto max-w-80 min-w-80"), + h.Div( + h.Class("flex flex-col gap-1"), + SidebarTitle(category), + CachedStoryList(category, 0, 50), + ), + ) + + if ctx.IsHxRequest() { + return h.SwapManyPartial(ctx, body) + } + return h.NewPartial(body) +} + +func SidebarTitle(defaultCategory string) *h.Element { + today := time.Now().Format("Mon, 02 Jan 2006") + return h.Div( + h.Class("flex flex-col px-2 pt-4 pb-2"), + h.Div( + h.Class("text-sm text-gray-600"), + h.Text(today), + ), + h.Div( + h.Class("font-bold text-xl"), + h.Text("Hacker News"), + ), + h.Div( + h.OnEvent(hx.LoadDomEvent, h.EvalJs(ScrollJs)), + h.OnEvent(hx.LoadEvent, h.EvalJs(ScrollJs)), + h.Class("scroll-container mt-2 flex gap-1 no-scrollbar overflow-y-hidden whitespace-nowrap overflow-x-auto"), + h.List(news.Categories, func(item news.Category, index int) *h.Element { + return CategoryBadge(defaultCategory, item) + }), + ), + ) +} + +func CategoryBadge(defaultCategory string, category news.Category) *h.Element { + selected := category.Path == defaultCategory + return components.Badge( + category.Name, + selected, + h.Attribute("hx-swap", "none"), + h.If(!selected, h.PostPartialOnClickQs(StorySidebar, h.NewQs("category", category.Path))), + ) +} + +var CachedStoryList = h.CachedPerKeyT3(time.Minute*5, func(category string, page int, limit int) (string, h.GetElementFunc) { + return fmt.Sprintf("%s-stories-%d-%d", category, page, limit), func() *h.Element { + stories := news.GetStories(category, page, limit) + return h.List(stories, func(item news.Story, index int) *h.Element { + return h.Div( + h.Attribute("hx-swap", "none"), + h.PostPartialOnClickQs(Story, h.NewQs("item", fmt.Sprintf("%d", item.Id))), + h.A(h.Href(item.Url)), + h.Class("block p-2 bg-white rounded-md shadow cursor-pointer"), + h.Div( + h.Class("font-bold"), + h.UnsafeRaw(item.Title), + ), + h.Div( + h.Class("text-sm text-gray-600"), + h.Div(h.TextF("%s ", item.By), h.UnsafeRaw("•"), h.TextF(" %s", timeformat.RelativeTime(item.Time))), + ), + h.Div( + h.Class("text-sm text-gray-600"), + h.UnsafeRaw(fmt.Sprintf("%d upvotes • %d comments", item.Score, item.Descendents)), + ), + ) + }) + } +}) diff --git a/examples/hackernews/partials/story.go b/examples/hackernews/partials/story.go new file mode 100644 index 0000000..1c05f1a --- /dev/null +++ b/examples/hackernews/partials/story.go @@ -0,0 +1,79 @@ +package partials + +import ( + "fmt" + "github.com/maddalax/htmgo/framework/h" + "hackernews/internal/news" + "hackernews/internal/timeformat" + "strconv" +) + +func Story(ctx *h.RequestContext) *h.Partial { + storyId, err := strconv.ParseInt(ctx.QueryParam("item"), 10, 64) + + if err != nil { + return h.SwapManyPartial( + ctx, + h.Div( + h.Text("Invalid story id"), + ), + ) + } + + story, err := news.GetStory(int(storyId)) + + if err != nil { + return h.SwapManyPartial( + ctx, + h.Div( + h.Text("Failed to load story"), + ), + ) + } + + if ctx.IsHxRequest() { + return h.SwapManyPartialWithHeaders( + ctx, + h.PushUrlHeader(fmt.Sprintf("/?item=%d", storyId)), + StoryBody(story), + ) + } + + return h.NewPartial( + StoryBody(story), + ) +} + +func StoryBody(story *news.Story) *h.Element { + return h.Div( + h.Id("story-body"), + h.Div( + h.Class("prose prose-2xl bg-white border-b border-gray-200 pb-3 max-w-3xl"), + h.H5( + h.Class("flex gap-2 items-center font-bold"), + h.UnsafeRaw(story.Title), + ), + h.A( + h.Href(story.Url), + h.Class("text-sm text-rose-400 no-underline"), + h.Text(story.Url), + ), + h.Div( + h.Class("text-sm text-gray-600"), + h.UnsafeRaw(story.Text), + ), + h.Div( + h.Class("text-sm text-gray-600 mt-2"), + h.TextF("%d upvotes ", story.Score), + h.UnsafeRaw("•"), + h.TextF(" %s ", story.By), + h.UnsafeRaw("•"), + h.TextF(" %s", timeformat.RelativeTime(story.Time)), + ), + ), + h.Div( + h.Class("mt-2 max-w-3xl"), + h.GetPartial(StoryComments, "load"), + ), + ) +} diff --git a/examples/hackernews/tailwind.config.js b/examples/hackernews/tailwind.config.js new file mode 100644 index 0000000..f1b453a --- /dev/null +++ b/examples/hackernews/tailwind.config.js @@ -0,0 +1,7 @@ +/** @type {import('tailwindcss').Config} */ +module.exports = { + content: ["**/*.go"], + plugins: [ + require('@tailwindcss/typography') + ], +}; diff --git a/framework/assets/dist/htmgo.js b/framework/assets/dist/htmgo.js index fd740d4..a0aadc4 100644 --- a/framework/assets/dist/htmgo.js +++ b/framework/assets/dist/htmgo.js @@ -1,3 +1,3 @@ -var te=function(){let htmx={onLoad:null,process:null,on:null,off:null,trigger:null,ajax:null,find:null,findAll:null,closest:null,values:function(e,t){return getInputValues(e,t||"post").values},remove:null,addClass:null,removeClass:null,toggleClass:null,takeClass:null,swap:null,defineExtension:null,removeExtension:null,logAll:null,logNone:null,logger:null,config:{historyEnabled:!0,historyCacheSize:10,refreshOnHistoryMiss:!1,defaultSwapStyle:"innerHTML",defaultSwapDelay:0,defaultSettleDelay:20,includeIndicatorStyles:!0,indicatorClass:"htmx-indicator",requestClass:"htmx-request",addedClass:"htmx-added",settlingClass:"htmx-settling",swappingClass:"htmx-swapping",allowEval:!0,allowScriptTags:!0,inlineScriptNonce:"",inlineStyleNonce:"",attributesToSettle:["class","style","width","height"],withCredentials:!1,timeout:0,wsReconnectDelay:"full-jitter",wsBinaryType:"blob",disableSelector:"[hx-disable], [data-hx-disable]",scrollBehavior:"instant",defaultFocusScroll:!1,getCacheBusterParam:!1,globalViewTransitions:!1,methodsThatUseUrlParams:["get","delete"],selfRequestsOnly:!0,ignoreTitle:!1,scrollIntoViewOnBoost:!0,triggerSpecsCache:null,disableInheritance:!1,responseHandling:[{code:"204",swap:!1},{code:"[23]..",swap:!0},{code:"[45]..",swap:!1,error:!0}],allowNestedOobSwaps:!0},parseInterval:null,_:null,version:"2.0.2"};htmx.onLoad=onLoadHelper,htmx.process=processNode,htmx.on=addEventListenerImpl,htmx.off=removeEventListenerImpl,htmx.trigger=triggerEvent,htmx.ajax=ajaxHelper,htmx.find=find,htmx.findAll=findAll,htmx.closest=closest,htmx.remove=removeElement,htmx.addClass=addClassToElement,htmx.removeClass=removeClassFromElement,htmx.toggleClass=toggleClassOnElement,htmx.takeClass=takeClassForElement,htmx.swap=swap,htmx.defineExtension=defineExtension,htmx.removeExtension=removeExtension,htmx.logAll=logAll,htmx.logNone=logNone,htmx.parseInterval=parseInterval,htmx._=internalEval;let internalAPI={addTriggerHandler,bodyContains,canAccessLocalStorage,findThisElement,filterValues,swap,hasAttribute,getAttributeValue,getClosestAttributeValue,getClosestMatch,getExpressionVars,getHeaders,getInputValues,getInternalData,getSwapSpecification,getTriggerSpecs,getTarget,makeFragment,mergeObjects,makeSettleInfo,oobSwap,querySelectorExt,settleImmediately,shouldCancel,triggerEvent,triggerErrorEvent,withExtensions},VERBS=["get","post","put","delete","patch"],VERB_SELECTOR=VERBS.map(function(e){return "[hx-"+e+"], [data-hx-"+e+"]"}).join(", "),HEAD_TAG_REGEX=makeTagRegEx("head");function makeTagRegEx(e,t=!1){return new RegExp(`<${e}(\\s[^>]*>|>)([\\s\\S]*?)<\\/${e}>`,t?"gim":"im")}function parseInterval(e){if(e==null)return;let t=NaN;return e.slice(-2)=="ms"?t=parseFloat(e.slice(0,-2)):e.slice(-1)=="s"?t=parseFloat(e.slice(0,-1))*1e3:e.slice(-1)=="m"?t=parseFloat(e.slice(0,-1))*1e3*60:t=parseFloat(e),isNaN(t)?void 0:t}function getRawAttribute(e,t){return e instanceof Element&&e.getAttribute(t)}function hasAttribute(e,t){return !!e.hasAttribute&&(e.hasAttribute(t)||e.hasAttribute("data-"+t))}function getAttributeValue(e,t){return getRawAttribute(e,t)||getRawAttribute(e,"data-"+t)}function parentElt(e){let t=e.parentElement;return !t&&e.parentNode instanceof ShadowRoot?e.parentNode:t}function getDocument(){return document}function getRootNode(e,t){return e.getRootNode?e.getRootNode({composed:t}):getDocument()}function getClosestMatch(e,t){for(;e&&!t(e);)e=parentElt(e);return e||null}function getAttributeValueWithDisinheritance(e,t,n){let r=getAttributeValue(t,n),o=getAttributeValue(t,"hx-disinherit");var i=getAttributeValue(t,"hx-inherit");if(e!==t){if(htmx.config.disableInheritance)return i&&(i==="*"||i.split(" ").indexOf(n)>=0)?r:null;if(o&&(o==="*"||o.split(" ").indexOf(n)>=0))return "unset"}return r}function getClosestAttributeValue(e,t){let n=null;if(getClosestMatch(e,function(r){return !!(n=getAttributeValueWithDisinheritance(e,asElement(r),t))}),n!=="unset")return n}function matches(e,t){let n=e instanceof Element&&(e.matches||e.matchesSelector||e.msMatchesSelector||e.mozMatchesSelector||e.webkitMatchesSelector||e.oMatchesSelector);return !!n&&n.call(e,t)}function getStartTag(e){let n=/<([a-z][^\/\0>\x20\t\r\n\f]*)/i.exec(e);return n?n[1].toLowerCase():""}function parseHTML(e){return new DOMParser().parseFromString(e,"text/html")}function takeChildrenFor(e,t){for(;t.childNodes.length>0;)e.append(t.childNodes[0]);}function duplicateScript(e){let t=getDocument().createElement("script");return forEach(e.attributes,function(n){t.setAttribute(n.name,n.value);}),t.textContent=e.textContent,t.async=!1,htmx.config.inlineScriptNonce&&(t.nonce=htmx.config.inlineScriptNonce),t}function isJavaScriptScriptNode(e){return e.matches("script")&&(e.type==="text/javascript"||e.type==="module"||e.type==="")}function normalizeScriptTags(e){Array.from(e.querySelectorAll("script")).forEach(t=>{if(isJavaScriptScriptNode(t)){let n=duplicateScript(t),r=t.parentNode;try{r.insertBefore(n,t);}catch(o){logError(o);}finally{t.remove();}}});}function makeFragment(e){let t=e.replace(HEAD_TAG_REGEX,""),n=getStartTag(t),r;if(n==="html"){r=new DocumentFragment;let i=parseHTML(e);takeChildrenFor(r,i.body),r.title=i.title;}else if(n==="body"){r=new DocumentFragment;let i=parseHTML(t);takeChildrenFor(r,i.body),r.title=i.title;}else {let i=parseHTML('");r=i.querySelector("template").content,r.title=i.title;var o=r.querySelector("title");o&&o.parentNode===r&&(o.remove(),r.title=o.innerText);}return r&&(htmx.config.allowScriptTags?normalizeScriptTags(r):r.querySelectorAll("script").forEach(i=>i.remove())),r}function maybeCall(e){e&&e();}function isType(e,t){return Object.prototype.toString.call(e)==="[object "+t+"]"}function isFunction(e){return typeof e=="function"}function isRawObject(e){return isType(e,"Object")}function getInternalData(e){let t="htmx-internal-data",n=e[t];return n||(n=e[t]={}),n}function toArray(e){let t=[];if(e)for(let n=0;n=0}function bodyContains(e){let t=e.getRootNode&&e.getRootNode();return t&&t instanceof window.ShadowRoot?getDocument().body.contains(t.host):getDocument().body.contains(e)}function splitOnWhitespace(e){return e.trim().split(/\s+/)}function mergeObjects(e,t){for(let n in t)t.hasOwnProperty(n)&&(e[n]=t[n]);return e}function parseJSON(e){try{return JSON.parse(e)}catch(t){return logError(t),null}}function canAccessLocalStorage(){let e="htmx:localStorageTest";try{return localStorage.setItem(e,e),localStorage.removeItem(e),!0}catch{return !1}}function normalizePath(e){try{let t=new URL(e);return t&&(e=t.pathname+t.search),/^\/$/.test(e)||(e=e.replace(/\/+$/,"")),e}catch{return e}}function internalEval(str){return maybeEval(getDocument().body,function(){return eval(str)})}function onLoadHelper(e){return htmx.on("htmx:load",function(n){e(n.detail.elt);})}function logAll(){htmx.logger=function(e,t,n){console&&console.log(t,e,n);};}function logNone(){htmx.logger=null;}function find(e,t){return typeof e!="string"?e.querySelector(t):find(getDocument(),e)}function findAll(e,t){return typeof e!="string"?e.querySelectorAll(t):findAll(getDocument(),e)}function getWindow(){return window}function removeElement(e,t){e=resolveTarget(e),t?getWindow().setTimeout(function(){removeElement(e),e=null;},t):parentElt(e).removeChild(e);}function asElement(e){return e instanceof Element?e:null}function asHtmlElement(e){return e instanceof HTMLElement?e:null}function asString(e){return typeof e=="string"?e:null}function asParentNode(e){return e instanceof Element||e instanceof Document||e instanceof DocumentFragment?e:null}function addClassToElement(e,t,n){e=asElement(resolveTarget(e)),e&&(n?getWindow().setTimeout(function(){addClassToElement(e,t),e=null;},n):e.classList&&e.classList.add(t));}function removeClassFromElement(e,t,n){let r=asElement(resolveTarget(e));r&&(n?getWindow().setTimeout(function(){removeClassFromElement(r,t),r=null;},n):r.classList&&(r.classList.remove(t),r.classList.length===0&&r.removeAttribute("class")));}function toggleClassOnElement(e,t){e=resolveTarget(e),e.classList.toggle(t);}function takeClassForElement(e,t){e=resolveTarget(e),forEach(e.parentElement.children,function(n){removeClassFromElement(n,t);}),addClassToElement(asElement(e),t);}function closest(e,t){if(e=asElement(resolveTarget(e)),e&&e.closest)return e.closest(t);do if(e==null||matches(e,t))return e;while(e=e&&asElement(parentElt(e)));return null}function startsWith(e,t){return e.substring(0,t.length)===t}function endsWith(e,t){return e.substring(e.length-t.length)===t}function normalizeSelector(e){let t=e.trim();return startsWith(t,"<")&&endsWith(t,"/>")?t.substring(1,t.length-2):t}function querySelectorAllExt(e,t,n){return e=resolveTarget(e),t.indexOf("closest ")===0?[closest(asElement(e),normalizeSelector(t.substr(8)))]:t.indexOf("find ")===0?[find(asParentNode(e),normalizeSelector(t.substr(5)))]:t==="next"?[asElement(e).nextElementSibling]:t.indexOf("next ")===0?[scanForwardQuery(e,normalizeSelector(t.substr(5)),!!n)]:t==="previous"?[asElement(e).previousElementSibling]:t.indexOf("previous ")===0?[scanBackwardsQuery(e,normalizeSelector(t.substr(9)),!!n)]:t==="document"?[document]:t==="window"?[window]:t==="body"?[document.body]:t==="root"?[getRootNode(e,!!n)]:t.indexOf("global ")===0?querySelectorAllExt(e,t.slice(7),!0):toArray(asParentNode(getRootNode(e,!!n)).querySelectorAll(normalizeSelector(t)))}var scanForwardQuery=function(e,t,n){let r=asParentNode(getRootNode(e,n)).querySelectorAll(t);for(let o=0;o=0;o--){let i=r[o];if(i.compareDocumentPosition(e)===Node.DOCUMENT_POSITION_FOLLOWING)return i}};function querySelectorExt(e,t){return typeof e!="string"?querySelectorAllExt(e,t)[0]:querySelectorAllExt(getDocument().body,e)[0]}function resolveTarget(e,t){return typeof e=="string"?find(asParentNode(t)||document,e):e}function processEventArgs(e,t,n){return isFunction(t)?{target:getDocument().body,event:asString(e),listener:t}:{target:resolveTarget(e),event:asString(t),listener:n}}function addEventListenerImpl(e,t,n){return ready(function(){let o=processEventArgs(e,t,n);o.target.addEventListener(o.event,o.listener);}),isFunction(t)?t:n}function removeEventListenerImpl(e,t,n){return ready(function(){let r=processEventArgs(e,t,n);r.target.removeEventListener(r.event,r.listener);}),isFunction(t)?t:n}let DUMMY_ELT=getDocument().createElement("output");function findAttributeTargets(e,t){let n=getClosestAttributeValue(e,t);if(n){if(n==="this")return [findThisElement(e,t)];{let r=querySelectorAllExt(e,n);return r.length===0?(logError('The selector "'+n+'" on '+t+" returned no matches!"),[DUMMY_ELT]):r}}}function findThisElement(e,t){return asElement(getClosestMatch(e,function(n){return getAttributeValue(asElement(n),t)!=null}))}function getTarget(e){let t=getClosestAttributeValue(e,"hx-target");return t?t==="this"?findThisElement(e,"hx-target"):querySelectorExt(e,t):getInternalData(e).boosted?getDocument().body:e}function shouldSettleAttribute(e){let t=htmx.config.attributesToSettle;for(let n=0;n0?(o=e.substr(0,e.indexOf(":")),r=e.substr(e.indexOf(":")+1,e.length)):o=e);let i=getDocument().querySelectorAll(r);return i?(forEach(i,function(s){let l,a=t.cloneNode(!0);l=getDocument().createDocumentFragment(),l.appendChild(a),isInlineSwap(o,s)||(l=asParentNode(a));let u={shouldSwap:!0,target:s,fragment:l};triggerEvent(s,"htmx:oobBeforeSwap",u)&&(s=u.target,u.shouldSwap&&swapWithStyle(o,s,s,l,n),forEach(n.elts,function(d){triggerEvent(d,"htmx:oobAfterSwap",u);}));}),t.parentNode.removeChild(t)):(t.parentNode.removeChild(t),triggerErrorEvent(getDocument().body,"htmx:oobErrorNoTarget",{content:t})),e}function handlePreservedElements(e){forEach(findAll(e,"[hx-preserve], [data-hx-preserve]"),function(t){let n=getAttributeValue(t,"id"),r=getDocument().getElementById(n);r!=null&&t.parentNode.replaceChild(r,t);});}function handleAttributes(e,t,n){forEach(t.querySelectorAll("[id]"),function(r){let o=getRawAttribute(r,"id");if(o&&o.length>0){let i=o.replace("'","\\'"),s=r.tagName.replace(":","\\:"),l=asParentNode(e),a=l&&l.querySelector(s+"[id='"+i+"']");if(a&&a!==l){let u=r.cloneNode();cloneAttributes(r,a),n.tasks.push(function(){cloneAttributes(r,u);});}}});}function makeAjaxLoadTask(e){return function(){removeClassFromElement(e,htmx.config.addedClass),processNode(asElement(e)),processFocus(asParentNode(e)),triggerEvent(e,"htmx:load");}}function processFocus(e){let t="[autofocus]",n=asHtmlElement(matches(e,t)?e:e.querySelector(t));n?.focus();}function insertNodesBefore(e,t,n,r){for(handleAttributes(e,n,r);n.childNodes.length>0;){let o=n.firstChild;addClassToElement(asElement(o),htmx.config.addedClass),e.insertBefore(o,t),o.nodeType!==Node.TEXT_NODE&&o.nodeType!==Node.COMMENT_NODE&&r.tasks.push(makeAjaxLoadTask(o));}}function stringHash(e,t){let n=0;for(;n0}function swap(e,t,n,r){r||(r={}),e=resolveTarget(e);let o=document.activeElement,i={};try{i={elt:o,start:o?o.selectionStart:null,end:o?o.selectionEnd:null};}catch{}let s=makeSettleInfo(e);if(n.swapStyle==="textContent")e.textContent=t;else {let a=makeFragment(t);if(s.title=a.title,r.selectOOB){let u=r.selectOOB.split(",");for(let d=0;d0?getWindow().setTimeout(l,n.settleDelay):l();}function handleTriggerHeader(e,t,n){let r=e.getResponseHeader(t);if(r.indexOf("{")===0){let o=parseJSON(r);for(let i in o)if(o.hasOwnProperty(i)){let s=o[i];isRawObject(s)?n=s.target!==void 0?s.target:n:s={value:s},triggerEvent(n,i,s);}}else {let o=r.split(",");for(let i=0;i0;){let s=t[0];if(s==="]"){if(r--,r===0){i===null&&(o=o+"true"),t.shift(),o+=")})";try{let l=maybeEval(e,function(){return Function(o)()},function(){return !0});return l.source=o,l}catch(l){return triggerErrorEvent(getDocument().body,"htmx:syntax:error",{error:l,source:o}),null}}}else s==="["&&r++;isPossibleRelativeReference(s,i,n)?o+="(("+n+"."+s+") ? ("+n+"."+s+") : (window."+s+"))":o=o+s,i=t.shift();}}}function consumeUntil(e,t){let n="";for(;e.length>0&&!t.test(e[0]);)n+=e.shift();return n}function consumeCSSSelector(e){let t;return e.length>0&&COMBINED_SELECTOR_START.test(e[0])?(e.shift(),t=consumeUntil(e,COMBINED_SELECTOR_END).trim(),e.shift()):t=consumeUntil(e,WHITESPACE_OR_COMMA),t}let INPUT_SELECTOR="input, textarea, select";function parseAndCacheTrigger(e,t,n){let r=[],o=tokenizeString(t);do{consumeUntil(o,NOT_WHITESPACE);let l=o.length,a=consumeUntil(o,/[,\[\s]/);if(a!=="")if(a==="every"){let u={trigger:"every"};consumeUntil(o,NOT_WHITESPACE),u.pollInterval=parseInterval(consumeUntil(o,/[,\[\s]/)),consumeUntil(o,NOT_WHITESPACE);var i=maybeGenerateConditional(e,o,"event");i&&(u.eventFilter=i),r.push(u);}else {let u={trigger:a};var i=maybeGenerateConditional(e,o,"event");for(i&&(u.eventFilter=i);o.length>0&&o[0]!==",";){consumeUntil(o,NOT_WHITESPACE);let c=o.shift();if(c==="changed")u.changed=!0;else if(c==="once")u.once=!0;else if(c==="consume")u.consume=!0;else if(c==="delay"&&o[0]===":")o.shift(),u.delay=parseInterval(consumeUntil(o,WHITESPACE_OR_COMMA));else if(c==="from"&&o[0]===":"){if(o.shift(),COMBINED_SELECTOR_START.test(o[0]))var s=consumeCSSSelector(o);else {var s=consumeUntil(o,WHITESPACE_OR_COMMA);if(s==="closest"||s==="find"||s==="next"||s==="previous"){o.shift();let b=consumeCSSSelector(o);b.length>0&&(s+=" "+b);}}u.from=s;}else c==="target"&&o[0]===":"?(o.shift(),u.target=consumeCSSSelector(o)):c==="throttle"&&o[0]===":"?(o.shift(),u.throttle=parseInterval(consumeUntil(o,WHITESPACE_OR_COMMA))):c==="queue"&&o[0]===":"?(o.shift(),u.queue=consumeUntil(o,WHITESPACE_OR_COMMA)):c==="root"&&o[0]===":"?(o.shift(),u[c]=consumeCSSSelector(o)):c==="threshold"&&o[0]===":"?(o.shift(),u[c]=consumeUntil(o,WHITESPACE_OR_COMMA)):triggerErrorEvent(e,"htmx:syntax:error",{token:o.shift()});}r.push(u);}o.length===l&&triggerErrorEvent(e,"htmx:syntax:error",{token:o.shift()}),consumeUntil(o,NOT_WHITESPACE);}while(o[0]===","&&o.shift());return n&&(n[t]=r),r}function getTriggerSpecs(e){let t=getAttributeValue(e,"hx-trigger"),n=[];if(t){let r=htmx.config.triggerSpecsCache;n=r&&r[t]||parseAndCacheTrigger(e,t,r);}return n.length>0?n:matches(e,"form")?[{trigger:"submit"}]:matches(e,'input[type="button"], input[type="submit"]')?[{trigger:"click"}]:matches(e,INPUT_SELECTOR)?[{trigger:"change"}]:[{trigger:"click"}]}function cancelPolling(e){getInternalData(e).cancelled=!0;}function processPolling(e,t,n){let r=getInternalData(e);r.timeout=getWindow().setTimeout(function(){bodyContains(e)&&r.cancelled!==!0&&(maybeFilterEvent(n,e,makeEvent("hx:poll:trigger",{triggerSpec:n,target:e}))||t(e),processPolling(e,t,n));},n.pollInterval);}function isLocalLink(e){return location.hostname===e.hostname&&getRawAttribute(e,"href")&&getRawAttribute(e,"href").indexOf("#")!==0}function eltIsDisabled(e){return closest(e,htmx.config.disableSelector)}function boostElement(e,t,n){if(e instanceof HTMLAnchorElement&&isLocalLink(e)&&(e.target===""||e.target==="_self")||e.tagName==="FORM"&&String(getRawAttribute(e,"method")).toLowerCase()!=="dialog"){t.boosted=!0;let r,o;if(e.tagName==="A")r="get",o=getRawAttribute(e,"href");else {let i=getRawAttribute(e,"method");r=i?i.toLowerCase():"get",o=getRawAttribute(e,"action");}n.forEach(function(i){addEventListener(e,function(s,l){let a=asElement(s);if(eltIsDisabled(a)){cleanUpElement(a);return}issueAjaxRequest(r,o,a,l);},t,i,!0);});}}function shouldCancel(e,t){let n=asElement(t);return n?!!((e.type==="submit"||e.type==="click")&&(n.tagName==="FORM"||matches(n,'input[type="submit"], button')&&closest(n,"form")!==null||n instanceof HTMLAnchorElement&&n.href&&(n.getAttribute("href")==="#"||n.getAttribute("href").indexOf("#")!==0))):!1}function ignoreBoostedAnchorCtrlClick(e,t){return getInternalData(e).boosted&&e instanceof HTMLAnchorElement&&t.type==="click"&&(t.ctrlKey||t.metaKey)}function maybeFilterEvent(e,t,n){let r=e.eventFilter;if(r)try{return r.call(t,n)!==!0}catch(o){let i=r.source;return triggerErrorEvent(getDocument().body,"htmx:eventFilter:error",{error:o,source:i}),!0}return !1}function addEventListener(e,t,n,r,o){let i=getInternalData(e),s;r.from?s=querySelectorAllExt(e,r.from):s=[e],r.changed&&s.forEach(function(l){let a=getInternalData(l);a.lastValue=l.value;}),forEach(s,function(l){let a=function(u){if(!bodyContains(e)){l.removeEventListener(r.trigger,a);return}if(ignoreBoostedAnchorCtrlClick(e,u)||((o||shouldCancel(u,e))&&u.preventDefault(),maybeFilterEvent(r,e,u)))return;let d=getInternalData(u);if(d.triggerSpec=r,d.handledFor==null&&(d.handledFor=[]),d.handledFor.indexOf(e)<0){if(d.handledFor.push(e),r.consume&&u.stopPropagation(),r.target&&u.target&&!matches(asElement(u.target),r.target))return;if(r.once){if(i.triggeredOnce)return;i.triggeredOnce=!0;}if(r.changed){let c=getInternalData(l),h=l.value;if(c.lastValue===h)return;c.lastValue=h;}if(i.delayed&&clearTimeout(i.delayed),i.throttle)return;r.throttle>0?i.throttle||(triggerEvent(e,"htmx:trigger"),t(e,u),i.throttle=getWindow().setTimeout(function(){i.throttle=null;},r.throttle)):r.delay>0?i.delayed=getWindow().setTimeout(function(){triggerEvent(e,"htmx:trigger"),t(e,u);},r.delay):(triggerEvent(e,"htmx:trigger"),t(e,u));}};n.listenerInfos==null&&(n.listenerInfos=[]),n.listenerInfos.push({trigger:r.trigger,listener:a,on:l}),l.addEventListener(r.trigger,a);});}let windowIsScrolling=!1,scrollHandler=null;function initScrollHandler(){scrollHandler||(scrollHandler=function(){windowIsScrolling=!0;},window.addEventListener("scroll",scrollHandler),setInterval(function(){windowIsScrolling&&(windowIsScrolling=!1,forEach(getDocument().querySelectorAll("[hx-trigger*='revealed'],[data-hx-trigger*='revealed']"),function(e){maybeReveal(e);}));},200));}function maybeReveal(e){!hasAttribute(e,"data-hx-revealed")&&isScrolledIntoView(e)&&(e.setAttribute("data-hx-revealed","true"),getInternalData(e).initHash?triggerEvent(e,"revealed"):e.addEventListener("htmx:afterProcessNode",function(){triggerEvent(e,"revealed");},{once:!0}));}function loadImmediately(e,t,n,r){let o=function(){n.loaded||(n.loaded=!0,t(e));};r>0?getWindow().setTimeout(o,r):o();}function processVerbs(e,t,n){let r=!1;return forEach(VERBS,function(o){if(hasAttribute(e,"hx-"+o)){let i=getAttributeValue(e,"hx-"+o);r=!0,t.path=i,t.verb=o,n.forEach(function(s){addTriggerHandler(e,s,t,function(l,a){let u=asElement(l);if(closest(u,htmx.config.disableSelector)){cleanUpElement(u);return}issueAjaxRequest(o,i,u,a);});});}}),r}function addTriggerHandler(e,t,n,r){if(t.trigger==="revealed")initScrollHandler(),addEventListener(e,r,n,t),maybeReveal(asElement(e));else if(t.trigger==="intersect"){let o={};t.root&&(o.root=querySelectorExt(e,t.root)),t.threshold&&(o.threshold=parseFloat(t.threshold)),new IntersectionObserver(function(s){for(let l=0;l0?(n.polling=!0,processPolling(asElement(e),r,t)):addEventListener(e,r,n,t);}function shouldProcessHxOn(e){let t=asElement(e);if(!t)return !1;let n=t.attributes;for(let r=0;r", "+i).join(""))}else return []}function maybeSetLastButtonClicked(e){let t=closest(asElement(e.target),"button, input[type='submit']"),n=getRelatedFormData(e);n&&(n.lastButtonClicked=t);}function maybeUnsetLastButtonClicked(e){let t=getRelatedFormData(e);t&&(t.lastButtonClicked=null);}function getRelatedFormData(e){let t=closest(asElement(e.target),"button, input[type='submit']");if(!t)return;let n=resolveTarget("#"+getRawAttribute(t,"form"),t.getRootNode())||closest(t,"form");if(n)return getInternalData(n)}function initButtonTracking(e){e.addEventListener("click",maybeSetLastButtonClicked),e.addEventListener("focusin",maybeSetLastButtonClicked),e.addEventListener("focusout",maybeUnsetLastButtonClicked);}function addHxOnEventHandler(e,t,n){let r=getInternalData(e);Array.isArray(r.onHandlers)||(r.onHandlers=[]);let o,i=function(s){maybeEval(e,function(){eltIsDisabled(e)||(o||(o=new Function("event",n)),o.call(e,s));});};e.addEventListener(t,i),r.onHandlers.push({event:t,listener:i});}function processHxOnWildcard(e){deInitOnHandlers(e);for(let t=0;thtmx.config.historyCacheSize;)i.shift();for(;i.length>0;)try{localStorage.setItem("htmx-history-cache",JSON.stringify(i));break}catch(l){triggerErrorEvent(getDocument().body,"htmx:historyCacheError",{cause:l,cache:i}),i.shift();}}function getCachedHistory(e){if(!canAccessLocalStorage())return null;e=normalizePath(e);let t=parseJSON(localStorage.getItem("htmx-history-cache"))||[];for(let n=0;n=200&&this.status<400){triggerEvent(getDocument().body,"htmx:historyCacheMissLoad",n);let r=makeFragment(this.response),o=r.querySelector("[hx-history-elt],[data-hx-history-elt]")||r,i=getHistoryElement(),s=makeSettleInfo(i);handleTitle(r.title),swapInnerHTML(i,o,s),settleImmediately(s.tasks),currentPathForHistory=e,triggerEvent(getDocument().body,"htmx:historyRestore",{path:e,cacheMiss:!0,serverResponse:this.response});}else triggerErrorEvent(getDocument().body,"htmx:historyCacheMissLoadError",n);},t.send();}function restoreHistory(e){saveCurrentPageToHistory(),e=e||location.pathname+location.search;let t=getCachedHistory(e);if(t){let n=makeFragment(t.content),r=getHistoryElement(),o=makeSettleInfo(r);handleTitle(n.title),swapInnerHTML(r,n,o),settleImmediately(o.tasks),getWindow().setTimeout(function(){window.scrollTo(0,t.scroll);},0),currentPathForHistory=e,triggerEvent(getDocument().body,"htmx:historyRestore",{path:e,item:t});}else htmx.config.refreshOnHistoryMiss?window.location.reload(!0):loadHistoryFromServer(e);}function addRequestIndicatorClasses(e){let t=findAttributeTargets(e,"hx-indicator");return t==null&&(t=[e]),forEach(t,function(n){let r=getInternalData(n);r.requestCount=(r.requestCount||0)+1,n.classList.add.call(n.classList,htmx.config.requestClass);}),t}function disableElements(e){let t=findAttributeTargets(e,"hx-disabled-elt");return t==null&&(t=[]),forEach(t,function(n){let r=getInternalData(n);r.requestCount=(r.requestCount||0)+1,n.setAttribute("disabled",""),n.setAttribute("data-disabled-by-htmx","");}),t}function removeRequestIndicators(e,t){forEach(e,function(n){let r=getInternalData(n);r.requestCount=(r.requestCount||0)-1,r.requestCount===0&&n.classList.remove.call(n.classList,htmx.config.requestClass);}),forEach(t,function(n){let r=getInternalData(n);r.requestCount=(r.requestCount||0)-1,r.requestCount===0&&(n.removeAttribute("disabled"),n.removeAttribute("data-disabled-by-htmx"));});}function haveSeenNode(e,t){for(let n=0;nt.indexOf(o)<0):r=r.filter(o=>o!==t),n.delete(e),forEach(r,o=>n.append(e,o));}}function processInputValue(e,t,n,r,o){if(!(r==null||haveSeenNode(e,r))){if(e.push(r),shouldInclude(r)){let i=getRawAttribute(r,"name"),s=r.value;r instanceof HTMLSelectElement&&r.multiple&&(s=toArray(r.querySelectorAll("option:checked")).map(function(l){return l.value})),r instanceof HTMLInputElement&&r.files&&(s=toArray(r.files)),addValueToFormData(i,s,t),o&&validateElement(r,n);}r instanceof HTMLFormElement&&(forEach(r.elements,function(i){e.indexOf(i)>=0?removeValueFromFormData(i.name,i.value,t):e.push(i),o&&validateElement(i,n);}),new FormData(r).forEach(function(i,s){i instanceof File&&i.name===""||addValueToFormData(s,i,t);}));}}function validateElement(e,t){let n=e;n.willValidate&&(triggerEvent(n,"htmx:validation:validate"),n.checkValidity()||(t.push({elt:n,message:n.validationMessage,validity:n.validity}),triggerEvent(n,"htmx:validation:failed",{message:n.validationMessage,validity:n.validity})));}function overrideFormData(e,t){for(let n of t.keys())e.delete(n);return t.forEach(function(n,r){e.append(r,n);}),e}function getInputValues(e,t){let n=[],r=new FormData,o=new FormData,i=[],s=getInternalData(e);s.lastButtonClicked&&!bodyContains(s.lastButtonClicked)&&(s.lastButtonClicked=null);let l=e instanceof HTMLFormElement&&e.noValidate!==!0||getAttributeValue(e,"hx-validate")==="true";if(s.lastButtonClicked&&(l=l&&s.lastButtonClicked.formNoValidate!==!0),t!=="get"&&processInputValue(n,o,i,closest(e,"form"),l),processInputValue(n,r,i,e,l),s.lastButtonClicked||e.tagName==="BUTTON"||e.tagName==="INPUT"&&getRawAttribute(e,"type")==="submit"){let u=s.lastButtonClicked||e,d=getRawAttribute(u,"name");addValueToFormData(d,u.value,o);}let a=findAttributeTargets(e,"hx-include");return forEach(a,function(u){processInputValue(n,r,i,asElement(u),l),matches(u,"form")||forEach(asParentNode(u).querySelectorAll(INPUT_SELECTOR),function(d){processInputValue(n,r,i,d,l);});}),overrideFormData(r,o),{errors:i,formData:r,values:formDataProxy(r)}}function appendParam(e,t,n){e!==""&&(e+="&"),String(n)==="[object Object]"&&(n=JSON.stringify(n));let r=encodeURIComponent(n);return e+=encodeURIComponent(t)+"="+r,e}function urlEncode(e){e=formDataFromObject(e);let t="";return e.forEach(function(n,r){t=appendParam(t,r,n);}),t}function getHeaders(e,t,n){let r={"HX-Request":"true","HX-Trigger":getRawAttribute(e,"id"),"HX-Trigger-Name":getRawAttribute(e,"name"),"HX-Target":getAttributeValue(t,"id"),"HX-Current-URL":getDocument().location.href};return getValuesForElement(e,"hx-headers",!1,r),n!==void 0&&(r["HX-Prompt"]=n),getInternalData(e).boosted&&(r["HX-Boosted"]="true"),r}function filterValues(e,t){let n=getClosestAttributeValue(t,"hx-params");if(n){if(n==="none")return new FormData;if(n==="*")return e;if(n.indexOf("not ")===0)return forEach(n.substr(4).split(","),function(r){r=r.trim(),e.delete(r);}),e;{let r=new FormData;return forEach(n.split(","),function(o){o=o.trim(),e.has(o)&&e.getAll(o).forEach(function(i){r.append(o,i);});}),r}}else return e}function isAnchorLink(e){return !!getRawAttribute(e,"href")&&getRawAttribute(e,"href").indexOf("#")>=0}function getSwapSpecification(e,t){let n=t||getClosestAttributeValue(e,"hx-swap"),r={swapStyle:getInternalData(e).boosted?"innerHTML":htmx.config.defaultSwapStyle,swapDelay:htmx.config.defaultSwapDelay,settleDelay:htmx.config.defaultSettleDelay};if(htmx.config.scrollIntoViewOnBoost&&getInternalData(e).boosted&&!isAnchorLink(e)&&(r.show="top"),n){let s=splitOnWhitespace(n);if(s.length>0)for(let l=0;l0?o.join(":"):null;r.scroll=d,r.scrollTarget=i;}else if(a.indexOf("show:")===0){var o=a.substr(5).split(":");let c=o.pop();var i=o.length>0?o.join(":"):null;r.show=c,r.showTarget=i;}else if(a.indexOf("focus-scroll:")===0){let u=a.substr(13);r.focusScroll=u=="true";}else l==0?r.swapStyle=a:logError("Unknown modifier in hx-swap: "+a);}}return r}function usesFormData(e){return getClosestAttributeValue(e,"hx-encoding")==="multipart/form-data"||matches(e,"form")&&getRawAttribute(e,"enctype")==="multipart/form-data"}function encodeParamsForBody(e,t,n){let r=null;return withExtensions(t,function(o){r==null&&(r=o.encodeParameters(e,n,t));}),r??(usesFormData(t)?overrideFormData(new FormData,formDataFromObject(n)):urlEncode(n))}function makeSettleInfo(e){return {tasks:[],elts:[e]}}function updateScrollState(e,t){let n=e[0],r=e[e.length-1];if(t.scroll){var o=null;t.scrollTarget&&(o=asElement(querySelectorExt(n,t.scrollTarget))),t.scroll==="top"&&(n||o)&&(o=o||n,o.scrollTop=0),t.scroll==="bottom"&&(r||o)&&(o=o||r,o.scrollTop=o.scrollHeight);}if(t.show){var o=null;if(t.showTarget){let s=t.showTarget;t.showTarget==="window"&&(s="body"),o=asElement(querySelectorExt(n,s));}t.show==="top"&&(n||o)&&(o=o||n,o.scrollIntoView({block:"start",behavior:htmx.config.scrollBehavior})),t.show==="bottom"&&(r||o)&&(o=o||r,o.scrollIntoView({block:"end",behavior:htmx.config.scrollBehavior}));}}function getValuesForElement(e,t,n,r){if(r==null&&(r={}),e==null)return r;let o=getAttributeValue(e,t);if(o){let i=o.trim(),s=n;if(i==="unset")return null;i.indexOf("javascript:")===0?(i=i.substr(11),s=!0):i.indexOf("js:")===0&&(i=i.substr(3),s=!0),i.indexOf("{")!==0&&(i="{"+i+"}");let l;s?l=maybeEval(e,function(){return Function("return ("+i+")")()},{}):l=parseJSON(i);for(let a in l)l.hasOwnProperty(a)&&r[a]==null&&(r[a]=l[a]);}return getValuesForElement(asElement(parentElt(e)),t,n,r)}function maybeEval(e,t,n){return htmx.config.allowEval?t():(triggerErrorEvent(e,"htmx:evalDisallowedError"),n)}function getHXVarsForElement(e,t){return getValuesForElement(e,"hx-vars",!0,t)}function getHXValsForElement(e,t){return getValuesForElement(e,"hx-vals",!1,t)}function getExpressionVars(e){return mergeObjects(getHXVarsForElement(e),getHXValsForElement(e))}function safelySetHeaderValue(e,t,n){if(n!==null)try{e.setRequestHeader(t,n);}catch{e.setRequestHeader(t,encodeURIComponent(n)),e.setRequestHeader(t+"-URI-AutoEncoded","true");}}function getPathFromResponse(e){if(e.responseURL&&typeof URL<"u")try{let t=new URL(e.responseURL);return t.pathname+t.search}catch{triggerErrorEvent(getDocument().body,"htmx:badResponseUrl",{url:e.responseURL});}}function hasHeader(e,t){return t.test(e.getAllResponseHeaders())}function ajaxHelper(e,t,n){return e=e.toLowerCase(),n?n instanceof Element||typeof n=="string"?issueAjaxRequest(e,t,null,null,{targetOverride:resolveTarget(n),returnPromise:!0}):issueAjaxRequest(e,t,resolveTarget(n.source),n.event,{handler:n.handler,headers:n.headers,values:n.values,targetOverride:resolveTarget(n.target),swapOverride:n.swap,select:n.select,returnPromise:!0}):issueAjaxRequest(e,t,null,null,{returnPromise:!0})}function hierarchyForElt(e){let t=[];for(;e;)t.push(e),e=e.parentElement;return t}function verifyPath(e,t,n){let r,o;return typeof URL=="function"?(o=new URL(t,document.location.href),r=document.location.origin===o.origin):(o=t,r=startsWith(t,document.location.origin)),htmx.config.selfRequestsOnly&&!r?!1:triggerEvent(e,"htmx:validateUrl",mergeObjects({url:o,sameHost:r},n))}function formDataFromObject(e){if(e instanceof FormData)return e;let t=new FormData;for(let n in e)e.hasOwnProperty(n)&&(typeof e[n].forEach=="function"?e[n].forEach(function(r){t.append(n,r);}):typeof e[n]=="object"&&!(e[n]instanceof Blob)?t.append(n,JSON.stringify(e[n])):t.append(n,e[n]));return t}function formDataArrayProxy(e,t,n){return new Proxy(n,{get:function(r,o){return typeof o=="number"?r[o]:o==="length"?r.length:o==="push"?function(i){r.push(i),e.append(t,i);}:typeof r[o]=="function"?function(){r[o].apply(r,arguments),e.delete(t),r.forEach(function(i){e.append(t,i);});}:r[o]&&r[o].length===1?r[o][0]:r[o]},set:function(r,o,i){return r[o]=i,e.delete(t),r.forEach(function(s){e.append(t,s);}),!0}})}function formDataProxy(e){return new Proxy(e,{get:function(t,n){if(typeof n=="symbol")return Reflect.get(t,n);if(n==="toJSON")return ()=>Object.fromEntries(e);if(n in t)return typeof t[n]=="function"?function(){return e[n].apply(e,arguments)}:t[n];let r=e.getAll(n);if(r.length!==0)return r.length===1?r[0]:formDataArrayProxy(t,n,r)},set:function(t,n,r){return typeof n!="string"?!1:(t.delete(n),typeof r.forEach=="function"?r.forEach(function(o){t.append(n,o);}):typeof r=="object"&&!(r instanceof Blob)?t.append(n,JSON.stringify(r)):t.append(n,r),!0)},deleteProperty:function(t,n){return typeof n=="string"&&t.delete(n),!0},ownKeys:function(t){return Reflect.ownKeys(Object.fromEntries(t))},getOwnPropertyDescriptor:function(t,n){return Reflect.getOwnPropertyDescriptor(Object.fromEntries(t),n)}})}function issueAjaxRequest(e,t,n,r,o,i){let s=null,l=null;if(o=o??{},o.returnPromise&&typeof Promise<"u")var a=new Promise(function(g,E){s=g,l=E;});n==null&&(n=getDocument().body);let u=o.handler||handleAjaxResponse,d=o.select||null;if(!bodyContains(n))return maybeCall(s),a;let c=o.targetOverride||asElement(getTarget(n));if(c==null||c==DUMMY_ELT)return triggerErrorEvent(n,"htmx:targetError",{target:getAttributeValue(n,"hx-target")}),maybeCall(l),a;let h=getInternalData(n),b=h.lastButtonClicked;if(b){let g=getRawAttribute(b,"formaction");g!=null&&(t=g);let E=getRawAttribute(b,"formmethod");E!=null&&E.toLowerCase()!=="dialog"&&(e=E);}let S=getClosestAttributeValue(n,"hx-confirm");if(i===void 0&&triggerEvent(n,"htmx:confirm",{target:c,elt:n,path:t,verb:e,triggeringEvent:r,etc:o,issueRequest:function(O){return issueAjaxRequest(e,t,n,r,o,!!O)},question:S})===!1)return maybeCall(s),a;let A=n,p=getClosestAttributeValue(n,"hx-sync"),x=null,T=!1;if(p){let g=p.split(":"),E=g[0].trim();if(E==="this"?A=findThisElement(n,"hx-sync"):A=asElement(querySelectorExt(n,E)),p=(g[1]||"drop").trim(),h=getInternalData(A),p==="drop"&&h.xhr&&h.abortable!==!0)return maybeCall(s),a;if(p==="abort"){if(h.xhr)return maybeCall(s),a;T=!0;}else p==="replace"?triggerEvent(A,"htmx:abort"):p.indexOf("queue")===0&&(x=(p.split(" ")[1]||"last").trim());}if(h.xhr)if(h.abortable)triggerEvent(A,"htmx:abort");else {if(x==null){if(r){let g=getInternalData(r);g&&g.triggerSpec&&g.triggerSpec.queue&&(x=g.triggerSpec.queue);}x==null&&(x="last");}return h.queuedRequests==null&&(h.queuedRequests=[]),x==="first"&&h.queuedRequests.length===0?h.queuedRequests.push(function(){issueAjaxRequest(e,t,n,r,o);}):x==="all"?h.queuedRequests.push(function(){issueAjaxRequest(e,t,n,r,o);}):x==="last"&&(h.queuedRequests=[],h.queuedRequests.push(function(){issueAjaxRequest(e,t,n,r,o);})),maybeCall(s),a}let m=new XMLHttpRequest;h.xhr=m,h.abortable=T;let H=function(){h.xhr=null,h.abortable=!1,h.queuedRequests!=null&&h.queuedRequests.length>0&&h.queuedRequests.shift()();},N=getClosestAttributeValue(n,"hx-prompt");if(N){var I=prompt(N);if(I===null||!triggerEvent(n,"htmx:prompt",{prompt:I,target:c}))return maybeCall(s),H(),a}if(S&&!i&&!confirm(S))return maybeCall(s),H(),a;let R=getHeaders(n,c,I);e!=="get"&&!usesFormData(n)&&(R["Content-Type"]="application/x-www-form-urlencoded"),o.headers&&(R=mergeObjects(R,o.headers));let v=getInputValues(n,e),q=v.errors,F=v.formData;o.values&&overrideFormData(F,formDataFromObject(o.values));let _=formDataFromObject(getExpressionVars(n)),W=overrideFormData(F,_),L=filterValues(W,n);htmx.config.getCacheBusterParam&&e==="get"&&L.set("org.htmx.cache-buster",getRawAttribute(c,"id")||"true"),(t==null||t==="")&&(t=getDocument().location.href);let X=getValuesForElement(n,"hx-request"),G=getInternalData(n).boosted,M=htmx.config.methodsThatUseUrlParams.indexOf(e)>=0,w={boosted:G,useUrlParams:M,formData:L,parameters:formDataProxy(L),unfilteredFormData:W,unfilteredParameters:formDataProxy(W),headers:R,target:c,verb:e,errors:q,withCredentials:o.credentials||X.credentials||htmx.config.withCredentials,timeout:o.timeout||X.timeout||htmx.config.timeout,path:t,triggeringEvent:r};if(!triggerEvent(n,"htmx:configRequest",w))return maybeCall(s),H(),a;if(t=w.path,e=w.verb,R=w.headers,L=formDataFromObject(w.parameters),q=w.errors,M=w.useUrlParams,q&&q.length>0)return triggerEvent(n,"htmx:validation:halted",w),maybeCall(s),H(),a;let Y=t.split("#"),Z=Y[0],j=Y[1],D=t;if(M&&(D=Z,!L.keys().next().done&&(D.indexOf("?")<0?D+="?":D+="&",D+=urlEncode(L),j&&(D+="#"+j))),!verifyPath(n,D,w))return triggerErrorEvent(n,"htmx:invalidPath",w),maybeCall(l),a;if(m.open(e.toUpperCase(),D,!0),m.overrideMimeType("text/html"),m.withCredentials=w.withCredentials,m.timeout=w.timeout,!X.noHeaders){for(let g in R)if(R.hasOwnProperty(g)){let E=R[g];safelySetHeaderValue(m,g,E);}}let y={xhr:m,target:c,requestConfig:w,etc:o,boosted:G,select:d,pathInfo:{requestPath:t,finalRequestPath:D,responsePath:null,anchor:j}};if(m.onload=function(){try{let g=hierarchyForElt(n);if(y.pathInfo.responsePath=getPathFromResponse(m),u(n,y),y.keepIndicators!==!0&&removeRequestIndicators(V,k),triggerEvent(n,"htmx:afterRequest",y),triggerEvent(n,"htmx:afterOnLoad",y),!bodyContains(n)){let E=null;for(;g.length>0&&E==null;){let O=g.shift();bodyContains(O)&&(E=O);}E&&(triggerEvent(E,"htmx:afterRequest",y),triggerEvent(E,"htmx:afterOnLoad",y));}maybeCall(s),H();}catch(g){throw triggerErrorEvent(n,"htmx:onLoadError",mergeObjects({error:g},y)),g}},m.onerror=function(){removeRequestIndicators(V,k),triggerErrorEvent(n,"htmx:afterRequest",y),triggerErrorEvent(n,"htmx:sendError",y),maybeCall(l),H();},m.onabort=function(){removeRequestIndicators(V,k),triggerErrorEvent(n,"htmx:afterRequest",y),triggerErrorEvent(n,"htmx:sendAbort",y),maybeCall(l),H();},m.ontimeout=function(){removeRequestIndicators(V,k),triggerErrorEvent(n,"htmx:afterRequest",y),triggerErrorEvent(n,"htmx:timeout",y),maybeCall(l),H();},!triggerEvent(n,"htmx:beforeRequest",y))return maybeCall(s),H(),a;var V=addRequestIndicatorClasses(n),k=disableElements(n);forEach(["loadstart","loadend","progress","abort"],function(g){forEach([m,m.upload],function(E){E.addEventListener(g,function(O){triggerEvent(n,"htmx:xhr:"+g,{lengthComputable:O.lengthComputable,loaded:O.loaded,total:O.total});});});}),triggerEvent(n,"htmx:beforeSend",y);let ee=M?null:encodeParamsForBody(m,n,L);return m.send(ee),a}function determineHistoryUpdates(e,t){let n=t.xhr,r=null,o=null;if(hasHeader(n,/HX-Push:/i)?(r=n.getResponseHeader("HX-Push"),o="push"):hasHeader(n,/HX-Push-Url:/i)?(r=n.getResponseHeader("HX-Push-Url"),o="push"):hasHeader(n,/HX-Replace-Url:/i)&&(r=n.getResponseHeader("HX-Replace-Url"),o="replace"),r)return r==="false"?{}:{type:o,path:r};let i=t.pathInfo.finalRequestPath,s=t.pathInfo.responsePath,l=getClosestAttributeValue(e,"hx-push-url"),a=getClosestAttributeValue(e,"hx-replace-url"),u=getInternalData(e).boosted,d=null,c=null;return l?(d="push",c=l):a?(d="replace",c=a):u&&(d="push",c=s||i),c?c==="false"?{}:(c==="true"&&(c=s||i),t.pathInfo.anchor&&c.indexOf("#")===-1&&(c=c+"#"+t.pathInfo.anchor),{type:d,path:c}):{}}function codeMatches(e,t){var n=new RegExp(e.code);return n.test(t.toString(10))}function resolveResponseHandling(e){for(var t=0;t0?getWindow().setTimeout(I,x.swapDelay):I();}c&&triggerErrorEvent(e,"htmx:responseError",mergeObjects({error:"Response Status Error Code "+n.status+" from "+t.pathInfo.requestPath},t));}}let extensions={};function extensionBase(){return {init:function(e){return null},getSelectors:function(){return null},onEvent:function(e,t){return !0},transformResponse:function(e,t,n){return e},isInlineSwap:function(e){return !1},handleSwap:function(e,t,n,r){return !1},encodeParameters:function(e,t,n){return null}}}function defineExtension(e,t){t.init&&t.init(internalAPI),extensions[e]=mergeObjects(extensionBase(),t);}function removeExtension(e){delete extensions[e];}function getExtensions(e,t,n){if(t==null&&(t=[]),e==null)return t;n==null&&(n=[]);let r=getAttributeValue(e,"hx-ext");return r&&forEach(r.split(","),function(o){if(o=o.replace(/ /g,""),o.slice(0,7)=="ignore:"){n.push(o.slice(7));return}if(n.indexOf(o)<0){let i=extensions[o];i&&t.indexOf(i)<0&&t.push(i);}}),getExtensions(asElement(parentElt(e)),t,n)}var isReady=!1;getDocument().addEventListener("DOMContentLoaded",function(){isReady=!0;});function ready(e){isReady||getDocument().readyState==="complete"?e():getDocument().addEventListener("DOMContentLoaded",e);}function insertIndicatorStyles(){if(htmx.config.includeIndicatorStyles!==!1){let e=htmx.config.inlineStyleNonce?` nonce="${htmx.config.inlineStyleNonce}"`:"";getDocument().head.insertAdjacentHTML("beforeend"," ."+htmx.config.indicatorClass+"{opacity:0} ."+htmx.config.requestClass+" ."+htmx.config.indicatorClass+"{opacity:1; transition: opacity 200ms ease-in;} ."+htmx.config.requestClass+"."+htmx.config.indicatorClass+"{opacity:1; transition: opacity 200ms ease-in;} ");}}function getMetaConfig(){let e=getDocument().querySelector('meta[name="htmx-config"]');return e?parseJSON(e.content):null}function mergeMetaConfig(){let e=getMetaConfig();e&&(htmx.config=mergeObjects(htmx.config,e));}return ready(function(){mergeMetaConfig(),insertIndicatorStyles();let e=getDocument().body;processNode(e);let t=getDocument().querySelectorAll("[hx-trigger='restored'],[data-hx-trigger='restored']");e.addEventListener("htmx:abort",function(r){let o=r.target,i=getInternalData(o);i&&i.xhr&&i.xhr.abort();});let n=window.onpopstate?window.onpopstate.bind(window):null;window.onpopstate=function(r){r.state&&r.state.htmx?(restoreHistory(),forEach(t,function(o){triggerEvent(o,"htmx:restored",{document:getDocument(),triggerEvent});})):n&&n(r);},getWindow().setTimeout(function(){triggerEvent(e,"htmx:load",{}),e=null;},0);}),htmx}(),f=te;function ne(e,t){if(e==="ignore")return !1;let n=e.split("/"),r=t.split("/");for(let o=0;o{let s=oe(t).replace("htmx:","hx-on::");if(!r.has(o)){if(o.hasAttribute(s)){let l=se(s.replace("hx-on::","htmx:"),{...n.detail,target:o});l.detail.meta="trigger-children",o.dispatchEvent(l),r.add(o);}o.children&&$(o,t,n,r);}});}f.defineExtension("trigger-children",{onEvent:(e,t)=>{if(!(t instanceof CustomEvent)||t.detail.meta==="trigger-children")return !1;let n=new Set,r=t.target||t.detail.target;return $(r,e,t,n),!0}});f.defineExtension("debug",{onEvent:function(e,t){console.debug?console.debug(e,t):console&&console.log("DEBUG:",e,t);}});var C=f.config,U,ae="hx-target-";function Q(e,t){return e.substring(0,t.length)===t}function le(e,t){if(!e||!t)return null;let n=t.toString(),r=[n,n.substr(0,2)+"*",n.substr(0,2)+"x",n.substr(0,1)+"*",n.substr(0,1)+"x",n.substr(0,1)+"**",n.substr(0,1)+"xx","*","x","***","xxx"];(Q(n,"4")||Q(n,"5"))&&r.push("error");for(let o=0;o{U=e,C.responseTargetUnsetsError===void 0&&(C.responseTargetUnsetsError=!0),C.responseTargetSetsError===void 0&&(C.responseTargetSetsError=!1),C.responseTargetPrefersExisting===void 0&&(C.responseTargetPrefersExisting=!1),C.responseTargetPrefersRetargetHeader===void 0&&(C.responseTargetPrefersRetargetHeader=!0);},onEvent:(e,t)=>{if(!(t instanceof CustomEvent))return !1;if(e==="htmx:beforeSwap"&&t.detail.xhr&&t.detail.xhr.status!==200){if(t.detail.target&&(C.responseTargetPrefersExisting||C.responseTargetPrefersRetargetHeader&&t.detail.xhr.getAllResponseHeaders().match(/HX-Retarget:/i)))return t.detail.shouldSwap=!0,z(t),!0;if(!t.detail.requestConfig)return !0;let n=le(t.detail.requestConfig.elt,t.detail.xhr.status);return n&&(z(t),t.detail.shouldSwap=!0,t.detail.target=n),!0}}});f.defineExtension("mutation-error",{onEvent:(e,t)=>{if(!(t instanceof CustomEvent))return !1;if(e==="htmx:afterRequest"){if(!t.detail||!t.detail.xhr)return;let n=t.detail.xhr.status;n>=400&&f.findAll("[hx-on\\:\\:mutation-error]").forEach(r=>{f.trigger(r,"htmx:mutation-error",{status:n});});}}});var B="";f.defineExtension("livereload",{init:function(){let e=!1;for(let n of Array.from(f.findAll("[hx-ext]")))if(n.getAttribute("hx-ext")?.split(" ").includes("livereload")){e=!0;break}if(!e)return;console.log("livereload extension initialized.");let t=new EventSource("/dev/livereload");t.onmessage=function(n){let r=n.data;B===""&&(B=r),B!==r&&(B=r,ue());},t.onerror=function(n){console.error("EventSource error:",n);};},onEvent:function(e,t){}});function ue(){window.location.reload();}var ce=/__eval_[A-Za-z0-9]+\([a-z]+\)/gm;f.defineExtension("htmgo",{onEvent:function(e,t){e==="htmx:beforeCleanupElement"&&t.target&&J(t.target);}});function J(e){let t=Array.from(e.attributes);for(let n of t){let r=n.value.match(ce)||[];for(let o of r){let i=o.replace("()","").replace("(this)","").replace(";",""),s=document.getElementById(i);s&&s.tagName==="SCRIPT"&&(console.debug("removing associated script with id",i),s.remove());}}}var P=null,K=new Set;f.defineExtension("sse",{init:function(e){P=e;},onEvent:function(e,t){let n=t.target;if(n instanceof HTMLElement&&(e==="htmx:beforeCleanupElement"&&J(n),e==="htmx:beforeProcessNode")){let r=document.querySelectorAll("[sse-connect]");for(let o of Array.from(r)){let i=o.getAttribute("sse-connect");i&&!K.has(i)&&(fe(o,i),K.add(i));}}}});function fe(e,t){if(!t)return;console.info("Connecting to EventSource",t);let n=new EventSource(t);n.addEventListener("close",function(r){f.trigger(e,"htmx:sseClose",{event:r});}),n.onopen=function(r){f.trigger(e,"htmx:sseOpen",{event:r});},n.onerror=function(r){f.trigger(e,"htmx:sseError",{event:r}),n.readyState==EventSource.CLOSED&&f.trigger(e,"htmx:sseClose",{event:r});},n.onmessage=function(r){let o=P.makeSettleInfo(e);f.trigger(e,"htmx:sseBeforeMessage",{event:r});let i=r.data,s=P.makeFragment(i),l=Array.from(s.children);for(let a of l)P.oobSwap(P.getAttributeValue(a,"hx-swap-oob")||"true",a,o),a.tagName==="SCRIPT"&&a.id.startsWith("__eval")&&document.body.appendChild(a);f.trigger(e,"htmx:sseAfterMessage",{event:r});};}window.htmx=f;function de(e){let t=window.location.href;setInterval(()=>{window.location.href!==t&&(e(t,window.location.href),t=window.location.href);},100);}de((e,t)=>{he(t);});function he(e){let t=new URL(e);document.querySelectorAll("[hx-trigger]").forEach(function(n){let r=n.getAttribute("hx-trigger");if(!r)return;if(r.split(", ").find(i=>i==="url"))f.swap(n,"url",{swapStyle:"outerHTML",swapDelay:0,settleDelay:0});else for(let[i,s]of t.searchParams){let l="qs:"+i;if(r.includes(l)){console.log("triggering",l),f.trigger(n,l,null);break}}}),document.querySelectorAll("[hx-match-qp]").forEach(n=>{let r=!1;for(let o of n.getAttributeNames())if(o.startsWith("hx-match-qp-mapping:")){let i=o.replace("hx-match-qp-mapping:","");if(t.searchParams.get(i)){f.swap(n,n.getAttribute(o)??"",{swapStyle:"innerHTML",swapDelay:0,settleDelay:0}),r=!0;break}}if(!r){let o=n.getAttribute("hx-match-qp-default");o&&f.swap(n,n.getAttribute("hx-match-qp-mapping:"+o)??"",{swapStyle:"innerHTML",swapDelay:0,settleDelay:0});}});} +var te=function(){let htmx={onLoad:null,process:null,on:null,off:null,trigger:null,ajax:null,find:null,findAll:null,closest:null,values:function(e,t){return getInputValues(e,t||"post").values},remove:null,addClass:null,removeClass:null,toggleClass:null,takeClass:null,swap:null,defineExtension:null,removeExtension:null,logAll:null,logNone:null,logger:null,config:{historyEnabled:!0,historyCacheSize:10,refreshOnHistoryMiss:!1,defaultSwapStyle:"innerHTML",defaultSwapDelay:0,defaultSettleDelay:20,includeIndicatorStyles:!0,indicatorClass:"htmx-indicator",requestClass:"htmx-request",addedClass:"htmx-added",settlingClass:"htmx-settling",swappingClass:"htmx-swapping",allowEval:!0,allowScriptTags:!0,inlineScriptNonce:"",inlineStyleNonce:"",attributesToSettle:["class","style","width","height"],withCredentials:!1,timeout:0,wsReconnectDelay:"full-jitter",wsBinaryType:"blob",disableSelector:"[hx-disable], [data-hx-disable]",scrollBehavior:"instant",defaultFocusScroll:!1,getCacheBusterParam:!1,globalViewTransitions:!1,methodsThatUseUrlParams:["get","delete"],selfRequestsOnly:!0,ignoreTitle:!1,scrollIntoViewOnBoost:!0,triggerSpecsCache:null,disableInheritance:!1,responseHandling:[{code:"204",swap:!1},{code:"[23]..",swap:!0},{code:"[45]..",swap:!1,error:!0}],allowNestedOobSwaps:!0},parseInterval:null,_:null,version:"2.0.2"};htmx.onLoad=onLoadHelper,htmx.process=processNode,htmx.on=addEventListenerImpl,htmx.off=removeEventListenerImpl,htmx.trigger=triggerEvent,htmx.ajax=ajaxHelper,htmx.find=find,htmx.findAll=findAll,htmx.closest=closest,htmx.remove=removeElement,htmx.addClass=addClassToElement,htmx.removeClass=removeClassFromElement,htmx.toggleClass=toggleClassOnElement,htmx.takeClass=takeClassForElement,htmx.swap=swap,htmx.defineExtension=defineExtension,htmx.removeExtension=removeExtension,htmx.logAll=logAll,htmx.logNone=logNone,htmx.parseInterval=parseInterval,htmx._=internalEval;let internalAPI={addTriggerHandler,bodyContains,canAccessLocalStorage,findThisElement,filterValues,swap,hasAttribute,getAttributeValue,getClosestAttributeValue,getClosestMatch,getExpressionVars,getHeaders,getInputValues,getInternalData,getSwapSpecification,getTriggerSpecs,getTarget,makeFragment,mergeObjects,makeSettleInfo,oobSwap,querySelectorExt,settleImmediately,shouldCancel,triggerEvent,triggerErrorEvent,withExtensions},VERBS=["get","post","put","delete","patch"],VERB_SELECTOR=VERBS.map(function(e){return "[hx-"+e+"], [data-hx-"+e+"]"}).join(", "),HEAD_TAG_REGEX=makeTagRegEx("head");function makeTagRegEx(e,t=!1){return new RegExp(`<${e}(\\s[^>]*>|>)([\\s\\S]*?)<\\/${e}>`,t?"gim":"im")}function parseInterval(e){if(e==null)return;let t=NaN;return e.slice(-2)=="ms"?t=parseFloat(e.slice(0,-2)):e.slice(-1)=="s"?t=parseFloat(e.slice(0,-1))*1e3:e.slice(-1)=="m"?t=parseFloat(e.slice(0,-1))*1e3*60:t=parseFloat(e),isNaN(t)?void 0:t}function getRawAttribute(e,t){return e instanceof Element&&e.getAttribute(t)}function hasAttribute(e,t){return !!e.hasAttribute&&(e.hasAttribute(t)||e.hasAttribute("data-"+t))}function getAttributeValue(e,t){return getRawAttribute(e,t)||getRawAttribute(e,"data-"+t)}function parentElt(e){let t=e.parentElement;return !t&&e.parentNode instanceof ShadowRoot?e.parentNode:t}function getDocument(){return document}function getRootNode(e,t){return e.getRootNode?e.getRootNode({composed:t}):getDocument()}function getClosestMatch(e,t){for(;e&&!t(e);)e=parentElt(e);return e||null}function getAttributeValueWithDisinheritance(e,t,n){let r=getAttributeValue(t,n),o=getAttributeValue(t,"hx-disinherit");var i=getAttributeValue(t,"hx-inherit");if(e!==t){if(htmx.config.disableInheritance)return i&&(i==="*"||i.split(" ").indexOf(n)>=0)?r:null;if(o&&(o==="*"||o.split(" ").indexOf(n)>=0))return "unset"}return r}function getClosestAttributeValue(e,t){let n=null;if(getClosestMatch(e,function(r){return !!(n=getAttributeValueWithDisinheritance(e,asElement(r),t))}),n!=="unset")return n}function matches(e,t){let n=e instanceof Element&&(e.matches||e.matchesSelector||e.msMatchesSelector||e.mozMatchesSelector||e.webkitMatchesSelector||e.oMatchesSelector);return !!n&&n.call(e,t)}function getStartTag(e){let n=/<([a-z][^\/\0>\x20\t\r\n\f]*)/i.exec(e);return n?n[1].toLowerCase():""}function parseHTML(e){return new DOMParser().parseFromString(e,"text/html")}function takeChildrenFor(e,t){for(;t.childNodes.length>0;)e.append(t.childNodes[0]);}function duplicateScript(e){let t=getDocument().createElement("script");return forEach(e.attributes,function(n){t.setAttribute(n.name,n.value);}),t.textContent=e.textContent,t.async=!1,htmx.config.inlineScriptNonce&&(t.nonce=htmx.config.inlineScriptNonce),t}function isJavaScriptScriptNode(e){return e.matches("script")&&(e.type==="text/javascript"||e.type==="module"||e.type==="")}function normalizeScriptTags(e){Array.from(e.querySelectorAll("script")).forEach(t=>{if(isJavaScriptScriptNode(t)){let n=duplicateScript(t),r=t.parentNode;try{r.insertBefore(n,t);}catch(o){logError(o);}finally{t.remove();}}});}function makeFragment(e){let t=e.replace(HEAD_TAG_REGEX,""),n=getStartTag(t),r;if(n==="html"){r=new DocumentFragment;let i=parseHTML(e);takeChildrenFor(r,i.body),r.title=i.title;}else if(n==="body"){r=new DocumentFragment;let i=parseHTML(t);takeChildrenFor(r,i.body),r.title=i.title;}else {let i=parseHTML('");r=i.querySelector("template").content,r.title=i.title;var o=r.querySelector("title");o&&o.parentNode===r&&(o.remove(),r.title=o.innerText);}return r&&(htmx.config.allowScriptTags?normalizeScriptTags(r):r.querySelectorAll("script").forEach(i=>i.remove())),r}function maybeCall(e){e&&e();}function isType(e,t){return Object.prototype.toString.call(e)==="[object "+t+"]"}function isFunction(e){return typeof e=="function"}function isRawObject(e){return isType(e,"Object")}function getInternalData(e){let t="htmx-internal-data",n=e[t];return n||(n=e[t]={}),n}function toArray(e){let t=[];if(e)for(let n=0;n=0}function bodyContains(e){let t=e.getRootNode&&e.getRootNode();return t&&t instanceof window.ShadowRoot?getDocument().body.contains(t.host):getDocument().body.contains(e)}function splitOnWhitespace(e){return e.trim().split(/\s+/)}function mergeObjects(e,t){for(let n in t)t.hasOwnProperty(n)&&(e[n]=t[n]);return e}function parseJSON(e){try{return JSON.parse(e)}catch(t){return logError(t),null}}function canAccessLocalStorage(){let e="htmx:localStorageTest";try{return localStorage.setItem(e,e),localStorage.removeItem(e),!0}catch{return !1}}function normalizePath(e){try{let t=new URL(e);return t&&(e=t.pathname+t.search),/^\/$/.test(e)||(e=e.replace(/\/+$/,"")),e}catch{return e}}function internalEval(str){return maybeEval(getDocument().body,function(){return eval(str)})}function onLoadHelper(e){return htmx.on("htmx:load",function(n){e(n.detail.elt);})}function logAll(){htmx.logger=function(e,t,n){console&&console.log(t,e,n);};}function logNone(){htmx.logger=null;}function find(e,t){return typeof e!="string"?e.querySelector(t):find(getDocument(),e)}function findAll(e,t){return typeof e!="string"?e.querySelectorAll(t):findAll(getDocument(),e)}function getWindow(){return window}function removeElement(e,t){e=resolveTarget(e),t?getWindow().setTimeout(function(){removeElement(e),e=null;},t):parentElt(e).removeChild(e);}function asElement(e){return e instanceof Element?e:null}function asHtmlElement(e){return e instanceof HTMLElement?e:null}function asString(e){return typeof e=="string"?e:null}function asParentNode(e){return e instanceof Element||e instanceof Document||e instanceof DocumentFragment?e:null}function addClassToElement(e,t,n){e=asElement(resolveTarget(e)),e&&(n?getWindow().setTimeout(function(){addClassToElement(e,t),e=null;},n):e.classList&&e.classList.add(t));}function removeClassFromElement(e,t,n){let r=asElement(resolveTarget(e));r&&(n?getWindow().setTimeout(function(){removeClassFromElement(r,t),r=null;},n):r.classList&&(r.classList.remove(t),r.classList.length===0&&r.removeAttribute("class")));}function toggleClassOnElement(e,t){e=resolveTarget(e),e.classList.toggle(t);}function takeClassForElement(e,t){e=resolveTarget(e),forEach(e.parentElement.children,function(n){removeClassFromElement(n,t);}),addClassToElement(asElement(e),t);}function closest(e,t){if(e=asElement(resolveTarget(e)),e&&e.closest)return e.closest(t);do if(e==null||matches(e,t))return e;while(e=e&&asElement(parentElt(e)));return null}function startsWith(e,t){return e.substring(0,t.length)===t}function endsWith(e,t){return e.substring(e.length-t.length)===t}function normalizeSelector(e){let t=e.trim();return startsWith(t,"<")&&endsWith(t,"/>")?t.substring(1,t.length-2):t}function querySelectorAllExt(e,t,n){return e=resolveTarget(e),t.indexOf("closest ")===0?[closest(asElement(e),normalizeSelector(t.substr(8)))]:t.indexOf("find ")===0?[find(asParentNode(e),normalizeSelector(t.substr(5)))]:t==="next"?[asElement(e).nextElementSibling]:t.indexOf("next ")===0?[scanForwardQuery(e,normalizeSelector(t.substr(5)),!!n)]:t==="previous"?[asElement(e).previousElementSibling]:t.indexOf("previous ")===0?[scanBackwardsQuery(e,normalizeSelector(t.substr(9)),!!n)]:t==="document"?[document]:t==="window"?[window]:t==="body"?[document.body]:t==="root"?[getRootNode(e,!!n)]:t.indexOf("global ")===0?querySelectorAllExt(e,t.slice(7),!0):toArray(asParentNode(getRootNode(e,!!n)).querySelectorAll(normalizeSelector(t)))}var scanForwardQuery=function(e,t,n){let r=asParentNode(getRootNode(e,n)).querySelectorAll(t);for(let o=0;o=0;o--){let i=r[o];if(i.compareDocumentPosition(e)===Node.DOCUMENT_POSITION_FOLLOWING)return i}};function querySelectorExt(e,t){return typeof e!="string"?querySelectorAllExt(e,t)[0]:querySelectorAllExt(getDocument().body,e)[0]}function resolveTarget(e,t){return typeof e=="string"?find(asParentNode(t)||document,e):e}function processEventArgs(e,t,n){return isFunction(t)?{target:getDocument().body,event:asString(e),listener:t}:{target:resolveTarget(e),event:asString(t),listener:n}}function addEventListenerImpl(e,t,n){return ready(function(){let o=processEventArgs(e,t,n);o.target.addEventListener(o.event,o.listener);}),isFunction(t)?t:n}function removeEventListenerImpl(e,t,n){return ready(function(){let r=processEventArgs(e,t,n);r.target.removeEventListener(r.event,r.listener);}),isFunction(t)?t:n}let DUMMY_ELT=getDocument().createElement("output");function findAttributeTargets(e,t){let n=getClosestAttributeValue(e,t);if(n){if(n==="this")return [findThisElement(e,t)];{let r=querySelectorAllExt(e,n);return r.length===0?(logError('The selector "'+n+'" on '+t+" returned no matches!"),[DUMMY_ELT]):r}}}function findThisElement(e,t){return asElement(getClosestMatch(e,function(n){return getAttributeValue(asElement(n),t)!=null}))}function getTarget(e){let t=getClosestAttributeValue(e,"hx-target");return t?t==="this"?findThisElement(e,"hx-target"):querySelectorExt(e,t):getInternalData(e).boosted?getDocument().body:e}function shouldSettleAttribute(e){let t=htmx.config.attributesToSettle;for(let n=0;n0?(o=e.substr(0,e.indexOf(":")),r=e.substr(e.indexOf(":")+1,e.length)):o=e);let i=getDocument().querySelectorAll(r);return i?(forEach(i,function(s){let l,a=t.cloneNode(!0);l=getDocument().createDocumentFragment(),l.appendChild(a),isInlineSwap(o,s)||(l=asParentNode(a));let u={shouldSwap:!0,target:s,fragment:l};triggerEvent(s,"htmx:oobBeforeSwap",u)&&(s=u.target,u.shouldSwap&&swapWithStyle(o,s,s,l,n),forEach(n.elts,function(d){triggerEvent(d,"htmx:oobAfterSwap",u);}));}),t.parentNode.removeChild(t)):(t.parentNode.removeChild(t),triggerErrorEvent(getDocument().body,"htmx:oobErrorNoTarget",{content:t})),e}function handlePreservedElements(e){forEach(findAll(e,"[hx-preserve], [data-hx-preserve]"),function(t){let n=getAttributeValue(t,"id"),r=getDocument().getElementById(n);r!=null&&t.parentNode.replaceChild(r,t);});}function handleAttributes(e,t,n){forEach(t.querySelectorAll("[id]"),function(r){let o=getRawAttribute(r,"id");if(o&&o.length>0){let i=o.replace("'","\\'"),s=r.tagName.replace(":","\\:"),l=asParentNode(e),a=l&&l.querySelector(s+"[id='"+i+"']");if(a&&a!==l){let u=r.cloneNode();cloneAttributes(r,a),n.tasks.push(function(){cloneAttributes(r,u);});}}});}function makeAjaxLoadTask(e){return function(){removeClassFromElement(e,htmx.config.addedClass),processNode(asElement(e)),processFocus(asParentNode(e)),triggerEvent(e,"htmx:load");}}function processFocus(e){let t="[autofocus]",n=asHtmlElement(matches(e,t)?e:e.querySelector(t));n?.focus();}function insertNodesBefore(e,t,n,r){for(handleAttributes(e,n,r);n.childNodes.length>0;){let o=n.firstChild;addClassToElement(asElement(o),htmx.config.addedClass),e.insertBefore(o,t),o.nodeType!==Node.TEXT_NODE&&o.nodeType!==Node.COMMENT_NODE&&r.tasks.push(makeAjaxLoadTask(o));}}function stringHash(e,t){let n=0;for(;n0}function swap(e,t,n,r){r||(r={}),e=resolveTarget(e);let o=document.activeElement,i={};try{i={elt:o,start:o?o.selectionStart:null,end:o?o.selectionEnd:null};}catch{}let s=makeSettleInfo(e);if(n.swapStyle==="textContent")e.textContent=t;else {let a=makeFragment(t);if(s.title=a.title,r.selectOOB){let u=r.selectOOB.split(",");for(let d=0;d0?getWindow().setTimeout(l,n.settleDelay):l();}function handleTriggerHeader(e,t,n){let r=e.getResponseHeader(t);if(r.indexOf("{")===0){let o=parseJSON(r);for(let i in o)if(o.hasOwnProperty(i)){let s=o[i];isRawObject(s)?n=s.target!==void 0?s.target:n:s={value:s},triggerEvent(n,i,s);}}else {let o=r.split(",");for(let i=0;i0;){let s=t[0];if(s==="]"){if(r--,r===0){i===null&&(o=o+"true"),t.shift(),o+=")})";try{let l=maybeEval(e,function(){return Function(o)()},function(){return !0});return l.source=o,l}catch(l){return triggerErrorEvent(getDocument().body,"htmx:syntax:error",{error:l,source:o}),null}}}else s==="["&&r++;isPossibleRelativeReference(s,i,n)?o+="(("+n+"."+s+") ? ("+n+"."+s+") : (window."+s+"))":o=o+s,i=t.shift();}}}function consumeUntil(e,t){let n="";for(;e.length>0&&!t.test(e[0]);)n+=e.shift();return n}function consumeCSSSelector(e){let t;return e.length>0&&COMBINED_SELECTOR_START.test(e[0])?(e.shift(),t=consumeUntil(e,COMBINED_SELECTOR_END).trim(),e.shift()):t=consumeUntil(e,WHITESPACE_OR_COMMA),t}let INPUT_SELECTOR="input, textarea, select";function parseAndCacheTrigger(e,t,n){let r=[],o=tokenizeString(t);do{consumeUntil(o,NOT_WHITESPACE);let l=o.length,a=consumeUntil(o,/[,\[\s]/);if(a!=="")if(a==="every"){let u={trigger:"every"};consumeUntil(o,NOT_WHITESPACE),u.pollInterval=parseInterval(consumeUntil(o,/[,\[\s]/)),consumeUntil(o,NOT_WHITESPACE);var i=maybeGenerateConditional(e,o,"event");i&&(u.eventFilter=i),r.push(u);}else {let u={trigger:a};var i=maybeGenerateConditional(e,o,"event");for(i&&(u.eventFilter=i);o.length>0&&o[0]!==",";){consumeUntil(o,NOT_WHITESPACE);let c=o.shift();if(c==="changed")u.changed=!0;else if(c==="once")u.once=!0;else if(c==="consume")u.consume=!0;else if(c==="delay"&&o[0]===":")o.shift(),u.delay=parseInterval(consumeUntil(o,WHITESPACE_OR_COMMA));else if(c==="from"&&o[0]===":"){if(o.shift(),COMBINED_SELECTOR_START.test(o[0]))var s=consumeCSSSelector(o);else {var s=consumeUntil(o,WHITESPACE_OR_COMMA);if(s==="closest"||s==="find"||s==="next"||s==="previous"){o.shift();let b=consumeCSSSelector(o);b.length>0&&(s+=" "+b);}}u.from=s;}else c==="target"&&o[0]===":"?(o.shift(),u.target=consumeCSSSelector(o)):c==="throttle"&&o[0]===":"?(o.shift(),u.throttle=parseInterval(consumeUntil(o,WHITESPACE_OR_COMMA))):c==="queue"&&o[0]===":"?(o.shift(),u.queue=consumeUntil(o,WHITESPACE_OR_COMMA)):c==="root"&&o[0]===":"?(o.shift(),u[c]=consumeCSSSelector(o)):c==="threshold"&&o[0]===":"?(o.shift(),u[c]=consumeUntil(o,WHITESPACE_OR_COMMA)):triggerErrorEvent(e,"htmx:syntax:error",{token:o.shift()});}r.push(u);}o.length===l&&triggerErrorEvent(e,"htmx:syntax:error",{token:o.shift()}),consumeUntil(o,NOT_WHITESPACE);}while(o[0]===","&&o.shift());return n&&(n[t]=r),r}function getTriggerSpecs(e){let t=getAttributeValue(e,"hx-trigger"),n=[];if(t){let r=htmx.config.triggerSpecsCache;n=r&&r[t]||parseAndCacheTrigger(e,t,r);}return n.length>0?n:matches(e,"form")?[{trigger:"submit"}]:matches(e,'input[type="button"], input[type="submit"]')?[{trigger:"click"}]:matches(e,INPUT_SELECTOR)?[{trigger:"change"}]:[{trigger:"click"}]}function cancelPolling(e){getInternalData(e).cancelled=!0;}function processPolling(e,t,n){let r=getInternalData(e);r.timeout=getWindow().setTimeout(function(){bodyContains(e)&&r.cancelled!==!0&&(maybeFilterEvent(n,e,makeEvent("hx:poll:trigger",{triggerSpec:n,target:e}))||t(e),processPolling(e,t,n));},n.pollInterval);}function isLocalLink(e){return location.hostname===e.hostname&&getRawAttribute(e,"href")&&getRawAttribute(e,"href").indexOf("#")!==0}function eltIsDisabled(e){return closest(e,htmx.config.disableSelector)}function boostElement(e,t,n){if(e instanceof HTMLAnchorElement&&isLocalLink(e)&&(e.target===""||e.target==="_self")||e.tagName==="FORM"&&String(getRawAttribute(e,"method")).toLowerCase()!=="dialog"){t.boosted=!0;let r,o;if(e.tagName==="A")r="get",o=getRawAttribute(e,"href");else {let i=getRawAttribute(e,"method");r=i?i.toLowerCase():"get",o=getRawAttribute(e,"action");}n.forEach(function(i){addEventListener(e,function(s,l){let a=asElement(s);if(eltIsDisabled(a)){cleanUpElement(a);return}issueAjaxRequest(r,o,a,l);},t,i,!0);});}}function shouldCancel(e,t){let n=asElement(t);return n?!!((e.type==="submit"||e.type==="click")&&(n.tagName==="FORM"||matches(n,'input[type="submit"], button')&&closest(n,"form")!==null||n instanceof HTMLAnchorElement&&n.href&&(n.getAttribute("href")==="#"||n.getAttribute("href").indexOf("#")!==0))):!1}function ignoreBoostedAnchorCtrlClick(e,t){return getInternalData(e).boosted&&e instanceof HTMLAnchorElement&&t.type==="click"&&(t.ctrlKey||t.metaKey)}function maybeFilterEvent(e,t,n){let r=e.eventFilter;if(r)try{return r.call(t,n)!==!0}catch(o){let i=r.source;return triggerErrorEvent(getDocument().body,"htmx:eventFilter:error",{error:o,source:i}),!0}return !1}function addEventListener(e,t,n,r,o){let i=getInternalData(e),s;r.from?s=querySelectorAllExt(e,r.from):s=[e],r.changed&&s.forEach(function(l){let a=getInternalData(l);a.lastValue=l.value;}),forEach(s,function(l){let a=function(u){if(!bodyContains(e)){l.removeEventListener(r.trigger,a);return}if(ignoreBoostedAnchorCtrlClick(e,u)||((o||shouldCancel(u,e))&&u.preventDefault(),maybeFilterEvent(r,e,u)))return;let d=getInternalData(u);if(d.triggerSpec=r,d.handledFor==null&&(d.handledFor=[]),d.handledFor.indexOf(e)<0){if(d.handledFor.push(e),r.consume&&u.stopPropagation(),r.target&&u.target&&!matches(asElement(u.target),r.target))return;if(r.once){if(i.triggeredOnce)return;i.triggeredOnce=!0;}if(r.changed){let c=getInternalData(l),h=l.value;if(c.lastValue===h)return;c.lastValue=h;}if(i.delayed&&clearTimeout(i.delayed),i.throttle)return;r.throttle>0?i.throttle||(triggerEvent(e,"htmx:trigger"),t(e,u),i.throttle=getWindow().setTimeout(function(){i.throttle=null;},r.throttle)):r.delay>0?i.delayed=getWindow().setTimeout(function(){triggerEvent(e,"htmx:trigger"),t(e,u);},r.delay):(triggerEvent(e,"htmx:trigger"),t(e,u));}};n.listenerInfos==null&&(n.listenerInfos=[]),n.listenerInfos.push({trigger:r.trigger,listener:a,on:l}),l.addEventListener(r.trigger,a);});}let windowIsScrolling=!1,scrollHandler=null;function initScrollHandler(){scrollHandler||(scrollHandler=function(){windowIsScrolling=!0;},window.addEventListener("scroll",scrollHandler),setInterval(function(){windowIsScrolling&&(windowIsScrolling=!1,forEach(getDocument().querySelectorAll("[hx-trigger*='revealed'],[data-hx-trigger*='revealed']"),function(e){maybeReveal(e);}));},200));}function maybeReveal(e){!hasAttribute(e,"data-hx-revealed")&&isScrolledIntoView(e)&&(e.setAttribute("data-hx-revealed","true"),getInternalData(e).initHash?triggerEvent(e,"revealed"):e.addEventListener("htmx:afterProcessNode",function(){triggerEvent(e,"revealed");},{once:!0}));}function loadImmediately(e,t,n,r){let o=function(){n.loaded||(n.loaded=!0,t(e));};r>0?getWindow().setTimeout(o,r):o();}function processVerbs(e,t,n){let r=!1;return forEach(VERBS,function(o){if(hasAttribute(e,"hx-"+o)){let i=getAttributeValue(e,"hx-"+o);r=!0,t.path=i,t.verb=o,n.forEach(function(s){addTriggerHandler(e,s,t,function(l,a){let u=asElement(l);if(closest(u,htmx.config.disableSelector)){cleanUpElement(u);return}issueAjaxRequest(o,i,u,a);});});}}),r}function addTriggerHandler(e,t,n,r){if(t.trigger==="revealed")initScrollHandler(),addEventListener(e,r,n,t),maybeReveal(asElement(e));else if(t.trigger==="intersect"){let o={};t.root&&(o.root=querySelectorExt(e,t.root)),t.threshold&&(o.threshold=parseFloat(t.threshold)),new IntersectionObserver(function(s){for(let l=0;l0?(n.polling=!0,processPolling(asElement(e),r,t)):addEventListener(e,r,n,t);}function shouldProcessHxOn(e){let t=asElement(e);if(!t)return !1;let n=t.attributes;for(let r=0;r", "+i).join(""))}else return []}function maybeSetLastButtonClicked(e){let t=closest(asElement(e.target),"button, input[type='submit']"),n=getRelatedFormData(e);n&&(n.lastButtonClicked=t);}function maybeUnsetLastButtonClicked(e){let t=getRelatedFormData(e);t&&(t.lastButtonClicked=null);}function getRelatedFormData(e){let t=closest(asElement(e.target),"button, input[type='submit']");if(!t)return;let n=resolveTarget("#"+getRawAttribute(t,"form"),t.getRootNode())||closest(t,"form");if(n)return getInternalData(n)}function initButtonTracking(e){e.addEventListener("click",maybeSetLastButtonClicked),e.addEventListener("focusin",maybeSetLastButtonClicked),e.addEventListener("focusout",maybeUnsetLastButtonClicked);}function addHxOnEventHandler(e,t,n){let r=getInternalData(e);Array.isArray(r.onHandlers)||(r.onHandlers=[]);let o,i=function(s){maybeEval(e,function(){eltIsDisabled(e)||(o||(o=new Function("event",n)),o.call(e,s));});};e.addEventListener(t,i),r.onHandlers.push({event:t,listener:i});}function processHxOnWildcard(e){deInitOnHandlers(e);for(let t=0;thtmx.config.historyCacheSize;)i.shift();for(;i.length>0;)try{localStorage.setItem("htmx-history-cache",JSON.stringify(i));break}catch(l){triggerErrorEvent(getDocument().body,"htmx:historyCacheError",{cause:l,cache:i}),i.shift();}}function getCachedHistory(e){if(!canAccessLocalStorage())return null;e=normalizePath(e);let t=parseJSON(localStorage.getItem("htmx-history-cache"))||[];for(let n=0;n=200&&this.status<400){triggerEvent(getDocument().body,"htmx:historyCacheMissLoad",n);let r=makeFragment(this.response),o=r.querySelector("[hx-history-elt],[data-hx-history-elt]")||r,i=getHistoryElement(),s=makeSettleInfo(i);handleTitle(r.title),swapInnerHTML(i,o,s),settleImmediately(s.tasks),currentPathForHistory=e,triggerEvent(getDocument().body,"htmx:historyRestore",{path:e,cacheMiss:!0,serverResponse:this.response});}else triggerErrorEvent(getDocument().body,"htmx:historyCacheMissLoadError",n);},t.send();}function restoreHistory(e){saveCurrentPageToHistory(),e=e||location.pathname+location.search;let t=getCachedHistory(e);if(t){let n=makeFragment(t.content),r=getHistoryElement(),o=makeSettleInfo(r);handleTitle(n.title),swapInnerHTML(r,n,o),settleImmediately(o.tasks),getWindow().setTimeout(function(){window.scrollTo(0,t.scroll);},0),currentPathForHistory=e,triggerEvent(getDocument().body,"htmx:historyRestore",{path:e,item:t});}else htmx.config.refreshOnHistoryMiss?window.location.reload(!0):loadHistoryFromServer(e);}function addRequestIndicatorClasses(e){let t=findAttributeTargets(e,"hx-indicator");return t==null&&(t=[e]),forEach(t,function(n){let r=getInternalData(n);r.requestCount=(r.requestCount||0)+1,n.classList.add.call(n.classList,htmx.config.requestClass);}),t}function disableElements(e){let t=findAttributeTargets(e,"hx-disabled-elt");return t==null&&(t=[]),forEach(t,function(n){let r=getInternalData(n);r.requestCount=(r.requestCount||0)+1,n.setAttribute("disabled",""),n.setAttribute("data-disabled-by-htmx","");}),t}function removeRequestIndicators(e,t){forEach(e,function(n){let r=getInternalData(n);r.requestCount=(r.requestCount||0)-1,r.requestCount===0&&n.classList.remove.call(n.classList,htmx.config.requestClass);}),forEach(t,function(n){let r=getInternalData(n);r.requestCount=(r.requestCount||0)-1,r.requestCount===0&&(n.removeAttribute("disabled"),n.removeAttribute("data-disabled-by-htmx"));});}function haveSeenNode(e,t){for(let n=0;nt.indexOf(o)<0):r=r.filter(o=>o!==t),n.delete(e),forEach(r,o=>n.append(e,o));}}function processInputValue(e,t,n,r,o){if(!(r==null||haveSeenNode(e,r))){if(e.push(r),shouldInclude(r)){let i=getRawAttribute(r,"name"),s=r.value;r instanceof HTMLSelectElement&&r.multiple&&(s=toArray(r.querySelectorAll("option:checked")).map(function(l){return l.value})),r instanceof HTMLInputElement&&r.files&&(s=toArray(r.files)),addValueToFormData(i,s,t),o&&validateElement(r,n);}r instanceof HTMLFormElement&&(forEach(r.elements,function(i){e.indexOf(i)>=0?removeValueFromFormData(i.name,i.value,t):e.push(i),o&&validateElement(i,n);}),new FormData(r).forEach(function(i,s){i instanceof File&&i.name===""||addValueToFormData(s,i,t);}));}}function validateElement(e,t){let n=e;n.willValidate&&(triggerEvent(n,"htmx:validation:validate"),n.checkValidity()||(t.push({elt:n,message:n.validationMessage,validity:n.validity}),triggerEvent(n,"htmx:validation:failed",{message:n.validationMessage,validity:n.validity})));}function overrideFormData(e,t){for(let n of t.keys())e.delete(n);return t.forEach(function(n,r){e.append(r,n);}),e}function getInputValues(e,t){let n=[],r=new FormData,o=new FormData,i=[],s=getInternalData(e);s.lastButtonClicked&&!bodyContains(s.lastButtonClicked)&&(s.lastButtonClicked=null);let l=e instanceof HTMLFormElement&&e.noValidate!==!0||getAttributeValue(e,"hx-validate")==="true";if(s.lastButtonClicked&&(l=l&&s.lastButtonClicked.formNoValidate!==!0),t!=="get"&&processInputValue(n,o,i,closest(e,"form"),l),processInputValue(n,r,i,e,l),s.lastButtonClicked||e.tagName==="BUTTON"||e.tagName==="INPUT"&&getRawAttribute(e,"type")==="submit"){let u=s.lastButtonClicked||e,d=getRawAttribute(u,"name");addValueToFormData(d,u.value,o);}let a=findAttributeTargets(e,"hx-include");return forEach(a,function(u){processInputValue(n,r,i,asElement(u),l),matches(u,"form")||forEach(asParentNode(u).querySelectorAll(INPUT_SELECTOR),function(d){processInputValue(n,r,i,d,l);});}),overrideFormData(r,o),{errors:i,formData:r,values:formDataProxy(r)}}function appendParam(e,t,n){e!==""&&(e+="&"),String(n)==="[object Object]"&&(n=JSON.stringify(n));let r=encodeURIComponent(n);return e+=encodeURIComponent(t)+"="+r,e}function urlEncode(e){e=formDataFromObject(e);let t="";return e.forEach(function(n,r){t=appendParam(t,r,n);}),t}function getHeaders(e,t,n){let r={"HX-Request":"true","HX-Trigger":getRawAttribute(e,"id"),"HX-Trigger-Name":getRawAttribute(e,"name"),"HX-Target":getAttributeValue(t,"id"),"HX-Current-URL":getDocument().location.href};return getValuesForElement(e,"hx-headers",!1,r),n!==void 0&&(r["HX-Prompt"]=n),getInternalData(e).boosted&&(r["HX-Boosted"]="true"),r}function filterValues(e,t){let n=getClosestAttributeValue(t,"hx-params");if(n){if(n==="none")return new FormData;if(n==="*")return e;if(n.indexOf("not ")===0)return forEach(n.substr(4).split(","),function(r){r=r.trim(),e.delete(r);}),e;{let r=new FormData;return forEach(n.split(","),function(o){o=o.trim(),e.has(o)&&e.getAll(o).forEach(function(i){r.append(o,i);});}),r}}else return e}function isAnchorLink(e){return !!getRawAttribute(e,"href")&&getRawAttribute(e,"href").indexOf("#")>=0}function getSwapSpecification(e,t){let n=t||getClosestAttributeValue(e,"hx-swap"),r={swapStyle:getInternalData(e).boosted?"innerHTML":htmx.config.defaultSwapStyle,swapDelay:htmx.config.defaultSwapDelay,settleDelay:htmx.config.defaultSettleDelay};if(htmx.config.scrollIntoViewOnBoost&&getInternalData(e).boosted&&!isAnchorLink(e)&&(r.show="top"),n){let s=splitOnWhitespace(n);if(s.length>0)for(let l=0;l0?o.join(":"):null;r.scroll=d,r.scrollTarget=i;}else if(a.indexOf("show:")===0){var o=a.substr(5).split(":");let c=o.pop();var i=o.length>0?o.join(":"):null;r.show=c,r.showTarget=i;}else if(a.indexOf("focus-scroll:")===0){let u=a.substr(13);r.focusScroll=u=="true";}else l==0?r.swapStyle=a:logError("Unknown modifier in hx-swap: "+a);}}return r}function usesFormData(e){return getClosestAttributeValue(e,"hx-encoding")==="multipart/form-data"||matches(e,"form")&&getRawAttribute(e,"enctype")==="multipart/form-data"}function encodeParamsForBody(e,t,n){let r=null;return withExtensions(t,function(o){r==null&&(r=o.encodeParameters(e,n,t));}),r??(usesFormData(t)?overrideFormData(new FormData,formDataFromObject(n)):urlEncode(n))}function makeSettleInfo(e){return {tasks:[],elts:[e]}}function updateScrollState(e,t){let n=e[0],r=e[e.length-1];if(t.scroll){var o=null;t.scrollTarget&&(o=asElement(querySelectorExt(n,t.scrollTarget))),t.scroll==="top"&&(n||o)&&(o=o||n,o.scrollTop=0),t.scroll==="bottom"&&(r||o)&&(o=o||r,o.scrollTop=o.scrollHeight);}if(t.show){var o=null;if(t.showTarget){let s=t.showTarget;t.showTarget==="window"&&(s="body"),o=asElement(querySelectorExt(n,s));}t.show==="top"&&(n||o)&&(o=o||n,o.scrollIntoView({block:"start",behavior:htmx.config.scrollBehavior})),t.show==="bottom"&&(r||o)&&(o=o||r,o.scrollIntoView({block:"end",behavior:htmx.config.scrollBehavior}));}}function getValuesForElement(e,t,n,r){if(r==null&&(r={}),e==null)return r;let o=getAttributeValue(e,t);if(o){let i=o.trim(),s=n;if(i==="unset")return null;i.indexOf("javascript:")===0?(i=i.substr(11),s=!0):i.indexOf("js:")===0&&(i=i.substr(3),s=!0),i.indexOf("{")!==0&&(i="{"+i+"}");let l;s?l=maybeEval(e,function(){return Function("return ("+i+")")()},{}):l=parseJSON(i);for(let a in l)l.hasOwnProperty(a)&&r[a]==null&&(r[a]=l[a]);}return getValuesForElement(asElement(parentElt(e)),t,n,r)}function maybeEval(e,t,n){return htmx.config.allowEval?t():(triggerErrorEvent(e,"htmx:evalDisallowedError"),n)}function getHXVarsForElement(e,t){return getValuesForElement(e,"hx-vars",!0,t)}function getHXValsForElement(e,t){return getValuesForElement(e,"hx-vals",!1,t)}function getExpressionVars(e){return mergeObjects(getHXVarsForElement(e),getHXValsForElement(e))}function safelySetHeaderValue(e,t,n){if(n!==null)try{e.setRequestHeader(t,n);}catch{e.setRequestHeader(t,encodeURIComponent(n)),e.setRequestHeader(t+"-URI-AutoEncoded","true");}}function getPathFromResponse(e){if(e.responseURL&&typeof URL<"u")try{let t=new URL(e.responseURL);return t.pathname+t.search}catch{triggerErrorEvent(getDocument().body,"htmx:badResponseUrl",{url:e.responseURL});}}function hasHeader(e,t){return t.test(e.getAllResponseHeaders())}function ajaxHelper(e,t,n){return e=e.toLowerCase(),n?n instanceof Element||typeof n=="string"?issueAjaxRequest(e,t,null,null,{targetOverride:resolveTarget(n),returnPromise:!0}):issueAjaxRequest(e,t,resolveTarget(n.source),n.event,{handler:n.handler,headers:n.headers,values:n.values,targetOverride:resolveTarget(n.target),swapOverride:n.swap,select:n.select,returnPromise:!0}):issueAjaxRequest(e,t,null,null,{returnPromise:!0})}function hierarchyForElt(e){let t=[];for(;e;)t.push(e),e=e.parentElement;return t}function verifyPath(e,t,n){let r,o;return typeof URL=="function"?(o=new URL(t,document.location.href),r=document.location.origin===o.origin):(o=t,r=startsWith(t,document.location.origin)),htmx.config.selfRequestsOnly&&!r?!1:triggerEvent(e,"htmx:validateUrl",mergeObjects({url:o,sameHost:r},n))}function formDataFromObject(e){if(e instanceof FormData)return e;let t=new FormData;for(let n in e)e.hasOwnProperty(n)&&(typeof e[n].forEach=="function"?e[n].forEach(function(r){t.append(n,r);}):typeof e[n]=="object"&&!(e[n]instanceof Blob)?t.append(n,JSON.stringify(e[n])):t.append(n,e[n]));return t}function formDataArrayProxy(e,t,n){return new Proxy(n,{get:function(r,o){return typeof o=="number"?r[o]:o==="length"?r.length:o==="push"?function(i){r.push(i),e.append(t,i);}:typeof r[o]=="function"?function(){r[o].apply(r,arguments),e.delete(t),r.forEach(function(i){e.append(t,i);});}:r[o]&&r[o].length===1?r[o][0]:r[o]},set:function(r,o,i){return r[o]=i,e.delete(t),r.forEach(function(s){e.append(t,s);}),!0}})}function formDataProxy(e){return new Proxy(e,{get:function(t,n){if(typeof n=="symbol")return Reflect.get(t,n);if(n==="toJSON")return ()=>Object.fromEntries(e);if(n in t)return typeof t[n]=="function"?function(){return e[n].apply(e,arguments)}:t[n];let r=e.getAll(n);if(r.length!==0)return r.length===1?r[0]:formDataArrayProxy(t,n,r)},set:function(t,n,r){return typeof n!="string"?!1:(t.delete(n),typeof r.forEach=="function"?r.forEach(function(o){t.append(n,o);}):typeof r=="object"&&!(r instanceof Blob)?t.append(n,JSON.stringify(r)):t.append(n,r),!0)},deleteProperty:function(t,n){return typeof n=="string"&&t.delete(n),!0},ownKeys:function(t){return Reflect.ownKeys(Object.fromEntries(t))},getOwnPropertyDescriptor:function(t,n){return Reflect.getOwnPropertyDescriptor(Object.fromEntries(t),n)}})}function issueAjaxRequest(e,t,n,r,o,i){let s=null,l=null;if(o=o??{},o.returnPromise&&typeof Promise<"u")var a=new Promise(function(g,E){s=g,l=E;});n==null&&(n=getDocument().body);let u=o.handler||handleAjaxResponse,d=o.select||null;if(!bodyContains(n))return maybeCall(s),a;let c=o.targetOverride||asElement(getTarget(n));if(c==null||c==DUMMY_ELT)return triggerErrorEvent(n,"htmx:targetError",{target:getAttributeValue(n,"hx-target")}),maybeCall(l),a;let h=getInternalData(n),b=h.lastButtonClicked;if(b){let g=getRawAttribute(b,"formaction");g!=null&&(t=g);let E=getRawAttribute(b,"formmethod");E!=null&&E.toLowerCase()!=="dialog"&&(e=E);}let S=getClosestAttributeValue(n,"hx-confirm");if(i===void 0&&triggerEvent(n,"htmx:confirm",{target:c,elt:n,path:t,verb:e,triggeringEvent:r,etc:o,issueRequest:function(O){return issueAjaxRequest(e,t,n,r,o,!!O)},question:S})===!1)return maybeCall(s),a;let A=n,p=getClosestAttributeValue(n,"hx-sync"),x=null,T=!1;if(p){let g=p.split(":"),E=g[0].trim();if(E==="this"?A=findThisElement(n,"hx-sync"):A=asElement(querySelectorExt(n,E)),p=(g[1]||"drop").trim(),h=getInternalData(A),p==="drop"&&h.xhr&&h.abortable!==!0)return maybeCall(s),a;if(p==="abort"){if(h.xhr)return maybeCall(s),a;T=!0;}else p==="replace"?triggerEvent(A,"htmx:abort"):p.indexOf("queue")===0&&(x=(p.split(" ")[1]||"last").trim());}if(h.xhr)if(h.abortable)triggerEvent(A,"htmx:abort");else {if(x==null){if(r){let g=getInternalData(r);g&&g.triggerSpec&&g.triggerSpec.queue&&(x=g.triggerSpec.queue);}x==null&&(x="last");}return h.queuedRequests==null&&(h.queuedRequests=[]),x==="first"&&h.queuedRequests.length===0?h.queuedRequests.push(function(){issueAjaxRequest(e,t,n,r,o);}):x==="all"?h.queuedRequests.push(function(){issueAjaxRequest(e,t,n,r,o);}):x==="last"&&(h.queuedRequests=[],h.queuedRequests.push(function(){issueAjaxRequest(e,t,n,r,o);})),maybeCall(s),a}let m=new XMLHttpRequest;h.xhr=m,h.abortable=T;let H=function(){h.xhr=null,h.abortable=!1,h.queuedRequests!=null&&h.queuedRequests.length>0&&h.queuedRequests.shift()();},N=getClosestAttributeValue(n,"hx-prompt");if(N){var I=prompt(N);if(I===null||!triggerEvent(n,"htmx:prompt",{prompt:I,target:c}))return maybeCall(s),H(),a}if(S&&!i&&!confirm(S))return maybeCall(s),H(),a;let R=getHeaders(n,c,I);e!=="get"&&!usesFormData(n)&&(R["Content-Type"]="application/x-www-form-urlencoded"),o.headers&&(R=mergeObjects(R,o.headers));let v=getInputValues(n,e),q=v.errors,F=v.formData;o.values&&overrideFormData(F,formDataFromObject(o.values));let _=formDataFromObject(getExpressionVars(n)),W=overrideFormData(F,_),L=filterValues(W,n);htmx.config.getCacheBusterParam&&e==="get"&&L.set("org.htmx.cache-buster",getRawAttribute(c,"id")||"true"),(t==null||t==="")&&(t=getDocument().location.href);let X=getValuesForElement(n,"hx-request"),Y=getInternalData(n).boosted,M=htmx.config.methodsThatUseUrlParams.indexOf(e)>=0,w={boosted:Y,useUrlParams:M,formData:L,parameters:formDataProxy(L),unfilteredFormData:W,unfilteredParameters:formDataProxy(W),headers:R,target:c,verb:e,errors:q,withCredentials:o.credentials||X.credentials||htmx.config.withCredentials,timeout:o.timeout||X.timeout||htmx.config.timeout,path:t,triggeringEvent:r};if(!triggerEvent(n,"htmx:configRequest",w))return maybeCall(s),H(),a;if(t=w.path,e=w.verb,R=w.headers,L=formDataFromObject(w.parameters),q=w.errors,M=w.useUrlParams,q&&q.length>0)return triggerEvent(n,"htmx:validation:halted",w),maybeCall(s),H(),a;let G=t.split("#"),Z=G[0],j=G[1],D=t;if(M&&(D=Z,!L.keys().next().done&&(D.indexOf("?")<0?D+="?":D+="&",D+=urlEncode(L),j&&(D+="#"+j))),!verifyPath(n,D,w))return triggerErrorEvent(n,"htmx:invalidPath",w),maybeCall(l),a;if(m.open(e.toUpperCase(),D,!0),m.overrideMimeType("text/html"),m.withCredentials=w.withCredentials,m.timeout=w.timeout,!X.noHeaders){for(let g in R)if(R.hasOwnProperty(g)){let E=R[g];safelySetHeaderValue(m,g,E);}}let y={xhr:m,target:c,requestConfig:w,etc:o,boosted:Y,select:d,pathInfo:{requestPath:t,finalRequestPath:D,responsePath:null,anchor:j}};if(m.onload=function(){try{let g=hierarchyForElt(n);if(y.pathInfo.responsePath=getPathFromResponse(m),u(n,y),y.keepIndicators!==!0&&removeRequestIndicators(V,k),triggerEvent(n,"htmx:afterRequest",y),triggerEvent(n,"htmx:afterOnLoad",y),!bodyContains(n)){let E=null;for(;g.length>0&&E==null;){let O=g.shift();bodyContains(O)&&(E=O);}E&&(triggerEvent(E,"htmx:afterRequest",y),triggerEvent(E,"htmx:afterOnLoad",y));}maybeCall(s),H();}catch(g){throw triggerErrorEvent(n,"htmx:onLoadError",mergeObjects({error:g},y)),g}},m.onerror=function(){removeRequestIndicators(V,k),triggerErrorEvent(n,"htmx:afterRequest",y),triggerErrorEvent(n,"htmx:sendError",y),maybeCall(l),H();},m.onabort=function(){removeRequestIndicators(V,k),triggerErrorEvent(n,"htmx:afterRequest",y),triggerErrorEvent(n,"htmx:sendAbort",y),maybeCall(l),H();},m.ontimeout=function(){removeRequestIndicators(V,k),triggerErrorEvent(n,"htmx:afterRequest",y),triggerErrorEvent(n,"htmx:timeout",y),maybeCall(l),H();},!triggerEvent(n,"htmx:beforeRequest",y))return maybeCall(s),H(),a;var V=addRequestIndicatorClasses(n),k=disableElements(n);forEach(["loadstart","loadend","progress","abort"],function(g){forEach([m,m.upload],function(E){E.addEventListener(g,function(O){triggerEvent(n,"htmx:xhr:"+g,{lengthComputable:O.lengthComputable,loaded:O.loaded,total:O.total});});});}),triggerEvent(n,"htmx:beforeSend",y);let ee=M?null:encodeParamsForBody(m,n,L);return m.send(ee),a}function determineHistoryUpdates(e,t){let n=t.xhr,r=null,o=null;if(hasHeader(n,/HX-Push:/i)?(r=n.getResponseHeader("HX-Push"),o="push"):hasHeader(n,/HX-Push-Url:/i)?(r=n.getResponseHeader("HX-Push-Url"),o="push"):hasHeader(n,/HX-Replace-Url:/i)&&(r=n.getResponseHeader("HX-Replace-Url"),o="replace"),r)return r==="false"?{}:{type:o,path:r};let i=t.pathInfo.finalRequestPath,s=t.pathInfo.responsePath,l=getClosestAttributeValue(e,"hx-push-url"),a=getClosestAttributeValue(e,"hx-replace-url"),u=getInternalData(e).boosted,d=null,c=null;return l?(d="push",c=l):a?(d="replace",c=a):u&&(d="push",c=s||i),c?c==="false"?{}:(c==="true"&&(c=s||i),t.pathInfo.anchor&&c.indexOf("#")===-1&&(c=c+"#"+t.pathInfo.anchor),{type:d,path:c}):{}}function codeMatches(e,t){var n=new RegExp(e.code);return n.test(t.toString(10))}function resolveResponseHandling(e){for(var t=0;t0?getWindow().setTimeout(I,x.swapDelay):I();}c&&triggerErrorEvent(e,"htmx:responseError",mergeObjects({error:"Response Status Error Code "+n.status+" from "+t.pathInfo.requestPath},t));}}let extensions={};function extensionBase(){return {init:function(e){return null},getSelectors:function(){return null},onEvent:function(e,t){return !0},transformResponse:function(e,t,n){return e},isInlineSwap:function(e){return !1},handleSwap:function(e,t,n,r){return !1},encodeParameters:function(e,t,n){return null}}}function defineExtension(e,t){t.init&&t.init(internalAPI),extensions[e]=mergeObjects(extensionBase(),t);}function removeExtension(e){delete extensions[e];}function getExtensions(e,t,n){if(t==null&&(t=[]),e==null)return t;n==null&&(n=[]);let r=getAttributeValue(e,"hx-ext");return r&&forEach(r.split(","),function(o){if(o=o.replace(/ /g,""),o.slice(0,7)=="ignore:"){n.push(o.slice(7));return}if(n.indexOf(o)<0){let i=extensions[o];i&&t.indexOf(i)<0&&t.push(i);}}),getExtensions(asElement(parentElt(e)),t,n)}var isReady=!1;getDocument().addEventListener("DOMContentLoaded",function(){isReady=!0;});function ready(e){isReady||getDocument().readyState==="complete"?e():getDocument().addEventListener("DOMContentLoaded",e);}function insertIndicatorStyles(){if(htmx.config.includeIndicatorStyles!==!1){let e=htmx.config.inlineStyleNonce?` nonce="${htmx.config.inlineStyleNonce}"`:"";getDocument().head.insertAdjacentHTML("beforeend"," ."+htmx.config.indicatorClass+"{opacity:0} ."+htmx.config.requestClass+" ."+htmx.config.indicatorClass+"{opacity:1; transition: opacity 200ms ease-in;} ."+htmx.config.requestClass+"."+htmx.config.indicatorClass+"{opacity:1; transition: opacity 200ms ease-in;} ");}}function getMetaConfig(){let e=getDocument().querySelector('meta[name="htmx-config"]');return e?parseJSON(e.content):null}function mergeMetaConfig(){let e=getMetaConfig();e&&(htmx.config=mergeObjects(htmx.config,e));}return ready(function(){mergeMetaConfig(),insertIndicatorStyles();let e=getDocument().body;processNode(e);let t=getDocument().querySelectorAll("[hx-trigger='restored'],[data-hx-trigger='restored']");e.addEventListener("htmx:abort",function(r){let o=r.target,i=getInternalData(o);i&&i.xhr&&i.xhr.abort();});let n=window.onpopstate?window.onpopstate.bind(window):null;window.onpopstate=function(r){r.state&&r.state.htmx?(restoreHistory(),forEach(t,function(o){triggerEvent(o,"htmx:restored",{document:getDocument(),triggerEvent});})):n&&n(r);},getWindow().setTimeout(function(){triggerEvent(e,"htmx:load",{}),e=null;},0);}),htmx}(),f=te;function ne(e,t){if(e==="ignore")return !1;let n=e.split("/"),r=t.split("/");for(let o=0;o{let s=oe(t).replace("htmx:","hx-on::");r.has(o)||(o.hasAttribute(s)&&setTimeout(()=>{let l=se(s.replace("hx-on::","htmx:"),{...n.detail,target:o});l.detail.meta="trigger-children",o.dispatchEvent(l),r.add(o);},1),o.children&&$(o,t,n,r));});}f.defineExtension("trigger-children",{onEvent:(e,t)=>{if(!(t instanceof CustomEvent)||t.detail.meta==="trigger-children")return !1;let n=new Set,r=t.target||t.detail.target;return $(r,e,t,n),!0}});f.defineExtension("debug",{onEvent:function(e,t){console.debug?console.debug(e,t):console&&console.log("DEBUG:",e,t);}});var C=f.config,B,ae="hx-target-";function Q(e,t){return e.substring(0,t.length)===t}function le(e,t){if(!e||!t)return null;let n=t.toString(),r=[n,n.substr(0,2)+"*",n.substr(0,2)+"x",n.substr(0,1)+"*",n.substr(0,1)+"x",n.substr(0,1)+"**",n.substr(0,1)+"xx","*","x","***","xxx"];(Q(n,"4")||Q(n,"5"))&&r.push("error");for(let o=0;o{B=e,C.responseTargetUnsetsError===void 0&&(C.responseTargetUnsetsError=!0),C.responseTargetSetsError===void 0&&(C.responseTargetSetsError=!1),C.responseTargetPrefersExisting===void 0&&(C.responseTargetPrefersExisting=!1),C.responseTargetPrefersRetargetHeader===void 0&&(C.responseTargetPrefersRetargetHeader=!0);},onEvent:(e,t)=>{if(!(t instanceof CustomEvent))return !1;if(e==="htmx:beforeSwap"&&t.detail.xhr&&t.detail.xhr.status!==200){if(t.detail.target&&(C.responseTargetPrefersExisting||C.responseTargetPrefersRetargetHeader&&t.detail.xhr.getAllResponseHeaders().match(/HX-Retarget:/i)))return t.detail.shouldSwap=!0,z(t),!0;if(!t.detail.requestConfig)return !0;let n=le(t.detail.requestConfig.elt,t.detail.xhr.status);return n&&(z(t),t.detail.shouldSwap=!0,t.detail.target=n),!0}}});f.defineExtension("mutation-error",{onEvent:(e,t)=>{if(!(t instanceof CustomEvent))return !1;if(e==="htmx:afterRequest"){if(!t.detail||!t.detail.xhr)return;let n=t.detail.xhr.status;n>=400&&f.findAll("[hx-on\\:\\:mutation-error]").forEach(r=>{f.trigger(r,"htmx:mutation-error",{status:n});});}}});var U="";f.defineExtension("livereload",{init:function(){let e=!1;for(let n of Array.from(f.findAll("[hx-ext]")))if(n.getAttribute("hx-ext")?.split(" ").includes("livereload")){e=!0;break}if(!e)return;console.log("livereload extension initialized.");let t=new EventSource("/dev/livereload");t.onmessage=function(n){let r=n.data;U===""&&(U=r),U!==r&&(U=r,ue());},t.onerror=function(n){console.error("EventSource error:",n);};},onEvent:function(e,t){}});function ue(){window.location.reload();}var ce=/__eval_[A-Za-z0-9]+\([a-z]+\)/gm;f.defineExtension("htmgo",{onEvent:function(e,t){e==="htmx:beforeCleanupElement"&&t.target&&J(t.target);}});function J(e){let t=Array.from(e.attributes);for(let n of t){let r=n.value.match(ce)||[];for(let o of r){let i=o.replace("()","").replace("(this)","").replace(";",""),s=document.getElementById(i);s&&s.tagName==="SCRIPT"&&(console.debug("removing associated script with id",i),s.remove());}}}var P=null,K=new Set;f.defineExtension("sse",{init:function(e){P=e;},onEvent:function(e,t){let n=t.target;if(n instanceof HTMLElement&&(e==="htmx:beforeCleanupElement"&&J(n),e==="htmx:beforeProcessNode")){let r=document.querySelectorAll("[sse-connect]");for(let o of Array.from(r)){let i=o.getAttribute("sse-connect");i&&!K.has(i)&&(fe(o,i),K.add(i));}}}});function fe(e,t){if(!t)return;console.info("Connecting to EventSource",t);let n=new EventSource(t);n.addEventListener("close",function(r){f.trigger(e,"htmx:sseClose",{event:r});}),n.onopen=function(r){f.trigger(e,"htmx:sseOpen",{event:r});},n.onerror=function(r){f.trigger(e,"htmx:sseError",{event:r}),n.readyState==EventSource.CLOSED&&f.trigger(e,"htmx:sseClose",{event:r});},n.onmessage=function(r){let o=P.makeSettleInfo(e);f.trigger(e,"htmx:sseBeforeMessage",{event:r});let i=r.data,s=P.makeFragment(i),l=Array.from(s.children);for(let a of l)P.oobSwap(P.getAttributeValue(a,"hx-swap-oob")||"true",a,o),a.tagName==="SCRIPT"&&a.id.startsWith("__eval")&&document.body.appendChild(a);f.trigger(e,"htmx:sseAfterMessage",{event:r});};}window.onload=function(){let e=["SCRIPT","LINK","STYLE","META","BASE","TITLE","HEAD","HTML","BODY"];for(let t of Array.from(document.querySelectorAll("[onload]")))if(t!=null&&t instanceof HTMLElement){if(e.includes(t.tagName))continue;t.onload(new Event("load"));}};window.htmx=f;function de(e){let t=window.location.href;setInterval(()=>{window.location.href!==t&&(e(t,window.location.href),t=window.location.href);},100);}de((e,t)=>{he(t);});function he(e){let t=new URL(e);document.querySelectorAll("[hx-trigger]").forEach(function(n){let r=n.getAttribute("hx-trigger");if(!r)return;if(r.split(", ").find(i=>i==="url"))f.swap(n,"url",{swapStyle:"outerHTML",swapDelay:0,settleDelay:0});else for(let[i,s]of t.searchParams){let l="qs:"+i;if(r.includes(l)){console.log("triggering",l),f.trigger(n,l,null);break}}}),document.querySelectorAll("[hx-match-qp]").forEach(n=>{let r=!1;for(let o of n.getAttributeNames())if(o.startsWith("hx-match-qp-mapping:")){let i=o.replace("hx-match-qp-mapping:","");if(t.searchParams.get(i)){f.swap(n,n.getAttribute(o)??"",{swapStyle:"innerHTML",swapDelay:0,settleDelay:0}),r=!0;break}}if(!r){let o=n.getAttribute("hx-match-qp-default");o&&f.swap(n,n.getAttribute("hx-match-qp-mapping:"+o)??"",{swapStyle:"innerHTML",swapDelay:0,settleDelay:0});}});} //# sourceMappingURL=htmgo.js.map -//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../js/node_modules/htmx.org/dist/htmx.esm.js","../js/htmxextensions/pathdeps.ts","../js/htmxextensions/trigger-children.ts","../js/htmxextensions/debug.ts","../js/htmxextensions/response-targets.ts","../js/htmxextensions/mutation-error.ts","../js/htmxextensions/livereload.ts","../js/htmxextensions/htmgo.ts","../js/htmxextensions/sse.ts","../js/htmgo.ts"],"names":["htmx","elt","type","verb","tag","global","str","interval","name","qualifiedName","parent","condition","initialElement","ancestor","attributeName","attributeValue","disinherit","inherit","closestAttr","e","selector","matchesFunction","match","resp","fragment","script","newScript","attr","response","responseWithNoHead","startTag","doc","titleElement","func","o","dataProp","data","arr","returnArr","i","el","rect","elemTop","elemBottom","rootNode","trigger","obj1","obj2","key","jString","error","test","path","url","callback","evt","event","eltOrSelector","delay","value","clazz","node","child","prefix","suffix","trimmedSelector","start","results","context","arg1","arg2","arg3","eventArgs","attrName","attrTarget","result","attribute","targetStr","attributesToSettle","mergeTo","mergeFrom","swapStyle","target","extensions","extension","oobValue","oobElement","settleInfo","targets","oobElementClone","beforeSwapDetails","preservedElt","id","oldElt","parentNode","newNode","normalizedId","normalizedTag","parentElt","oldNode","newAttributes","autofocus","autoFocusedElt","insertBefore","string","hash","char","internalData","handlerInfo","element","info","newElt","eltBeforeNewContent","firstChild","ext","newElements","j","oobElts","content","swapSpec","swapOptions","activeElt","selectionInfo","oobSelectValues","oobSelectValue","template","newFragment","newActiveElt","focusOptions","doSettle","task","anchorTarget","xhr","header","triggerBody","triggers","eventName","detail","eventNames","tokens","position","startPosition","startChar","symbol","token","last","paramName","bracketCount","conditionalSource","conditionFunction","explicitTrigger","cache","triggerSpecs","initialLength","every","eventFilter","triggerSpec","from_arg","handler","spec","nodeData","rawAttribute","source","explicitCancel","elementData","eltsToListenOn","eltToListenOn","eltToListenOnData","eventListener","eventData","load","explicitAction","observerOptions","entries","attributes","elements","iter","boostedSelector","extensionSelectors","selectors","s","form","code","listener","afterOnPosition","nextChar","toDo","msg","eventResult","kebabName","kebabedEvent","rootElt","innerHTML","title","scroll","historyCache","newHistoryItem","className","clone","disableHistoryCache","tasks","request","details","historyElement","cached","indicators","ic","disabledElts","disabledElement","disabled","processed","formData","v","values","errors","validate","input","receiver","donor","priorityFormData","button","includes","descendant","returnStr","realValue","prompt","headers","inputValues","paramsValue","newValues","swapInfoOverride","swapInfo","split","splitSpec","scrollVal","selectorVal","showVal","focusScrollVal","filteredParameters","encodedParameters","first","evalAsDefault","evaluateValue","varsValues","toEval","defaultVal","expressionVars","headerValue","regexp","requestConfig","sameHost","obj","array","index","prop","etc","confirmed","resolve","reject","promise","_resolve","_reject","responseHandler","select","eltData","submitter","buttonPath","buttonVerb","confirmQuestion","skipConfirmation","syncElt","syncStrategy","queueStrategy","abortable","syncStrings","endRequestLock","promptQuestion","promptResponse","rawFormData","allFormData","filteredFormData","requestAttrValues","eltIsBoosted","useUrlParams","splitPath","pathNoAnchor","anchor","finalPath","responseInfo","hierarchy","disableElts","secondaryTriggerElt","parentEltInHierarchy","params","pathFromHeaders","typeFromHeaders","requestPath","responsePath","pushUrl","replaceUrl","elementIsBoosted","saveType","responseHandlingConfig","status","regExp","responseHandlingElement","titleElt","responseInfoSelect","redirectPath","redirectSwapSpec","shouldRefresh","historyUpdate","responseHandling","shouldSwap","isError","ignoreTitle","selectOverride","swapOverride","serverResponse","settleResolve","settleReject","selectOOB","doSwap","finalElt","shouldTransition","settlePromise","innerDoSwap","api","text","parameters","extensionsToReturn","extensionsToIgnore","extensionsForElement","extensionName","fn","nonceAttribute","metaConfig","body","restoredElts","originalPopstate","htmx_esm_default","dependsOn","pathSpec","dependencyPath","urlPath","dependencyElement","pathElement","refreshPath","eltsWithDeps","config","kebabEventName","ignoredEvents","makeEvent","triggerChildren","triggered","newEvent","attrPrefix","startsWith","getRespCodeTarget","respCodeNumber","respCode","attrPossibilities","attrValue","handleErrorFlag","apiRef","lastVersion","enabled","eventSource","message","reload","evalFuncRegex","removeAssociatedScripts","matches","ele","connectEventSource","children","watchUrl","lastUrl","_","newUrl","onUrlChange","hasMatch","defaultKey"],"mappings":"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","file":"htmgo.js","sourcesContent":["var htmx = (function() {\n  'use strict'\n\n  // Public API\n  const htmx = {\n    // Tsc madness here, assigning the functions directly results in an invalid TypeScript output, but reassigning is fine\n    /* Event processing */\n    /** @type {typeof onLoadHelper} */\n    onLoad: null,\n    /** @type {typeof processNode} */\n    process: null,\n    /** @type {typeof addEventListenerImpl} */\n    on: null,\n    /** @type {typeof removeEventListenerImpl} */\n    off: null,\n    /** @type {typeof triggerEvent} */\n    trigger: null,\n    /** @type {typeof ajaxHelper} */\n    ajax: null,\n    /* DOM querying helpers */\n    /** @type {typeof find} */\n    find: null,\n    /** @type {typeof findAll} */\n    findAll: null,\n    /** @type {typeof closest} */\n    closest: null,\n    /**\n     * Returns the input values that would resolve for a given element via the htmx value resolution mechanism\n     *\n     * @see https://htmx.org/api/#values\n     *\n     * @param {Element} elt the element to resolve values on\n     * @param {HttpVerb} type the request type (e.g. **get** or **post**) non-GET's will include the enclosing form of the element. Defaults to **post**\n     * @returns {Object}\n     */\n    values: function(elt, type) {\n      const inputValues = getInputValues(elt, type || 'post')\n      return inputValues.values\n    },\n    /* DOM manipulation helpers */\n    /** @type {typeof removeElement} */\n    remove: null,\n    /** @type {typeof addClassToElement} */\n    addClass: null,\n    /** @type {typeof removeClassFromElement} */\n    removeClass: null,\n    /** @type {typeof toggleClassOnElement} */\n    toggleClass: null,\n    /** @type {typeof takeClassForElement} */\n    takeClass: null,\n    /** @type {typeof swap} */\n    swap: null,\n    /* Extension entrypoints */\n    /** @type {typeof defineExtension} */\n    defineExtension: null,\n    /** @type {typeof removeExtension} */\n    removeExtension: null,\n    /* Debugging */\n    /** @type {typeof logAll} */\n    logAll: null,\n    /** @type {typeof logNone} */\n    logNone: null,\n    /* Debugging */\n    /**\n     * The logger htmx uses to log with\n     *\n     * @see https://htmx.org/api/#logger\n     */\n    logger: null,\n    /**\n     * A property holding the configuration htmx uses at runtime.\n     *\n     * Note that using a [meta tag](https://htmx.org/docs/#config) is the preferred mechanism for setting these properties.\n     *\n     * @see https://htmx.org/api/#config\n     */\n    config: {\n      /**\n       * Whether to use history.\n       * @type boolean\n       * @default true\n       */\n      historyEnabled: true,\n      /**\n       * The number of pages to keep in **localStorage** for history support.\n       * @type number\n       * @default 10\n       */\n      historyCacheSize: 10,\n      /**\n       * @type boolean\n       * @default false\n       */\n      refreshOnHistoryMiss: false,\n      /**\n       * The default swap style to use if **[hx-swap](https://htmx.org/attributes/hx-swap)** is omitted.\n       * @type HtmxSwapStyle\n       * @default 'innerHTML'\n       */\n      defaultSwapStyle: 'innerHTML',\n      /**\n       * The default delay between receiving a response from the server and doing the swap.\n       * @type number\n       * @default 0\n       */\n      defaultSwapDelay: 0,\n      /**\n       * The default delay between completing the content swap and settling attributes.\n       * @type number\n       * @default 20\n       */\n      defaultSettleDelay: 20,\n      /**\n       * If true, htmx will inject a small amount of CSS into the page to make indicators invisible unless the **htmx-indicator** class is present.\n       * @type boolean\n       * @default true\n       */\n      includeIndicatorStyles: true,\n      /**\n       * The class to place on indicators when a request is in flight.\n       * @type string\n       * @default 'htmx-indicator'\n       */\n      indicatorClass: 'htmx-indicator',\n      /**\n       * The class to place on triggering elements when a request is in flight.\n       * @type string\n       * @default 'htmx-request'\n       */\n      requestClass: 'htmx-request',\n      /**\n       * The class to temporarily place on elements that htmx has added to the DOM.\n       * @type string\n       * @default 'htmx-added'\n       */\n      addedClass: 'htmx-added',\n      /**\n       * The class to place on target elements when htmx is in the settling phase.\n       * @type string\n       * @default 'htmx-settling'\n       */\n      settlingClass: 'htmx-settling',\n      /**\n       * The class to place on target elements when htmx is in the swapping phase.\n       * @type string\n       * @default 'htmx-swapping'\n       */\n      swappingClass: 'htmx-swapping',\n      /**\n       * Allows the use of eval-like functionality in htmx, to enable **hx-vars**, trigger conditions & script tag evaluation. Can be set to **false** for CSP compatibility.\n       * @type boolean\n       * @default true\n       */\n      allowEval: true,\n      /**\n       * If set to false, disables the interpretation of script tags.\n       * @type boolean\n       * @default true\n       */\n      allowScriptTags: true,\n      /**\n       * If set, the nonce will be added to inline scripts.\n       * @type string\n       * @default ''\n       */\n      inlineScriptNonce: '',\n      /**\n       * If set, the nonce will be added to inline styles.\n       * @type string\n       * @default ''\n       */\n      inlineStyleNonce: '',\n      /**\n       * The attributes to settle during the settling phase.\n       * @type string[]\n       * @default ['class', 'style', 'width', 'height']\n       */\n      attributesToSettle: ['class', 'style', 'width', 'height'],\n      /**\n       * Allow cross-site Access-Control requests using credentials such as cookies, authorization headers or TLS client certificates.\n       * @type boolean\n       * @default false\n       */\n      withCredentials: false,\n      /**\n       * @type number\n       * @default 0\n       */\n      timeout: 0,\n      /**\n       * The default implementation of **getWebSocketReconnectDelay** for reconnecting after unexpected connection loss by the event code **Abnormal Closure**, **Service Restart** or **Try Again Later**.\n       * @type {'full-jitter' | ((retryCount:number) => number)}\n       * @default \"full-jitter\"\n       */\n      wsReconnectDelay: 'full-jitter',\n      /**\n       * The type of binary data being received over the WebSocket connection\n       * @type BinaryType\n       * @default 'blob'\n       */\n      wsBinaryType: 'blob',\n      /**\n       * @type string\n       * @default '[hx-disable], [data-hx-disable]'\n       */\n      disableSelector: '[hx-disable], [data-hx-disable]',\n      /**\n       * @type {'auto' | 'instant' | 'smooth'}\n       * @default 'instant'\n       */\n      scrollBehavior: 'instant',\n      /**\n       * If the focused element should be scrolled into view.\n       * @type boolean\n       * @default false\n       */\n      defaultFocusScroll: false,\n      /**\n       * If set to true htmx will include a cache-busting parameter in GET requests to avoid caching partial responses by the browser\n       * @type boolean\n       * @default false\n       */\n      getCacheBusterParam: false,\n      /**\n       * If set to true, htmx will use the View Transition API when swapping in new content.\n       * @type boolean\n       * @default false\n       */\n      globalViewTransitions: false,\n      /**\n       * htmx will format requests with these methods by encoding their parameters in the URL, not the request body\n       * @type {(HttpVerb)[]}\n       * @default ['get', 'delete']\n       */\n      methodsThatUseUrlParams: ['get', 'delete'],\n      /**\n       * If set to true, disables htmx-based requests to non-origin hosts.\n       * @type boolean\n       * @default false\n       */\n      selfRequestsOnly: true,\n      /**\n       * If set to true htmx will not update the title of the document when a title tag is found in new content\n       * @type boolean\n       * @default false\n       */\n      ignoreTitle: false,\n      /**\n       * Whether the target of a boosted element is scrolled into the viewport.\n       * @type boolean\n       * @default true\n       */\n      scrollIntoViewOnBoost: true,\n      /**\n       * The cache to store evaluated trigger specifications into.\n       * You may define a simple object to use a never-clearing cache, or implement your own system using a [proxy object](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Proxy)\n       * @type {Object|null}\n       * @default null\n       */\n      triggerSpecsCache: null,\n      /** @type boolean */\n      disableInheritance: false,\n      /** @type HtmxResponseHandlingConfig[] */\n      responseHandling: [\n        { code: '204', swap: false },\n        { code: '[23]..', swap: true },\n        { code: '[45]..', swap: false, error: true }\n      ],\n      /**\n       * Whether to process OOB swaps on elements that are nested within the main response element.\n       * @type boolean\n       * @default true\n       */\n      allowNestedOobSwaps: true\n    },\n    /** @type {typeof parseInterval} */\n    parseInterval: null,\n    /** @type {typeof internalEval} */\n    _: null,\n    version: '2.0.2'\n  }\n  // Tsc madness part 2\n  htmx.onLoad = onLoadHelper\n  htmx.process = processNode\n  htmx.on = addEventListenerImpl\n  htmx.off = removeEventListenerImpl\n  htmx.trigger = triggerEvent\n  htmx.ajax = ajaxHelper\n  htmx.find = find\n  htmx.findAll = findAll\n  htmx.closest = closest\n  htmx.remove = removeElement\n  htmx.addClass = addClassToElement\n  htmx.removeClass = removeClassFromElement\n  htmx.toggleClass = toggleClassOnElement\n  htmx.takeClass = takeClassForElement\n  htmx.swap = swap\n  htmx.defineExtension = defineExtension\n  htmx.removeExtension = removeExtension\n  htmx.logAll = logAll\n  htmx.logNone = logNone\n  htmx.parseInterval = parseInterval\n  htmx._ = internalEval\n\n  const internalAPI = {\n    addTriggerHandler,\n    bodyContains,\n    canAccessLocalStorage,\n    findThisElement,\n    filterValues,\n    swap,\n    hasAttribute,\n    getAttributeValue,\n    getClosestAttributeValue,\n    getClosestMatch,\n    getExpressionVars,\n    getHeaders,\n    getInputValues,\n    getInternalData,\n    getSwapSpecification,\n    getTriggerSpecs,\n    getTarget,\n    makeFragment,\n    mergeObjects,\n    makeSettleInfo,\n    oobSwap,\n    querySelectorExt,\n    settleImmediately,\n    shouldCancel,\n    triggerEvent,\n    triggerErrorEvent,\n    withExtensions\n  }\n\n  const VERBS = ['get', 'post', 'put', 'delete', 'patch']\n  const VERB_SELECTOR = VERBS.map(function(verb) {\n    return '[hx-' + verb + '], [data-hx-' + verb + ']'\n  }).join(', ')\n\n  const HEAD_TAG_REGEX = makeTagRegEx('head')\n\n  //= ===================================================================\n  // Utilities\n  //= ===================================================================\n\n  /**\n   * @param {string} tag\n   * @param {boolean} global\n   * @returns {RegExp}\n   */\n  function makeTagRegEx(tag, global = false) {\n    return new RegExp(`<${tag}(\\\\s[^>]*>|>)([\\\\s\\\\S]*?)<\\\\/${tag}>`,\n      global ? 'gim' : 'im')\n  }\n\n  /**\n   * Parses an interval string consistent with the way htmx does. Useful for plugins that have timing-related attributes.\n   *\n   * Caution: Accepts an int followed by either **s** or **ms**. All other values use **parseFloat**\n   *\n   * @see https://htmx.org/api/#parseInterval\n   *\n   * @param {string} str timing string\n   * @returns {number|undefined}\n   */\n  function parseInterval(str) {\n    if (str == undefined) {\n      return undefined\n    }\n\n    let interval = NaN\n    if (str.slice(-2) == 'ms') {\n      interval = parseFloat(str.slice(0, -2))\n    } else if (str.slice(-1) == 's') {\n      interval = parseFloat(str.slice(0, -1)) * 1000\n    } else if (str.slice(-1) == 'm') {\n      interval = parseFloat(str.slice(0, -1)) * 1000 * 60\n    } else {\n      interval = parseFloat(str)\n    }\n    return isNaN(interval) ? undefined : interval\n  }\n\n  /**\n   * @param {Node} elt\n   * @param {string} name\n   * @returns {(string | null)}\n   */\n  function getRawAttribute(elt, name) {\n    return elt instanceof Element && elt.getAttribute(name)\n  }\n\n  /**\n   * @param {Element} elt\n   * @param {string} qualifiedName\n   * @returns {boolean}\n   */\n  // resolve with both hx and data-hx prefixes\n  function hasAttribute(elt, qualifiedName) {\n    return !!elt.hasAttribute && (elt.hasAttribute(qualifiedName) ||\n      elt.hasAttribute('data-' + qualifiedName))\n  }\n\n  /**\n   *\n   * @param {Node} elt\n   * @param {string} qualifiedName\n   * @returns {(string | null)}\n   */\n  function getAttributeValue(elt, qualifiedName) {\n    return getRawAttribute(elt, qualifiedName) || getRawAttribute(elt, 'data-' + qualifiedName)\n  }\n\n  /**\n   * @param {Node} elt\n   * @returns {Node | null}\n   */\n  function parentElt(elt) {\n    const parent = elt.parentElement\n    if (!parent && elt.parentNode instanceof ShadowRoot) return elt.parentNode\n    return parent\n  }\n\n  /**\n   * @returns {Document}\n   */\n  function getDocument() {\n    return document\n  }\n\n  /**\n   * @param {Node} elt\n   * @param {boolean} global\n   * @returns {Node|Document}\n   */\n  function getRootNode(elt, global) {\n    return elt.getRootNode ? elt.getRootNode({ composed: global }) : getDocument()\n  }\n\n  /**\n   * @param {Node} elt\n   * @param {(e:Node) => boolean} condition\n   * @returns {Node | null}\n   */\n  function getClosestMatch(elt, condition) {\n    while (elt && !condition(elt)) {\n      elt = parentElt(elt)\n    }\n\n    return elt || null\n  }\n\n  /**\n   * @param {Element} initialElement\n   * @param {Element} ancestor\n   * @param {string} attributeName\n   * @returns {string|null}\n   */\n  function getAttributeValueWithDisinheritance(initialElement, ancestor, attributeName) {\n    const attributeValue = getAttributeValue(ancestor, attributeName)\n    const disinherit = getAttributeValue(ancestor, 'hx-disinherit')\n    var inherit = getAttributeValue(ancestor, 'hx-inherit')\n    if (initialElement !== ancestor) {\n      if (htmx.config.disableInheritance) {\n        if (inherit && (inherit === '*' || inherit.split(' ').indexOf(attributeName) >= 0)) {\n          return attributeValue\n        } else {\n          return null\n        }\n      }\n      if (disinherit && (disinherit === '*' || disinherit.split(' ').indexOf(attributeName) >= 0)) {\n        return 'unset'\n      }\n    }\n    return attributeValue\n  }\n\n  /**\n   * @param {Element} elt\n   * @param {string} attributeName\n   * @returns {string | null}\n   */\n  function getClosestAttributeValue(elt, attributeName) {\n    let closestAttr = null\n    getClosestMatch(elt, function(e) {\n      return !!(closestAttr = getAttributeValueWithDisinheritance(elt, asElement(e), attributeName))\n    })\n    if (closestAttr !== 'unset') {\n      return closestAttr\n    }\n  }\n\n  /**\n   * @param {Node} elt\n   * @param {string} selector\n   * @returns {boolean}\n   */\n  function matches(elt, selector) {\n    // @ts-ignore: non-standard properties for browser compatibility\n    // noinspection JSUnresolvedVariable\n    const matchesFunction = elt instanceof Element && (elt.matches || elt.matchesSelector || elt.msMatchesSelector || elt.mozMatchesSelector || elt.webkitMatchesSelector || elt.oMatchesSelector)\n    return !!matchesFunction && matchesFunction.call(elt, selector)\n  }\n\n  /**\n   * @param {string} str\n   * @returns {string}\n   */\n  function getStartTag(str) {\n    const tagMatcher = /<([a-z][^\\/\\0>\\x20\\t\\r\\n\\f]*)/i\n    const match = tagMatcher.exec(str)\n    if (match) {\n      return match[1].toLowerCase()\n    } else {\n      return ''\n    }\n  }\n\n  /**\n   * @param {string} resp\n   * @returns {Document}\n   */\n  function parseHTML(resp) {\n    const parser = new DOMParser()\n    return parser.parseFromString(resp, 'text/html')\n  }\n\n  /**\n   * @param {DocumentFragment} fragment\n   * @param {Node} elt\n   */\n  function takeChildrenFor(fragment, elt) {\n    while (elt.childNodes.length > 0) {\n      fragment.append(elt.childNodes[0])\n    }\n  }\n\n  /**\n   * @param {HTMLScriptElement} script\n   * @returns {HTMLScriptElement}\n   */\n  function duplicateScript(script) {\n    const newScript = getDocument().createElement('script')\n    forEach(script.attributes, function(attr) {\n      newScript.setAttribute(attr.name, attr.value)\n    })\n    newScript.textContent = script.textContent\n    newScript.async = false\n    if (htmx.config.inlineScriptNonce) {\n      newScript.nonce = htmx.config.inlineScriptNonce\n    }\n    return newScript\n  }\n\n  /**\n   * @param {HTMLScriptElement} script\n   * @returns {boolean}\n   */\n  function isJavaScriptScriptNode(script) {\n    return script.matches('script') && (script.type === 'text/javascript' || script.type === 'module' || script.type === '')\n  }\n\n  /**\n   * we have to make new copies of script tags that we are going to insert because\n   * SOME browsers (not saying who, but it involves an element and an animal) don't\n   * execute scripts created in <template> tags when they are inserted into the DOM\n   * and all the others do lmao\n   * @param {DocumentFragment} fragment\n   */\n  function normalizeScriptTags(fragment) {\n    Array.from(fragment.querySelectorAll('script')).forEach(/** @param {HTMLScriptElement} script */ (script) => {\n      if (isJavaScriptScriptNode(script)) {\n        const newScript = duplicateScript(script)\n        const parent = script.parentNode\n        try {\n          parent.insertBefore(newScript, script)\n        } catch (e) {\n          logError(e)\n        } finally {\n          script.remove()\n        }\n      }\n    })\n  }\n\n  /**\n   * @typedef {DocumentFragment & {title?: string}} DocumentFragmentWithTitle\n   * @description  a document fragment representing the response HTML, including\n   * a `title` property for any title information found\n   */\n\n  /**\n   * @param {string} response HTML\n   * @returns {DocumentFragmentWithTitle}\n   */\n  function makeFragment(response) {\n    // strip head tag to determine shape of response we are dealing with\n    const responseWithNoHead = response.replace(HEAD_TAG_REGEX, '')\n    const startTag = getStartTag(responseWithNoHead)\n    /** @type DocumentFragmentWithTitle */\n    let fragment\n    if (startTag === 'html') {\n      // if it is a full document, parse it and return the body\n      fragment = /** @type DocumentFragmentWithTitle */ (new DocumentFragment())\n      const doc = parseHTML(response)\n      takeChildrenFor(fragment, doc.body)\n      fragment.title = doc.title\n    } else if (startTag === 'body') {\n      // parse body w/o wrapping in template\n      fragment = /** @type DocumentFragmentWithTitle */ (new DocumentFragment())\n      const doc = parseHTML(responseWithNoHead)\n      takeChildrenFor(fragment, doc.body)\n      fragment.title = doc.title\n    } else {\n      // otherwise we have non-body partial HTML content, so wrap it in a template to maximize parsing flexibility\n      const doc = parseHTML('<body><template class=\"internal-htmx-wrapper\">' + responseWithNoHead + '</template></body>')\n      fragment = /** @type DocumentFragmentWithTitle */ (doc.querySelector('template').content)\n      // extract title into fragment for later processing\n      fragment.title = doc.title\n\n      // for legacy reasons we support a title tag at the root level of non-body responses, so we need to handle it\n      var titleElement = fragment.querySelector('title')\n      if (titleElement && titleElement.parentNode === fragment) {\n        titleElement.remove()\n        fragment.title = titleElement.innerText\n      }\n    }\n    if (fragment) {\n      if (htmx.config.allowScriptTags) {\n        normalizeScriptTags(fragment)\n      } else {\n        // remove all script tags if scripts are disabled\n        fragment.querySelectorAll('script').forEach((script) => script.remove())\n      }\n    }\n    return fragment\n  }\n\n  /**\n   * @param {Function} func\n   */\n  function maybeCall(func) {\n    if (func) {\n      func()\n    }\n  }\n\n  /**\n   * @param {any} o\n   * @param {string} type\n   * @returns\n   */\n  function isType(o, type) {\n    return Object.prototype.toString.call(o) === '[object ' + type + ']'\n  }\n\n  /**\n   * @param {*} o\n   * @returns {o is Function}\n   */\n  function isFunction(o) {\n    return typeof o === 'function'\n  }\n\n  /**\n   * @param {*} o\n   * @returns {o is Object}\n   */\n  function isRawObject(o) {\n    return isType(o, 'Object')\n  }\n\n  /**\n   * @typedef {Object} OnHandler\n   * @property {(keyof HTMLElementEventMap)|string} event\n   * @property {EventListener} listener\n   */\n\n  /**\n   * @typedef {Object} ListenerInfo\n   * @property {string} trigger\n   * @property {EventListener} listener\n   * @property {EventTarget} on\n   */\n\n  /**\n   * @typedef {Object} HtmxNodeInternalData\n   * Element data\n   * @property {number} [initHash]\n   * @property {boolean} [boosted]\n   * @property {OnHandler[]} [onHandlers]\n   * @property {number} [timeout]\n   * @property {ListenerInfo[]} [listenerInfos]\n   * @property {boolean} [cancelled]\n   * @property {boolean} [triggeredOnce]\n   * @property {number} [delayed]\n   * @property {number|null} [throttle]\n   * @property {string} [lastValue]\n   * @property {boolean} [loaded]\n   * @property {string} [path]\n   * @property {string} [verb]\n   * @property {boolean} [polling]\n   * @property {HTMLButtonElement|HTMLInputElement|null} [lastButtonClicked]\n   * @property {number} [requestCount]\n   * @property {XMLHttpRequest} [xhr]\n   * @property {(() => void)[]} [queuedRequests]\n   * @property {boolean} [abortable]\n   *\n   * Event data\n   * @property {HtmxTriggerSpecification} [triggerSpec]\n   * @property {EventTarget[]} [handledFor]\n   */\n\n  /**\n   * getInternalData retrieves \"private\" data stored by htmx within an element\n   * @param {EventTarget|Event} elt\n   * @returns {HtmxNodeInternalData}\n   */\n  function getInternalData(elt) {\n    const dataProp = 'htmx-internal-data'\n    let data = elt[dataProp]\n    if (!data) {\n      data = elt[dataProp] = {}\n    }\n    return data\n  }\n\n  /**\n   * toArray converts an ArrayLike object into a real array.\n   * @template T\n   * @param {ArrayLike<T>} arr\n   * @returns {T[]}\n   */\n  function toArray(arr) {\n    const returnArr = []\n    if (arr) {\n      for (let i = 0; i < arr.length; i++) {\n        returnArr.push(arr[i])\n      }\n    }\n    return returnArr\n  }\n\n  /**\n   * @template T\n   * @param {T[]|NamedNodeMap|HTMLCollection|HTMLFormControlsCollection|ArrayLike<T>} arr\n   * @param {(T) => void} func\n   */\n  function forEach(arr, func) {\n    if (arr) {\n      for (let i = 0; i < arr.length; i++) {\n        func(arr[i])\n      }\n    }\n  }\n\n  /**\n   * @param {Element} el\n   * @returns {boolean}\n   */\n  function isScrolledIntoView(el) {\n    const rect = el.getBoundingClientRect()\n    const elemTop = rect.top\n    const elemBottom = rect.bottom\n    return elemTop < window.innerHeight && elemBottom >= 0\n  }\n\n  /**\n   * @param {Node} elt\n   * @returns {boolean}\n   */\n  function bodyContains(elt) {\n    // IE Fix\n    const rootNode = elt.getRootNode && elt.getRootNode()\n    if (rootNode && rootNode instanceof window.ShadowRoot) {\n      return getDocument().body.contains(rootNode.host)\n    } else {\n      return getDocument().body.contains(elt)\n    }\n  }\n\n  /**\n   * @param {string} trigger\n   * @returns {string[]}\n   */\n  function splitOnWhitespace(trigger) {\n    return trigger.trim().split(/\\s+/)\n  }\n\n  /**\n   * mergeObjects takes all the keys from\n   * obj2 and duplicates them into obj1\n   * @template T1\n   * @template T2\n   * @param {T1} obj1\n   * @param {T2} obj2\n   * @returns {T1 & T2}\n   */\n  function mergeObjects(obj1, obj2) {\n    for (const key in obj2) {\n      if (obj2.hasOwnProperty(key)) {\n        // @ts-ignore tsc doesn't seem to properly handle types merging\n        obj1[key] = obj2[key]\n      }\n    }\n    // @ts-ignore tsc doesn't seem to properly handle types merging\n    return obj1\n  }\n\n  /**\n   * @param {string} jString\n   * @returns {any|null}\n   */\n  function parseJSON(jString) {\n    try {\n      return JSON.parse(jString)\n    } catch (error) {\n      logError(error)\n      return null\n    }\n  }\n\n  /**\n   * @returns {boolean}\n   */\n  function canAccessLocalStorage() {\n    const test = 'htmx:localStorageTest'\n    try {\n      localStorage.setItem(test, test)\n      localStorage.removeItem(test)\n      return true\n    } catch (e) {\n      return false\n    }\n  }\n\n  /**\n   * @param {string} path\n   * @returns {string}\n   */\n  function normalizePath(path) {\n    try {\n      const url = new URL(path)\n      if (url) {\n        path = url.pathname + url.search\n      }\n      // remove trailing slash, unless index page\n      if (!(/^\\/$/.test(path))) {\n        path = path.replace(/\\/+$/, '')\n      }\n      return path\n    } catch (e) {\n      // be kind to IE11, which doesn't support URL()\n      return path\n    }\n  }\n\n  //= =========================================================================================\n  // public API\n  //= =========================================================================================\n\n  /**\n   * @param {string} str\n   * @returns {any}\n   */\n  function internalEval(str) {\n    return maybeEval(getDocument().body, function() {\n      return eval(str)\n    })\n  }\n\n  /**\n   * Adds a callback for the **htmx:load** event. This can be used to process new content, for example initializing the content with a javascript library\n   *\n   * @see https://htmx.org/api/#onLoad\n   *\n   * @param {(elt: Node) => void} callback the callback to call on newly loaded content\n   * @returns {EventListener}\n   */\n  function onLoadHelper(callback) {\n    const value = htmx.on('htmx:load', /** @param {CustomEvent} evt */ function(evt) {\n      callback(evt.detail.elt)\n    })\n    return value\n  }\n\n  /**\n   * Log all htmx events, useful for debugging.\n   *\n   * @see https://htmx.org/api/#logAll\n   */\n  function logAll() {\n    htmx.logger = function(elt, event, data) {\n      if (console) {\n        console.log(event, elt, data)\n      }\n    }\n  }\n\n  function logNone() {\n    htmx.logger = null\n  }\n\n  /**\n   * Finds an element matching the selector\n   *\n   * @see https://htmx.org/api/#find\n   *\n   * @param {ParentNode|string} eltOrSelector  the root element to find the matching element in, inclusive | the selector to match\n   * @param {string} [selector] the selector to match\n   * @returns {Element|null}\n   */\n  function find(eltOrSelector, selector) {\n    if (typeof eltOrSelector !== 'string') {\n      return eltOrSelector.querySelector(selector)\n    } else {\n      return find(getDocument(), eltOrSelector)\n    }\n  }\n\n  /**\n   * Finds all elements matching the selector\n   *\n   * @see https://htmx.org/api/#findAll\n   *\n   * @param {ParentNode|string} eltOrSelector the root element to find the matching elements in, inclusive | the selector to match\n   * @param {string} [selector] the selector to match\n   * @returns {NodeListOf<Element>}\n   */\n  function findAll(eltOrSelector, selector) {\n    if (typeof eltOrSelector !== 'string') {\n      return eltOrSelector.querySelectorAll(selector)\n    } else {\n      return findAll(getDocument(), eltOrSelector)\n    }\n  }\n\n  /**\n   * @returns Window\n   */\n  function getWindow() {\n    return window\n  }\n\n  /**\n   * Removes an element from the DOM\n   *\n   * @see https://htmx.org/api/#remove\n   *\n   * @param {Node} elt\n   * @param {number} [delay]\n   */\n  function removeElement(elt, delay) {\n    elt = resolveTarget(elt)\n    if (delay) {\n      getWindow().setTimeout(function() {\n        removeElement(elt)\n        elt = null\n      }, delay)\n    } else {\n      parentElt(elt).removeChild(elt)\n    }\n  }\n\n  /**\n   * @param {any} elt\n   * @return {Element|null}\n   */\n  function asElement(elt) {\n    return elt instanceof Element ? elt : null\n  }\n\n  /**\n   * @param {any} elt\n   * @return {HTMLElement|null}\n   */\n  function asHtmlElement(elt) {\n    return elt instanceof HTMLElement ? elt : null\n  }\n\n  /**\n   * @param {any} value\n   * @return {string|null}\n   */\n  function asString(value) {\n    return typeof value === 'string' ? value : null\n  }\n\n  /**\n   * @param {EventTarget} elt\n   * @return {ParentNode|null}\n   */\n  function asParentNode(elt) {\n    return elt instanceof Element || elt instanceof Document || elt instanceof DocumentFragment ? elt : null\n  }\n\n  /**\n   * This method adds a class to the given element.\n   *\n   * @see https://htmx.org/api/#addClass\n   *\n   * @param {Element|string} elt the element to add the class to\n   * @param {string} clazz the class to add\n   * @param {number} [delay] the delay (in milliseconds) before class is added\n   */\n  function addClassToElement(elt, clazz, delay) {\n    elt = asElement(resolveTarget(elt))\n    if (!elt) {\n      return\n    }\n    if (delay) {\n      getWindow().setTimeout(function() {\n        addClassToElement(elt, clazz)\n        elt = null\n      }, delay)\n    } else {\n      elt.classList && elt.classList.add(clazz)\n    }\n  }\n\n  /**\n   * Removes a class from the given element\n   *\n   * @see https://htmx.org/api/#removeClass\n   *\n   * @param {Node|string} node element to remove the class from\n   * @param {string} clazz the class to remove\n   * @param {number} [delay] the delay (in milliseconds before class is removed)\n   */\n  function removeClassFromElement(node, clazz, delay) {\n    let elt = asElement(resolveTarget(node))\n    if (!elt) {\n      return\n    }\n    if (delay) {\n      getWindow().setTimeout(function() {\n        removeClassFromElement(elt, clazz)\n        elt = null\n      }, delay)\n    } else {\n      if (elt.classList) {\n        elt.classList.remove(clazz)\n        // if there are no classes left, remove the class attribute\n        if (elt.classList.length === 0) {\n          elt.removeAttribute('class')\n        }\n      }\n    }\n  }\n\n  /**\n   * Toggles the given class on an element\n   *\n   * @see https://htmx.org/api/#toggleClass\n   *\n   * @param {Element|string} elt the element to toggle the class on\n   * @param {string} clazz the class to toggle\n   */\n  function toggleClassOnElement(elt, clazz) {\n    elt = resolveTarget(elt)\n    elt.classList.toggle(clazz)\n  }\n\n  /**\n   * Takes the given class from its siblings, so that among its siblings, only the given element will have the class.\n   *\n   * @see https://htmx.org/api/#takeClass\n   *\n   * @param {Node|string} elt the element that will take the class\n   * @param {string} clazz the class to take\n   */\n  function takeClassForElement(elt, clazz) {\n    elt = resolveTarget(elt)\n    forEach(elt.parentElement.children, function(child) {\n      removeClassFromElement(child, clazz)\n    })\n    addClassToElement(asElement(elt), clazz)\n  }\n\n  /**\n   * Finds the closest matching element in the given elements parentage, inclusive of the element\n   *\n   * @see https://htmx.org/api/#closest\n   *\n   * @param {Element|string} elt the element to find the selector from\n   * @param {string} selector the selector to find\n   * @returns {Element|null}\n   */\n  function closest(elt, selector) {\n    elt = asElement(resolveTarget(elt))\n    if (elt && elt.closest) {\n      return elt.closest(selector)\n    } else {\n      // TODO remove when IE goes away\n      do {\n        if (elt == null || matches(elt, selector)) {\n          return elt\n        }\n      }\n      while (elt = elt && asElement(parentElt(elt)))\n      return null\n    }\n  }\n\n  /**\n   * @param {string} str\n   * @param {string} prefix\n   * @returns {boolean}\n   */\n  function startsWith(str, prefix) {\n    return str.substring(0, prefix.length) === prefix\n  }\n\n  /**\n   * @param {string} str\n   * @param {string} suffix\n   * @returns {boolean}\n   */\n  function endsWith(str, suffix) {\n    return str.substring(str.length - suffix.length) === suffix\n  }\n\n  /**\n   * @param {string} selector\n   * @returns {string}\n   */\n  function normalizeSelector(selector) {\n    const trimmedSelector = selector.trim()\n    if (startsWith(trimmedSelector, '<') && endsWith(trimmedSelector, '/>')) {\n      return trimmedSelector.substring(1, trimmedSelector.length - 2)\n    } else {\n      return trimmedSelector\n    }\n  }\n\n  /**\n   * @param {Node|Element|Document|string} elt\n   * @param {string} selector\n   * @param {boolean=} global\n   * @returns {(Node|Window)[]}\n   */\n  function querySelectorAllExt(elt, selector, global) {\n    elt = resolveTarget(elt)\n    if (selector.indexOf('closest ') === 0) {\n      return [closest(asElement(elt), normalizeSelector(selector.substr(8)))]\n    } else if (selector.indexOf('find ') === 0) {\n      return [find(asParentNode(elt), normalizeSelector(selector.substr(5)))]\n    } else if (selector === 'next') {\n      return [asElement(elt).nextElementSibling]\n    } else if (selector.indexOf('next ') === 0) {\n      return [scanForwardQuery(elt, normalizeSelector(selector.substr(5)), !!global)]\n    } else if (selector === 'previous') {\n      return [asElement(elt).previousElementSibling]\n    } else if (selector.indexOf('previous ') === 0) {\n      return [scanBackwardsQuery(elt, normalizeSelector(selector.substr(9)), !!global)]\n    } else if (selector === 'document') {\n      return [document]\n    } else if (selector === 'window') {\n      return [window]\n    } else if (selector === 'body') {\n      return [document.body]\n    } else if (selector === 'root') {\n      return [getRootNode(elt, !!global)]\n    } else if (selector.indexOf('global ') === 0) {\n      return querySelectorAllExt(elt, selector.slice(7), true)\n    } else {\n      return toArray(asParentNode(getRootNode(elt, !!global)).querySelectorAll(normalizeSelector(selector)))\n    }\n  }\n\n  /**\n   * @param {Node} start\n   * @param {string} match\n   * @param {boolean} global\n   * @returns {Element}\n   */\n  var scanForwardQuery = function(start, match, global) {\n    const results = asParentNode(getRootNode(start, global)).querySelectorAll(match)\n    for (let i = 0; i < results.length; i++) {\n      const elt = results[i]\n      if (elt.compareDocumentPosition(start) === Node.DOCUMENT_POSITION_PRECEDING) {\n        return elt\n      }\n    }\n  }\n\n  /**\n   * @param {Node} start\n   * @param {string} match\n   * @param {boolean} global\n   * @returns {Element}\n   */\n  var scanBackwardsQuery = function(start, match, global) {\n    const results = asParentNode(getRootNode(start, global)).querySelectorAll(match)\n    for (let i = results.length - 1; i >= 0; i--) {\n      const elt = results[i]\n      if (elt.compareDocumentPosition(start) === Node.DOCUMENT_POSITION_FOLLOWING) {\n        return elt\n      }\n    }\n  }\n\n  /**\n   * @param {Node|string} eltOrSelector\n   * @param {string=} selector\n   * @returns {Node|Window}\n   */\n  function querySelectorExt(eltOrSelector, selector) {\n    if (typeof eltOrSelector !== 'string') {\n      return querySelectorAllExt(eltOrSelector, selector)[0]\n    } else {\n      return querySelectorAllExt(getDocument().body, eltOrSelector)[0]\n    }\n  }\n\n  /**\n   * @template {EventTarget} T\n   * @param {T|string} eltOrSelector\n   * @param {T} [context]\n   * @returns {Element|T|null}\n   */\n  function resolveTarget(eltOrSelector, context) {\n    if (typeof eltOrSelector === 'string') {\n      return find(asParentNode(context) || document, eltOrSelector)\n    } else {\n      return eltOrSelector\n    }\n  }\n\n  /**\n   * @typedef {keyof HTMLElementEventMap|string} AnyEventName\n   */\n\n  /**\n   * @typedef {Object} EventArgs\n   * @property {EventTarget} target\n   * @property {AnyEventName} event\n   * @property {EventListener} listener\n   */\n\n  /**\n   * @param {EventTarget|AnyEventName} arg1\n   * @param {AnyEventName|EventListener} arg2\n   * @param {EventListener} [arg3]\n   * @returns {EventArgs}\n   */\n  function processEventArgs(arg1, arg2, arg3) {\n    if (isFunction(arg2)) {\n      return {\n        target: getDocument().body,\n        event: asString(arg1),\n        listener: arg2\n      }\n    } else {\n      return {\n        target: resolveTarget(arg1),\n        event: asString(arg2),\n        listener: arg3\n      }\n    }\n  }\n\n  /**\n   * Adds an event listener to an element\n   *\n   * @see https://htmx.org/api/#on\n   *\n   * @param {EventTarget|string} arg1 the element to add the listener to | the event name to add the listener for\n   * @param {string|EventListener} arg2 the event name to add the listener for | the listener to add\n   * @param {EventListener} [arg3] the listener to add\n   * @returns {EventListener}\n   */\n  function addEventListenerImpl(arg1, arg2, arg3) {\n    ready(function() {\n      const eventArgs = processEventArgs(arg1, arg2, arg3)\n      eventArgs.target.addEventListener(eventArgs.event, eventArgs.listener)\n    })\n    const b = isFunction(arg2)\n    return b ? arg2 : arg3\n  }\n\n  /**\n   * Removes an event listener from an element\n   *\n   * @see https://htmx.org/api/#off\n   *\n   * @param {EventTarget|string} arg1 the element to remove the listener from | the event name to remove the listener from\n   * @param {string|EventListener} arg2 the event name to remove the listener from | the listener to remove\n   * @param {EventListener} [arg3] the listener to remove\n   * @returns {EventListener}\n   */\n  function removeEventListenerImpl(arg1, arg2, arg3) {\n    ready(function() {\n      const eventArgs = processEventArgs(arg1, arg2, arg3)\n      eventArgs.target.removeEventListener(eventArgs.event, eventArgs.listener)\n    })\n    return isFunction(arg2) ? arg2 : arg3\n  }\n\n  //= ===================================================================\n  // Node processing\n  //= ===================================================================\n\n  const DUMMY_ELT = getDocument().createElement('output') // dummy element for bad selectors\n  /**\n   * @param {Element} elt\n   * @param {string} attrName\n   * @returns {(Node|Window)[]}\n   */\n  function findAttributeTargets(elt, attrName) {\n    const attrTarget = getClosestAttributeValue(elt, attrName)\n    if (attrTarget) {\n      if (attrTarget === 'this') {\n        return [findThisElement(elt, attrName)]\n      } else {\n        const result = querySelectorAllExt(elt, attrTarget)\n        if (result.length === 0) {\n          logError('The selector \"' + attrTarget + '\" on ' + attrName + ' returned no matches!')\n          return [DUMMY_ELT]\n        } else {\n          return result\n        }\n      }\n    }\n  }\n\n  /**\n   * @param {Element} elt\n   * @param {string} attribute\n   * @returns {Element|null}\n   */\n  function findThisElement(elt, attribute) {\n    return asElement(getClosestMatch(elt, function(elt) {\n      return getAttributeValue(asElement(elt), attribute) != null\n    }))\n  }\n\n  /**\n   * @param {Element} elt\n   * @returns {Node|Window|null}\n   */\n  function getTarget(elt) {\n    const targetStr = getClosestAttributeValue(elt, 'hx-target')\n    if (targetStr) {\n      if (targetStr === 'this') {\n        return findThisElement(elt, 'hx-target')\n      } else {\n        return querySelectorExt(elt, targetStr)\n      }\n    } else {\n      const data = getInternalData(elt)\n      if (data.boosted) {\n        return getDocument().body\n      } else {\n        return elt\n      }\n    }\n  }\n\n  /**\n   * @param {string} name\n   * @returns {boolean}\n   */\n  function shouldSettleAttribute(name) {\n    const attributesToSettle = htmx.config.attributesToSettle\n    for (let i = 0; i < attributesToSettle.length; i++) {\n      if (name === attributesToSettle[i]) {\n        return true\n      }\n    }\n    return false\n  }\n\n  /**\n   * @param {Element} mergeTo\n   * @param {Element} mergeFrom\n   */\n  function cloneAttributes(mergeTo, mergeFrom) {\n    forEach(mergeTo.attributes, function(attr) {\n      if (!mergeFrom.hasAttribute(attr.name) && shouldSettleAttribute(attr.name)) {\n        mergeTo.removeAttribute(attr.name)\n      }\n    })\n    forEach(mergeFrom.attributes, function(attr) {\n      if (shouldSettleAttribute(attr.name)) {\n        mergeTo.setAttribute(attr.name, attr.value)\n      }\n    })\n  }\n\n  /**\n   * @param {HtmxSwapStyle} swapStyle\n   * @param {Element} target\n   * @returns {boolean}\n   */\n  function isInlineSwap(swapStyle, target) {\n    const extensions = getExtensions(target)\n    for (let i = 0; i < extensions.length; i++) {\n      const extension = extensions[i]\n      try {\n        if (extension.isInlineSwap(swapStyle)) {\n          return true\n        }\n      } catch (e) {\n        logError(e)\n      }\n    }\n    return swapStyle === 'outerHTML'\n  }\n\n  /**\n   * @param {string} oobValue\n   * @param {Element} oobElement\n   * @param {HtmxSettleInfo} settleInfo\n   * @returns\n   */\n  function oobSwap(oobValue, oobElement, settleInfo) {\n    let selector = '#' + getRawAttribute(oobElement, 'id')\n    /** @type HtmxSwapStyle */\n    let swapStyle = 'outerHTML'\n    if (oobValue === 'true') {\n      // do nothing\n    } else if (oobValue.indexOf(':') > 0) {\n      swapStyle = oobValue.substr(0, oobValue.indexOf(':'))\n      selector = oobValue.substr(oobValue.indexOf(':') + 1, oobValue.length)\n    } else {\n      swapStyle = oobValue\n    }\n\n    const targets = getDocument().querySelectorAll(selector)\n    if (targets) {\n      forEach(\n        targets,\n        function(target) {\n          let fragment\n          const oobElementClone = oobElement.cloneNode(true)\n          fragment = getDocument().createDocumentFragment()\n          fragment.appendChild(oobElementClone)\n          if (!isInlineSwap(swapStyle, target)) {\n            fragment = asParentNode(oobElementClone) // if this is not an inline swap, we use the content of the node, not the node itself\n          }\n\n          const beforeSwapDetails = { shouldSwap: true, target, fragment }\n          if (!triggerEvent(target, 'htmx:oobBeforeSwap', beforeSwapDetails)) return\n\n          target = beforeSwapDetails.target // allow re-targeting\n          if (beforeSwapDetails.shouldSwap) {\n            swapWithStyle(swapStyle, target, target, fragment, settleInfo)\n          }\n          forEach(settleInfo.elts, function(elt) {\n            triggerEvent(elt, 'htmx:oobAfterSwap', beforeSwapDetails)\n          })\n        }\n      )\n      oobElement.parentNode.removeChild(oobElement)\n    } else {\n      oobElement.parentNode.removeChild(oobElement)\n      triggerErrorEvent(getDocument().body, 'htmx:oobErrorNoTarget', { content: oobElement })\n    }\n    return oobValue\n  }\n\n  /**\n   * @param {DocumentFragment} fragment\n   */\n  function handlePreservedElements(fragment) {\n    forEach(findAll(fragment, '[hx-preserve], [data-hx-preserve]'), function(preservedElt) {\n      const id = getAttributeValue(preservedElt, 'id')\n      const oldElt = getDocument().getElementById(id)\n      if (oldElt != null) {\n        preservedElt.parentNode.replaceChild(oldElt, preservedElt)\n      }\n    })\n  }\n\n  /**\n   * @param {Node} parentNode\n   * @param {ParentNode} fragment\n   * @param {HtmxSettleInfo} settleInfo\n   */\n  function handleAttributes(parentNode, fragment, settleInfo) {\n    forEach(fragment.querySelectorAll('[id]'), function(newNode) {\n      const id = getRawAttribute(newNode, 'id')\n      if (id && id.length > 0) {\n        const normalizedId = id.replace(\"'\", \"\\\\'\")\n        const normalizedTag = newNode.tagName.replace(':', '\\\\:')\n        const parentElt = asParentNode(parentNode)\n        const oldNode = parentElt && parentElt.querySelector(normalizedTag + \"[id='\" + normalizedId + \"']\")\n        if (oldNode && oldNode !== parentElt) {\n          const newAttributes = newNode.cloneNode()\n          cloneAttributes(newNode, oldNode)\n          settleInfo.tasks.push(function() {\n            cloneAttributes(newNode, newAttributes)\n          })\n        }\n      }\n    })\n  }\n\n  /**\n   * @param {Node} child\n   * @returns {HtmxSettleTask}\n   */\n  function makeAjaxLoadTask(child) {\n    return function() {\n      removeClassFromElement(child, htmx.config.addedClass)\n      processNode(asElement(child))\n      processFocus(asParentNode(child))\n      triggerEvent(child, 'htmx:load')\n    }\n  }\n\n  /**\n   * @param {ParentNode} child\n   */\n  function processFocus(child) {\n    const autofocus = '[autofocus]'\n    const autoFocusedElt = asHtmlElement(matches(child, autofocus) ? child : child.querySelector(autofocus))\n    if (autoFocusedElt != null) {\n      autoFocusedElt.focus()\n    }\n  }\n\n  /**\n   * @param {Node} parentNode\n   * @param {Node} insertBefore\n   * @param {ParentNode} fragment\n   * @param {HtmxSettleInfo} settleInfo\n   */\n  function insertNodesBefore(parentNode, insertBefore, fragment, settleInfo) {\n    handleAttributes(parentNode, fragment, settleInfo)\n    while (fragment.childNodes.length > 0) {\n      const child = fragment.firstChild\n      addClassToElement(asElement(child), htmx.config.addedClass)\n      parentNode.insertBefore(child, insertBefore)\n      if (child.nodeType !== Node.TEXT_NODE && child.nodeType !== Node.COMMENT_NODE) {\n        settleInfo.tasks.push(makeAjaxLoadTask(child))\n      }\n    }\n  }\n\n  /**\n   * based on https://gist.github.com/hyamamoto/fd435505d29ebfa3d9716fd2be8d42f0,\n   * derived from Java's string hashcode implementation\n   * @param {string} string\n   * @param {number} hash\n   * @returns {number}\n   */\n  function stringHash(string, hash) {\n    let char = 0\n    while (char < string.length) {\n      hash = (hash << 5) - hash + string.charCodeAt(char++) | 0 // bitwise or ensures we have a 32-bit int\n    }\n    return hash\n  }\n\n  /**\n   * @param {Element} elt\n   * @returns {number}\n   */\n  function attributeHash(elt) {\n    let hash = 0\n    // IE fix\n    if (elt.attributes) {\n      for (let i = 0; i < elt.attributes.length; i++) {\n        const attribute = elt.attributes[i]\n        if (attribute.value) { // only include attributes w/ actual values (empty is same as non-existent)\n          hash = stringHash(attribute.name, hash)\n          hash = stringHash(attribute.value, hash)\n        }\n      }\n    }\n    return hash\n  }\n\n  /**\n   * @param {EventTarget} elt\n   */\n  function deInitOnHandlers(elt) {\n    const internalData = getInternalData(elt)\n    if (internalData.onHandlers) {\n      for (let i = 0; i < internalData.onHandlers.length; i++) {\n        const handlerInfo = internalData.onHandlers[i]\n        removeEventListenerImpl(elt, handlerInfo.event, handlerInfo.listener)\n      }\n      delete internalData.onHandlers\n    }\n  }\n\n  /**\n   * @param {Node} element\n   */\n  function deInitNode(element) {\n    const internalData = getInternalData(element)\n    if (internalData.timeout) {\n      clearTimeout(internalData.timeout)\n    }\n    if (internalData.listenerInfos) {\n      forEach(internalData.listenerInfos, function(info) {\n        if (info.on) {\n          removeEventListenerImpl(info.on, info.trigger, info.listener)\n        }\n      })\n    }\n    deInitOnHandlers(element)\n    forEach(Object.keys(internalData), function(key) { delete internalData[key] })\n  }\n\n  /**\n   * @param {Node} element\n   */\n  function cleanUpElement(element) {\n    triggerEvent(element, 'htmx:beforeCleanupElement')\n    deInitNode(element)\n    // @ts-ignore IE11 code\n    // noinspection JSUnresolvedReference\n    if (element.children) { // IE\n      // @ts-ignore\n      forEach(element.children, function(child) { cleanUpElement(child) })\n    }\n  }\n\n  /**\n   * @param {Node} target\n   * @param {ParentNode} fragment\n   * @param {HtmxSettleInfo} settleInfo\n   */\n  function swapOuterHTML(target, fragment, settleInfo) {\n    if (target instanceof Element && target.tagName === 'BODY') { // special case the body to innerHTML because DocumentFragments can't contain a body elt unfortunately\n      return swapInnerHTML(target, fragment, settleInfo)\n    }\n    /** @type {Node} */\n    let newElt\n    const eltBeforeNewContent = target.previousSibling\n    insertNodesBefore(parentElt(target), target, fragment, settleInfo)\n    if (eltBeforeNewContent == null) {\n      newElt = parentElt(target).firstChild\n    } else {\n      newElt = eltBeforeNewContent.nextSibling\n    }\n    settleInfo.elts = settleInfo.elts.filter(function(e) { return e !== target })\n    // scan through all newly added content and add all elements to the settle info so we trigger\n    // events properly on them\n    while (newElt && newElt !== target) {\n      if (newElt instanceof Element) {\n        settleInfo.elts.push(newElt)\n      }\n      newElt = newElt.nextSibling\n    }\n    cleanUpElement(target)\n    if (target instanceof Element) {\n      target.remove()\n    } else {\n      target.parentNode.removeChild(target)\n    }\n  }\n\n  /**\n   * @param {Node} target\n   * @param {ParentNode} fragment\n   * @param {HtmxSettleInfo} settleInfo\n   */\n  function swapAfterBegin(target, fragment, settleInfo) {\n    return insertNodesBefore(target, target.firstChild, fragment, settleInfo)\n  }\n\n  /**\n   * @param {Node} target\n   * @param {ParentNode} fragment\n   * @param {HtmxSettleInfo} settleInfo\n   */\n  function swapBeforeBegin(target, fragment, settleInfo) {\n    return insertNodesBefore(parentElt(target), target, fragment, settleInfo)\n  }\n\n  /**\n   * @param {Node} target\n   * @param {ParentNode} fragment\n   * @param {HtmxSettleInfo} settleInfo\n   */\n  function swapBeforeEnd(target, fragment, settleInfo) {\n    return insertNodesBefore(target, null, fragment, settleInfo)\n  }\n\n  /**\n   * @param {Node} target\n   * @param {ParentNode} fragment\n   * @param {HtmxSettleInfo} settleInfo\n   */\n  function swapAfterEnd(target, fragment, settleInfo) {\n    return insertNodesBefore(parentElt(target), target.nextSibling, fragment, settleInfo)\n  }\n\n  /**\n   * @param {Node} target\n   */\n  function swapDelete(target) {\n    cleanUpElement(target)\n    return parentElt(target).removeChild(target)\n  }\n\n  /**\n   * @param {Node} target\n   * @param {ParentNode} fragment\n   * @param {HtmxSettleInfo} settleInfo\n   */\n  function swapInnerHTML(target, fragment, settleInfo) {\n    const firstChild = target.firstChild\n    insertNodesBefore(target, firstChild, fragment, settleInfo)\n    if (firstChild) {\n      while (firstChild.nextSibling) {\n        cleanUpElement(firstChild.nextSibling)\n        target.removeChild(firstChild.nextSibling)\n      }\n      cleanUpElement(firstChild)\n      target.removeChild(firstChild)\n    }\n  }\n\n  /**\n   * @param {HtmxSwapStyle} swapStyle\n   * @param {Element} elt\n   * @param {Node} target\n   * @param {ParentNode} fragment\n   * @param {HtmxSettleInfo} settleInfo\n   */\n  function swapWithStyle(swapStyle, elt, target, fragment, settleInfo) {\n    switch (swapStyle) {\n      case 'none':\n        return\n      case 'outerHTML':\n        swapOuterHTML(target, fragment, settleInfo)\n        return\n      case 'afterbegin':\n        swapAfterBegin(target, fragment, settleInfo)\n        return\n      case 'beforebegin':\n        swapBeforeBegin(target, fragment, settleInfo)\n        return\n      case 'beforeend':\n        swapBeforeEnd(target, fragment, settleInfo)\n        return\n      case 'afterend':\n        swapAfterEnd(target, fragment, settleInfo)\n        return\n      case 'delete':\n        swapDelete(target)\n        return\n      default:\n        var extensions = getExtensions(elt)\n        for (let i = 0; i < extensions.length; i++) {\n          const ext = extensions[i]\n          try {\n            const newElements = ext.handleSwap(swapStyle, target, fragment, settleInfo)\n            if (newElements) {\n              if (Array.isArray(newElements)) {\n                // if handleSwap returns an array (like) of elements, we handle them\n                for (let j = 0; j < newElements.length; j++) {\n                  const child = newElements[j]\n                  if (child.nodeType !== Node.TEXT_NODE && child.nodeType !== Node.COMMENT_NODE) {\n                    settleInfo.tasks.push(makeAjaxLoadTask(child))\n                  }\n                }\n              }\n              return\n            }\n          } catch (e) {\n            logError(e)\n          }\n        }\n        if (swapStyle === 'innerHTML') {\n          swapInnerHTML(target, fragment, settleInfo)\n        } else {\n          swapWithStyle(htmx.config.defaultSwapStyle, elt, target, fragment, settleInfo)\n        }\n    }\n  }\n\n  /**\n   * @param {DocumentFragment} fragment\n   * @param {HtmxSettleInfo} settleInfo\n   */\n  function findAndSwapOobElements(fragment, settleInfo) {\n    var oobElts = findAll(fragment, '[hx-swap-oob], [data-hx-swap-oob]')\n    forEach(oobElts, function(oobElement) {\n      if (htmx.config.allowNestedOobSwaps || oobElement.parentElement === null) {\n        const oobValue = getAttributeValue(oobElement, 'hx-swap-oob')\n        if (oobValue != null) {\n          oobSwap(oobValue, oobElement, settleInfo)\n        }\n      } else {\n        oobElement.removeAttribute('hx-swap-oob')\n        oobElement.removeAttribute('data-hx-swap-oob')\n      }\n    })\n    return oobElts.length > 0\n  }\n\n  /**\n   * Implements complete swapping pipeline, including: focus and selection preservation,\n   * title updates, scroll, OOB swapping, normal swapping and settling\n   * @param {string|Element} target\n   * @param {string} content\n   * @param {HtmxSwapSpecification} swapSpec\n   * @param {SwapOptions} [swapOptions]\n   */\n  function swap(target, content, swapSpec, swapOptions) {\n    if (!swapOptions) {\n      swapOptions = {}\n    }\n\n    target = resolveTarget(target)\n\n    // preserve focus and selection\n    const activeElt = document.activeElement\n    let selectionInfo = {}\n    try {\n      selectionInfo = {\n        elt: activeElt,\n        // @ts-ignore\n        start: activeElt ? activeElt.selectionStart : null,\n        // @ts-ignore\n        end: activeElt ? activeElt.selectionEnd : null\n      }\n    } catch (e) {\n      // safari issue - see https://github.com/microsoft/playwright/issues/5894\n    }\n    const settleInfo = makeSettleInfo(target)\n\n    // For text content swaps, don't parse the response as HTML, just insert it\n    if (swapSpec.swapStyle === 'textContent') {\n      target.textContent = content\n    // Otherwise, make the fragment and process it\n    } else {\n      let fragment = makeFragment(content)\n\n      settleInfo.title = fragment.title\n\n      // select-oob swaps\n      if (swapOptions.selectOOB) {\n        const oobSelectValues = swapOptions.selectOOB.split(',')\n        for (let i = 0; i < oobSelectValues.length; i++) {\n          const oobSelectValue = oobSelectValues[i].split(':', 2)\n          let id = oobSelectValue[0].trim()\n          if (id.indexOf('#') === 0) {\n            id = id.substring(1)\n          }\n          const oobValue = oobSelectValue[1] || 'true'\n          const oobElement = fragment.querySelector('#' + id)\n          if (oobElement) {\n            oobSwap(oobValue, oobElement, settleInfo)\n          }\n        }\n      }\n      // oob swaps\n      findAndSwapOobElements(fragment, settleInfo)\n      forEach(findAll(fragment, 'template'), /** @param {HTMLTemplateElement} template */function(template) {\n        if (findAndSwapOobElements(template.content, settleInfo)) {\n          // Avoid polluting the DOM with empty templates that were only used to encapsulate oob swap\n          template.remove()\n        }\n      })\n\n      // normal swap\n      if (swapOptions.select) {\n        const newFragment = getDocument().createDocumentFragment()\n        forEach(fragment.querySelectorAll(swapOptions.select), function(node) {\n          newFragment.appendChild(node)\n        })\n        fragment = newFragment\n      }\n      handlePreservedElements(fragment)\n      swapWithStyle(swapSpec.swapStyle, swapOptions.contextElement, target, fragment, settleInfo)\n    }\n\n    // apply saved focus and selection information to swapped content\n    if (selectionInfo.elt &&\n      !bodyContains(selectionInfo.elt) &&\n      getRawAttribute(selectionInfo.elt, 'id')) {\n      const newActiveElt = document.getElementById(getRawAttribute(selectionInfo.elt, 'id'))\n      const focusOptions = { preventScroll: swapSpec.focusScroll !== undefined ? !swapSpec.focusScroll : !htmx.config.defaultFocusScroll }\n      if (newActiveElt) {\n        // @ts-ignore\n        if (selectionInfo.start && newActiveElt.setSelectionRange) {\n          try {\n            // @ts-ignore\n            newActiveElt.setSelectionRange(selectionInfo.start, selectionInfo.end)\n          } catch (e) {\n            // the setSelectionRange method is present on fields that don't support it, so just let this fail\n          }\n        }\n        newActiveElt.focus(focusOptions)\n      }\n    }\n\n    target.classList.remove(htmx.config.swappingClass)\n    forEach(settleInfo.elts, function(elt) {\n      if (elt.classList) {\n        elt.classList.add(htmx.config.settlingClass)\n      }\n      triggerEvent(elt, 'htmx:afterSwap', swapOptions.eventInfo)\n    })\n    if (swapOptions.afterSwapCallback) {\n      swapOptions.afterSwapCallback()\n    }\n\n    // merge in new title after swap but before settle\n    if (!swapSpec.ignoreTitle) {\n      handleTitle(settleInfo.title)\n    }\n\n    // settle\n    const doSettle = function() {\n      forEach(settleInfo.tasks, function(task) {\n        task.call()\n      })\n      forEach(settleInfo.elts, function(elt) {\n        if (elt.classList) {\n          elt.classList.remove(htmx.config.settlingClass)\n        }\n        triggerEvent(elt, 'htmx:afterSettle', swapOptions.eventInfo)\n      })\n\n      if (swapOptions.anchor) {\n        const anchorTarget = asElement(resolveTarget('#' + swapOptions.anchor))\n        if (anchorTarget) {\n          anchorTarget.scrollIntoView({ block: 'start', behavior: 'auto' })\n        }\n      }\n\n      updateScrollState(settleInfo.elts, swapSpec)\n      if (swapOptions.afterSettleCallback) {\n        swapOptions.afterSettleCallback()\n      }\n    }\n\n    if (swapSpec.settleDelay > 0) {\n      getWindow().setTimeout(doSettle, swapSpec.settleDelay)\n    } else {\n      doSettle()\n    }\n  }\n\n  /**\n   * @param {XMLHttpRequest} xhr\n   * @param {string} header\n   * @param {EventTarget} elt\n   */\n  function handleTriggerHeader(xhr, header, elt) {\n    const triggerBody = xhr.getResponseHeader(header)\n    if (triggerBody.indexOf('{') === 0) {\n      const triggers = parseJSON(triggerBody)\n      for (const eventName in triggers) {\n        if (triggers.hasOwnProperty(eventName)) {\n          let detail = triggers[eventName]\n          if (isRawObject(detail)) {\n            // @ts-ignore\n            elt = detail.target !== undefined ? detail.target : elt\n          } else {\n            detail = { value: detail }\n          }\n          triggerEvent(elt, eventName, detail)\n        }\n      }\n    } else {\n      const eventNames = triggerBody.split(',')\n      for (let i = 0; i < eventNames.length; i++) {\n        triggerEvent(elt, eventNames[i].trim(), [])\n      }\n    }\n  }\n\n  const WHITESPACE = /\\s/\n  const WHITESPACE_OR_COMMA = /[\\s,]/\n  const SYMBOL_START = /[_$a-zA-Z]/\n  const SYMBOL_CONT = /[_$a-zA-Z0-9]/\n  const STRINGISH_START = ['\"', \"'\", '/']\n  const NOT_WHITESPACE = /[^\\s]/\n  const COMBINED_SELECTOR_START = /[{(]/\n  const COMBINED_SELECTOR_END = /[})]/\n\n  /**\n   * @param {string} str\n   * @returns {string[]}\n   */\n  function tokenizeString(str) {\n    /** @type string[] */\n    const tokens = []\n    let position = 0\n    while (position < str.length) {\n      if (SYMBOL_START.exec(str.charAt(position))) {\n        var startPosition = position\n        while (SYMBOL_CONT.exec(str.charAt(position + 1))) {\n          position++\n        }\n        tokens.push(str.substr(startPosition, position - startPosition + 1))\n      } else if (STRINGISH_START.indexOf(str.charAt(position)) !== -1) {\n        const startChar = str.charAt(position)\n        var startPosition = position\n        position++\n        while (position < str.length && str.charAt(position) !== startChar) {\n          if (str.charAt(position) === '\\\\') {\n            position++\n          }\n          position++\n        }\n        tokens.push(str.substr(startPosition, position - startPosition + 1))\n      } else {\n        const symbol = str.charAt(position)\n        tokens.push(symbol)\n      }\n      position++\n    }\n    return tokens\n  }\n\n  /**\n   * @param {string} token\n   * @param {string|null} last\n   * @param {string} paramName\n   * @returns {boolean}\n   */\n  function isPossibleRelativeReference(token, last, paramName) {\n    return SYMBOL_START.exec(token.charAt(0)) &&\n      token !== 'true' &&\n      token !== 'false' &&\n      token !== 'this' &&\n      token !== paramName &&\n      last !== '.'\n  }\n\n  /**\n   * @param {EventTarget|string} elt\n   * @param {string[]} tokens\n   * @param {string} paramName\n   * @returns {ConditionalFunction|null}\n   */\n  function maybeGenerateConditional(elt, tokens, paramName) {\n    if (tokens[0] === '[') {\n      tokens.shift()\n      let bracketCount = 1\n      let conditionalSource = ' return (function(' + paramName + '){ return ('\n      let last = null\n      while (tokens.length > 0) {\n        const token = tokens[0]\n        // @ts-ignore For some reason tsc doesn't understand the shift call, and thinks we're comparing the same value here, i.e. '[' vs ']'\n        if (token === ']') {\n          bracketCount--\n          if (bracketCount === 0) {\n            if (last === null) {\n              conditionalSource = conditionalSource + 'true'\n            }\n            tokens.shift()\n            conditionalSource += ')})'\n            try {\n              const conditionFunction = maybeEval(elt, function() {\n                return Function(conditionalSource)()\n              },\n              function() { return true })\n              conditionFunction.source = conditionalSource\n              return conditionFunction\n            } catch (e) {\n              triggerErrorEvent(getDocument().body, 'htmx:syntax:error', { error: e, source: conditionalSource })\n              return null\n            }\n          }\n        } else if (token === '[') {\n          bracketCount++\n        }\n        if (isPossibleRelativeReference(token, last, paramName)) {\n          conditionalSource += '((' + paramName + '.' + token + ') ? (' + paramName + '.' + token + ') : (window.' + token + '))'\n        } else {\n          conditionalSource = conditionalSource + token\n        }\n        last = tokens.shift()\n      }\n    }\n  }\n\n  /**\n   * @param {string[]} tokens\n   * @param {RegExp} match\n   * @returns {string}\n   */\n  function consumeUntil(tokens, match) {\n    let result = ''\n    while (tokens.length > 0 && !match.test(tokens[0])) {\n      result += tokens.shift()\n    }\n    return result\n  }\n\n  /**\n   * @param {string[]} tokens\n   * @returns {string}\n   */\n  function consumeCSSSelector(tokens) {\n    let result\n    if (tokens.length > 0 && COMBINED_SELECTOR_START.test(tokens[0])) {\n      tokens.shift()\n      result = consumeUntil(tokens, COMBINED_SELECTOR_END).trim()\n      tokens.shift()\n    } else {\n      result = consumeUntil(tokens, WHITESPACE_OR_COMMA)\n    }\n    return result\n  }\n\n  const INPUT_SELECTOR = 'input, textarea, select'\n\n  /**\n   * @param {Element} elt\n   * @param {string} explicitTrigger\n   * @param {Object} cache for trigger specs\n   * @returns {HtmxTriggerSpecification[]}\n   */\n  function parseAndCacheTrigger(elt, explicitTrigger, cache) {\n    /** @type HtmxTriggerSpecification[] */\n    const triggerSpecs = []\n    const tokens = tokenizeString(explicitTrigger)\n    do {\n      consumeUntil(tokens, NOT_WHITESPACE)\n      const initialLength = tokens.length\n      const trigger = consumeUntil(tokens, /[,\\[\\s]/)\n      if (trigger !== '') {\n        if (trigger === 'every') {\n          /** @type HtmxTriggerSpecification */\n          const every = { trigger: 'every' }\n          consumeUntil(tokens, NOT_WHITESPACE)\n          every.pollInterval = parseInterval(consumeUntil(tokens, /[,\\[\\s]/))\n          consumeUntil(tokens, NOT_WHITESPACE)\n          var eventFilter = maybeGenerateConditional(elt, tokens, 'event')\n          if (eventFilter) {\n            every.eventFilter = eventFilter\n          }\n          triggerSpecs.push(every)\n        } else {\n          /** @type HtmxTriggerSpecification */\n          const triggerSpec = { trigger }\n          var eventFilter = maybeGenerateConditional(elt, tokens, 'event')\n          if (eventFilter) {\n            triggerSpec.eventFilter = eventFilter\n          }\n          while (tokens.length > 0 && tokens[0] !== ',') {\n            consumeUntil(tokens, NOT_WHITESPACE)\n            const token = tokens.shift()\n            if (token === 'changed') {\n              triggerSpec.changed = true\n            } else if (token === 'once') {\n              triggerSpec.once = true\n            } else if (token === 'consume') {\n              triggerSpec.consume = true\n            } else if (token === 'delay' && tokens[0] === ':') {\n              tokens.shift()\n              triggerSpec.delay = parseInterval(consumeUntil(tokens, WHITESPACE_OR_COMMA))\n            } else if (token === 'from' && tokens[0] === ':') {\n              tokens.shift()\n              if (COMBINED_SELECTOR_START.test(tokens[0])) {\n                var from_arg = consumeCSSSelector(tokens)\n              } else {\n                var from_arg = consumeUntil(tokens, WHITESPACE_OR_COMMA)\n                if (from_arg === 'closest' || from_arg === 'find' || from_arg === 'next' || from_arg === 'previous') {\n                  tokens.shift()\n                  const selector = consumeCSSSelector(tokens)\n                  // `next` and `previous` allow a selector-less syntax\n                  if (selector.length > 0) {\n                    from_arg += ' ' + selector\n                  }\n                }\n              }\n              triggerSpec.from = from_arg\n            } else if (token === 'target' && tokens[0] === ':') {\n              tokens.shift()\n              triggerSpec.target = consumeCSSSelector(tokens)\n            } else if (token === 'throttle' && tokens[0] === ':') {\n              tokens.shift()\n              triggerSpec.throttle = parseInterval(consumeUntil(tokens, WHITESPACE_OR_COMMA))\n            } else if (token === 'queue' && tokens[0] === ':') {\n              tokens.shift()\n              triggerSpec.queue = consumeUntil(tokens, WHITESPACE_OR_COMMA)\n            } else if (token === 'root' && tokens[0] === ':') {\n              tokens.shift()\n              triggerSpec[token] = consumeCSSSelector(tokens)\n            } else if (token === 'threshold' && tokens[0] === ':') {\n              tokens.shift()\n              triggerSpec[token] = consumeUntil(tokens, WHITESPACE_OR_COMMA)\n            } else {\n              triggerErrorEvent(elt, 'htmx:syntax:error', { token: tokens.shift() })\n            }\n          }\n          triggerSpecs.push(triggerSpec)\n        }\n      }\n      if (tokens.length === initialLength) {\n        triggerErrorEvent(elt, 'htmx:syntax:error', { token: tokens.shift() })\n      }\n      consumeUntil(tokens, NOT_WHITESPACE)\n    } while (tokens[0] === ',' && tokens.shift())\n    if (cache) {\n      cache[explicitTrigger] = triggerSpecs\n    }\n    return triggerSpecs\n  }\n\n  /**\n   * @param {Element} elt\n   * @returns {HtmxTriggerSpecification[]}\n   */\n  function getTriggerSpecs(elt) {\n    const explicitTrigger = getAttributeValue(elt, 'hx-trigger')\n    let triggerSpecs = []\n    if (explicitTrigger) {\n      const cache = htmx.config.triggerSpecsCache\n      triggerSpecs = (cache && cache[explicitTrigger]) || parseAndCacheTrigger(elt, explicitTrigger, cache)\n    }\n\n    if (triggerSpecs.length > 0) {\n      return triggerSpecs\n    } else if (matches(elt, 'form')) {\n      return [{ trigger: 'submit' }]\n    } else if (matches(elt, 'input[type=\"button\"], input[type=\"submit\"]')) {\n      return [{ trigger: 'click' }]\n    } else if (matches(elt, INPUT_SELECTOR)) {\n      return [{ trigger: 'change' }]\n    } else {\n      return [{ trigger: 'click' }]\n    }\n  }\n\n  /**\n   * @param {Element} elt\n   */\n  function cancelPolling(elt) {\n    getInternalData(elt).cancelled = true\n  }\n\n  /**\n   * @param {Element} elt\n   * @param {TriggerHandler} handler\n   * @param {HtmxTriggerSpecification} spec\n   */\n  function processPolling(elt, handler, spec) {\n    const nodeData = getInternalData(elt)\n    nodeData.timeout = getWindow().setTimeout(function() {\n      if (bodyContains(elt) && nodeData.cancelled !== true) {\n        if (!maybeFilterEvent(spec, elt, makeEvent('hx:poll:trigger', {\n          triggerSpec: spec,\n          target: elt\n        }))) {\n          handler(elt)\n        }\n        processPolling(elt, handler, spec)\n      }\n    }, spec.pollInterval)\n  }\n\n  /**\n   * @param {HTMLAnchorElement} elt\n   * @returns {boolean}\n   */\n  function isLocalLink(elt) {\n    return location.hostname === elt.hostname &&\n      getRawAttribute(elt, 'href') &&\n      getRawAttribute(elt, 'href').indexOf('#') !== 0\n  }\n\n  /**\n   * @param {Element} elt\n   */\n  function eltIsDisabled(elt) {\n    return closest(elt, htmx.config.disableSelector)\n  }\n\n  /**\n   * @param {Element} elt\n   * @param {HtmxNodeInternalData} nodeData\n   * @param {HtmxTriggerSpecification[]} triggerSpecs\n   */\n  function boostElement(elt, nodeData, triggerSpecs) {\n    if ((elt instanceof HTMLAnchorElement && isLocalLink(elt) && (elt.target === '' || elt.target === '_self')) || (elt.tagName === 'FORM' && String(getRawAttribute(elt, 'method')).toLowerCase() !== 'dialog')) {\n      nodeData.boosted = true\n      let verb, path\n      if (elt.tagName === 'A') {\n        verb = 'get'\n        path = getRawAttribute(elt, 'href')\n      } else {\n        const rawAttribute = getRawAttribute(elt, 'method')\n        verb = rawAttribute ? rawAttribute.toLowerCase() : 'get'\n        if (verb === 'get') {\n        }\n        path = getRawAttribute(elt, 'action')\n      }\n      triggerSpecs.forEach(function(triggerSpec) {\n        addEventListener(elt, function(node, evt) {\n          const elt = asElement(node)\n          if (eltIsDisabled(elt)) {\n            cleanUpElement(elt)\n            return\n          }\n          issueAjaxRequest(verb, path, elt, evt)\n        }, nodeData, triggerSpec, true)\n      })\n    }\n  }\n\n  /**\n   * @param {Event} evt\n   * @param {Node} node\n   * @returns {boolean}\n   */\n  function shouldCancel(evt, node) {\n    const elt = asElement(node)\n    if (!elt) {\n      return false\n    }\n    if (evt.type === 'submit' || evt.type === 'click') {\n      if (elt.tagName === 'FORM') {\n        return true\n      }\n      if (matches(elt, 'input[type=\"submit\"], button') && closest(elt, 'form') !== null) {\n        return true\n      }\n      if (elt instanceof HTMLAnchorElement && elt.href &&\n        (elt.getAttribute('href') === '#' || elt.getAttribute('href').indexOf('#') !== 0)) {\n        return true\n      }\n    }\n    return false\n  }\n\n  /**\n   * @param {Node} elt\n   * @param {Event|MouseEvent|KeyboardEvent|TouchEvent} evt\n   * @returns {boolean}\n   */\n  function ignoreBoostedAnchorCtrlClick(elt, evt) {\n    return getInternalData(elt).boosted && elt instanceof HTMLAnchorElement && evt.type === 'click' &&\n      // @ts-ignore this will resolve to undefined for events that don't define those properties, which is fine\n      (evt.ctrlKey || evt.metaKey)\n  }\n\n  /**\n   * @param {HtmxTriggerSpecification} triggerSpec\n   * @param {Node} elt\n   * @param {Event} evt\n   * @returns {boolean}\n   */\n  function maybeFilterEvent(triggerSpec, elt, evt) {\n    const eventFilter = triggerSpec.eventFilter\n    if (eventFilter) {\n      try {\n        return eventFilter.call(elt, evt) !== true\n      } catch (e) {\n        const source = eventFilter.source\n        triggerErrorEvent(getDocument().body, 'htmx:eventFilter:error', { error: e, source })\n        return true\n      }\n    }\n    return false\n  }\n\n  /**\n   * @param {Node} elt\n   * @param {TriggerHandler} handler\n   * @param {HtmxNodeInternalData} nodeData\n   * @param {HtmxTriggerSpecification} triggerSpec\n   * @param {boolean} [explicitCancel]\n   */\n  function addEventListener(elt, handler, nodeData, triggerSpec, explicitCancel) {\n    const elementData = getInternalData(elt)\n    /** @type {(Node|Window)[]} */\n    let eltsToListenOn\n    if (triggerSpec.from) {\n      eltsToListenOn = querySelectorAllExt(elt, triggerSpec.from)\n    } else {\n      eltsToListenOn = [elt]\n    }\n    // store the initial values of the elements, so we can tell if they change\n    if (triggerSpec.changed) {\n      eltsToListenOn.forEach(function(eltToListenOn) {\n        const eltToListenOnData = getInternalData(eltToListenOn)\n        // @ts-ignore value will be undefined for non-input elements, which is fine\n        eltToListenOnData.lastValue = eltToListenOn.value\n      })\n    }\n    forEach(eltsToListenOn, function(eltToListenOn) {\n      /** @type EventListener */\n      const eventListener = function(evt) {\n        if (!bodyContains(elt)) {\n          eltToListenOn.removeEventListener(triggerSpec.trigger, eventListener)\n          return\n        }\n        if (ignoreBoostedAnchorCtrlClick(elt, evt)) {\n          return\n        }\n        if (explicitCancel || shouldCancel(evt, elt)) {\n          evt.preventDefault()\n        }\n        if (maybeFilterEvent(triggerSpec, elt, evt)) {\n          return\n        }\n        const eventData = getInternalData(evt)\n        eventData.triggerSpec = triggerSpec\n        if (eventData.handledFor == null) {\n          eventData.handledFor = []\n        }\n        if (eventData.handledFor.indexOf(elt) < 0) {\n          eventData.handledFor.push(elt)\n          if (triggerSpec.consume) {\n            evt.stopPropagation()\n          }\n          if (triggerSpec.target && evt.target) {\n            if (!matches(asElement(evt.target), triggerSpec.target)) {\n              return\n            }\n          }\n          if (triggerSpec.once) {\n            if (elementData.triggeredOnce) {\n              return\n            } else {\n              elementData.triggeredOnce = true\n            }\n          }\n          if (triggerSpec.changed) {\n            const eltToListenOnData = getInternalData(eltToListenOn)\n            // @ts-ignore value will be undefined for non-input elements, which is fine\n            const value = eltToListenOn.value\n            if (eltToListenOnData.lastValue === value) {\n              return\n            }\n            eltToListenOnData.lastValue = value\n          }\n          if (elementData.delayed) {\n            clearTimeout(elementData.delayed)\n          }\n          if (elementData.throttle) {\n            return\n          }\n\n          if (triggerSpec.throttle > 0) {\n            if (!elementData.throttle) {\n              triggerEvent(elt, 'htmx:trigger')\n              handler(elt, evt)\n              elementData.throttle = getWindow().setTimeout(function() {\n                elementData.throttle = null\n              }, triggerSpec.throttle)\n            }\n          } else if (triggerSpec.delay > 0) {\n            elementData.delayed = getWindow().setTimeout(function() {\n              triggerEvent(elt, 'htmx:trigger')\n              handler(elt, evt)\n            }, triggerSpec.delay)\n          } else {\n            triggerEvent(elt, 'htmx:trigger')\n            handler(elt, evt)\n          }\n        }\n      }\n      if (nodeData.listenerInfos == null) {\n        nodeData.listenerInfos = []\n      }\n      nodeData.listenerInfos.push({\n        trigger: triggerSpec.trigger,\n        listener: eventListener,\n        on: eltToListenOn\n      })\n      eltToListenOn.addEventListener(triggerSpec.trigger, eventListener)\n    })\n  }\n\n  let windowIsScrolling = false // used by initScrollHandler\n  let scrollHandler = null\n  function initScrollHandler() {\n    if (!scrollHandler) {\n      scrollHandler = function() {\n        windowIsScrolling = true\n      }\n      window.addEventListener('scroll', scrollHandler)\n      setInterval(function() {\n        if (windowIsScrolling) {\n          windowIsScrolling = false\n          forEach(getDocument().querySelectorAll(\"[hx-trigger*='revealed'],[data-hx-trigger*='revealed']\"), function(elt) {\n            maybeReveal(elt)\n          })\n        }\n      }, 200)\n    }\n  }\n\n  /**\n   * @param {Element} elt\n   */\n  function maybeReveal(elt) {\n    if (!hasAttribute(elt, 'data-hx-revealed') && isScrolledIntoView(elt)) {\n      elt.setAttribute('data-hx-revealed', 'true')\n      const nodeData = getInternalData(elt)\n      if (nodeData.initHash) {\n        triggerEvent(elt, 'revealed')\n      } else {\n        // if the node isn't initialized, wait for it before triggering the request\n        elt.addEventListener('htmx:afterProcessNode', function() { triggerEvent(elt, 'revealed') }, { once: true })\n      }\n    }\n  }\n\n  //= ===================================================================\n\n  /**\n   * @param {Element} elt\n   * @param {TriggerHandler} handler\n   * @param {HtmxNodeInternalData} nodeData\n   * @param {number} delay\n   */\n  function loadImmediately(elt, handler, nodeData, delay) {\n    const load = function() {\n      if (!nodeData.loaded) {\n        nodeData.loaded = true\n        handler(elt)\n      }\n    }\n    if (delay > 0) {\n      getWindow().setTimeout(load, delay)\n    } else {\n      load()\n    }\n  }\n\n  /**\n   * @param {Element} elt\n   * @param {HtmxNodeInternalData} nodeData\n   * @param {HtmxTriggerSpecification[]} triggerSpecs\n   * @returns {boolean}\n   */\n  function processVerbs(elt, nodeData, triggerSpecs) {\n    let explicitAction = false\n    forEach(VERBS, function(verb) {\n      if (hasAttribute(elt, 'hx-' + verb)) {\n        const path = getAttributeValue(elt, 'hx-' + verb)\n        explicitAction = true\n        nodeData.path = path\n        nodeData.verb = verb\n        triggerSpecs.forEach(function(triggerSpec) {\n          addTriggerHandler(elt, triggerSpec, nodeData, function(node, evt) {\n            const elt = asElement(node)\n            if (closest(elt, htmx.config.disableSelector)) {\n              cleanUpElement(elt)\n              return\n            }\n            issueAjaxRequest(verb, path, elt, evt)\n          })\n        })\n      }\n    })\n    return explicitAction\n  }\n\n  /**\n   * @callback TriggerHandler\n   * @param {Node} elt\n   * @param {Event} [evt]\n   */\n\n  /**\n   * @param {Node} elt\n   * @param {HtmxTriggerSpecification} triggerSpec\n   * @param {HtmxNodeInternalData} nodeData\n   * @param {TriggerHandler} handler\n   */\n  function addTriggerHandler(elt, triggerSpec, nodeData, handler) {\n    if (triggerSpec.trigger === 'revealed') {\n      initScrollHandler()\n      addEventListener(elt, handler, nodeData, triggerSpec)\n      maybeReveal(asElement(elt))\n    } else if (triggerSpec.trigger === 'intersect') {\n      const observerOptions = {}\n      if (triggerSpec.root) {\n        observerOptions.root = querySelectorExt(elt, triggerSpec.root)\n      }\n      if (triggerSpec.threshold) {\n        observerOptions.threshold = parseFloat(triggerSpec.threshold)\n      }\n      const observer = new IntersectionObserver(function(entries) {\n        for (let i = 0; i < entries.length; i++) {\n          const entry = entries[i]\n          if (entry.isIntersecting) {\n            triggerEvent(elt, 'intersect')\n            break\n          }\n        }\n      }, observerOptions)\n      observer.observe(asElement(elt))\n      addEventListener(asElement(elt), handler, nodeData, triggerSpec)\n    } else if (triggerSpec.trigger === 'load') {\n      if (!maybeFilterEvent(triggerSpec, elt, makeEvent('load', { elt }))) {\n        loadImmediately(asElement(elt), handler, nodeData, triggerSpec.delay)\n      }\n    } else if (triggerSpec.pollInterval > 0) {\n      nodeData.polling = true\n      processPolling(asElement(elt), handler, triggerSpec)\n    } else {\n      addEventListener(elt, handler, nodeData, triggerSpec)\n    }\n  }\n\n  /**\n   * @param {Node} node\n   * @returns {boolean}\n   */\n  function shouldProcessHxOn(node) {\n    const elt = asElement(node)\n    if (!elt) {\n      return false\n    }\n    const attributes = elt.attributes\n    for (let j = 0; j < attributes.length; j++) {\n      const attrName = attributes[j].name\n      if (startsWith(attrName, 'hx-on:') || startsWith(attrName, 'data-hx-on:') ||\n        startsWith(attrName, 'hx-on-') || startsWith(attrName, 'data-hx-on-')) {\n        return true\n      }\n    }\n    return false\n  }\n\n  /**\n   * @param {Node} elt\n   * @returns {Element[]}\n   */\n  const HX_ON_QUERY = new XPathEvaluator()\n    .createExpression('.//*[@*[ starts-with(name(), \"hx-on:\") or starts-with(name(), \"data-hx-on:\") or' +\n      ' starts-with(name(), \"hx-on-\") or starts-with(name(), \"data-hx-on-\") ]]')\n\n  function processHXOnRoot(elt, elements) {\n    if (shouldProcessHxOn(elt)) {\n      elements.push(asElement(elt))\n    }\n    const iter = HX_ON_QUERY.evaluate(elt)\n    let node = null\n    while (node = iter.iterateNext()) elements.push(asElement(node))\n  }\n\n  function findHxOnWildcardElements(elt) {\n    /** @type {Element[]} */\n    const elements = []\n    if (elt instanceof DocumentFragment) {\n      for (const child of elt.childNodes) {\n        processHXOnRoot(child, elements)\n      }\n    } else {\n      processHXOnRoot(elt, elements)\n    }\n    return elements\n  }\n\n  /**\n   * @param {Element} elt\n   * @returns {NodeListOf<Element>|[]}\n   */\n  function findElementsToProcess(elt) {\n    if (elt.querySelectorAll) {\n      const boostedSelector = ', [hx-boost] a, [data-hx-boost] a, a[hx-boost], a[data-hx-boost]'\n\n      const extensionSelectors = []\n      for (const e in extensions) {\n        const extension = extensions[e]\n        if (extension.getSelectors) {\n          var selectors = extension.getSelectors()\n          if (selectors) {\n            extensionSelectors.push(selectors)\n          }\n        }\n      }\n\n      const results = elt.querySelectorAll(VERB_SELECTOR + boostedSelector + \", form, [type='submit'],\" +\n        ' [hx-ext], [data-hx-ext], [hx-trigger], [data-hx-trigger]' + extensionSelectors.flat().map(s => ', ' + s).join(''))\n\n      return results\n    } else {\n      return []\n    }\n  }\n\n  /**\n   * Handle submit buttons/inputs that have the form attribute set\n   * see https://developer.mozilla.org/docs/Web/HTML/Element/button\n   * @param {Event} evt\n   */\n  function maybeSetLastButtonClicked(evt) {\n    const elt = /** @type {HTMLButtonElement|HTMLInputElement} */ (closest(asElement(evt.target), \"button, input[type='submit']\"))\n    const internalData = getRelatedFormData(evt)\n    if (internalData) {\n      internalData.lastButtonClicked = elt\n    }\n  }\n\n  /**\n   * @param {Event} evt\n   */\n  function maybeUnsetLastButtonClicked(evt) {\n    const internalData = getRelatedFormData(evt)\n    if (internalData) {\n      internalData.lastButtonClicked = null\n    }\n  }\n\n  /**\n   * @param {Event} evt\n   * @returns {HtmxNodeInternalData|undefined}\n   */\n  function getRelatedFormData(evt) {\n    const elt = closest(asElement(evt.target), \"button, input[type='submit']\")\n    if (!elt) {\n      return\n    }\n    const form = resolveTarget('#' + getRawAttribute(elt, 'form'), elt.getRootNode()) || closest(elt, 'form')\n    if (!form) {\n      return\n    }\n    return getInternalData(form)\n  }\n\n  /**\n   * @param {EventTarget} elt\n   */\n  function initButtonTracking(elt) {\n    // need to handle both click and focus in:\n    //   focusin - in case someone tabs in to a button and hits the space bar\n    //   click - on OSX buttons do not focus on click see https://bugs.webkit.org/show_bug.cgi?id=13724\n    elt.addEventListener('click', maybeSetLastButtonClicked)\n    elt.addEventListener('focusin', maybeSetLastButtonClicked)\n    elt.addEventListener('focusout', maybeUnsetLastButtonClicked)\n  }\n\n  /**\n   * @param {Element} elt\n   * @param {string} eventName\n   * @param {string} code\n   */\n  function addHxOnEventHandler(elt, eventName, code) {\n    const nodeData = getInternalData(elt)\n    if (!Array.isArray(nodeData.onHandlers)) {\n      nodeData.onHandlers = []\n    }\n    let func\n    /** @type EventListener */\n    const listener = function(e) {\n      maybeEval(elt, function() {\n        if (eltIsDisabled(elt)) {\n          return\n        }\n        if (!func) {\n          func = new Function('event', code)\n        }\n        func.call(elt, e)\n      })\n    }\n    elt.addEventListener(eventName, listener)\n    nodeData.onHandlers.push({ event: eventName, listener })\n  }\n\n  /**\n   * @param {Element} elt\n   */\n  function processHxOnWildcard(elt) {\n    // wipe any previous on handlers so that this function takes precedence\n    deInitOnHandlers(elt)\n\n    for (let i = 0; i < elt.attributes.length; i++) {\n      const name = elt.attributes[i].name\n      const value = elt.attributes[i].value\n      if (startsWith(name, 'hx-on') || startsWith(name, 'data-hx-on')) {\n        const afterOnPosition = name.indexOf('-on') + 3\n        const nextChar = name.slice(afterOnPosition, afterOnPosition + 1)\n        if (nextChar === '-' || nextChar === ':') {\n          let eventName = name.slice(afterOnPosition + 1)\n          // if the eventName starts with a colon or dash, prepend \"htmx\" for shorthand support\n          if (startsWith(eventName, ':')) {\n            eventName = 'htmx' + eventName\n          } else if (startsWith(eventName, '-')) {\n            eventName = 'htmx:' + eventName.slice(1)\n          } else if (startsWith(eventName, 'htmx-')) {\n            eventName = 'htmx:' + eventName.slice(5)\n          }\n\n          addHxOnEventHandler(elt, eventName, value)\n        }\n      }\n    }\n  }\n\n  /**\n   * @param {Element|HTMLInputElement} elt\n   */\n  function initNode(elt) {\n    if (closest(elt, htmx.config.disableSelector)) {\n      cleanUpElement(elt)\n      return\n    }\n    const nodeData = getInternalData(elt)\n    if (nodeData.initHash !== attributeHash(elt)) {\n      // clean up any previously processed info\n      deInitNode(elt)\n\n      nodeData.initHash = attributeHash(elt)\n\n      triggerEvent(elt, 'htmx:beforeProcessNode')\n\n      // @ts-ignore value will be undefined for non-input elements, which is fine\n      if (elt.value) {\n        // @ts-ignore\n        nodeData.lastValue = elt.value\n      }\n\n      const triggerSpecs = getTriggerSpecs(elt)\n      const hasExplicitHttpAction = processVerbs(elt, nodeData, triggerSpecs)\n\n      if (!hasExplicitHttpAction) {\n        if (getClosestAttributeValue(elt, 'hx-boost') === 'true') {\n          boostElement(elt, nodeData, triggerSpecs)\n        } else if (hasAttribute(elt, 'hx-trigger')) {\n          triggerSpecs.forEach(function(triggerSpec) {\n            // For \"naked\" triggers, don't do anything at all\n            addTriggerHandler(elt, triggerSpec, nodeData, function() {\n            })\n          })\n        }\n      }\n\n      // Handle submit buttons/inputs that have the form attribute set\n      // see https://developer.mozilla.org/docs/Web/HTML/Element/button\n      if (elt.tagName === 'FORM' || (getRawAttribute(elt, 'type') === 'submit' && hasAttribute(elt, 'form'))) {\n        initButtonTracking(elt)\n      }\n\n      triggerEvent(elt, 'htmx:afterProcessNode')\n    }\n  }\n\n  /**\n   * Processes new content, enabling htmx behavior. This can be useful if you have content that is added to the DOM outside of the normal htmx request cycle but still want htmx attributes to work.\n   *\n   * @see https://htmx.org/api/#process\n   *\n   * @param {Element|string} elt element to process\n   */\n  function processNode(elt) {\n    elt = resolveTarget(elt)\n    if (closest(elt, htmx.config.disableSelector)) {\n      cleanUpElement(elt)\n      return\n    }\n    initNode(elt)\n    forEach(findElementsToProcess(elt), function(child) { initNode(child) })\n    forEach(findHxOnWildcardElements(elt), processHxOnWildcard)\n  }\n\n  //= ===================================================================\n  // Event/Log Support\n  //= ===================================================================\n\n  /**\n   * @param {string} str\n   * @returns {string}\n   */\n  function kebabEventName(str) {\n    return str.replace(/([a-z0-9])([A-Z])/g, '$1-$2').toLowerCase()\n  }\n\n  /**\n   * @param {string} eventName\n   * @param {any} detail\n   * @returns {CustomEvent}\n   */\n  function makeEvent(eventName, detail) {\n    let evt\n    if (window.CustomEvent && typeof window.CustomEvent === 'function') {\n      // TODO: `composed: true` here is a hack to make global event handlers work with events in shadow DOM\n      // This breaks expected encapsulation but needs to be here until decided otherwise by core devs\n      evt = new CustomEvent(eventName, { bubbles: true, cancelable: true, composed: true, detail })\n    } else {\n      evt = getDocument().createEvent('CustomEvent')\n      evt.initCustomEvent(eventName, true, true, detail)\n    }\n    return evt\n  }\n\n  /**\n   * @param {EventTarget|string} elt\n   * @param {string} eventName\n   * @param {any=} detail\n   */\n  function triggerErrorEvent(elt, eventName, detail) {\n    triggerEvent(elt, eventName, mergeObjects({ error: eventName }, detail))\n  }\n\n  /**\n   * @param {string} eventName\n   * @returns {boolean}\n   */\n  function ignoreEventForLogging(eventName) {\n    return eventName === 'htmx:afterProcessNode'\n  }\n\n  /**\n   * `withExtensions` locates all active extensions for a provided element, then\n   * executes the provided function using each of the active extensions.  It should\n   * be called internally at every extendable execution point in htmx.\n   *\n   * @param {Element} elt\n   * @param {(extension:HtmxExtension) => void} toDo\n   * @returns void\n   */\n  function withExtensions(elt, toDo) {\n    forEach(getExtensions(elt), function(extension) {\n      try {\n        toDo(extension)\n      } catch (e) {\n        logError(e)\n      }\n    })\n  }\n\n  function logError(msg) {\n    if (console.error) {\n      console.error(msg)\n    } else if (console.log) {\n      console.log('ERROR: ', msg)\n    }\n  }\n\n  /**\n   * Triggers a given event on an element\n   *\n   * @see https://htmx.org/api/#trigger\n   *\n   * @param {EventTarget|string} elt the element to trigger the event on\n   * @param {string} eventName the name of the event to trigger\n   * @param {any=} detail details for the event\n   * @returns {boolean}\n   */\n  function triggerEvent(elt, eventName, detail) {\n    elt = resolveTarget(elt)\n    if (detail == null) {\n      detail = {}\n    }\n    detail.elt = elt\n    const event = makeEvent(eventName, detail)\n    if (htmx.logger && !ignoreEventForLogging(eventName)) {\n      htmx.logger(elt, eventName, detail)\n    }\n    if (detail.error) {\n      logError(detail.error)\n      triggerEvent(elt, 'htmx:error', { errorInfo: detail })\n    }\n    let eventResult = elt.dispatchEvent(event)\n    const kebabName = kebabEventName(eventName)\n    if (eventResult && kebabName !== eventName) {\n      const kebabedEvent = makeEvent(kebabName, event.detail)\n      eventResult = eventResult && elt.dispatchEvent(kebabedEvent)\n    }\n    withExtensions(asElement(elt), function(extension) {\n      eventResult = eventResult && (extension.onEvent(eventName, event) !== false && !event.defaultPrevented)\n    })\n    return eventResult\n  }\n\n  //= ===================================================================\n  // History Support\n  //= ===================================================================\n  let currentPathForHistory = location.pathname + location.search\n\n  /**\n   * @returns {Element}\n   */\n  function getHistoryElement() {\n    const historyElt = getDocument().querySelector('[hx-history-elt],[data-hx-history-elt]')\n    return historyElt || getDocument().body\n  }\n\n  /**\n   * @param {string} url\n   * @param {Element} rootElt\n   */\n  function saveToHistoryCache(url, rootElt) {\n    if (!canAccessLocalStorage()) {\n      return\n    }\n\n    // get state to save\n    const innerHTML = cleanInnerHtmlForHistory(rootElt)\n    const title = getDocument().title\n    const scroll = window.scrollY\n\n    if (htmx.config.historyCacheSize <= 0) {\n      // make sure that an eventually already existing cache is purged\n      localStorage.removeItem('htmx-history-cache')\n      return\n    }\n\n    url = normalizePath(url)\n\n    const historyCache = parseJSON(localStorage.getItem('htmx-history-cache')) || []\n    for (let i = 0; i < historyCache.length; i++) {\n      if (historyCache[i].url === url) {\n        historyCache.splice(i, 1)\n        break\n      }\n    }\n\n    /** @type HtmxHistoryItem */\n    const newHistoryItem = { url, content: innerHTML, title, scroll }\n\n    triggerEvent(getDocument().body, 'htmx:historyItemCreated', { item: newHistoryItem, cache: historyCache })\n\n    historyCache.push(newHistoryItem)\n    while (historyCache.length > htmx.config.historyCacheSize) {\n      historyCache.shift()\n    }\n\n    // keep trying to save the cache until it succeeds or is empty\n    while (historyCache.length > 0) {\n      try {\n        localStorage.setItem('htmx-history-cache', JSON.stringify(historyCache))\n        break\n      } catch (e) {\n        triggerErrorEvent(getDocument().body, 'htmx:historyCacheError', { cause: e, cache: historyCache })\n        historyCache.shift() // shrink the cache and retry\n      }\n    }\n  }\n\n  /**\n   * @typedef {Object} HtmxHistoryItem\n   * @property {string} url\n   * @property {string} content\n   * @property {string} title\n   * @property {number} scroll\n   */\n\n  /**\n   * @param {string} url\n   * @returns {HtmxHistoryItem|null}\n   */\n  function getCachedHistory(url) {\n    if (!canAccessLocalStorage()) {\n      return null\n    }\n\n    url = normalizePath(url)\n\n    const historyCache = parseJSON(localStorage.getItem('htmx-history-cache')) || []\n    for (let i = 0; i < historyCache.length; i++) {\n      if (historyCache[i].url === url) {\n        return historyCache[i]\n      }\n    }\n    return null\n  }\n\n  /**\n   * @param {Element} elt\n   * @returns {string}\n   */\n  function cleanInnerHtmlForHistory(elt) {\n    const className = htmx.config.requestClass\n    const clone = /** @type Element */ (elt.cloneNode(true))\n    forEach(findAll(clone, '.' + className), function(child) {\n      removeClassFromElement(child, className)\n    })\n    // remove the disabled attribute for any element disabled due to an htmx request\n    forEach(findAll(clone, '[data-disabled-by-htmx]'), function(child) {\n      child.removeAttribute('disabled')\n    })\n    return clone.innerHTML\n  }\n\n  function saveCurrentPageToHistory() {\n    const elt = getHistoryElement()\n    const path = currentPathForHistory || location.pathname + location.search\n\n    // Allow history snapshot feature to be disabled where hx-history=\"false\"\n    // is present *anywhere* in the current document we're about to save,\n    // so we can prevent privileged data entering the cache.\n    // The page will still be reachable as a history entry, but htmx will fetch it\n    // live from the server onpopstate rather than look in the localStorage cache\n    let disableHistoryCache\n    try {\n      disableHistoryCache = getDocument().querySelector('[hx-history=\"false\" i],[data-hx-history=\"false\" i]')\n    } catch (e) {\n    // IE11: insensitive modifier not supported so fallback to case sensitive selector\n      disableHistoryCache = getDocument().querySelector('[hx-history=\"false\"],[data-hx-history=\"false\"]')\n    }\n    if (!disableHistoryCache) {\n      triggerEvent(getDocument().body, 'htmx:beforeHistorySave', { path, historyElt: elt })\n      saveToHistoryCache(path, elt)\n    }\n\n    if (htmx.config.historyEnabled) history.replaceState({ htmx: true }, getDocument().title, window.location.href)\n  }\n\n  /**\n   * @param {string} path\n   */\n  function pushUrlIntoHistory(path) {\n  // remove the cache buster parameter, if any\n    if (htmx.config.getCacheBusterParam) {\n      path = path.replace(/org\\.htmx\\.cache-buster=[^&]*&?/, '')\n      if (endsWith(path, '&') || endsWith(path, '?')) {\n        path = path.slice(0, -1)\n      }\n    }\n    if (htmx.config.historyEnabled) {\n      history.pushState({ htmx: true }, '', path)\n    }\n    currentPathForHistory = path\n  }\n\n  /**\n   * @param {string} path\n   */\n  function replaceUrlInHistory(path) {\n    if (htmx.config.historyEnabled) history.replaceState({ htmx: true }, '', path)\n    currentPathForHistory = path\n  }\n\n  /**\n   * @param {HtmxSettleTask[]} tasks\n   */\n  function settleImmediately(tasks) {\n    forEach(tasks, function(task) {\n      task.call(undefined)\n    })\n  }\n\n  /**\n   * @param {string} path\n   */\n  function loadHistoryFromServer(path) {\n    const request = new XMLHttpRequest()\n    const details = { path, xhr: request }\n    triggerEvent(getDocument().body, 'htmx:historyCacheMiss', details)\n    request.open('GET', path, true)\n    request.setRequestHeader('HX-Request', 'true')\n    request.setRequestHeader('HX-History-Restore-Request', 'true')\n    request.setRequestHeader('HX-Current-URL', getDocument().location.href)\n    request.onload = function() {\n      if (this.status >= 200 && this.status < 400) {\n        triggerEvent(getDocument().body, 'htmx:historyCacheMissLoad', details)\n        const fragment = makeFragment(this.response)\n        /** @type ParentNode */\n        const content = fragment.querySelector('[hx-history-elt],[data-hx-history-elt]') || fragment\n        const historyElement = getHistoryElement()\n        const settleInfo = makeSettleInfo(historyElement)\n        handleTitle(fragment.title)\n\n        swapInnerHTML(historyElement, content, settleInfo)\n        settleImmediately(settleInfo.tasks)\n        currentPathForHistory = path\n        triggerEvent(getDocument().body, 'htmx:historyRestore', { path, cacheMiss: true, serverResponse: this.response })\n      } else {\n        triggerErrorEvent(getDocument().body, 'htmx:historyCacheMissLoadError', details)\n      }\n    }\n    request.send()\n  }\n\n  /**\n   * @param {string} [path]\n   */\n  function restoreHistory(path) {\n    saveCurrentPageToHistory()\n    path = path || location.pathname + location.search\n    const cached = getCachedHistory(path)\n    if (cached) {\n      const fragment = makeFragment(cached.content)\n      const historyElement = getHistoryElement()\n      const settleInfo = makeSettleInfo(historyElement)\n      handleTitle(fragment.title)\n      swapInnerHTML(historyElement, fragment, settleInfo)\n      settleImmediately(settleInfo.tasks)\n      getWindow().setTimeout(function() {\n        window.scrollTo(0, cached.scroll)\n      }, 0) // next 'tick', so browser has time to render layout\n      currentPathForHistory = path\n      triggerEvent(getDocument().body, 'htmx:historyRestore', { path, item: cached })\n    } else {\n      if (htmx.config.refreshOnHistoryMiss) {\n        // @ts-ignore: optional parameter in reload() function throws error\n        // noinspection JSUnresolvedReference\n        window.location.reload(true)\n      } else {\n        loadHistoryFromServer(path)\n      }\n    }\n  }\n\n  /**\n   * @param {Element} elt\n   * @returns {Element[]}\n   */\n  function addRequestIndicatorClasses(elt) {\n    let indicators = /** @type Element[] */ (findAttributeTargets(elt, 'hx-indicator'))\n    if (indicators == null) {\n      indicators = [elt]\n    }\n    forEach(indicators, function(ic) {\n      const internalData = getInternalData(ic)\n      internalData.requestCount = (internalData.requestCount || 0) + 1\n      ic.classList.add.call(ic.classList, htmx.config.requestClass)\n    })\n    return indicators\n  }\n\n  /**\n   * @param {Element} elt\n   * @returns {Element[]}\n   */\n  function disableElements(elt) {\n    let disabledElts = /** @type Element[] */ (findAttributeTargets(elt, 'hx-disabled-elt'))\n    if (disabledElts == null) {\n      disabledElts = []\n    }\n    forEach(disabledElts, function(disabledElement) {\n      const internalData = getInternalData(disabledElement)\n      internalData.requestCount = (internalData.requestCount || 0) + 1\n      disabledElement.setAttribute('disabled', '')\n      disabledElement.setAttribute('data-disabled-by-htmx', '')\n    })\n    return disabledElts\n  }\n\n  /**\n   * @param {Element[]} indicators\n   * @param {Element[]} disabled\n   */\n  function removeRequestIndicators(indicators, disabled) {\n    forEach(indicators, function(ic) {\n      const internalData = getInternalData(ic)\n      internalData.requestCount = (internalData.requestCount || 0) - 1\n      if (internalData.requestCount === 0) {\n        ic.classList.remove.call(ic.classList, htmx.config.requestClass)\n      }\n    })\n    forEach(disabled, function(disabledElement) {\n      const internalData = getInternalData(disabledElement)\n      internalData.requestCount = (internalData.requestCount || 0) - 1\n      if (internalData.requestCount === 0) {\n        disabledElement.removeAttribute('disabled')\n        disabledElement.removeAttribute('data-disabled-by-htmx')\n      }\n    })\n  }\n\n  //= ===================================================================\n  // Input Value Processing\n  //= ===================================================================\n\n  /**\n   * @param {Element[]} processed\n   * @param {Element} elt\n   * @returns {boolean}\n   */\n  function haveSeenNode(processed, elt) {\n    for (let i = 0; i < processed.length; i++) {\n      const node = processed[i]\n      if (node.isSameNode(elt)) {\n        return true\n      }\n    }\n    return false\n  }\n\n  /**\n   * @param {Element} element\n   * @return {boolean}\n   */\n  function shouldInclude(element) {\n    // Cast to trick tsc, undefined values will work fine here\n    const elt = /** @type {HTMLInputElement} */ (element)\n    if (elt.name === '' || elt.name == null || elt.disabled || closest(elt, 'fieldset[disabled]')) {\n      return false\n    }\n    // ignore \"submitter\" types (see jQuery src/serialize.js)\n    if (elt.type === 'button' || elt.type === 'submit' || elt.tagName === 'image' || elt.tagName === 'reset' || elt.tagName === 'file') {\n      return false\n    }\n    if (elt.type === 'checkbox' || elt.type === 'radio') {\n      return elt.checked\n    }\n    return true\n  }\n\n  /** @param {string} name\n   * @param {string|Array|FormDataEntryValue} value\n   * @param {FormData} formData */\n  function addValueToFormData(name, value, formData) {\n    if (name != null && value != null) {\n      if (Array.isArray(value)) {\n        value.forEach(function(v) { formData.append(name, v) })\n      } else {\n        formData.append(name, value)\n      }\n    }\n  }\n\n  /** @param {string} name\n   * @param {string|Array} value\n   * @param {FormData} formData */\n  function removeValueFromFormData(name, value, formData) {\n    if (name != null && value != null) {\n      let values = formData.getAll(name)\n      if (Array.isArray(value)) {\n        values = values.filter(v => value.indexOf(v) < 0)\n      } else {\n        values = values.filter(v => v !== value)\n      }\n      formData.delete(name)\n      forEach(values, v => formData.append(name, v))\n    }\n  }\n\n  /**\n   * @param {Element[]} processed\n   * @param {FormData} formData\n   * @param {HtmxElementValidationError[]} errors\n   * @param {Element|HTMLInputElement|HTMLSelectElement|HTMLFormElement} elt\n   * @param {boolean} validate\n   */\n  function processInputValue(processed, formData, errors, elt, validate) {\n    if (elt == null || haveSeenNode(processed, elt)) {\n      return\n    } else {\n      processed.push(elt)\n    }\n    if (shouldInclude(elt)) {\n      const name = getRawAttribute(elt, 'name')\n      // @ts-ignore value will be undefined for non-input elements, which is fine\n      let value = elt.value\n      if (elt instanceof HTMLSelectElement && elt.multiple) {\n        value = toArray(elt.querySelectorAll('option:checked')).map(function(e) { return (/** @type HTMLOptionElement */(e)).value })\n      }\n      // include file inputs\n      if (elt instanceof HTMLInputElement && elt.files) {\n        value = toArray(elt.files)\n      }\n      addValueToFormData(name, value, formData)\n      if (validate) {\n        validateElement(elt, errors)\n      }\n    }\n    if (elt instanceof HTMLFormElement) {\n      forEach(elt.elements, function(input) {\n        if (processed.indexOf(input) >= 0) {\n          // The input has already been processed and added to the values, but the FormData that will be\n          //  constructed right after on the form, will include it once again. So remove that input's value\n          //  now to avoid duplicates\n          removeValueFromFormData(input.name, input.value, formData)\n        } else {\n          processed.push(input)\n        }\n        if (validate) {\n          validateElement(input, errors)\n        }\n      })\n      new FormData(elt).forEach(function(value, name) {\n        if (value instanceof File && value.name === '') {\n          return // ignore no-name files\n        }\n        addValueToFormData(name, value, formData)\n      })\n    }\n  }\n\n  /**\n   *\n   * @param {Element} elt\n   * @param {HtmxElementValidationError[]} errors\n   */\n  function validateElement(elt, errors) {\n    const element = /** @type {HTMLElement & ElementInternals} */ (elt)\n    if (element.willValidate) {\n      triggerEvent(element, 'htmx:validation:validate')\n      if (!element.checkValidity()) {\n        errors.push({ elt: element, message: element.validationMessage, validity: element.validity })\n        triggerEvent(element, 'htmx:validation:failed', { message: element.validationMessage, validity: element.validity })\n      }\n    }\n  }\n\n  /**\n   * Override values in the one FormData with those from another.\n   * @param {FormData} receiver the formdata that will be mutated\n   * @param {FormData} donor the formdata that will provide the overriding values\n   * @returns {FormData} the {@linkcode receiver}\n   */\n  function overrideFormData(receiver, donor) {\n    for (const key of donor.keys()) {\n      receiver.delete(key)\n    }\n    donor.forEach(function(value, key) {\n      receiver.append(key, value)\n    })\n    return receiver\n  }\n\n  /**\n * @param {Element|HTMLFormElement} elt\n * @param {HttpVerb} verb\n * @returns {{errors: HtmxElementValidationError[], formData: FormData, values: Object}}\n */\n  function getInputValues(elt, verb) {\n    /** @type Element[] */\n    const processed = []\n    const formData = new FormData()\n    const priorityFormData = new FormData()\n    /** @type HtmxElementValidationError[] */\n    const errors = []\n    const internalData = getInternalData(elt)\n    if (internalData.lastButtonClicked && !bodyContains(internalData.lastButtonClicked)) {\n      internalData.lastButtonClicked = null\n    }\n\n    // only validate when form is directly submitted and novalidate or formnovalidate are not set\n    // or if the element has an explicit hx-validate=\"true\" on it\n    let validate = (elt instanceof HTMLFormElement && elt.noValidate !== true) || getAttributeValue(elt, 'hx-validate') === 'true'\n    if (internalData.lastButtonClicked) {\n      validate = validate && internalData.lastButtonClicked.formNoValidate !== true\n    }\n\n    // for a non-GET include the closest form\n    if (verb !== 'get') {\n      processInputValue(processed, priorityFormData, errors, closest(elt, 'form'), validate)\n    }\n\n    // include the element itself\n    processInputValue(processed, formData, errors, elt, validate)\n\n    // if a button or submit was clicked last, include its value\n    if (internalData.lastButtonClicked || elt.tagName === 'BUTTON' ||\n    (elt.tagName === 'INPUT' && getRawAttribute(elt, 'type') === 'submit')) {\n      const button = internalData.lastButtonClicked || (/** @type HTMLInputElement|HTMLButtonElement */(elt))\n      const name = getRawAttribute(button, 'name')\n      addValueToFormData(name, button.value, priorityFormData)\n    }\n\n    // include any explicit includes\n    const includes = findAttributeTargets(elt, 'hx-include')\n    forEach(includes, function(node) {\n      processInputValue(processed, formData, errors, asElement(node), validate)\n      // if a non-form is included, include any input values within it\n      if (!matches(node, 'form')) {\n        forEach(asParentNode(node).querySelectorAll(INPUT_SELECTOR), function(descendant) {\n          processInputValue(processed, formData, errors, descendant, validate)\n        })\n      }\n    })\n\n    // values from a <form> take precedence, overriding the regular values\n    overrideFormData(formData, priorityFormData)\n\n    return { errors, formData, values: formDataProxy(formData) }\n  }\n\n  /**\n   * @param {string} returnStr\n   * @param {string} name\n   * @param {any} realValue\n   * @returns {string}\n   */\n  function appendParam(returnStr, name, realValue) {\n    if (returnStr !== '') {\n      returnStr += '&'\n    }\n    if (String(realValue) === '[object Object]') {\n      realValue = JSON.stringify(realValue)\n    }\n    const s = encodeURIComponent(realValue)\n    returnStr += encodeURIComponent(name) + '=' + s\n    return returnStr\n  }\n\n  /**\n   * @param {FormData|Object} values\n   * @returns string\n   */\n  function urlEncode(values) {\n    values = formDataFromObject(values)\n    let returnStr = ''\n    values.forEach(function(value, key) {\n      returnStr = appendParam(returnStr, key, value)\n    })\n    return returnStr\n  }\n\n  //= ===================================================================\n  // Ajax\n  //= ===================================================================\n\n  /**\n * @param {Element} elt\n * @param {Element} target\n * @param {string} prompt\n * @returns {HtmxHeaderSpecification}\n */\n  function getHeaders(elt, target, prompt) {\n    /** @type HtmxHeaderSpecification */\n    const headers = {\n      'HX-Request': 'true',\n      'HX-Trigger': getRawAttribute(elt, 'id'),\n      'HX-Trigger-Name': getRawAttribute(elt, 'name'),\n      'HX-Target': getAttributeValue(target, 'id'),\n      'HX-Current-URL': getDocument().location.href\n    }\n    getValuesForElement(elt, 'hx-headers', false, headers)\n    if (prompt !== undefined) {\n      headers['HX-Prompt'] = prompt\n    }\n    if (getInternalData(elt).boosted) {\n      headers['HX-Boosted'] = 'true'\n    }\n    return headers\n  }\n\n  /**\n * filterValues takes an object containing form input values\n * and returns a new object that only contains keys that are\n * specified by the closest \"hx-params\" attribute\n * @param {FormData} inputValues\n * @param {Element} elt\n * @returns {FormData}\n */\n  function filterValues(inputValues, elt) {\n    const paramsValue = getClosestAttributeValue(elt, 'hx-params')\n    if (paramsValue) {\n      if (paramsValue === 'none') {\n        return new FormData()\n      } else if (paramsValue === '*') {\n        return inputValues\n      } else if (paramsValue.indexOf('not ') === 0) {\n        forEach(paramsValue.substr(4).split(','), function(name) {\n          name = name.trim()\n          inputValues.delete(name)\n        })\n        return inputValues\n      } else {\n        const newValues = new FormData()\n        forEach(paramsValue.split(','), function(name) {\n          name = name.trim()\n          if (inputValues.has(name)) {\n            inputValues.getAll(name).forEach(function(value) { newValues.append(name, value) })\n          }\n        })\n        return newValues\n      }\n    } else {\n      return inputValues\n    }\n  }\n\n  /**\n   * @param {Element} elt\n   * @return {boolean}\n   */\n  function isAnchorLink(elt) {\n    return !!getRawAttribute(elt, 'href') && getRawAttribute(elt, 'href').indexOf('#') >= 0\n  }\n\n  /**\n * @param {Element} elt\n * @param {HtmxSwapStyle} [swapInfoOverride]\n * @returns {HtmxSwapSpecification}\n */\n  function getSwapSpecification(elt, swapInfoOverride) {\n    const swapInfo = swapInfoOverride || getClosestAttributeValue(elt, 'hx-swap')\n    /** @type HtmxSwapSpecification */\n    const swapSpec = {\n      swapStyle: getInternalData(elt).boosted ? 'innerHTML' : htmx.config.defaultSwapStyle,\n      swapDelay: htmx.config.defaultSwapDelay,\n      settleDelay: htmx.config.defaultSettleDelay\n    }\n    if (htmx.config.scrollIntoViewOnBoost && getInternalData(elt).boosted && !isAnchorLink(elt)) {\n      swapSpec.show = 'top'\n    }\n    if (swapInfo) {\n      const split = splitOnWhitespace(swapInfo)\n      if (split.length > 0) {\n        for (let i = 0; i < split.length; i++) {\n          const value = split[i]\n          if (value.indexOf('swap:') === 0) {\n            swapSpec.swapDelay = parseInterval(value.substr(5))\n          } else if (value.indexOf('settle:') === 0) {\n            swapSpec.settleDelay = parseInterval(value.substr(7))\n          } else if (value.indexOf('transition:') === 0) {\n            swapSpec.transition = value.substr(11) === 'true'\n          } else if (value.indexOf('ignoreTitle:') === 0) {\n            swapSpec.ignoreTitle = value.substr(12) === 'true'\n          } else if (value.indexOf('scroll:') === 0) {\n            const scrollSpec = value.substr(7)\n            var splitSpec = scrollSpec.split(':')\n            const scrollVal = splitSpec.pop()\n            var selectorVal = splitSpec.length > 0 ? splitSpec.join(':') : null\n            // @ts-ignore\n            swapSpec.scroll = scrollVal\n            swapSpec.scrollTarget = selectorVal\n          } else if (value.indexOf('show:') === 0) {\n            const showSpec = value.substr(5)\n            var splitSpec = showSpec.split(':')\n            const showVal = splitSpec.pop()\n            var selectorVal = splitSpec.length > 0 ? splitSpec.join(':') : null\n            swapSpec.show = showVal\n            swapSpec.showTarget = selectorVal\n          } else if (value.indexOf('focus-scroll:') === 0) {\n            const focusScrollVal = value.substr('focus-scroll:'.length)\n            swapSpec.focusScroll = focusScrollVal == 'true'\n          } else if (i == 0) {\n            swapSpec.swapStyle = value\n          } else {\n            logError('Unknown modifier in hx-swap: ' + value)\n          }\n        }\n      }\n    }\n    return swapSpec\n  }\n\n  /**\n   * @param {Element} elt\n   * @return {boolean}\n   */\n  function usesFormData(elt) {\n    return getClosestAttributeValue(elt, 'hx-encoding') === 'multipart/form-data' ||\n    (matches(elt, 'form') && getRawAttribute(elt, 'enctype') === 'multipart/form-data')\n  }\n\n  /**\n   * @param {XMLHttpRequest} xhr\n   * @param {Element} elt\n   * @param {FormData} filteredParameters\n   * @returns {*|string|null}\n   */\n  function encodeParamsForBody(xhr, elt, filteredParameters) {\n    let encodedParameters = null\n    withExtensions(elt, function(extension) {\n      if (encodedParameters == null) {\n        encodedParameters = extension.encodeParameters(xhr, filteredParameters, elt)\n      }\n    })\n    if (encodedParameters != null) {\n      return encodedParameters\n    } else {\n      if (usesFormData(elt)) {\n        // Force conversion to an actual FormData object in case filteredParameters is a formDataProxy\n        // See https://github.com/bigskysoftware/htmx/issues/2317\n        return overrideFormData(new FormData(), formDataFromObject(filteredParameters))\n      } else {\n        return urlEncode(filteredParameters)\n      }\n    }\n  }\n\n  /**\n *\n * @param {Element} target\n * @returns {HtmxSettleInfo}\n */\n  function makeSettleInfo(target) {\n    return { tasks: [], elts: [target] }\n  }\n\n  /**\n   * @param {Element[]} content\n   * @param {HtmxSwapSpecification} swapSpec\n   */\n  function updateScrollState(content, swapSpec) {\n    const first = content[0]\n    const last = content[content.length - 1]\n    if (swapSpec.scroll) {\n      var target = null\n      if (swapSpec.scrollTarget) {\n        target = asElement(querySelectorExt(first, swapSpec.scrollTarget))\n      }\n      if (swapSpec.scroll === 'top' && (first || target)) {\n        target = target || first\n        target.scrollTop = 0\n      }\n      if (swapSpec.scroll === 'bottom' && (last || target)) {\n        target = target || last\n        target.scrollTop = target.scrollHeight\n      }\n    }\n    if (swapSpec.show) {\n      var target = null\n      if (swapSpec.showTarget) {\n        let targetStr = swapSpec.showTarget\n        if (swapSpec.showTarget === 'window') {\n          targetStr = 'body'\n        }\n        target = asElement(querySelectorExt(first, targetStr))\n      }\n      if (swapSpec.show === 'top' && (first || target)) {\n        target = target || first\n        // @ts-ignore For some reason tsc doesn't recognize \"instant\" as a valid option for now\n        target.scrollIntoView({ block: 'start', behavior: htmx.config.scrollBehavior })\n      }\n      if (swapSpec.show === 'bottom' && (last || target)) {\n        target = target || last\n        // @ts-ignore For some reason tsc doesn't recognize \"instant\" as a valid option for now\n        target.scrollIntoView({ block: 'end', behavior: htmx.config.scrollBehavior })\n      }\n    }\n  }\n\n  /**\n * @param {Element} elt\n * @param {string} attr\n * @param {boolean=} evalAsDefault\n * @param {Object=} values\n * @returns {Object}\n */\n  function getValuesForElement(elt, attr, evalAsDefault, values) {\n    if (values == null) {\n      values = {}\n    }\n    if (elt == null) {\n      return values\n    }\n    const attributeValue = getAttributeValue(elt, attr)\n    if (attributeValue) {\n      let str = attributeValue.trim()\n      let evaluateValue = evalAsDefault\n      if (str === 'unset') {\n        return null\n      }\n      if (str.indexOf('javascript:') === 0) {\n        str = str.substr(11)\n        evaluateValue = true\n      } else if (str.indexOf('js:') === 0) {\n        str = str.substr(3)\n        evaluateValue = true\n      }\n      if (str.indexOf('{') !== 0) {\n        str = '{' + str + '}'\n      }\n      let varsValues\n      if (evaluateValue) {\n        varsValues = maybeEval(elt, function() { return Function('return (' + str + ')')() }, {})\n      } else {\n        varsValues = parseJSON(str)\n      }\n      for (const key in varsValues) {\n        if (varsValues.hasOwnProperty(key)) {\n          if (values[key] == null) {\n            values[key] = varsValues[key]\n          }\n        }\n      }\n    }\n    return getValuesForElement(asElement(parentElt(elt)), attr, evalAsDefault, values)\n  }\n\n  /**\n   * @param {EventTarget|string} elt\n   * @param {() => any} toEval\n   * @param {any=} defaultVal\n   * @returns {any}\n   */\n  function maybeEval(elt, toEval, defaultVal) {\n    if (htmx.config.allowEval) {\n      return toEval()\n    } else {\n      triggerErrorEvent(elt, 'htmx:evalDisallowedError')\n      return defaultVal\n    }\n  }\n\n  /**\n * @param {Element} elt\n * @param {*?} expressionVars\n * @returns\n */\n  function getHXVarsForElement(elt, expressionVars) {\n    return getValuesForElement(elt, 'hx-vars', true, expressionVars)\n  }\n\n  /**\n * @param {Element} elt\n * @param {*?} expressionVars\n * @returns\n */\n  function getHXValsForElement(elt, expressionVars) {\n    return getValuesForElement(elt, 'hx-vals', false, expressionVars)\n  }\n\n  /**\n * @param {Element} elt\n * @returns {FormData}\n */\n  function getExpressionVars(elt) {\n    return mergeObjects(getHXVarsForElement(elt), getHXValsForElement(elt))\n  }\n\n  /**\n   * @param {XMLHttpRequest} xhr\n   * @param {string} header\n   * @param {string|null} headerValue\n   */\n  function safelySetHeaderValue(xhr, header, headerValue) {\n    if (headerValue !== null) {\n      try {\n        xhr.setRequestHeader(header, headerValue)\n      } catch (e) {\n      // On an exception, try to set the header URI encoded instead\n        xhr.setRequestHeader(header, encodeURIComponent(headerValue))\n        xhr.setRequestHeader(header + '-URI-AutoEncoded', 'true')\n      }\n    }\n  }\n\n  /**\n   * @param {XMLHttpRequest} xhr\n   * @return {string}\n   */\n  function getPathFromResponse(xhr) {\n  // NB: IE11 does not support this stuff\n    if (xhr.responseURL && typeof (URL) !== 'undefined') {\n      try {\n        const url = new URL(xhr.responseURL)\n        return url.pathname + url.search\n      } catch (e) {\n        triggerErrorEvent(getDocument().body, 'htmx:badResponseUrl', { url: xhr.responseURL })\n      }\n    }\n  }\n\n  /**\n   * @param {XMLHttpRequest} xhr\n   * @param {RegExp} regexp\n   * @return {boolean}\n   */\n  function hasHeader(xhr, regexp) {\n    return regexp.test(xhr.getAllResponseHeaders())\n  }\n\n  /**\n   * Issues an htmx-style AJAX request\n   *\n   * @see https://htmx.org/api/#ajax\n   *\n   * @param {HttpVerb} verb\n   * @param {string} path the URL path to make the AJAX\n   * @param {Element|string|HtmxAjaxHelperContext} context the element to target (defaults to the **body**) | a selector for the target | a context object that contains any of the following\n   * @return {Promise<void>} Promise that resolves immediately if no request is sent, or when the request is complete\n   */\n  function ajaxHelper(verb, path, context) {\n    verb = (/** @type HttpVerb */(verb.toLowerCase()))\n    if (context) {\n      if (context instanceof Element || typeof context === 'string') {\n        return issueAjaxRequest(verb, path, null, null, {\n          targetOverride: resolveTarget(context),\n          returnPromise: true\n        })\n      } else {\n        return issueAjaxRequest(verb, path, resolveTarget(context.source), context.event,\n          {\n            handler: context.handler,\n            headers: context.headers,\n            values: context.values,\n            targetOverride: resolveTarget(context.target),\n            swapOverride: context.swap,\n            select: context.select,\n            returnPromise: true\n          })\n      }\n    } else {\n      return issueAjaxRequest(verb, path, null, null, {\n        returnPromise: true\n      })\n    }\n  }\n\n  /**\n   * @param {Element} elt\n   * @return {Element[]}\n   */\n  function hierarchyForElt(elt) {\n    const arr = []\n    while (elt) {\n      arr.push(elt)\n      elt = elt.parentElement\n    }\n    return arr\n  }\n\n  /**\n   * @param {Element} elt\n   * @param {string} path\n   * @param {HtmxRequestConfig} requestConfig\n   * @return {boolean}\n   */\n  function verifyPath(elt, path, requestConfig) {\n    let sameHost\n    let url\n    if (typeof URL === 'function') {\n      url = new URL(path, document.location.href)\n      const origin = document.location.origin\n      sameHost = origin === url.origin\n    } else {\n    // IE11 doesn't support URL\n      url = path\n      sameHost = startsWith(path, document.location.origin)\n    }\n\n    if (htmx.config.selfRequestsOnly) {\n      if (!sameHost) {\n        return false\n      }\n    }\n    return triggerEvent(elt, 'htmx:validateUrl', mergeObjects({ url, sameHost }, requestConfig))\n  }\n\n  /**\n   * @param {Object|FormData} obj\n   * @return {FormData}\n   */\n  function formDataFromObject(obj) {\n    if (obj instanceof FormData) return obj\n    const formData = new FormData()\n    for (const key in obj) {\n      if (obj.hasOwnProperty(key)) {\n        if (typeof obj[key].forEach === 'function') {\n          obj[key].forEach(function(v) { formData.append(key, v) })\n        } else if (typeof obj[key] === 'object' && !(obj[key] instanceof Blob)) {\n          formData.append(key, JSON.stringify(obj[key]))\n        } else {\n          formData.append(key, obj[key])\n        }\n      }\n    }\n    return formData\n  }\n\n  /**\n   * @param {FormData} formData\n   * @param {string} name\n   * @param {Array} array\n   * @returns {Array}\n   */\n  function formDataArrayProxy(formData, name, array) {\n    // mutating the array should mutate the underlying form data\n    return new Proxy(array, {\n      get: function(target, key) {\n        if (typeof key === 'number') return target[key]\n        if (key === 'length') return target.length\n        if (key === 'push') {\n          return function(value) {\n            target.push(value)\n            formData.append(name, value)\n          }\n        }\n        if (typeof target[key] === 'function') {\n          return function() {\n            target[key].apply(target, arguments)\n            formData.delete(name)\n            target.forEach(function(v) { formData.append(name, v) })\n          }\n        }\n\n        if (target[key] && target[key].length === 1) {\n          return target[key][0]\n        } else {\n          return target[key]\n        }\n      },\n      set: function(target, index, value) {\n        target[index] = value\n        formData.delete(name)\n        target.forEach(function(v) { formData.append(name, v) })\n        return true\n      }\n    })\n  }\n\n  /**\n   * @param {FormData} formData\n   * @returns {Object}\n   */\n  function formDataProxy(formData) {\n    return new Proxy(formData, {\n      get: function(target, name) {\n        if (typeof name === 'symbol') {\n          // Forward symbol calls to the FormData itself directly\n          return Reflect.get(target, name)\n        }\n        if (name === 'toJSON') {\n          // Support JSON.stringify call on proxy\n          return () => Object.fromEntries(formData)\n        }\n        if (name in target) {\n          // Wrap in function with apply to correctly bind the FormData context, as a direct call would result in an illegal invocation error\n          if (typeof target[name] === 'function') {\n            return function() {\n              return formData[name].apply(formData, arguments)\n            }\n          } else {\n            return target[name]\n          }\n        }\n        const array = formData.getAll(name)\n        // Those 2 undefined & single value returns are for retro-compatibility as we weren't using FormData before\n        if (array.length === 0) {\n          return undefined\n        } else if (array.length === 1) {\n          return array[0]\n        } else {\n          return formDataArrayProxy(target, name, array)\n        }\n      },\n      set: function(target, name, value) {\n        if (typeof name !== 'string') {\n          return false\n        }\n        target.delete(name)\n        if (typeof value.forEach === 'function') {\n          value.forEach(function(v) { target.append(name, v) })\n        } else if (typeof value === 'object' && !(value instanceof Blob)) {\n          target.append(name, JSON.stringify(value))\n        } else {\n          target.append(name, value)\n        }\n        return true\n      },\n      deleteProperty: function(target, name) {\n        if (typeof name === 'string') {\n          target.delete(name)\n        }\n        return true\n      },\n      // Support Object.assign call from proxy\n      ownKeys: function(target) {\n        return Reflect.ownKeys(Object.fromEntries(target))\n      },\n      getOwnPropertyDescriptor: function(target, prop) {\n        return Reflect.getOwnPropertyDescriptor(Object.fromEntries(target), prop)\n      }\n    })\n  }\n\n  /**\n   * @param {HttpVerb} verb\n   * @param {string} path\n   * @param {Element} elt\n   * @param {Event} event\n   * @param {HtmxAjaxEtc} [etc]\n   * @param {boolean} [confirmed]\n   * @return {Promise<void>}\n   */\n  function issueAjaxRequest(verb, path, elt, event, etc, confirmed) {\n    let resolve = null\n    let reject = null\n    etc = etc != null ? etc : {}\n    if (etc.returnPromise && typeof Promise !== 'undefined') {\n      var promise = new Promise(function(_resolve, _reject) {\n        resolve = _resolve\n        reject = _reject\n      })\n    }\n    if (elt == null) {\n      elt = getDocument().body\n    }\n    const responseHandler = etc.handler || handleAjaxResponse\n    const select = etc.select || null\n\n    if (!bodyContains(elt)) {\n    // do not issue requests for elements removed from the DOM\n      maybeCall(resolve)\n      return promise\n    }\n    const target = etc.targetOverride || asElement(getTarget(elt))\n    if (target == null || target == DUMMY_ELT) {\n      triggerErrorEvent(elt, 'htmx:targetError', { target: getAttributeValue(elt, 'hx-target') })\n      maybeCall(reject)\n      return promise\n    }\n\n    let eltData = getInternalData(elt)\n    const submitter = eltData.lastButtonClicked\n\n    if (submitter) {\n      const buttonPath = getRawAttribute(submitter, 'formaction')\n      if (buttonPath != null) {\n        path = buttonPath\n      }\n\n      const buttonVerb = getRawAttribute(submitter, 'formmethod')\n      if (buttonVerb != null) {\n      // ignore buttons with formmethod=\"dialog\"\n        if (buttonVerb.toLowerCase() !== 'dialog') {\n          verb = (/** @type HttpVerb */(buttonVerb))\n        }\n      }\n    }\n\n    const confirmQuestion = getClosestAttributeValue(elt, 'hx-confirm')\n    // allow event-based confirmation w/ a callback\n    if (confirmed === undefined) {\n      const issueRequest = function(skipConfirmation) {\n        return issueAjaxRequest(verb, path, elt, event, etc, !!skipConfirmation)\n      }\n      const confirmDetails = { target, elt, path, verb, triggeringEvent: event, etc, issueRequest, question: confirmQuestion }\n      if (triggerEvent(elt, 'htmx:confirm', confirmDetails) === false) {\n        maybeCall(resolve)\n        return promise\n      }\n    }\n\n    let syncElt = elt\n    let syncStrategy = getClosestAttributeValue(elt, 'hx-sync')\n    let queueStrategy = null\n    let abortable = false\n    if (syncStrategy) {\n      const syncStrings = syncStrategy.split(':')\n      const selector = syncStrings[0].trim()\n      if (selector === 'this') {\n        syncElt = findThisElement(elt, 'hx-sync')\n      } else {\n        syncElt = asElement(querySelectorExt(elt, selector))\n      }\n      // default to the drop strategy\n      syncStrategy = (syncStrings[1] || 'drop').trim()\n      eltData = getInternalData(syncElt)\n      if (syncStrategy === 'drop' && eltData.xhr && eltData.abortable !== true) {\n        maybeCall(resolve)\n        return promise\n      } else if (syncStrategy === 'abort') {\n        if (eltData.xhr) {\n          maybeCall(resolve)\n          return promise\n        } else {\n          abortable = true\n        }\n      } else if (syncStrategy === 'replace') {\n        triggerEvent(syncElt, 'htmx:abort') // abort the current request and continue\n      } else if (syncStrategy.indexOf('queue') === 0) {\n        const queueStrArray = syncStrategy.split(' ')\n        queueStrategy = (queueStrArray[1] || 'last').trim()\n      }\n    }\n\n    if (eltData.xhr) {\n      if (eltData.abortable) {\n        triggerEvent(syncElt, 'htmx:abort') // abort the current request and continue\n      } else {\n        if (queueStrategy == null) {\n          if (event) {\n            const eventData = getInternalData(event)\n            if (eventData && eventData.triggerSpec && eventData.triggerSpec.queue) {\n              queueStrategy = eventData.triggerSpec.queue\n            }\n          }\n          if (queueStrategy == null) {\n            queueStrategy = 'last'\n          }\n        }\n        if (eltData.queuedRequests == null) {\n          eltData.queuedRequests = []\n        }\n        if (queueStrategy === 'first' && eltData.queuedRequests.length === 0) {\n          eltData.queuedRequests.push(function() {\n            issueAjaxRequest(verb, path, elt, event, etc)\n          })\n        } else if (queueStrategy === 'all') {\n          eltData.queuedRequests.push(function() {\n            issueAjaxRequest(verb, path, elt, event, etc)\n          })\n        } else if (queueStrategy === 'last') {\n          eltData.queuedRequests = [] // dump existing queue\n          eltData.queuedRequests.push(function() {\n            issueAjaxRequest(verb, path, elt, event, etc)\n          })\n        }\n        maybeCall(resolve)\n        return promise\n      }\n    }\n\n    const xhr = new XMLHttpRequest()\n    eltData.xhr = xhr\n    eltData.abortable = abortable\n    const endRequestLock = function() {\n      eltData.xhr = null\n      eltData.abortable = false\n      if (eltData.queuedRequests != null &&\n      eltData.queuedRequests.length > 0) {\n        const queuedRequest = eltData.queuedRequests.shift()\n        queuedRequest()\n      }\n    }\n    const promptQuestion = getClosestAttributeValue(elt, 'hx-prompt')\n    if (promptQuestion) {\n      var promptResponse = prompt(promptQuestion)\n      // prompt returns null if cancelled and empty string if accepted with no entry\n      if (promptResponse === null ||\n      !triggerEvent(elt, 'htmx:prompt', { prompt: promptResponse, target })) {\n        maybeCall(resolve)\n        endRequestLock()\n        return promise\n      }\n    }\n\n    if (confirmQuestion && !confirmed) {\n      if (!confirm(confirmQuestion)) {\n        maybeCall(resolve)\n        endRequestLock()\n        return promise\n      }\n    }\n\n    let headers = getHeaders(elt, target, promptResponse)\n\n    if (verb !== 'get' && !usesFormData(elt)) {\n      headers['Content-Type'] = 'application/x-www-form-urlencoded'\n    }\n\n    if (etc.headers) {\n      headers = mergeObjects(headers, etc.headers)\n    }\n    const results = getInputValues(elt, verb)\n    let errors = results.errors\n    const rawFormData = results.formData\n    if (etc.values) {\n      overrideFormData(rawFormData, formDataFromObject(etc.values))\n    }\n    const expressionVars = formDataFromObject(getExpressionVars(elt))\n    const allFormData = overrideFormData(rawFormData, expressionVars)\n    let filteredFormData = filterValues(allFormData, elt)\n\n    if (htmx.config.getCacheBusterParam && verb === 'get') {\n      filteredFormData.set('org.htmx.cache-buster', getRawAttribute(target, 'id') || 'true')\n    }\n\n    // behavior of anchors w/ empty href is to use the current URL\n    if (path == null || path === '') {\n      path = getDocument().location.href\n    }\n\n    /**\n     * @type {Object}\n     * @property {boolean} [credentials]\n     * @property {number} [timeout]\n     * @property {boolean} [noHeaders]\n     */\n    const requestAttrValues = getValuesForElement(elt, 'hx-request')\n\n    const eltIsBoosted = getInternalData(elt).boosted\n\n    let useUrlParams = htmx.config.methodsThatUseUrlParams.indexOf(verb) >= 0\n\n    /** @type HtmxRequestConfig */\n    const requestConfig = {\n      boosted: eltIsBoosted,\n      useUrlParams,\n      formData: filteredFormData,\n      parameters: formDataProxy(filteredFormData),\n      unfilteredFormData: allFormData,\n      unfilteredParameters: formDataProxy(allFormData),\n      headers,\n      target,\n      verb,\n      errors,\n      withCredentials: etc.credentials || requestAttrValues.credentials || htmx.config.withCredentials,\n      timeout: etc.timeout || requestAttrValues.timeout || htmx.config.timeout,\n      path,\n      triggeringEvent: event\n    }\n\n    if (!triggerEvent(elt, 'htmx:configRequest', requestConfig)) {\n      maybeCall(resolve)\n      endRequestLock()\n      return promise\n    }\n\n    // copy out in case the object was overwritten\n    path = requestConfig.path\n    verb = requestConfig.verb\n    headers = requestConfig.headers\n    filteredFormData = formDataFromObject(requestConfig.parameters)\n    errors = requestConfig.errors\n    useUrlParams = requestConfig.useUrlParams\n\n    if (errors && errors.length > 0) {\n      triggerEvent(elt, 'htmx:validation:halted', requestConfig)\n      maybeCall(resolve)\n      endRequestLock()\n      return promise\n    }\n\n    const splitPath = path.split('#')\n    const pathNoAnchor = splitPath[0]\n    const anchor = splitPath[1]\n\n    let finalPath = path\n    if (useUrlParams) {\n      finalPath = pathNoAnchor\n      const hasValues = !filteredFormData.keys().next().done\n      if (hasValues) {\n        if (finalPath.indexOf('?') < 0) {\n          finalPath += '?'\n        } else {\n          finalPath += '&'\n        }\n        finalPath += urlEncode(filteredFormData)\n        if (anchor) {\n          finalPath += '#' + anchor\n        }\n      }\n    }\n\n    if (!verifyPath(elt, finalPath, requestConfig)) {\n      triggerErrorEvent(elt, 'htmx:invalidPath', requestConfig)\n      maybeCall(reject)\n      return promise\n    }\n\n    xhr.open(verb.toUpperCase(), finalPath, true)\n    xhr.overrideMimeType('text/html')\n    xhr.withCredentials = requestConfig.withCredentials\n    xhr.timeout = requestConfig.timeout\n\n    // request headers\n    if (requestAttrValues.noHeaders) {\n    // ignore all headers\n    } else {\n      for (const header in headers) {\n        if (headers.hasOwnProperty(header)) {\n          const headerValue = headers[header]\n          safelySetHeaderValue(xhr, header, headerValue)\n        }\n      }\n    }\n\n    /** @type {HtmxResponseInfo} */\n    const responseInfo = {\n      xhr,\n      target,\n      requestConfig,\n      etc,\n      boosted: eltIsBoosted,\n      select,\n      pathInfo: {\n        requestPath: path,\n        finalRequestPath: finalPath,\n        responsePath: null,\n        anchor\n      }\n    }\n\n    xhr.onload = function() {\n      try {\n        const hierarchy = hierarchyForElt(elt)\n        responseInfo.pathInfo.responsePath = getPathFromResponse(xhr)\n        responseHandler(elt, responseInfo)\n        if (responseInfo.keepIndicators !== true) {\n          removeRequestIndicators(indicators, disableElts)\n        }\n        triggerEvent(elt, 'htmx:afterRequest', responseInfo)\n        triggerEvent(elt, 'htmx:afterOnLoad', responseInfo)\n        // if the body no longer contains the element, trigger the event on the closest parent\n        // remaining in the DOM\n        if (!bodyContains(elt)) {\n          let secondaryTriggerElt = null\n          while (hierarchy.length > 0 && secondaryTriggerElt == null) {\n            const parentEltInHierarchy = hierarchy.shift()\n            if (bodyContains(parentEltInHierarchy)) {\n              secondaryTriggerElt = parentEltInHierarchy\n            }\n          }\n          if (secondaryTriggerElt) {\n            triggerEvent(secondaryTriggerElt, 'htmx:afterRequest', responseInfo)\n            triggerEvent(secondaryTriggerElt, 'htmx:afterOnLoad', responseInfo)\n          }\n        }\n        maybeCall(resolve)\n        endRequestLock()\n      } catch (e) {\n        triggerErrorEvent(elt, 'htmx:onLoadError', mergeObjects({ error: e }, responseInfo))\n        throw e\n      }\n    }\n    xhr.onerror = function() {\n      removeRequestIndicators(indicators, disableElts)\n      triggerErrorEvent(elt, 'htmx:afterRequest', responseInfo)\n      triggerErrorEvent(elt, 'htmx:sendError', responseInfo)\n      maybeCall(reject)\n      endRequestLock()\n    }\n    xhr.onabort = function() {\n      removeRequestIndicators(indicators, disableElts)\n      triggerErrorEvent(elt, 'htmx:afterRequest', responseInfo)\n      triggerErrorEvent(elt, 'htmx:sendAbort', responseInfo)\n      maybeCall(reject)\n      endRequestLock()\n    }\n    xhr.ontimeout = function() {\n      removeRequestIndicators(indicators, disableElts)\n      triggerErrorEvent(elt, 'htmx:afterRequest', responseInfo)\n      triggerErrorEvent(elt, 'htmx:timeout', responseInfo)\n      maybeCall(reject)\n      endRequestLock()\n    }\n    if (!triggerEvent(elt, 'htmx:beforeRequest', responseInfo)) {\n      maybeCall(resolve)\n      endRequestLock()\n      return promise\n    }\n    var indicators = addRequestIndicatorClasses(elt)\n    var disableElts = disableElements(elt)\n\n    forEach(['loadstart', 'loadend', 'progress', 'abort'], function(eventName) {\n      forEach([xhr, xhr.upload], function(target) {\n        target.addEventListener(eventName, function(event) {\n          triggerEvent(elt, 'htmx:xhr:' + eventName, {\n            lengthComputable: event.lengthComputable,\n            loaded: event.loaded,\n            total: event.total\n          })\n        })\n      })\n    })\n    triggerEvent(elt, 'htmx:beforeSend', responseInfo)\n    const params = useUrlParams ? null : encodeParamsForBody(xhr, elt, filteredFormData)\n    xhr.send(params)\n    return promise\n  }\n\n  /**\n   * @typedef {Object} HtmxHistoryUpdate\n   * @property {string|null} [type]\n   * @property {string|null} [path]\n   */\n\n  /**\n   * @param {Element} elt\n   * @param {HtmxResponseInfo} responseInfo\n   * @return {HtmxHistoryUpdate}\n   */\n  function determineHistoryUpdates(elt, responseInfo) {\n    const xhr = responseInfo.xhr\n\n    //= ==========================================\n    // First consult response headers\n    //= ==========================================\n    let pathFromHeaders = null\n    let typeFromHeaders = null\n    if (hasHeader(xhr, /HX-Push:/i)) {\n      pathFromHeaders = xhr.getResponseHeader('HX-Push')\n      typeFromHeaders = 'push'\n    } else if (hasHeader(xhr, /HX-Push-Url:/i)) {\n      pathFromHeaders = xhr.getResponseHeader('HX-Push-Url')\n      typeFromHeaders = 'push'\n    } else if (hasHeader(xhr, /HX-Replace-Url:/i)) {\n      pathFromHeaders = xhr.getResponseHeader('HX-Replace-Url')\n      typeFromHeaders = 'replace'\n    }\n\n    // if there was a response header, that has priority\n    if (pathFromHeaders) {\n      if (pathFromHeaders === 'false') {\n        return {}\n      } else {\n        return {\n          type: typeFromHeaders,\n          path: pathFromHeaders\n        }\n      }\n    }\n\n    //= ==========================================\n    // Next resolve via DOM values\n    //= ==========================================\n    const requestPath = responseInfo.pathInfo.finalRequestPath\n    const responsePath = responseInfo.pathInfo.responsePath\n\n    const pushUrl = getClosestAttributeValue(elt, 'hx-push-url')\n    const replaceUrl = getClosestAttributeValue(elt, 'hx-replace-url')\n    const elementIsBoosted = getInternalData(elt).boosted\n\n    let saveType = null\n    let path = null\n\n    if (pushUrl) {\n      saveType = 'push'\n      path = pushUrl\n    } else if (replaceUrl) {\n      saveType = 'replace'\n      path = replaceUrl\n    } else if (elementIsBoosted) {\n      saveType = 'push'\n      path = responsePath || requestPath // if there is no response path, go with the original request path\n    }\n\n    if (path) {\n    // false indicates no push, return empty object\n      if (path === 'false') {\n        return {}\n      }\n\n      // true indicates we want to follow wherever the server ended up sending us\n      if (path === 'true') {\n        path = responsePath || requestPath // if there is no response path, go with the original request path\n      }\n\n      // restore any anchor associated with the request\n      if (responseInfo.pathInfo.anchor && path.indexOf('#') === -1) {\n        path = path + '#' + responseInfo.pathInfo.anchor\n      }\n\n      return {\n        type: saveType,\n        path\n      }\n    } else {\n      return {}\n    }\n  }\n\n  /**\n   * @param {HtmxResponseHandlingConfig} responseHandlingConfig\n   * @param {number} status\n   * @return {boolean}\n   */\n  function codeMatches(responseHandlingConfig, status) {\n    var regExp = new RegExp(responseHandlingConfig.code)\n    return regExp.test(status.toString(10))\n  }\n\n  /**\n   * @param {XMLHttpRequest} xhr\n   * @return {HtmxResponseHandlingConfig}\n   */\n  function resolveResponseHandling(xhr) {\n    for (var i = 0; i < htmx.config.responseHandling.length; i++) {\n      /** @type HtmxResponseHandlingConfig */\n      var responseHandlingElement = htmx.config.responseHandling[i]\n      if (codeMatches(responseHandlingElement, xhr.status)) {\n        return responseHandlingElement\n      }\n    }\n    // no matches, return no swap\n    return {\n      swap: false\n    }\n  }\n\n  /**\n   * @param {string} title\n   */\n  function handleTitle(title) {\n    if (title) {\n      const titleElt = find('title')\n      if (titleElt) {\n        titleElt.innerHTML = title\n      } else {\n        window.document.title = title\n      }\n    }\n  }\n\n  /**\n   * @param {Element} elt\n   * @param {HtmxResponseInfo} responseInfo\n   */\n  function handleAjaxResponse(elt, responseInfo) {\n    const xhr = responseInfo.xhr\n    let target = responseInfo.target\n    const etc = responseInfo.etc\n    const responseInfoSelect = responseInfo.select\n\n    if (!triggerEvent(elt, 'htmx:beforeOnLoad', responseInfo)) return\n\n    if (hasHeader(xhr, /HX-Trigger:/i)) {\n      handleTriggerHeader(xhr, 'HX-Trigger', elt)\n    }\n\n    if (hasHeader(xhr, /HX-Location:/i)) {\n      saveCurrentPageToHistory()\n      let redirectPath = xhr.getResponseHeader('HX-Location')\n      /** @type {HtmxAjaxHelperContext&{path:string}} */\n      var redirectSwapSpec\n      if (redirectPath.indexOf('{') === 0) {\n        redirectSwapSpec = parseJSON(redirectPath)\n        // what's the best way to throw an error if the user didn't include this\n        redirectPath = redirectSwapSpec.path\n        delete redirectSwapSpec.path\n      }\n      ajaxHelper('get', redirectPath, redirectSwapSpec).then(function() {\n        pushUrlIntoHistory(redirectPath)\n      })\n      return\n    }\n\n    const shouldRefresh = hasHeader(xhr, /HX-Refresh:/i) && xhr.getResponseHeader('HX-Refresh') === 'true'\n\n    if (hasHeader(xhr, /HX-Redirect:/i)) {\n      responseInfo.keepIndicators = true\n      location.href = xhr.getResponseHeader('HX-Redirect')\n      shouldRefresh && location.reload()\n      return\n    }\n\n    if (shouldRefresh) {\n      responseInfo.keepIndicators = true\n      location.reload()\n      return\n    }\n\n    if (hasHeader(xhr, /HX-Retarget:/i)) {\n      if (xhr.getResponseHeader('HX-Retarget') === 'this') {\n        responseInfo.target = elt\n      } else {\n        responseInfo.target = asElement(querySelectorExt(elt, xhr.getResponseHeader('HX-Retarget')))\n      }\n    }\n\n    const historyUpdate = determineHistoryUpdates(elt, responseInfo)\n\n    const responseHandling = resolveResponseHandling(xhr)\n    const shouldSwap = responseHandling.swap\n    let isError = !!responseHandling.error\n    let ignoreTitle = htmx.config.ignoreTitle || responseHandling.ignoreTitle\n    let selectOverride = responseHandling.select\n    if (responseHandling.target) {\n      responseInfo.target = asElement(querySelectorExt(elt, responseHandling.target))\n    }\n    var swapOverride = etc.swapOverride\n    if (swapOverride == null && responseHandling.swapOverride) {\n      swapOverride = responseHandling.swapOverride\n    }\n\n    // response headers override response handling config\n    if (hasHeader(xhr, /HX-Retarget:/i)) {\n      if (xhr.getResponseHeader('HX-Retarget') === 'this') {\n        responseInfo.target = elt\n      } else {\n        responseInfo.target = asElement(querySelectorExt(elt, xhr.getResponseHeader('HX-Retarget')))\n      }\n    }\n    if (hasHeader(xhr, /HX-Reswap:/i)) {\n      swapOverride = xhr.getResponseHeader('HX-Reswap')\n    }\n\n    var serverResponse = xhr.response\n    /** @type HtmxBeforeSwapDetails */\n    var beforeSwapDetails = mergeObjects({\n      shouldSwap,\n      serverResponse,\n      isError,\n      ignoreTitle,\n      selectOverride\n    }, responseInfo)\n\n    if (responseHandling.event && !triggerEvent(target, responseHandling.event, beforeSwapDetails)) return\n\n    if (!triggerEvent(target, 'htmx:beforeSwap', beforeSwapDetails)) return\n\n    target = beforeSwapDetails.target // allow re-targeting\n    serverResponse = beforeSwapDetails.serverResponse // allow updating content\n    isError = beforeSwapDetails.isError // allow updating error\n    ignoreTitle = beforeSwapDetails.ignoreTitle // allow updating ignoring title\n    selectOverride = beforeSwapDetails.selectOverride // allow updating select override\n\n    responseInfo.target = target // Make updated target available to response events\n    responseInfo.failed = isError // Make failed property available to response events\n    responseInfo.successful = !isError // Make successful property available to response events\n\n    if (beforeSwapDetails.shouldSwap) {\n      if (xhr.status === 286) {\n        cancelPolling(elt)\n      }\n\n      withExtensions(elt, function(extension) {\n        serverResponse = extension.transformResponse(serverResponse, xhr, elt)\n      })\n\n      // Save current page if there will be a history update\n      if (historyUpdate.type) {\n        saveCurrentPageToHistory()\n      }\n\n      if (hasHeader(xhr, /HX-Reswap:/i)) {\n        swapOverride = xhr.getResponseHeader('HX-Reswap')\n      }\n      var swapSpec = getSwapSpecification(elt, swapOverride)\n\n      if (!swapSpec.hasOwnProperty('ignoreTitle')) {\n        swapSpec.ignoreTitle = ignoreTitle\n      }\n\n      target.classList.add(htmx.config.swappingClass)\n\n      // optional transition API promise callbacks\n      let settleResolve = null\n      let settleReject = null\n\n      if (responseInfoSelect) {\n        selectOverride = responseInfoSelect\n      }\n\n      if (hasHeader(xhr, /HX-Reselect:/i)) {\n        selectOverride = xhr.getResponseHeader('HX-Reselect')\n      }\n\n      const selectOOB = getClosestAttributeValue(elt, 'hx-select-oob')\n      const select = getClosestAttributeValue(elt, 'hx-select')\n\n      let doSwap = function() {\n        try {\n          // if we need to save history, do so, before swapping so that relative resources have the correct base URL\n          if (historyUpdate.type) {\n            triggerEvent(getDocument().body, 'htmx:beforeHistoryUpdate', mergeObjects({ history: historyUpdate }, responseInfo))\n            if (historyUpdate.type === 'push') {\n              pushUrlIntoHistory(historyUpdate.path)\n              triggerEvent(getDocument().body, 'htmx:pushedIntoHistory', { path: historyUpdate.path })\n            } else {\n              replaceUrlInHistory(historyUpdate.path)\n              triggerEvent(getDocument().body, 'htmx:replacedInHistory', { path: historyUpdate.path })\n            }\n          }\n\n          swap(target, serverResponse, swapSpec, {\n            select: selectOverride || select,\n            selectOOB,\n            eventInfo: responseInfo,\n            anchor: responseInfo.pathInfo.anchor,\n            contextElement: elt,\n            afterSwapCallback: function() {\n              if (hasHeader(xhr, /HX-Trigger-After-Swap:/i)) {\n                let finalElt = elt\n                if (!bodyContains(elt)) {\n                  finalElt = getDocument().body\n                }\n                handleTriggerHeader(xhr, 'HX-Trigger-After-Swap', finalElt)\n              }\n            },\n            afterSettleCallback: function() {\n              if (hasHeader(xhr, /HX-Trigger-After-Settle:/i)) {\n                let finalElt = elt\n                if (!bodyContains(elt)) {\n                  finalElt = getDocument().body\n                }\n                handleTriggerHeader(xhr, 'HX-Trigger-After-Settle', finalElt)\n              }\n              maybeCall(settleResolve)\n            }\n          })\n        } catch (e) {\n          triggerErrorEvent(elt, 'htmx:swapError', responseInfo)\n          maybeCall(settleReject)\n          throw e\n        }\n      }\n\n      let shouldTransition = htmx.config.globalViewTransitions\n      if (swapSpec.hasOwnProperty('transition')) {\n        shouldTransition = swapSpec.transition\n      }\n\n      if (shouldTransition &&\n              triggerEvent(elt, 'htmx:beforeTransition', responseInfo) &&\n              typeof Promise !== 'undefined' &&\n              // @ts-ignore experimental feature atm\n              document.startViewTransition) {\n        const settlePromise = new Promise(function(_resolve, _reject) {\n          settleResolve = _resolve\n          settleReject = _reject\n        })\n        // wrap the original doSwap() in a call to startViewTransition()\n        const innerDoSwap = doSwap\n        doSwap = function() {\n          // @ts-ignore experimental feature atm\n          document.startViewTransition(function() {\n            innerDoSwap()\n            return settlePromise\n          })\n        }\n      }\n\n      if (swapSpec.swapDelay > 0) {\n        getWindow().setTimeout(doSwap, swapSpec.swapDelay)\n      } else {\n        doSwap()\n      }\n    }\n    if (isError) {\n      triggerErrorEvent(elt, 'htmx:responseError', mergeObjects({ error: 'Response Status Error Code ' + xhr.status + ' from ' + responseInfo.pathInfo.requestPath }, responseInfo))\n    }\n  }\n\n  //= ===================================================================\n  // Extensions API\n  //= ===================================================================\n\n  /** @type {Object<string, HtmxExtension>} */\n  const extensions = {}\n\n  /**\n   * extensionBase defines the default functions for all extensions.\n   * @returns {HtmxExtension}\n   */\n  function extensionBase() {\n    return {\n      init: function(api) { return null },\n      getSelectors: function() { return null },\n      onEvent: function(name, evt) { return true },\n      transformResponse: function(text, xhr, elt) { return text },\n      isInlineSwap: function(swapStyle) { return false },\n      handleSwap: function(swapStyle, target, fragment, settleInfo) { return false },\n      encodeParameters: function(xhr, parameters, elt) { return null }\n    }\n  }\n\n  /**\n   * defineExtension initializes the extension and adds it to the htmx registry\n   *\n   * @see https://htmx.org/api/#defineExtension\n   *\n   * @param {string} name the extension name\n   * @param {HtmxExtension} extension the extension definition\n   */\n  function defineExtension(name, extension) {\n    if (extension.init) {\n      extension.init(internalAPI)\n    }\n    extensions[name] = mergeObjects(extensionBase(), extension)\n  }\n\n  /**\n   * removeExtension removes an extension from the htmx registry\n   *\n   * @see https://htmx.org/api/#removeExtension\n   *\n   * @param {string} name\n   */\n  function removeExtension(name) {\n    delete extensions[name]\n  }\n\n  /**\n   * getExtensions searches up the DOM tree to return all extensions that can be applied to a given element\n   *\n   * @param {Element} elt\n   * @param {HtmxExtension[]=} extensionsToReturn\n   * @param {string[]=} extensionsToIgnore\n   * @returns {HtmxExtension[]}\n   */\n  function getExtensions(elt, extensionsToReturn, extensionsToIgnore) {\n    if (extensionsToReturn == undefined) {\n      extensionsToReturn = []\n    }\n    if (elt == undefined) {\n      return extensionsToReturn\n    }\n    if (extensionsToIgnore == undefined) {\n      extensionsToIgnore = []\n    }\n    const extensionsForElement = getAttributeValue(elt, 'hx-ext')\n    if (extensionsForElement) {\n      forEach(extensionsForElement.split(','), function(extensionName) {\n        extensionName = extensionName.replace(/ /g, '')\n        if (extensionName.slice(0, 7) == 'ignore:') {\n          extensionsToIgnore.push(extensionName.slice(7))\n          return\n        }\n        if (extensionsToIgnore.indexOf(extensionName) < 0) {\n          const extension = extensions[extensionName]\n          if (extension && extensionsToReturn.indexOf(extension) < 0) {\n            extensionsToReturn.push(extension)\n          }\n        }\n      })\n    }\n    return getExtensions(asElement(parentElt(elt)), extensionsToReturn, extensionsToIgnore)\n  }\n\n  //= ===================================================================\n  // Initialization\n  //= ===================================================================\n  var isReady = false\n  getDocument().addEventListener('DOMContentLoaded', function() {\n    isReady = true\n  })\n\n  /**\n   * Execute a function now if DOMContentLoaded has fired, otherwise listen for it.\n   *\n   * This function uses isReady because there is no reliable way to ask the browser whether\n   * the DOMContentLoaded event has already been fired; there's a gap between DOMContentLoaded\n   * firing and readystate=complete.\n   */\n  function ready(fn) {\n    // Checking readyState here is a failsafe in case the htmx script tag entered the DOM by\n    // some means other than the initial page load.\n    if (isReady || getDocument().readyState === 'complete') {\n      fn()\n    } else {\n      getDocument().addEventListener('DOMContentLoaded', fn)\n    }\n  }\n\n  function insertIndicatorStyles() {\n    if (htmx.config.includeIndicatorStyles !== false) {\n      const nonceAttribute = htmx.config.inlineStyleNonce ? ` nonce=\"${htmx.config.inlineStyleNonce}\"` : ''\n      getDocument().head.insertAdjacentHTML('beforeend',\n        '<style' + nonceAttribute + '>\\\n      .' + htmx.config.indicatorClass + '{opacity:0}\\\n      .' + htmx.config.requestClass + ' .' + htmx.config.indicatorClass + '{opacity:1; transition: opacity 200ms ease-in;}\\\n      .' + htmx.config.requestClass + '.' + htmx.config.indicatorClass + '{opacity:1; transition: opacity 200ms ease-in;}\\\n      </style>')\n    }\n  }\n\n  function getMetaConfig() {\n    /** @type HTMLMetaElement */\n    const element = getDocument().querySelector('meta[name=\"htmx-config\"]')\n    if (element) {\n      return parseJSON(element.content)\n    } else {\n      return null\n    }\n  }\n\n  function mergeMetaConfig() {\n    const metaConfig = getMetaConfig()\n    if (metaConfig) {\n      htmx.config = mergeObjects(htmx.config, metaConfig)\n    }\n  }\n\n  // initialize the document\n  ready(function() {\n    mergeMetaConfig()\n    insertIndicatorStyles()\n    let body = getDocument().body\n    processNode(body)\n    const restoredElts = getDocument().querySelectorAll(\n      \"[hx-trigger='restored'],[data-hx-trigger='restored']\"\n    )\n    body.addEventListener('htmx:abort', function(evt) {\n      const target = evt.target\n      const internalData = getInternalData(target)\n      if (internalData && internalData.xhr) {\n        internalData.xhr.abort()\n      }\n    })\n    /** @type {(ev: PopStateEvent) => any} */\n    const originalPopstate = window.onpopstate ? window.onpopstate.bind(window) : null\n    /** @type {(ev: PopStateEvent) => any} */\n    window.onpopstate = function(event) {\n      if (event.state && event.state.htmx) {\n        restoreHistory()\n        forEach(restoredElts, function(elt) {\n          triggerEvent(elt, 'htmx:restored', {\n            document: getDocument(),\n            triggerEvent\n          })\n        })\n      } else {\n        if (originalPopstate) {\n          originalPopstate(event)\n        }\n      }\n    }\n    getWindow().setTimeout(function() {\n      triggerEvent(body, 'htmx:load', {}) // give ready handlers a chance to load up before firing this event\n      body = null // kill reference for gc\n    }, 0)\n  })\n\n  return htmx\n})()\n\n/** @typedef {'get'|'head'|'post'|'put'|'delete'|'connect'|'options'|'trace'|'patch'} HttpVerb */\n\n/**\n * @typedef {Object} SwapOptions\n * @property {string} [select]\n * @property {string} [selectOOB]\n * @property {*} [eventInfo]\n * @property {string} [anchor]\n * @property {Element} [contextElement]\n * @property {swapCallback} [afterSwapCallback]\n * @property {swapCallback} [afterSettleCallback]\n */\n\n/**\n * @callback swapCallback\n */\n\n/**\n * @typedef {'innerHTML' | 'outerHTML' | 'beforebegin' | 'afterbegin' | 'beforeend' | 'afterend' | 'delete' | 'none' | string} HtmxSwapStyle\n */\n\n/**\n * @typedef HtmxSwapSpecification\n * @property {HtmxSwapStyle} swapStyle\n * @property {number} swapDelay\n * @property {number} settleDelay\n * @property {boolean} [transition]\n * @property {boolean} [ignoreTitle]\n * @property {string} [head]\n * @property {'top' | 'bottom'} [scroll]\n * @property {string} [scrollTarget]\n * @property {string} [show]\n * @property {string} [showTarget]\n * @property {boolean} [focusScroll]\n */\n\n/**\n * @typedef {((this:Node, evt:Event) => boolean) & {source: string}} ConditionalFunction\n */\n\n/**\n * @typedef {Object} HtmxTriggerSpecification\n * @property {string} trigger\n * @property {number} [pollInterval]\n * @property {ConditionalFunction} [eventFilter]\n * @property {boolean} [changed]\n * @property {boolean} [once]\n * @property {boolean} [consume]\n * @property {number} [delay]\n * @property {string} [from]\n * @property {string} [target]\n * @property {number} [throttle]\n * @property {string} [queue]\n * @property {string} [root]\n * @property {string} [threshold]\n */\n\n/**\n * @typedef {{elt: Element, message: string, validity: ValidityState}} HtmxElementValidationError\n */\n\n/**\n * @typedef {Record<string, string>} HtmxHeaderSpecification\n * @property {'true'} HX-Request\n * @property {string|null} HX-Trigger\n * @property {string|null} HX-Trigger-Name\n * @property {string|null} HX-Target\n * @property {string} HX-Current-URL\n * @property {string} [HX-Prompt]\n * @property {'true'} [HX-Boosted]\n * @property {string} [Content-Type]\n * @property {'true'} [HX-History-Restore-Request]\n */\n\n/** @typedef HtmxAjaxHelperContext\n * @property {Element|string} [source]\n * @property {Event} [event]\n * @property {HtmxAjaxHandler} [handler]\n * @property {Element|string} [target]\n * @property {HtmxSwapStyle} [swap]\n * @property {Object|FormData} [values]\n * @property {Record<string,string>} [headers]\n * @property {string} [select]\n */\n\n/**\n * @typedef {Object} HtmxRequestConfig\n * @property {boolean} boosted\n * @property {boolean} useUrlParams\n * @property {FormData} formData\n * @property {Object} parameters formData proxy\n * @property {FormData} unfilteredFormData\n * @property {Object} unfilteredParameters unfilteredFormData proxy\n * @property {HtmxHeaderSpecification} headers\n * @property {Element} target\n * @property {HttpVerb} verb\n * @property {HtmxElementValidationError[]} errors\n * @property {boolean} withCredentials\n * @property {number} timeout\n * @property {string} path\n * @property {Event} triggeringEvent\n */\n\n/**\n * @typedef {Object} HtmxResponseInfo\n * @property {XMLHttpRequest} xhr\n * @property {Element} target\n * @property {HtmxRequestConfig} requestConfig\n * @property {HtmxAjaxEtc} etc\n * @property {boolean} boosted\n * @property {string} select\n * @property {{requestPath: string, finalRequestPath: string, responsePath: string|null, anchor: string}} pathInfo\n * @property {boolean} [failed]\n * @property {boolean} [successful]\n * @property {boolean} [keepIndicators]\n */\n\n/**\n * @typedef {Object} HtmxAjaxEtc\n * @property {boolean} [returnPromise]\n * @property {HtmxAjaxHandler} [handler]\n * @property {string} [select]\n * @property {Element} [targetOverride]\n * @property {HtmxSwapStyle} [swapOverride]\n * @property {Record<string,string>} [headers]\n * @property {Object|FormData} [values]\n * @property {boolean} [credentials]\n * @property {number} [timeout]\n */\n\n/**\n * @typedef {Object} HtmxResponseHandlingConfig\n * @property {string} [code]\n * @property {boolean} swap\n * @property {boolean} [error]\n * @property {boolean} [ignoreTitle]\n * @property {string} [select]\n * @property {string} [target]\n * @property {string} [swapOverride]\n * @property {string} [event]\n */\n\n/**\n * @typedef {HtmxResponseInfo & {shouldSwap: boolean, serverResponse: any, isError: boolean, ignoreTitle: boolean, selectOverride:string}} HtmxBeforeSwapDetails\n */\n\n/**\n * @callback HtmxAjaxHandler\n * @param {Element} elt\n * @param {HtmxResponseInfo} responseInfo\n */\n\n/**\n * @typedef {(() => void)} HtmxSettleTask\n */\n\n/**\n * @typedef {Object} HtmxSettleInfo\n * @property {HtmxSettleTask[]} tasks\n * @property {Element[]} elts\n * @property {string} [title]\n */\n\n/**\n * @see https://github.com/bigskysoftware/htmx-extensions/blob/main/README.md\n * @typedef {Object} HtmxExtension\n * @property {(api: any) => void} init\n * @property {(name: string, event: Event|CustomEvent) => boolean} onEvent\n * @property {(text: string, xhr: XMLHttpRequest, elt: Element) => string} transformResponse\n * @property {(swapStyle: HtmxSwapStyle) => boolean} isInlineSwap\n * @property {(swapStyle: HtmxSwapStyle, target: Node, fragment: Node, settleInfo: HtmxSettleInfo) => boolean|Node[]} handleSwap\n * @property {(xhr: XMLHttpRequest, parameters: FormData, elt: Node) => *|string|null} encodeParameters\n * @property {() => string[]|null} getSelectors\n */\nexport default htmx\n","import htmx from \"htmx.org\";\n\nfunction dependsOn(pathSpec: any, url: string) {\n  if (pathSpec === \"ignore\") {\n    return false;\n  }\n  const dependencyPath = pathSpec.split(\"/\");\n  const urlPath = url.split(\"/\");\n  for (let i = 0; i < urlPath.length; i++) {\n    const dependencyElement = dependencyPath.shift();\n    const pathElement = urlPath[i];\n    if (dependencyElement !== pathElement && dependencyElement !== \"*\") {\n      return false;\n    }\n    if (\n      dependencyPath.length === 0 ||\n      (dependencyPath.length === 1 && dependencyPath[0] === \"\")\n    ) {\n      return true;\n    }\n  }\n  return false;\n}\n\nfunction refreshPath(path: string) {\n  const eltsWithDeps = htmx.findAll(\"[path-deps]\");\n  for (let i = 0; i < eltsWithDeps.length; i++) {\n    const elt = eltsWithDeps[i];\n    if (dependsOn(elt.getAttribute(\"path-deps\"), path)) {\n      htmx.trigger(elt, \"path-deps\", null);\n    }\n  }\n}\n\nhtmx.defineExtension(\"path-deps\", {\n  // @ts-ignore\n  onEvent: function (name, evt) {\n    if (!(evt instanceof CustomEvent)) {\n      return false;\n    }\n    if (name === \"htmx:beforeOnLoad\") {\n      const config = evt.detail.requestConfig;\n      // mutating call\n      if (\n        config &&\n        config.verb !== \"get\" &&\n        evt.target != null &&\n        evt.target instanceof Element &&\n        evt.target.getAttribute(\"path-deps\") !== \"ignore\"\n      ) {\n        refreshPath(config.path);\n      }\n    }\n  },\n});\n","import htmx from \"htmx.org\";\n\nfunction kebabEventName(str: string) {\n    return str.replace(/([a-z0-9])([A-Z])/g, '$1-$2').toLowerCase()\n}\n\nconst ignoredEvents = ['htmx:beforeProcessNode', 'htmx:afterProcessNode', 'htmx:beforeSwap', 'htmx:afterSwap', 'htmx:beforeOnLoad', 'htmx:afterOnLoad', 'htmx:configRequest', 'htmx:configResponse', 'htmx:responseError'];\n\nfunction makeEvent(eventName: string, detail: any) {\n    let evt\n    if (window.CustomEvent && typeof window.CustomEvent === 'function') {\n        // TODO: `composed: true` here is a hack to make global event handlers work with events in shadow DOM\n        evt = new CustomEvent(eventName, { bubbles: false, cancelable: true, composed: true, detail })\n    } else {\n        evt = document.createEvent('CustomEvent')\n        evt.initCustomEvent(eventName, true, true, detail)\n    }\n    return evt\n}\n\nfunction triggerChildren(target: HTMLElement, name: string, event: CustomEvent, triggered: Set<HTMLElement>) {\n    if(ignoredEvents.includes(name)) {\n        return\n    }\n    if (target && target.children) {\n        Array.from(target.children).forEach((e) => {\n            const kehab = kebabEventName(name);\n            const eventName = kehab.replace(\"htmx:\", \"hx-on::\")\n            if (!triggered.has(e as HTMLElement)) {\n                if(e.hasAttribute(eventName)) {\n                    const newEvent = makeEvent(eventName.replace(\"hx-on::\", \"htmx:\"), {\n                        ...event.detail,\n                        target: e,\n                    })\n                    newEvent.detail.meta = 'trigger-children'\n                    e.dispatchEvent(newEvent)\n                    triggered.add(e as HTMLElement);\n                }\n                if (e.children) {\n                    triggerChildren(e as HTMLElement, name, event, triggered);\n                }\n            }\n        });\n    }\n}\n\n\n// @ts-ignore\nhtmx.defineExtension(\"trigger-children\", {\n    onEvent: (name, evt: Event | CustomEvent) => {\n        if (!(evt instanceof CustomEvent)) {\n            return false;\n        }\n        if(evt.detail.meta === 'trigger-children') {\n            return false;\n        }\n        const triggered = new Set<HTMLElement>();\n        const target = evt.target as HTMLElement || evt.detail.target as HTMLElement;\n        triggerChildren(target, name, evt, triggered);\n        return true;\n    },\n});\n","import htmx from \"htmx.org\";\n\nhtmx.defineExtension(\"debug\", {\n  // @ts-ignore\n  onEvent: function (name, evt) {\n    if (console.debug) {\n      console.debug(name, evt);\n    } else if (console) {\n      console.log(\"DEBUG:\", name, evt);\n    } else {\n      // noop\n    }\n  },\n});\n","import htmx from \"htmx.org\";\nconst config: any = htmx.config;\n\n/** @type {import(\"../htmx\").HtmxInternalApi} */\nlet api: any;\n\nconst attrPrefix = \"hx-target-\";\n\n// IE11 doesn't support string.startsWith\nfunction startsWith(str: string, prefix: string) {\n  return str.substring(0, prefix.length) === prefix;\n}\n\n/**\n * @param {HTMLElement} elt\n * @param respCodeNumber\n * @returns {HTMLElement | null}\n */\nfunction getRespCodeTarget(elt: Element, respCodeNumber: number) {\n  if (!elt || !respCodeNumber) return null;\n\n  const respCode = respCodeNumber.toString();\n\n  // '*' is the original syntax, as the obvious character for a wildcard.\n  // The 'x' alternative was added for maximum compatibility with HTML\n  // templating engines, due to ambiguity around which characters are\n  // supported in HTML attributes.\n  //\n  // Start with the most specific possible attribute and generalize from\n  // there.\n  const attrPossibilities = [\n    respCode,\n\n    respCode.substr(0, 2) + \"*\",\n    respCode.substr(0, 2) + \"x\",\n\n    respCode.substr(0, 1) + \"*\",\n    respCode.substr(0, 1) + \"x\",\n    respCode.substr(0, 1) + \"**\",\n    respCode.substr(0, 1) + \"xx\",\n\n    \"*\",\n    \"x\",\n    \"***\",\n    \"xxx\",\n  ];\n  if (startsWith(respCode, \"4\") || startsWith(respCode, \"5\")) {\n    attrPossibilities.push(\"error\");\n  }\n\n  for (let i = 0; i < attrPossibilities.length; i++) {\n    const attr = attrPrefix + attrPossibilities[i];\n    const attrValue = api.getClosestAttributeValue(elt, attr);\n    if (attrValue) {\n      if (attrValue === \"this\") {\n        return api.findThisElement(elt, attr);\n      } else {\n        return api.querySelectorExt(elt, attrValue);\n      }\n    }\n  }\n\n  return null;\n}\n\n/** @param {Event} evt */\nfunction handleErrorFlag(evt: CustomEvent) {\n  if (evt.detail.isError) {\n    if (config.responseTargetUnsetsError) {\n      evt.detail.isError = false;\n    }\n  } else if (config.responseTargetSetsError) {\n    evt.detail.isError = true;\n  }\n}\n\nhtmx.defineExtension(\"response-targets\", {\n  // @ts-ignore\n  init: (apiRef) => {\n    api = apiRef;\n\n    if (config.responseTargetUnsetsError === undefined) {\n      config.responseTargetUnsetsError = true;\n    }\n    if (config.responseTargetSetsError === undefined) {\n      config.responseTargetSetsError = false;\n    }\n    if (config.responseTargetPrefersExisting === undefined) {\n      config.responseTargetPrefersExisting = false;\n    }\n    if (config.responseTargetPrefersRetargetHeader === undefined) {\n      config.responseTargetPrefersRetargetHeader = true;\n    }\n  },\n\n  // @ts-ignore\n  onEvent: (name, evt) => {\n    if (!(evt instanceof CustomEvent)) {\n      return false;\n    }\n    if (\n      name === \"htmx:beforeSwap\" &&\n      evt.detail.xhr &&\n      evt.detail.xhr.status !== 200\n    ) {\n      if (evt.detail.target) {\n        if (config.responseTargetPrefersExisting) {\n          evt.detail.shouldSwap = true;\n          handleErrorFlag(evt);\n          return true;\n        }\n        if (\n          config.responseTargetPrefersRetargetHeader &&\n          evt.detail.xhr.getAllResponseHeaders().match(/HX-Retarget:/i)\n        ) {\n          evt.detail.shouldSwap = true;\n          handleErrorFlag(evt);\n          return true;\n        }\n      }\n      if (!evt.detail.requestConfig) {\n        return true;\n      }\n      const target = getRespCodeTarget(\n        evt.detail.requestConfig.elt,\n        evt.detail.xhr.status,\n      );\n      if (target) {\n        handleErrorFlag(evt);\n        evt.detail.shouldSwap = true;\n        evt.detail.target = target;\n      }\n      return true;\n    }\n  },\n});\n","import htmx from \"htmx.org\";\n\nhtmx.defineExtension(\"mutation-error\", {\n  // @ts-ignore\n  onEvent: (name, evt) => {\n    if (!(evt instanceof CustomEvent)) {\n      return false;\n    }\n    if (name === \"htmx:afterRequest\") {\n      if (!evt.detail || !evt.detail.xhr) {\n        return;\n      }\n      const status = evt.detail.xhr.status;\n      if (status >= 400) {\n        htmx.findAll(\"[hx-on\\\\:\\\\:mutation-error]\").forEach((element) => {\n          htmx.trigger(element, \"htmx:mutation-error\", { status });\n        });\n      }\n    }\n  },\n});\n","import htmx from \"htmx.org\";\n\nlet lastVersion = \"\";\n\nhtmx.defineExtension(\"livereload\", {\n    init: function () {\n\n        let enabled = false\n        for (const element of Array.from(htmx.findAll(\"[hx-ext]\"))) {\n            const value = element.getAttribute(\"hx-ext\");\n            if(value?.split(\" \").includes(\"livereload\")) {\n                enabled = true\n                break;\n            }\n        }\n\n        if(!enabled) {\n            return\n        }\n\n        console.log('livereload extension initialized.');\n        // Create a new EventSource object and point it to your SSE endpoint\n        const eventSource = new EventSource('/dev/livereload');\n        // Listen for messages from the server\n        eventSource.onmessage = function(event) {\n            const message = event.data\n            // Log the message data received from the server\n            if(lastVersion === \"\") {\n                lastVersion = message;\n            }\n            if(lastVersion !== message) {\n                lastVersion = message;\n                reload()\n            }\n        };\n        // Handle errors (e.g., when the connection is closed)\n        eventSource.onerror = function(error) {\n            console.error('EventSource error:', error);\n        };\n\n    },\n    // @ts-ignore\n    onEvent: function (name, evt) {\n\n    },\n});\n\nfunction reload() {\n    window.location.reload()\n}\n","import htmx from \"htmx.org\";\n\nconst evalFuncRegex =/__eval_[A-Za-z0-9]+\\([a-z]+\\)/gm\n\nhtmx.defineExtension(\"htmgo\", {\n    // @ts-ignore\n    onEvent: function (name, evt) {\n       if(name === \"htmx:beforeCleanupElement\" && evt.target) {\n           removeAssociatedScripts(evt.target as HTMLElement);\n       }\n    },\n});\n\nexport function removeAssociatedScripts(element: HTMLElement) {\n   const attributes = Array.from(element.attributes)\n    for (let attribute of attributes) {\n       const matches = attribute.value.match(evalFuncRegex) || []\n        for (let match of matches) {\n            const id = match.replace(\"()\", \"\").replace(\"(this)\", \"\").replace(\";\", \"\")\n            const ele = document.getElementById(id)\n            if(ele && ele.tagName === \"SCRIPT\") {\n                console.debug(\"removing associated script with id\", id)\n                ele.remove()\n            }\n        }\n    }\n}\n","import htmx from 'htmx.org'\nimport {removeAssociatedScripts} from \"./htmgo\";\n\nlet api : any = null;\nlet processed = new Set<string>()\n\nhtmx.defineExtension(\"sse\", {\n    init: function (apiRef) {\n        api = apiRef;\n    },\n    // @ts-ignore\n    onEvent: function (name, evt) {\n        const target = evt.target;\n        if(!(target instanceof HTMLElement)) {\n            return\n        }\n\n        if(name === 'htmx:beforeCleanupElement') {\n            removeAssociatedScripts(target);\n        }\n\n        if(name === 'htmx:beforeProcessNode') {\n            const elements = document.querySelectorAll('[sse-connect]');\n            for (let element of Array.from(elements)) {\n                const url = element.getAttribute(\"sse-connect\")!;\n                if(url && !processed.has(url)) {\n                    connectEventSource(element, url)\n                    processed.add(url)\n                }\n            }\n        }\n    }\n})\n\nfunction connectEventSource(ele: Element, url: string) {\n    if(!url) {\n        return\n    }\n    console.info('Connecting to EventSource', url)\n    const eventSource = new EventSource(url);\n\n    eventSource.addEventListener(\"close\", function(event) {\n        htmx.trigger(ele, \"htmx:sseClose\", {event: event});\n    })\n\n    eventSource.onopen = function(event) {\n        htmx.trigger(ele, \"htmx:sseOpen\", {event: event});\n    }\n\n    eventSource.onerror = function(event) {\n        htmx.trigger(ele, \"htmx:sseError\", {event: event});\n        if (eventSource.readyState == EventSource.CLOSED) {\n            htmx.trigger(ele, \"htmx:sseClose\", {event: event});\n        }\n    }\n\n    eventSource.onmessage = function(event) {\n        const settleInfo = api.makeSettleInfo(ele);\n        htmx.trigger(ele, \"htmx:sseBeforeMessage\", {event: event});\n        const response = event.data\n        const fragment = api.makeFragment(response) as DocumentFragment;\n        const children = Array.from(fragment.children);\n        for (let child of children) {\n            api.oobSwap(api.getAttributeValue(child, 'hx-swap-oob') || 'true', child, settleInfo);\n            // support htmgo eval__ scripts\n            if(child.tagName === 'SCRIPT' && child.id.startsWith(\"__eval\")) {\n                document.body.appendChild(child);\n            }\n        }\n        htmx.trigger(ele, \"htmx:sseAfterMessage\", {event: event});\n    }\n}\n","import htmx from \"htmx.org\";\nimport \"./htmxextensions/pathdeps\";\nimport \"./htmxextensions/trigger-children\";\nimport \"./htmxextensions/debug\";\nimport \"./htmxextensions/response-targets\";\nimport \"./htmxextensions/mutation-error\";\nimport \"./htmxextensions/livereload\"\nimport \"./htmxextensions/htmgo\";\nimport \"./htmxextensions/sse\"\n\n// @ts-ignore\nwindow.htmx = htmx;\n\nfunction watchUrl(callback: (oldUrl: string, newUrl: string) => void) {\n  let lastUrl = window.location.href;\n  setInterval(() => {\n    if (window.location.href !== lastUrl) {\n      callback(lastUrl, window.location.href);\n      lastUrl = window.location.href;\n    }\n  }, 100);\n}\n\nwatchUrl((_, newUrl) => {\n  onUrlChange(newUrl);\n});\n\nfunction onUrlChange(newUrl: string) {\n  let url = new URL(newUrl);\n\n  document.querySelectorAll(\"[hx-trigger]\").forEach(function (element) {\n    const triggers = element.getAttribute(\"hx-trigger\");\n    if (!triggers) {\n      return;\n    }\n    const split = triggers.split(\", \");\n    if (split.find((s) => s === \"url\")) {\n      htmx.swap(element, \"url\", {\n        swapStyle: \"outerHTML\",\n        swapDelay: 0,\n        settleDelay: 0,\n      });\n    } else {\n      for (let [key, values] of url.searchParams) {\n        let eventName = \"qs:\" + key;\n        if (triggers.includes(eventName)) {\n          console.log(\"triggering\", eventName);\n          htmx.trigger(element, eventName, null);\n          break;\n        }\n      }\n    }\n  });\n\n  document.querySelectorAll(\"[hx-match-qp]\").forEach((el) => {\n    let hasMatch = false;\n    for (let name of el.getAttributeNames()) {\n      if (name.startsWith(\"hx-match-qp-mapping:\")) {\n        let match = name.replace(\"hx-match-qp-mapping:\", \"\");\n        let value = url.searchParams.get(match);\n        if (value) {\n          htmx.swap(el, el.getAttribute(name) ?? \"\", {\n            swapStyle: \"innerHTML\",\n            swapDelay: 0,\n            settleDelay: 0,\n          });\n          hasMatch = true;\n          break;\n        }\n      }\n    }\n    if (!hasMatch) {\n      let defaultKey = el.getAttribute(\"hx-match-qp-default\");\n      if (defaultKey) {\n        htmx.swap(\n          el,\n          el.getAttribute(\"hx-match-qp-mapping:\" + defaultKey) ?? \"\",\n          { swapStyle: \"innerHTML\", swapDelay: 0, settleDelay: 0 },\n        );\n      }\n    }\n  });\n}\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../js/node_modules/htmx.org/dist/htmx.esm.js","../js/htmxextensions/pathdeps.ts","../js/htmxextensions/trigger-children.ts","../js/htmxextensions/debug.ts","../js/htmxextensions/response-targets.ts","../js/htmxextensions/mutation-error.ts","../js/htmxextensions/livereload.ts","../js/htmxextensions/htmgo.ts","../js/htmxextensions/sse.ts","../js/htmgo.ts"],"names":["htmx","elt","type","verb","tag","global","str","interval","name","qualifiedName","parent","condition","initialElement","ancestor","attributeName","attributeValue","disinherit","inherit","closestAttr","e","selector","matchesFunction","match","resp","fragment","script","newScript","attr","response","responseWithNoHead","startTag","doc","titleElement","func","o","dataProp","data","arr","returnArr","i","el","rect","elemTop","elemBottom","rootNode","trigger","obj1","obj2","key","jString","error","test","path","url","callback","evt","event","eltOrSelector","delay","value","clazz","node","child","prefix","suffix","trimmedSelector","start","results","context","arg1","arg2","arg3","eventArgs","attrName","attrTarget","result","attribute","targetStr","attributesToSettle","mergeTo","mergeFrom","swapStyle","target","extensions","extension","oobValue","oobElement","settleInfo","targets","oobElementClone","beforeSwapDetails","preservedElt","id","oldElt","parentNode","newNode","normalizedId","normalizedTag","parentElt","oldNode","newAttributes","autofocus","autoFocusedElt","insertBefore","string","hash","char","internalData","handlerInfo","element","info","newElt","eltBeforeNewContent","firstChild","ext","newElements","j","oobElts","content","swapSpec","swapOptions","activeElt","selectionInfo","oobSelectValues","oobSelectValue","template","newFragment","newActiveElt","focusOptions","doSettle","task","anchorTarget","xhr","header","triggerBody","triggers","eventName","detail","eventNames","tokens","position","startPosition","startChar","symbol","token","last","paramName","bracketCount","conditionalSource","conditionFunction","explicitTrigger","cache","triggerSpecs","initialLength","every","eventFilter","triggerSpec","from_arg","handler","spec","nodeData","rawAttribute","source","explicitCancel","elementData","eltsToListenOn","eltToListenOn","eltToListenOnData","eventListener","eventData","load","explicitAction","observerOptions","entries","attributes","elements","iter","boostedSelector","extensionSelectors","selectors","s","form","code","listener","afterOnPosition","nextChar","toDo","msg","eventResult","kebabName","kebabedEvent","rootElt","innerHTML","title","scroll","historyCache","newHistoryItem","className","clone","disableHistoryCache","tasks","request","details","historyElement","cached","indicators","ic","disabledElts","disabledElement","disabled","processed","formData","v","values","errors","validate","input","receiver","donor","priorityFormData","button","includes","descendant","returnStr","realValue","prompt","headers","inputValues","paramsValue","newValues","swapInfoOverride","swapInfo","split","splitSpec","scrollVal","selectorVal","showVal","focusScrollVal","filteredParameters","encodedParameters","first","evalAsDefault","evaluateValue","varsValues","toEval","defaultVal","expressionVars","headerValue","regexp","requestConfig","sameHost","obj","array","index","prop","etc","confirmed","resolve","reject","promise","_resolve","_reject","responseHandler","select","eltData","submitter","buttonPath","buttonVerb","confirmQuestion","skipConfirmation","syncElt","syncStrategy","queueStrategy","abortable","syncStrings","endRequestLock","promptQuestion","promptResponse","rawFormData","allFormData","filteredFormData","requestAttrValues","eltIsBoosted","useUrlParams","splitPath","pathNoAnchor","anchor","finalPath","responseInfo","hierarchy","disableElts","secondaryTriggerElt","parentEltInHierarchy","params","pathFromHeaders","typeFromHeaders","requestPath","responsePath","pushUrl","replaceUrl","elementIsBoosted","saveType","responseHandlingConfig","status","regExp","responseHandlingElement","titleElt","responseInfoSelect","redirectPath","redirectSwapSpec","shouldRefresh","historyUpdate","responseHandling","shouldSwap","isError","ignoreTitle","selectOverride","swapOverride","serverResponse","settleResolve","settleReject","selectOOB","doSwap","finalElt","shouldTransition","settlePromise","innerDoSwap","api","text","parameters","extensionsToReturn","extensionsToIgnore","extensionsForElement","extensionName","fn","nonceAttribute","metaConfig","body","restoredElts","originalPopstate","htmx_esm_default","dependsOn","pathSpec","dependencyPath","urlPath","dependencyElement","pathElement","refreshPath","eltsWithDeps","config","kebabEventName","ignoredEvents","makeEvent","triggerChildren","triggered","newEvent","attrPrefix","startsWith","getRespCodeTarget","respCodeNumber","respCode","attrPossibilities","attrValue","handleErrorFlag","apiRef","lastVersion","enabled","eventSource","message","reload","evalFuncRegex","removeAssociatedScripts","matches","ele","connectEventSource","children","ignored","watchUrl","lastUrl","_","newUrl","onUrlChange","hasMatch","defaultKey"],"mappings":"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","file":"htmgo.js","sourcesContent":["var htmx = (function() {\n  'use strict'\n\n  // Public API\n  const htmx = {\n    // Tsc madness here, assigning the functions directly results in an invalid TypeScript output, but reassigning is fine\n    /* Event processing */\n    /** @type {typeof onLoadHelper} */\n    onLoad: null,\n    /** @type {typeof processNode} */\n    process: null,\n    /** @type {typeof addEventListenerImpl} */\n    on: null,\n    /** @type {typeof removeEventListenerImpl} */\n    off: null,\n    /** @type {typeof triggerEvent} */\n    trigger: null,\n    /** @type {typeof ajaxHelper} */\n    ajax: null,\n    /* DOM querying helpers */\n    /** @type {typeof find} */\n    find: null,\n    /** @type {typeof findAll} */\n    findAll: null,\n    /** @type {typeof closest} */\n    closest: null,\n    /**\n     * Returns the input values that would resolve for a given element via the htmx value resolution mechanism\n     *\n     * @see https://htmx.org/api/#values\n     *\n     * @param {Element} elt the element to resolve values on\n     * @param {HttpVerb} type the request type (e.g. **get** or **post**) non-GET's will include the enclosing form of the element. Defaults to **post**\n     * @returns {Object}\n     */\n    values: function(elt, type) {\n      const inputValues = getInputValues(elt, type || 'post')\n      return inputValues.values\n    },\n    /* DOM manipulation helpers */\n    /** @type {typeof removeElement} */\n    remove: null,\n    /** @type {typeof addClassToElement} */\n    addClass: null,\n    /** @type {typeof removeClassFromElement} */\n    removeClass: null,\n    /** @type {typeof toggleClassOnElement} */\n    toggleClass: null,\n    /** @type {typeof takeClassForElement} */\n    takeClass: null,\n    /** @type {typeof swap} */\n    swap: null,\n    /* Extension entrypoints */\n    /** @type {typeof defineExtension} */\n    defineExtension: null,\n    /** @type {typeof removeExtension} */\n    removeExtension: null,\n    /* Debugging */\n    /** @type {typeof logAll} */\n    logAll: null,\n    /** @type {typeof logNone} */\n    logNone: null,\n    /* Debugging */\n    /**\n     * The logger htmx uses to log with\n     *\n     * @see https://htmx.org/api/#logger\n     */\n    logger: null,\n    /**\n     * A property holding the configuration htmx uses at runtime.\n     *\n     * Note that using a [meta tag](https://htmx.org/docs/#config) is the preferred mechanism for setting these properties.\n     *\n     * @see https://htmx.org/api/#config\n     */\n    config: {\n      /**\n       * Whether to use history.\n       * @type boolean\n       * @default true\n       */\n      historyEnabled: true,\n      /**\n       * The number of pages to keep in **localStorage** for history support.\n       * @type number\n       * @default 10\n       */\n      historyCacheSize: 10,\n      /**\n       * @type boolean\n       * @default false\n       */\n      refreshOnHistoryMiss: false,\n      /**\n       * The default swap style to use if **[hx-swap](https://htmx.org/attributes/hx-swap)** is omitted.\n       * @type HtmxSwapStyle\n       * @default 'innerHTML'\n       */\n      defaultSwapStyle: 'innerHTML',\n      /**\n       * The default delay between receiving a response from the server and doing the swap.\n       * @type number\n       * @default 0\n       */\n      defaultSwapDelay: 0,\n      /**\n       * The default delay between completing the content swap and settling attributes.\n       * @type number\n       * @default 20\n       */\n      defaultSettleDelay: 20,\n      /**\n       * If true, htmx will inject a small amount of CSS into the page to make indicators invisible unless the **htmx-indicator** class is present.\n       * @type boolean\n       * @default true\n       */\n      includeIndicatorStyles: true,\n      /**\n       * The class to place on indicators when a request is in flight.\n       * @type string\n       * @default 'htmx-indicator'\n       */\n      indicatorClass: 'htmx-indicator',\n      /**\n       * The class to place on triggering elements when a request is in flight.\n       * @type string\n       * @default 'htmx-request'\n       */\n      requestClass: 'htmx-request',\n      /**\n       * The class to temporarily place on elements that htmx has added to the DOM.\n       * @type string\n       * @default 'htmx-added'\n       */\n      addedClass: 'htmx-added',\n      /**\n       * The class to place on target elements when htmx is in the settling phase.\n       * @type string\n       * @default 'htmx-settling'\n       */\n      settlingClass: 'htmx-settling',\n      /**\n       * The class to place on target elements when htmx is in the swapping phase.\n       * @type string\n       * @default 'htmx-swapping'\n       */\n      swappingClass: 'htmx-swapping',\n      /**\n       * Allows the use of eval-like functionality in htmx, to enable **hx-vars**, trigger conditions & script tag evaluation. Can be set to **false** for CSP compatibility.\n       * @type boolean\n       * @default true\n       */\n      allowEval: true,\n      /**\n       * If set to false, disables the interpretation of script tags.\n       * @type boolean\n       * @default true\n       */\n      allowScriptTags: true,\n      /**\n       * If set, the nonce will be added to inline scripts.\n       * @type string\n       * @default ''\n       */\n      inlineScriptNonce: '',\n      /**\n       * If set, the nonce will be added to inline styles.\n       * @type string\n       * @default ''\n       */\n      inlineStyleNonce: '',\n      /**\n       * The attributes to settle during the settling phase.\n       * @type string[]\n       * @default ['class', 'style', 'width', 'height']\n       */\n      attributesToSettle: ['class', 'style', 'width', 'height'],\n      /**\n       * Allow cross-site Access-Control requests using credentials such as cookies, authorization headers or TLS client certificates.\n       * @type boolean\n       * @default false\n       */\n      withCredentials: false,\n      /**\n       * @type number\n       * @default 0\n       */\n      timeout: 0,\n      /**\n       * The default implementation of **getWebSocketReconnectDelay** for reconnecting after unexpected connection loss by the event code **Abnormal Closure**, **Service Restart** or **Try Again Later**.\n       * @type {'full-jitter' | ((retryCount:number) => number)}\n       * @default \"full-jitter\"\n       */\n      wsReconnectDelay: 'full-jitter',\n      /**\n       * The type of binary data being received over the WebSocket connection\n       * @type BinaryType\n       * @default 'blob'\n       */\n      wsBinaryType: 'blob',\n      /**\n       * @type string\n       * @default '[hx-disable], [data-hx-disable]'\n       */\n      disableSelector: '[hx-disable], [data-hx-disable]',\n      /**\n       * @type {'auto' | 'instant' | 'smooth'}\n       * @default 'instant'\n       */\n      scrollBehavior: 'instant',\n      /**\n       * If the focused element should be scrolled into view.\n       * @type boolean\n       * @default false\n       */\n      defaultFocusScroll: false,\n      /**\n       * If set to true htmx will include a cache-busting parameter in GET requests to avoid caching partial responses by the browser\n       * @type boolean\n       * @default false\n       */\n      getCacheBusterParam: false,\n      /**\n       * If set to true, htmx will use the View Transition API when swapping in new content.\n       * @type boolean\n       * @default false\n       */\n      globalViewTransitions: false,\n      /**\n       * htmx will format requests with these methods by encoding their parameters in the URL, not the request body\n       * @type {(HttpVerb)[]}\n       * @default ['get', 'delete']\n       */\n      methodsThatUseUrlParams: ['get', 'delete'],\n      /**\n       * If set to true, disables htmx-based requests to non-origin hosts.\n       * @type boolean\n       * @default false\n       */\n      selfRequestsOnly: true,\n      /**\n       * If set to true htmx will not update the title of the document when a title tag is found in new content\n       * @type boolean\n       * @default false\n       */\n      ignoreTitle: false,\n      /**\n       * Whether the target of a boosted element is scrolled into the viewport.\n       * @type boolean\n       * @default true\n       */\n      scrollIntoViewOnBoost: true,\n      /**\n       * The cache to store evaluated trigger specifications into.\n       * You may define a simple object to use a never-clearing cache, or implement your own system using a [proxy object](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Proxy)\n       * @type {Object|null}\n       * @default null\n       */\n      triggerSpecsCache: null,\n      /** @type boolean */\n      disableInheritance: false,\n      /** @type HtmxResponseHandlingConfig[] */\n      responseHandling: [\n        { code: '204', swap: false },\n        { code: '[23]..', swap: true },\n        { code: '[45]..', swap: false, error: true }\n      ],\n      /**\n       * Whether to process OOB swaps on elements that are nested within the main response element.\n       * @type boolean\n       * @default true\n       */\n      allowNestedOobSwaps: true\n    },\n    /** @type {typeof parseInterval} */\n    parseInterval: null,\n    /** @type {typeof internalEval} */\n    _: null,\n    version: '2.0.2'\n  }\n  // Tsc madness part 2\n  htmx.onLoad = onLoadHelper\n  htmx.process = processNode\n  htmx.on = addEventListenerImpl\n  htmx.off = removeEventListenerImpl\n  htmx.trigger = triggerEvent\n  htmx.ajax = ajaxHelper\n  htmx.find = find\n  htmx.findAll = findAll\n  htmx.closest = closest\n  htmx.remove = removeElement\n  htmx.addClass = addClassToElement\n  htmx.removeClass = removeClassFromElement\n  htmx.toggleClass = toggleClassOnElement\n  htmx.takeClass = takeClassForElement\n  htmx.swap = swap\n  htmx.defineExtension = defineExtension\n  htmx.removeExtension = removeExtension\n  htmx.logAll = logAll\n  htmx.logNone = logNone\n  htmx.parseInterval = parseInterval\n  htmx._ = internalEval\n\n  const internalAPI = {\n    addTriggerHandler,\n    bodyContains,\n    canAccessLocalStorage,\n    findThisElement,\n    filterValues,\n    swap,\n    hasAttribute,\n    getAttributeValue,\n    getClosestAttributeValue,\n    getClosestMatch,\n    getExpressionVars,\n    getHeaders,\n    getInputValues,\n    getInternalData,\n    getSwapSpecification,\n    getTriggerSpecs,\n    getTarget,\n    makeFragment,\n    mergeObjects,\n    makeSettleInfo,\n    oobSwap,\n    querySelectorExt,\n    settleImmediately,\n    shouldCancel,\n    triggerEvent,\n    triggerErrorEvent,\n    withExtensions\n  }\n\n  const VERBS = ['get', 'post', 'put', 'delete', 'patch']\n  const VERB_SELECTOR = VERBS.map(function(verb) {\n    return '[hx-' + verb + '], [data-hx-' + verb + ']'\n  }).join(', ')\n\n  const HEAD_TAG_REGEX = makeTagRegEx('head')\n\n  //= ===================================================================\n  // Utilities\n  //= ===================================================================\n\n  /**\n   * @param {string} tag\n   * @param {boolean} global\n   * @returns {RegExp}\n   */\n  function makeTagRegEx(tag, global = false) {\n    return new RegExp(`<${tag}(\\\\s[^>]*>|>)([\\\\s\\\\S]*?)<\\\\/${tag}>`,\n      global ? 'gim' : 'im')\n  }\n\n  /**\n   * Parses an interval string consistent with the way htmx does. Useful for plugins that have timing-related attributes.\n   *\n   * Caution: Accepts an int followed by either **s** or **ms**. All other values use **parseFloat**\n   *\n   * @see https://htmx.org/api/#parseInterval\n   *\n   * @param {string} str timing string\n   * @returns {number|undefined}\n   */\n  function parseInterval(str) {\n    if (str == undefined) {\n      return undefined\n    }\n\n    let interval = NaN\n    if (str.slice(-2) == 'ms') {\n      interval = parseFloat(str.slice(0, -2))\n    } else if (str.slice(-1) == 's') {\n      interval = parseFloat(str.slice(0, -1)) * 1000\n    } else if (str.slice(-1) == 'm') {\n      interval = parseFloat(str.slice(0, -1)) * 1000 * 60\n    } else {\n      interval = parseFloat(str)\n    }\n    return isNaN(interval) ? undefined : interval\n  }\n\n  /**\n   * @param {Node} elt\n   * @param {string} name\n   * @returns {(string | null)}\n   */\n  function getRawAttribute(elt, name) {\n    return elt instanceof Element && elt.getAttribute(name)\n  }\n\n  /**\n   * @param {Element} elt\n   * @param {string} qualifiedName\n   * @returns {boolean}\n   */\n  // resolve with both hx and data-hx prefixes\n  function hasAttribute(elt, qualifiedName) {\n    return !!elt.hasAttribute && (elt.hasAttribute(qualifiedName) ||\n      elt.hasAttribute('data-' + qualifiedName))\n  }\n\n  /**\n   *\n   * @param {Node} elt\n   * @param {string} qualifiedName\n   * @returns {(string | null)}\n   */\n  function getAttributeValue(elt, qualifiedName) {\n    return getRawAttribute(elt, qualifiedName) || getRawAttribute(elt, 'data-' + qualifiedName)\n  }\n\n  /**\n   * @param {Node} elt\n   * @returns {Node | null}\n   */\n  function parentElt(elt) {\n    const parent = elt.parentElement\n    if (!parent && elt.parentNode instanceof ShadowRoot) return elt.parentNode\n    return parent\n  }\n\n  /**\n   * @returns {Document}\n   */\n  function getDocument() {\n    return document\n  }\n\n  /**\n   * @param {Node} elt\n   * @param {boolean} global\n   * @returns {Node|Document}\n   */\n  function getRootNode(elt, global) {\n    return elt.getRootNode ? elt.getRootNode({ composed: global }) : getDocument()\n  }\n\n  /**\n   * @param {Node} elt\n   * @param {(e:Node) => boolean} condition\n   * @returns {Node | null}\n   */\n  function getClosestMatch(elt, condition) {\n    while (elt && !condition(elt)) {\n      elt = parentElt(elt)\n    }\n\n    return elt || null\n  }\n\n  /**\n   * @param {Element} initialElement\n   * @param {Element} ancestor\n   * @param {string} attributeName\n   * @returns {string|null}\n   */\n  function getAttributeValueWithDisinheritance(initialElement, ancestor, attributeName) {\n    const attributeValue = getAttributeValue(ancestor, attributeName)\n    const disinherit = getAttributeValue(ancestor, 'hx-disinherit')\n    var inherit = getAttributeValue(ancestor, 'hx-inherit')\n    if (initialElement !== ancestor) {\n      if (htmx.config.disableInheritance) {\n        if (inherit && (inherit === '*' || inherit.split(' ').indexOf(attributeName) >= 0)) {\n          return attributeValue\n        } else {\n          return null\n        }\n      }\n      if (disinherit && (disinherit === '*' || disinherit.split(' ').indexOf(attributeName) >= 0)) {\n        return 'unset'\n      }\n    }\n    return attributeValue\n  }\n\n  /**\n   * @param {Element} elt\n   * @param {string} attributeName\n   * @returns {string | null}\n   */\n  function getClosestAttributeValue(elt, attributeName) {\n    let closestAttr = null\n    getClosestMatch(elt, function(e) {\n      return !!(closestAttr = getAttributeValueWithDisinheritance(elt, asElement(e), attributeName))\n    })\n    if (closestAttr !== 'unset') {\n      return closestAttr\n    }\n  }\n\n  /**\n   * @param {Node} elt\n   * @param {string} selector\n   * @returns {boolean}\n   */\n  function matches(elt, selector) {\n    // @ts-ignore: non-standard properties for browser compatibility\n    // noinspection JSUnresolvedVariable\n    const matchesFunction = elt instanceof Element && (elt.matches || elt.matchesSelector || elt.msMatchesSelector || elt.mozMatchesSelector || elt.webkitMatchesSelector || elt.oMatchesSelector)\n    return !!matchesFunction && matchesFunction.call(elt, selector)\n  }\n\n  /**\n   * @param {string} str\n   * @returns {string}\n   */\n  function getStartTag(str) {\n    const tagMatcher = /<([a-z][^\\/\\0>\\x20\\t\\r\\n\\f]*)/i\n    const match = tagMatcher.exec(str)\n    if (match) {\n      return match[1].toLowerCase()\n    } else {\n      return ''\n    }\n  }\n\n  /**\n   * @param {string} resp\n   * @returns {Document}\n   */\n  function parseHTML(resp) {\n    const parser = new DOMParser()\n    return parser.parseFromString(resp, 'text/html')\n  }\n\n  /**\n   * @param {DocumentFragment} fragment\n   * @param {Node} elt\n   */\n  function takeChildrenFor(fragment, elt) {\n    while (elt.childNodes.length > 0) {\n      fragment.append(elt.childNodes[0])\n    }\n  }\n\n  /**\n   * @param {HTMLScriptElement} script\n   * @returns {HTMLScriptElement}\n   */\n  function duplicateScript(script) {\n    const newScript = getDocument().createElement('script')\n    forEach(script.attributes, function(attr) {\n      newScript.setAttribute(attr.name, attr.value)\n    })\n    newScript.textContent = script.textContent\n    newScript.async = false\n    if (htmx.config.inlineScriptNonce) {\n      newScript.nonce = htmx.config.inlineScriptNonce\n    }\n    return newScript\n  }\n\n  /**\n   * @param {HTMLScriptElement} script\n   * @returns {boolean}\n   */\n  function isJavaScriptScriptNode(script) {\n    return script.matches('script') && (script.type === 'text/javascript' || script.type === 'module' || script.type === '')\n  }\n\n  /**\n   * we have to make new copies of script tags that we are going to insert because\n   * SOME browsers (not saying who, but it involves an element and an animal) don't\n   * execute scripts created in <template> tags when they are inserted into the DOM\n   * and all the others do lmao\n   * @param {DocumentFragment} fragment\n   */\n  function normalizeScriptTags(fragment) {\n    Array.from(fragment.querySelectorAll('script')).forEach(/** @param {HTMLScriptElement} script */ (script) => {\n      if (isJavaScriptScriptNode(script)) {\n        const newScript = duplicateScript(script)\n        const parent = script.parentNode\n        try {\n          parent.insertBefore(newScript, script)\n        } catch (e) {\n          logError(e)\n        } finally {\n          script.remove()\n        }\n      }\n    })\n  }\n\n  /**\n   * @typedef {DocumentFragment & {title?: string}} DocumentFragmentWithTitle\n   * @description  a document fragment representing the response HTML, including\n   * a `title` property for any title information found\n   */\n\n  /**\n   * @param {string} response HTML\n   * @returns {DocumentFragmentWithTitle}\n   */\n  function makeFragment(response) {\n    // strip head tag to determine shape of response we are dealing with\n    const responseWithNoHead = response.replace(HEAD_TAG_REGEX, '')\n    const startTag = getStartTag(responseWithNoHead)\n    /** @type DocumentFragmentWithTitle */\n    let fragment\n    if (startTag === 'html') {\n      // if it is a full document, parse it and return the body\n      fragment = /** @type DocumentFragmentWithTitle */ (new DocumentFragment())\n      const doc = parseHTML(response)\n      takeChildrenFor(fragment, doc.body)\n      fragment.title = doc.title\n    } else if (startTag === 'body') {\n      // parse body w/o wrapping in template\n      fragment = /** @type DocumentFragmentWithTitle */ (new DocumentFragment())\n      const doc = parseHTML(responseWithNoHead)\n      takeChildrenFor(fragment, doc.body)\n      fragment.title = doc.title\n    } else {\n      // otherwise we have non-body partial HTML content, so wrap it in a template to maximize parsing flexibility\n      const doc = parseHTML('<body><template class=\"internal-htmx-wrapper\">' + responseWithNoHead + '</template></body>')\n      fragment = /** @type DocumentFragmentWithTitle */ (doc.querySelector('template').content)\n      // extract title into fragment for later processing\n      fragment.title = doc.title\n\n      // for legacy reasons we support a title tag at the root level of non-body responses, so we need to handle it\n      var titleElement = fragment.querySelector('title')\n      if (titleElement && titleElement.parentNode === fragment) {\n        titleElement.remove()\n        fragment.title = titleElement.innerText\n      }\n    }\n    if (fragment) {\n      if (htmx.config.allowScriptTags) {\n        normalizeScriptTags(fragment)\n      } else {\n        // remove all script tags if scripts are disabled\n        fragment.querySelectorAll('script').forEach((script) => script.remove())\n      }\n    }\n    return fragment\n  }\n\n  /**\n   * @param {Function} func\n   */\n  function maybeCall(func) {\n    if (func) {\n      func()\n    }\n  }\n\n  /**\n   * @param {any} o\n   * @param {string} type\n   * @returns\n   */\n  function isType(o, type) {\n    return Object.prototype.toString.call(o) === '[object ' + type + ']'\n  }\n\n  /**\n   * @param {*} o\n   * @returns {o is Function}\n   */\n  function isFunction(o) {\n    return typeof o === 'function'\n  }\n\n  /**\n   * @param {*} o\n   * @returns {o is Object}\n   */\n  function isRawObject(o) {\n    return isType(o, 'Object')\n  }\n\n  /**\n   * @typedef {Object} OnHandler\n   * @property {(keyof HTMLElementEventMap)|string} event\n   * @property {EventListener} listener\n   */\n\n  /**\n   * @typedef {Object} ListenerInfo\n   * @property {string} trigger\n   * @property {EventListener} listener\n   * @property {EventTarget} on\n   */\n\n  /**\n   * @typedef {Object} HtmxNodeInternalData\n   * Element data\n   * @property {number} [initHash]\n   * @property {boolean} [boosted]\n   * @property {OnHandler[]} [onHandlers]\n   * @property {number} [timeout]\n   * @property {ListenerInfo[]} [listenerInfos]\n   * @property {boolean} [cancelled]\n   * @property {boolean} [triggeredOnce]\n   * @property {number} [delayed]\n   * @property {number|null} [throttle]\n   * @property {string} [lastValue]\n   * @property {boolean} [loaded]\n   * @property {string} [path]\n   * @property {string} [verb]\n   * @property {boolean} [polling]\n   * @property {HTMLButtonElement|HTMLInputElement|null} [lastButtonClicked]\n   * @property {number} [requestCount]\n   * @property {XMLHttpRequest} [xhr]\n   * @property {(() => void)[]} [queuedRequests]\n   * @property {boolean} [abortable]\n   *\n   * Event data\n   * @property {HtmxTriggerSpecification} [triggerSpec]\n   * @property {EventTarget[]} [handledFor]\n   */\n\n  /**\n   * getInternalData retrieves \"private\" data stored by htmx within an element\n   * @param {EventTarget|Event} elt\n   * @returns {HtmxNodeInternalData}\n   */\n  function getInternalData(elt) {\n    const dataProp = 'htmx-internal-data'\n    let data = elt[dataProp]\n    if (!data) {\n      data = elt[dataProp] = {}\n    }\n    return data\n  }\n\n  /**\n   * toArray converts an ArrayLike object into a real array.\n   * @template T\n   * @param {ArrayLike<T>} arr\n   * @returns {T[]}\n   */\n  function toArray(arr) {\n    const returnArr = []\n    if (arr) {\n      for (let i = 0; i < arr.length; i++) {\n        returnArr.push(arr[i])\n      }\n    }\n    return returnArr\n  }\n\n  /**\n   * @template T\n   * @param {T[]|NamedNodeMap|HTMLCollection|HTMLFormControlsCollection|ArrayLike<T>} arr\n   * @param {(T) => void} func\n   */\n  function forEach(arr, func) {\n    if (arr) {\n      for (let i = 0; i < arr.length; i++) {\n        func(arr[i])\n      }\n    }\n  }\n\n  /**\n   * @param {Element} el\n   * @returns {boolean}\n   */\n  function isScrolledIntoView(el) {\n    const rect = el.getBoundingClientRect()\n    const elemTop = rect.top\n    const elemBottom = rect.bottom\n    return elemTop < window.innerHeight && elemBottom >= 0\n  }\n\n  /**\n   * @param {Node} elt\n   * @returns {boolean}\n   */\n  function bodyContains(elt) {\n    // IE Fix\n    const rootNode = elt.getRootNode && elt.getRootNode()\n    if (rootNode && rootNode instanceof window.ShadowRoot) {\n      return getDocument().body.contains(rootNode.host)\n    } else {\n      return getDocument().body.contains(elt)\n    }\n  }\n\n  /**\n   * @param {string} trigger\n   * @returns {string[]}\n   */\n  function splitOnWhitespace(trigger) {\n    return trigger.trim().split(/\\s+/)\n  }\n\n  /**\n   * mergeObjects takes all the keys from\n   * obj2 and duplicates them into obj1\n   * @template T1\n   * @template T2\n   * @param {T1} obj1\n   * @param {T2} obj2\n   * @returns {T1 & T2}\n   */\n  function mergeObjects(obj1, obj2) {\n    for (const key in obj2) {\n      if (obj2.hasOwnProperty(key)) {\n        // @ts-ignore tsc doesn't seem to properly handle types merging\n        obj1[key] = obj2[key]\n      }\n    }\n    // @ts-ignore tsc doesn't seem to properly handle types merging\n    return obj1\n  }\n\n  /**\n   * @param {string} jString\n   * @returns {any|null}\n   */\n  function parseJSON(jString) {\n    try {\n      return JSON.parse(jString)\n    } catch (error) {\n      logError(error)\n      return null\n    }\n  }\n\n  /**\n   * @returns {boolean}\n   */\n  function canAccessLocalStorage() {\n    const test = 'htmx:localStorageTest'\n    try {\n      localStorage.setItem(test, test)\n      localStorage.removeItem(test)\n      return true\n    } catch (e) {\n      return false\n    }\n  }\n\n  /**\n   * @param {string} path\n   * @returns {string}\n   */\n  function normalizePath(path) {\n    try {\n      const url = new URL(path)\n      if (url) {\n        path = url.pathname + url.search\n      }\n      // remove trailing slash, unless index page\n      if (!(/^\\/$/.test(path))) {\n        path = path.replace(/\\/+$/, '')\n      }\n      return path\n    } catch (e) {\n      // be kind to IE11, which doesn't support URL()\n      return path\n    }\n  }\n\n  //= =========================================================================================\n  // public API\n  //= =========================================================================================\n\n  /**\n   * @param {string} str\n   * @returns {any}\n   */\n  function internalEval(str) {\n    return maybeEval(getDocument().body, function() {\n      return eval(str)\n    })\n  }\n\n  /**\n   * Adds a callback for the **htmx:load** event. This can be used to process new content, for example initializing the content with a javascript library\n   *\n   * @see https://htmx.org/api/#onLoad\n   *\n   * @param {(elt: Node) => void} callback the callback to call on newly loaded content\n   * @returns {EventListener}\n   */\n  function onLoadHelper(callback) {\n    const value = htmx.on('htmx:load', /** @param {CustomEvent} evt */ function(evt) {\n      callback(evt.detail.elt)\n    })\n    return value\n  }\n\n  /**\n   * Log all htmx events, useful for debugging.\n   *\n   * @see https://htmx.org/api/#logAll\n   */\n  function logAll() {\n    htmx.logger = function(elt, event, data) {\n      if (console) {\n        console.log(event, elt, data)\n      }\n    }\n  }\n\n  function logNone() {\n    htmx.logger = null\n  }\n\n  /**\n   * Finds an element matching the selector\n   *\n   * @see https://htmx.org/api/#find\n   *\n   * @param {ParentNode|string} eltOrSelector  the root element to find the matching element in, inclusive | the selector to match\n   * @param {string} [selector] the selector to match\n   * @returns {Element|null}\n   */\n  function find(eltOrSelector, selector) {\n    if (typeof eltOrSelector !== 'string') {\n      return eltOrSelector.querySelector(selector)\n    } else {\n      return find(getDocument(), eltOrSelector)\n    }\n  }\n\n  /**\n   * Finds all elements matching the selector\n   *\n   * @see https://htmx.org/api/#findAll\n   *\n   * @param {ParentNode|string} eltOrSelector the root element to find the matching elements in, inclusive | the selector to match\n   * @param {string} [selector] the selector to match\n   * @returns {NodeListOf<Element>}\n   */\n  function findAll(eltOrSelector, selector) {\n    if (typeof eltOrSelector !== 'string') {\n      return eltOrSelector.querySelectorAll(selector)\n    } else {\n      return findAll(getDocument(), eltOrSelector)\n    }\n  }\n\n  /**\n   * @returns Window\n   */\n  function getWindow() {\n    return window\n  }\n\n  /**\n   * Removes an element from the DOM\n   *\n   * @see https://htmx.org/api/#remove\n   *\n   * @param {Node} elt\n   * @param {number} [delay]\n   */\n  function removeElement(elt, delay) {\n    elt = resolveTarget(elt)\n    if (delay) {\n      getWindow().setTimeout(function() {\n        removeElement(elt)\n        elt = null\n      }, delay)\n    } else {\n      parentElt(elt).removeChild(elt)\n    }\n  }\n\n  /**\n   * @param {any} elt\n   * @return {Element|null}\n   */\n  function asElement(elt) {\n    return elt instanceof Element ? elt : null\n  }\n\n  /**\n   * @param {any} elt\n   * @return {HTMLElement|null}\n   */\n  function asHtmlElement(elt) {\n    return elt instanceof HTMLElement ? elt : null\n  }\n\n  /**\n   * @param {any} value\n   * @return {string|null}\n   */\n  function asString(value) {\n    return typeof value === 'string' ? value : null\n  }\n\n  /**\n   * @param {EventTarget} elt\n   * @return {ParentNode|null}\n   */\n  function asParentNode(elt) {\n    return elt instanceof Element || elt instanceof Document || elt instanceof DocumentFragment ? elt : null\n  }\n\n  /**\n   * This method adds a class to the given element.\n   *\n   * @see https://htmx.org/api/#addClass\n   *\n   * @param {Element|string} elt the element to add the class to\n   * @param {string} clazz the class to add\n   * @param {number} [delay] the delay (in milliseconds) before class is added\n   */\n  function addClassToElement(elt, clazz, delay) {\n    elt = asElement(resolveTarget(elt))\n    if (!elt) {\n      return\n    }\n    if (delay) {\n      getWindow().setTimeout(function() {\n        addClassToElement(elt, clazz)\n        elt = null\n      }, delay)\n    } else {\n      elt.classList && elt.classList.add(clazz)\n    }\n  }\n\n  /**\n   * Removes a class from the given element\n   *\n   * @see https://htmx.org/api/#removeClass\n   *\n   * @param {Node|string} node element to remove the class from\n   * @param {string} clazz the class to remove\n   * @param {number} [delay] the delay (in milliseconds before class is removed)\n   */\n  function removeClassFromElement(node, clazz, delay) {\n    let elt = asElement(resolveTarget(node))\n    if (!elt) {\n      return\n    }\n    if (delay) {\n      getWindow().setTimeout(function() {\n        removeClassFromElement(elt, clazz)\n        elt = null\n      }, delay)\n    } else {\n      if (elt.classList) {\n        elt.classList.remove(clazz)\n        // if there are no classes left, remove the class attribute\n        if (elt.classList.length === 0) {\n          elt.removeAttribute('class')\n        }\n      }\n    }\n  }\n\n  /**\n   * Toggles the given class on an element\n   *\n   * @see https://htmx.org/api/#toggleClass\n   *\n   * @param {Element|string} elt the element to toggle the class on\n   * @param {string} clazz the class to toggle\n   */\n  function toggleClassOnElement(elt, clazz) {\n    elt = resolveTarget(elt)\n    elt.classList.toggle(clazz)\n  }\n\n  /**\n   * Takes the given class from its siblings, so that among its siblings, only the given element will have the class.\n   *\n   * @see https://htmx.org/api/#takeClass\n   *\n   * @param {Node|string} elt the element that will take the class\n   * @param {string} clazz the class to take\n   */\n  function takeClassForElement(elt, clazz) {\n    elt = resolveTarget(elt)\n    forEach(elt.parentElement.children, function(child) {\n      removeClassFromElement(child, clazz)\n    })\n    addClassToElement(asElement(elt), clazz)\n  }\n\n  /**\n   * Finds the closest matching element in the given elements parentage, inclusive of the element\n   *\n   * @see https://htmx.org/api/#closest\n   *\n   * @param {Element|string} elt the element to find the selector from\n   * @param {string} selector the selector to find\n   * @returns {Element|null}\n   */\n  function closest(elt, selector) {\n    elt = asElement(resolveTarget(elt))\n    if (elt && elt.closest) {\n      return elt.closest(selector)\n    } else {\n      // TODO remove when IE goes away\n      do {\n        if (elt == null || matches(elt, selector)) {\n          return elt\n        }\n      }\n      while (elt = elt && asElement(parentElt(elt)))\n      return null\n    }\n  }\n\n  /**\n   * @param {string} str\n   * @param {string} prefix\n   * @returns {boolean}\n   */\n  function startsWith(str, prefix) {\n    return str.substring(0, prefix.length) === prefix\n  }\n\n  /**\n   * @param {string} str\n   * @param {string} suffix\n   * @returns {boolean}\n   */\n  function endsWith(str, suffix) {\n    return str.substring(str.length - suffix.length) === suffix\n  }\n\n  /**\n   * @param {string} selector\n   * @returns {string}\n   */\n  function normalizeSelector(selector) {\n    const trimmedSelector = selector.trim()\n    if (startsWith(trimmedSelector, '<') && endsWith(trimmedSelector, '/>')) {\n      return trimmedSelector.substring(1, trimmedSelector.length - 2)\n    } else {\n      return trimmedSelector\n    }\n  }\n\n  /**\n   * @param {Node|Element|Document|string} elt\n   * @param {string} selector\n   * @param {boolean=} global\n   * @returns {(Node|Window)[]}\n   */\n  function querySelectorAllExt(elt, selector, global) {\n    elt = resolveTarget(elt)\n    if (selector.indexOf('closest ') === 0) {\n      return [closest(asElement(elt), normalizeSelector(selector.substr(8)))]\n    } else if (selector.indexOf('find ') === 0) {\n      return [find(asParentNode(elt), normalizeSelector(selector.substr(5)))]\n    } else if (selector === 'next') {\n      return [asElement(elt).nextElementSibling]\n    } else if (selector.indexOf('next ') === 0) {\n      return [scanForwardQuery(elt, normalizeSelector(selector.substr(5)), !!global)]\n    } else if (selector === 'previous') {\n      return [asElement(elt).previousElementSibling]\n    } else if (selector.indexOf('previous ') === 0) {\n      return [scanBackwardsQuery(elt, normalizeSelector(selector.substr(9)), !!global)]\n    } else if (selector === 'document') {\n      return [document]\n    } else if (selector === 'window') {\n      return [window]\n    } else if (selector === 'body') {\n      return [document.body]\n    } else if (selector === 'root') {\n      return [getRootNode(elt, !!global)]\n    } else if (selector.indexOf('global ') === 0) {\n      return querySelectorAllExt(elt, selector.slice(7), true)\n    } else {\n      return toArray(asParentNode(getRootNode(elt, !!global)).querySelectorAll(normalizeSelector(selector)))\n    }\n  }\n\n  /**\n   * @param {Node} start\n   * @param {string} match\n   * @param {boolean} global\n   * @returns {Element}\n   */\n  var scanForwardQuery = function(start, match, global) {\n    const results = asParentNode(getRootNode(start, global)).querySelectorAll(match)\n    for (let i = 0; i < results.length; i++) {\n      const elt = results[i]\n      if (elt.compareDocumentPosition(start) === Node.DOCUMENT_POSITION_PRECEDING) {\n        return elt\n      }\n    }\n  }\n\n  /**\n   * @param {Node} start\n   * @param {string} match\n   * @param {boolean} global\n   * @returns {Element}\n   */\n  var scanBackwardsQuery = function(start, match, global) {\n    const results = asParentNode(getRootNode(start, global)).querySelectorAll(match)\n    for (let i = results.length - 1; i >= 0; i--) {\n      const elt = results[i]\n      if (elt.compareDocumentPosition(start) === Node.DOCUMENT_POSITION_FOLLOWING) {\n        return elt\n      }\n    }\n  }\n\n  /**\n   * @param {Node|string} eltOrSelector\n   * @param {string=} selector\n   * @returns {Node|Window}\n   */\n  function querySelectorExt(eltOrSelector, selector) {\n    if (typeof eltOrSelector !== 'string') {\n      return querySelectorAllExt(eltOrSelector, selector)[0]\n    } else {\n      return querySelectorAllExt(getDocument().body, eltOrSelector)[0]\n    }\n  }\n\n  /**\n   * @template {EventTarget} T\n   * @param {T|string} eltOrSelector\n   * @param {T} [context]\n   * @returns {Element|T|null}\n   */\n  function resolveTarget(eltOrSelector, context) {\n    if (typeof eltOrSelector === 'string') {\n      return find(asParentNode(context) || document, eltOrSelector)\n    } else {\n      return eltOrSelector\n    }\n  }\n\n  /**\n   * @typedef {keyof HTMLElementEventMap|string} AnyEventName\n   */\n\n  /**\n   * @typedef {Object} EventArgs\n   * @property {EventTarget} target\n   * @property {AnyEventName} event\n   * @property {EventListener} listener\n   */\n\n  /**\n   * @param {EventTarget|AnyEventName} arg1\n   * @param {AnyEventName|EventListener} arg2\n   * @param {EventListener} [arg3]\n   * @returns {EventArgs}\n   */\n  function processEventArgs(arg1, arg2, arg3) {\n    if (isFunction(arg2)) {\n      return {\n        target: getDocument().body,\n        event: asString(arg1),\n        listener: arg2\n      }\n    } else {\n      return {\n        target: resolveTarget(arg1),\n        event: asString(arg2),\n        listener: arg3\n      }\n    }\n  }\n\n  /**\n   * Adds an event listener to an element\n   *\n   * @see https://htmx.org/api/#on\n   *\n   * @param {EventTarget|string} arg1 the element to add the listener to | the event name to add the listener for\n   * @param {string|EventListener} arg2 the event name to add the listener for | the listener to add\n   * @param {EventListener} [arg3] the listener to add\n   * @returns {EventListener}\n   */\n  function addEventListenerImpl(arg1, arg2, arg3) {\n    ready(function() {\n      const eventArgs = processEventArgs(arg1, arg2, arg3)\n      eventArgs.target.addEventListener(eventArgs.event, eventArgs.listener)\n    })\n    const b = isFunction(arg2)\n    return b ? arg2 : arg3\n  }\n\n  /**\n   * Removes an event listener from an element\n   *\n   * @see https://htmx.org/api/#off\n   *\n   * @param {EventTarget|string} arg1 the element to remove the listener from | the event name to remove the listener from\n   * @param {string|EventListener} arg2 the event name to remove the listener from | the listener to remove\n   * @param {EventListener} [arg3] the listener to remove\n   * @returns {EventListener}\n   */\n  function removeEventListenerImpl(arg1, arg2, arg3) {\n    ready(function() {\n      const eventArgs = processEventArgs(arg1, arg2, arg3)\n      eventArgs.target.removeEventListener(eventArgs.event, eventArgs.listener)\n    })\n    return isFunction(arg2) ? arg2 : arg3\n  }\n\n  //= ===================================================================\n  // Node processing\n  //= ===================================================================\n\n  const DUMMY_ELT = getDocument().createElement('output') // dummy element for bad selectors\n  /**\n   * @param {Element} elt\n   * @param {string} attrName\n   * @returns {(Node|Window)[]}\n   */\n  function findAttributeTargets(elt, attrName) {\n    const attrTarget = getClosestAttributeValue(elt, attrName)\n    if (attrTarget) {\n      if (attrTarget === 'this') {\n        return [findThisElement(elt, attrName)]\n      } else {\n        const result = querySelectorAllExt(elt, attrTarget)\n        if (result.length === 0) {\n          logError('The selector \"' + attrTarget + '\" on ' + attrName + ' returned no matches!')\n          return [DUMMY_ELT]\n        } else {\n          return result\n        }\n      }\n    }\n  }\n\n  /**\n   * @param {Element} elt\n   * @param {string} attribute\n   * @returns {Element|null}\n   */\n  function findThisElement(elt, attribute) {\n    return asElement(getClosestMatch(elt, function(elt) {\n      return getAttributeValue(asElement(elt), attribute) != null\n    }))\n  }\n\n  /**\n   * @param {Element} elt\n   * @returns {Node|Window|null}\n   */\n  function getTarget(elt) {\n    const targetStr = getClosestAttributeValue(elt, 'hx-target')\n    if (targetStr) {\n      if (targetStr === 'this') {\n        return findThisElement(elt, 'hx-target')\n      } else {\n        return querySelectorExt(elt, targetStr)\n      }\n    } else {\n      const data = getInternalData(elt)\n      if (data.boosted) {\n        return getDocument().body\n      } else {\n        return elt\n      }\n    }\n  }\n\n  /**\n   * @param {string} name\n   * @returns {boolean}\n   */\n  function shouldSettleAttribute(name) {\n    const attributesToSettle = htmx.config.attributesToSettle\n    for (let i = 0; i < attributesToSettle.length; i++) {\n      if (name === attributesToSettle[i]) {\n        return true\n      }\n    }\n    return false\n  }\n\n  /**\n   * @param {Element} mergeTo\n   * @param {Element} mergeFrom\n   */\n  function cloneAttributes(mergeTo, mergeFrom) {\n    forEach(mergeTo.attributes, function(attr) {\n      if (!mergeFrom.hasAttribute(attr.name) && shouldSettleAttribute(attr.name)) {\n        mergeTo.removeAttribute(attr.name)\n      }\n    })\n    forEach(mergeFrom.attributes, function(attr) {\n      if (shouldSettleAttribute(attr.name)) {\n        mergeTo.setAttribute(attr.name, attr.value)\n      }\n    })\n  }\n\n  /**\n   * @param {HtmxSwapStyle} swapStyle\n   * @param {Element} target\n   * @returns {boolean}\n   */\n  function isInlineSwap(swapStyle, target) {\n    const extensions = getExtensions(target)\n    for (let i = 0; i < extensions.length; i++) {\n      const extension = extensions[i]\n      try {\n        if (extension.isInlineSwap(swapStyle)) {\n          return true\n        }\n      } catch (e) {\n        logError(e)\n      }\n    }\n    return swapStyle === 'outerHTML'\n  }\n\n  /**\n   * @param {string} oobValue\n   * @param {Element} oobElement\n   * @param {HtmxSettleInfo} settleInfo\n   * @returns\n   */\n  function oobSwap(oobValue, oobElement, settleInfo) {\n    let selector = '#' + getRawAttribute(oobElement, 'id')\n    /** @type HtmxSwapStyle */\n    let swapStyle = 'outerHTML'\n    if (oobValue === 'true') {\n      // do nothing\n    } else if (oobValue.indexOf(':') > 0) {\n      swapStyle = oobValue.substr(0, oobValue.indexOf(':'))\n      selector = oobValue.substr(oobValue.indexOf(':') + 1, oobValue.length)\n    } else {\n      swapStyle = oobValue\n    }\n\n    const targets = getDocument().querySelectorAll(selector)\n    if (targets) {\n      forEach(\n        targets,\n        function(target) {\n          let fragment\n          const oobElementClone = oobElement.cloneNode(true)\n          fragment = getDocument().createDocumentFragment()\n          fragment.appendChild(oobElementClone)\n          if (!isInlineSwap(swapStyle, target)) {\n            fragment = asParentNode(oobElementClone) // if this is not an inline swap, we use the content of the node, not the node itself\n          }\n\n          const beforeSwapDetails = { shouldSwap: true, target, fragment }\n          if (!triggerEvent(target, 'htmx:oobBeforeSwap', beforeSwapDetails)) return\n\n          target = beforeSwapDetails.target // allow re-targeting\n          if (beforeSwapDetails.shouldSwap) {\n            swapWithStyle(swapStyle, target, target, fragment, settleInfo)\n          }\n          forEach(settleInfo.elts, function(elt) {\n            triggerEvent(elt, 'htmx:oobAfterSwap', beforeSwapDetails)\n          })\n        }\n      )\n      oobElement.parentNode.removeChild(oobElement)\n    } else {\n      oobElement.parentNode.removeChild(oobElement)\n      triggerErrorEvent(getDocument().body, 'htmx:oobErrorNoTarget', { content: oobElement })\n    }\n    return oobValue\n  }\n\n  /**\n   * @param {DocumentFragment} fragment\n   */\n  function handlePreservedElements(fragment) {\n    forEach(findAll(fragment, '[hx-preserve], [data-hx-preserve]'), function(preservedElt) {\n      const id = getAttributeValue(preservedElt, 'id')\n      const oldElt = getDocument().getElementById(id)\n      if (oldElt != null) {\n        preservedElt.parentNode.replaceChild(oldElt, preservedElt)\n      }\n    })\n  }\n\n  /**\n   * @param {Node} parentNode\n   * @param {ParentNode} fragment\n   * @param {HtmxSettleInfo} settleInfo\n   */\n  function handleAttributes(parentNode, fragment, settleInfo) {\n    forEach(fragment.querySelectorAll('[id]'), function(newNode) {\n      const id = getRawAttribute(newNode, 'id')\n      if (id && id.length > 0) {\n        const normalizedId = id.replace(\"'\", \"\\\\'\")\n        const normalizedTag = newNode.tagName.replace(':', '\\\\:')\n        const parentElt = asParentNode(parentNode)\n        const oldNode = parentElt && parentElt.querySelector(normalizedTag + \"[id='\" + normalizedId + \"']\")\n        if (oldNode && oldNode !== parentElt) {\n          const newAttributes = newNode.cloneNode()\n          cloneAttributes(newNode, oldNode)\n          settleInfo.tasks.push(function() {\n            cloneAttributes(newNode, newAttributes)\n          })\n        }\n      }\n    })\n  }\n\n  /**\n   * @param {Node} child\n   * @returns {HtmxSettleTask}\n   */\n  function makeAjaxLoadTask(child) {\n    return function() {\n      removeClassFromElement(child, htmx.config.addedClass)\n      processNode(asElement(child))\n      processFocus(asParentNode(child))\n      triggerEvent(child, 'htmx:load')\n    }\n  }\n\n  /**\n   * @param {ParentNode} child\n   */\n  function processFocus(child) {\n    const autofocus = '[autofocus]'\n    const autoFocusedElt = asHtmlElement(matches(child, autofocus) ? child : child.querySelector(autofocus))\n    if (autoFocusedElt != null) {\n      autoFocusedElt.focus()\n    }\n  }\n\n  /**\n   * @param {Node} parentNode\n   * @param {Node} insertBefore\n   * @param {ParentNode} fragment\n   * @param {HtmxSettleInfo} settleInfo\n   */\n  function insertNodesBefore(parentNode, insertBefore, fragment, settleInfo) {\n    handleAttributes(parentNode, fragment, settleInfo)\n    while (fragment.childNodes.length > 0) {\n      const child = fragment.firstChild\n      addClassToElement(asElement(child), htmx.config.addedClass)\n      parentNode.insertBefore(child, insertBefore)\n      if (child.nodeType !== Node.TEXT_NODE && child.nodeType !== Node.COMMENT_NODE) {\n        settleInfo.tasks.push(makeAjaxLoadTask(child))\n      }\n    }\n  }\n\n  /**\n   * based on https://gist.github.com/hyamamoto/fd435505d29ebfa3d9716fd2be8d42f0,\n   * derived from Java's string hashcode implementation\n   * @param {string} string\n   * @param {number} hash\n   * @returns {number}\n   */\n  function stringHash(string, hash) {\n    let char = 0\n    while (char < string.length) {\n      hash = (hash << 5) - hash + string.charCodeAt(char++) | 0 // bitwise or ensures we have a 32-bit int\n    }\n    return hash\n  }\n\n  /**\n   * @param {Element} elt\n   * @returns {number}\n   */\n  function attributeHash(elt) {\n    let hash = 0\n    // IE fix\n    if (elt.attributes) {\n      for (let i = 0; i < elt.attributes.length; i++) {\n        const attribute = elt.attributes[i]\n        if (attribute.value) { // only include attributes w/ actual values (empty is same as non-existent)\n          hash = stringHash(attribute.name, hash)\n          hash = stringHash(attribute.value, hash)\n        }\n      }\n    }\n    return hash\n  }\n\n  /**\n   * @param {EventTarget} elt\n   */\n  function deInitOnHandlers(elt) {\n    const internalData = getInternalData(elt)\n    if (internalData.onHandlers) {\n      for (let i = 0; i < internalData.onHandlers.length; i++) {\n        const handlerInfo = internalData.onHandlers[i]\n        removeEventListenerImpl(elt, handlerInfo.event, handlerInfo.listener)\n      }\n      delete internalData.onHandlers\n    }\n  }\n\n  /**\n   * @param {Node} element\n   */\n  function deInitNode(element) {\n    const internalData = getInternalData(element)\n    if (internalData.timeout) {\n      clearTimeout(internalData.timeout)\n    }\n    if (internalData.listenerInfos) {\n      forEach(internalData.listenerInfos, function(info) {\n        if (info.on) {\n          removeEventListenerImpl(info.on, info.trigger, info.listener)\n        }\n      })\n    }\n    deInitOnHandlers(element)\n    forEach(Object.keys(internalData), function(key) { delete internalData[key] })\n  }\n\n  /**\n   * @param {Node} element\n   */\n  function cleanUpElement(element) {\n    triggerEvent(element, 'htmx:beforeCleanupElement')\n    deInitNode(element)\n    // @ts-ignore IE11 code\n    // noinspection JSUnresolvedReference\n    if (element.children) { // IE\n      // @ts-ignore\n      forEach(element.children, function(child) { cleanUpElement(child) })\n    }\n  }\n\n  /**\n   * @param {Node} target\n   * @param {ParentNode} fragment\n   * @param {HtmxSettleInfo} settleInfo\n   */\n  function swapOuterHTML(target, fragment, settleInfo) {\n    if (target instanceof Element && target.tagName === 'BODY') { // special case the body to innerHTML because DocumentFragments can't contain a body elt unfortunately\n      return swapInnerHTML(target, fragment, settleInfo)\n    }\n    /** @type {Node} */\n    let newElt\n    const eltBeforeNewContent = target.previousSibling\n    insertNodesBefore(parentElt(target), target, fragment, settleInfo)\n    if (eltBeforeNewContent == null) {\n      newElt = parentElt(target).firstChild\n    } else {\n      newElt = eltBeforeNewContent.nextSibling\n    }\n    settleInfo.elts = settleInfo.elts.filter(function(e) { return e !== target })\n    // scan through all newly added content and add all elements to the settle info so we trigger\n    // events properly on them\n    while (newElt && newElt !== target) {\n      if (newElt instanceof Element) {\n        settleInfo.elts.push(newElt)\n      }\n      newElt = newElt.nextSibling\n    }\n    cleanUpElement(target)\n    if (target instanceof Element) {\n      target.remove()\n    } else {\n      target.parentNode.removeChild(target)\n    }\n  }\n\n  /**\n   * @param {Node} target\n   * @param {ParentNode} fragment\n   * @param {HtmxSettleInfo} settleInfo\n   */\n  function swapAfterBegin(target, fragment, settleInfo) {\n    return insertNodesBefore(target, target.firstChild, fragment, settleInfo)\n  }\n\n  /**\n   * @param {Node} target\n   * @param {ParentNode} fragment\n   * @param {HtmxSettleInfo} settleInfo\n   */\n  function swapBeforeBegin(target, fragment, settleInfo) {\n    return insertNodesBefore(parentElt(target), target, fragment, settleInfo)\n  }\n\n  /**\n   * @param {Node} target\n   * @param {ParentNode} fragment\n   * @param {HtmxSettleInfo} settleInfo\n   */\n  function swapBeforeEnd(target, fragment, settleInfo) {\n    return insertNodesBefore(target, null, fragment, settleInfo)\n  }\n\n  /**\n   * @param {Node} target\n   * @param {ParentNode} fragment\n   * @param {HtmxSettleInfo} settleInfo\n   */\n  function swapAfterEnd(target, fragment, settleInfo) {\n    return insertNodesBefore(parentElt(target), target.nextSibling, fragment, settleInfo)\n  }\n\n  /**\n   * @param {Node} target\n   */\n  function swapDelete(target) {\n    cleanUpElement(target)\n    return parentElt(target).removeChild(target)\n  }\n\n  /**\n   * @param {Node} target\n   * @param {ParentNode} fragment\n   * @param {HtmxSettleInfo} settleInfo\n   */\n  function swapInnerHTML(target, fragment, settleInfo) {\n    const firstChild = target.firstChild\n    insertNodesBefore(target, firstChild, fragment, settleInfo)\n    if (firstChild) {\n      while (firstChild.nextSibling) {\n        cleanUpElement(firstChild.nextSibling)\n        target.removeChild(firstChild.nextSibling)\n      }\n      cleanUpElement(firstChild)\n      target.removeChild(firstChild)\n    }\n  }\n\n  /**\n   * @param {HtmxSwapStyle} swapStyle\n   * @param {Element} elt\n   * @param {Node} target\n   * @param {ParentNode} fragment\n   * @param {HtmxSettleInfo} settleInfo\n   */\n  function swapWithStyle(swapStyle, elt, target, fragment, settleInfo) {\n    switch (swapStyle) {\n      case 'none':\n        return\n      case 'outerHTML':\n        swapOuterHTML(target, fragment, settleInfo)\n        return\n      case 'afterbegin':\n        swapAfterBegin(target, fragment, settleInfo)\n        return\n      case 'beforebegin':\n        swapBeforeBegin(target, fragment, settleInfo)\n        return\n      case 'beforeend':\n        swapBeforeEnd(target, fragment, settleInfo)\n        return\n      case 'afterend':\n        swapAfterEnd(target, fragment, settleInfo)\n        return\n      case 'delete':\n        swapDelete(target)\n        return\n      default:\n        var extensions = getExtensions(elt)\n        for (let i = 0; i < extensions.length; i++) {\n          const ext = extensions[i]\n          try {\n            const newElements = ext.handleSwap(swapStyle, target, fragment, settleInfo)\n            if (newElements) {\n              if (Array.isArray(newElements)) {\n                // if handleSwap returns an array (like) of elements, we handle them\n                for (let j = 0; j < newElements.length; j++) {\n                  const child = newElements[j]\n                  if (child.nodeType !== Node.TEXT_NODE && child.nodeType !== Node.COMMENT_NODE) {\n                    settleInfo.tasks.push(makeAjaxLoadTask(child))\n                  }\n                }\n              }\n              return\n            }\n          } catch (e) {\n            logError(e)\n          }\n        }\n        if (swapStyle === 'innerHTML') {\n          swapInnerHTML(target, fragment, settleInfo)\n        } else {\n          swapWithStyle(htmx.config.defaultSwapStyle, elt, target, fragment, settleInfo)\n        }\n    }\n  }\n\n  /**\n   * @param {DocumentFragment} fragment\n   * @param {HtmxSettleInfo} settleInfo\n   */\n  function findAndSwapOobElements(fragment, settleInfo) {\n    var oobElts = findAll(fragment, '[hx-swap-oob], [data-hx-swap-oob]')\n    forEach(oobElts, function(oobElement) {\n      if (htmx.config.allowNestedOobSwaps || oobElement.parentElement === null) {\n        const oobValue = getAttributeValue(oobElement, 'hx-swap-oob')\n        if (oobValue != null) {\n          oobSwap(oobValue, oobElement, settleInfo)\n        }\n      } else {\n        oobElement.removeAttribute('hx-swap-oob')\n        oobElement.removeAttribute('data-hx-swap-oob')\n      }\n    })\n    return oobElts.length > 0\n  }\n\n  /**\n   * Implements complete swapping pipeline, including: focus and selection preservation,\n   * title updates, scroll, OOB swapping, normal swapping and settling\n   * @param {string|Element} target\n   * @param {string} content\n   * @param {HtmxSwapSpecification} swapSpec\n   * @param {SwapOptions} [swapOptions]\n   */\n  function swap(target, content, swapSpec, swapOptions) {\n    if (!swapOptions) {\n      swapOptions = {}\n    }\n\n    target = resolveTarget(target)\n\n    // preserve focus and selection\n    const activeElt = document.activeElement\n    let selectionInfo = {}\n    try {\n      selectionInfo = {\n        elt: activeElt,\n        // @ts-ignore\n        start: activeElt ? activeElt.selectionStart : null,\n        // @ts-ignore\n        end: activeElt ? activeElt.selectionEnd : null\n      }\n    } catch (e) {\n      // safari issue - see https://github.com/microsoft/playwright/issues/5894\n    }\n    const settleInfo = makeSettleInfo(target)\n\n    // For text content swaps, don't parse the response as HTML, just insert it\n    if (swapSpec.swapStyle === 'textContent') {\n      target.textContent = content\n    // Otherwise, make the fragment and process it\n    } else {\n      let fragment = makeFragment(content)\n\n      settleInfo.title = fragment.title\n\n      // select-oob swaps\n      if (swapOptions.selectOOB) {\n        const oobSelectValues = swapOptions.selectOOB.split(',')\n        for (let i = 0; i < oobSelectValues.length; i++) {\n          const oobSelectValue = oobSelectValues[i].split(':', 2)\n          let id = oobSelectValue[0].trim()\n          if (id.indexOf('#') === 0) {\n            id = id.substring(1)\n          }\n          const oobValue = oobSelectValue[1] || 'true'\n          const oobElement = fragment.querySelector('#' + id)\n          if (oobElement) {\n            oobSwap(oobValue, oobElement, settleInfo)\n          }\n        }\n      }\n      // oob swaps\n      findAndSwapOobElements(fragment, settleInfo)\n      forEach(findAll(fragment, 'template'), /** @param {HTMLTemplateElement} template */function(template) {\n        if (findAndSwapOobElements(template.content, settleInfo)) {\n          // Avoid polluting the DOM with empty templates that were only used to encapsulate oob swap\n          template.remove()\n        }\n      })\n\n      // normal swap\n      if (swapOptions.select) {\n        const newFragment = getDocument().createDocumentFragment()\n        forEach(fragment.querySelectorAll(swapOptions.select), function(node) {\n          newFragment.appendChild(node)\n        })\n        fragment = newFragment\n      }\n      handlePreservedElements(fragment)\n      swapWithStyle(swapSpec.swapStyle, swapOptions.contextElement, target, fragment, settleInfo)\n    }\n\n    // apply saved focus and selection information to swapped content\n    if (selectionInfo.elt &&\n      !bodyContains(selectionInfo.elt) &&\n      getRawAttribute(selectionInfo.elt, 'id')) {\n      const newActiveElt = document.getElementById(getRawAttribute(selectionInfo.elt, 'id'))\n      const focusOptions = { preventScroll: swapSpec.focusScroll !== undefined ? !swapSpec.focusScroll : !htmx.config.defaultFocusScroll }\n      if (newActiveElt) {\n        // @ts-ignore\n        if (selectionInfo.start && newActiveElt.setSelectionRange) {\n          try {\n            // @ts-ignore\n            newActiveElt.setSelectionRange(selectionInfo.start, selectionInfo.end)\n          } catch (e) {\n            // the setSelectionRange method is present on fields that don't support it, so just let this fail\n          }\n        }\n        newActiveElt.focus(focusOptions)\n      }\n    }\n\n    target.classList.remove(htmx.config.swappingClass)\n    forEach(settleInfo.elts, function(elt) {\n      if (elt.classList) {\n        elt.classList.add(htmx.config.settlingClass)\n      }\n      triggerEvent(elt, 'htmx:afterSwap', swapOptions.eventInfo)\n    })\n    if (swapOptions.afterSwapCallback) {\n      swapOptions.afterSwapCallback()\n    }\n\n    // merge in new title after swap but before settle\n    if (!swapSpec.ignoreTitle) {\n      handleTitle(settleInfo.title)\n    }\n\n    // settle\n    const doSettle = function() {\n      forEach(settleInfo.tasks, function(task) {\n        task.call()\n      })\n      forEach(settleInfo.elts, function(elt) {\n        if (elt.classList) {\n          elt.classList.remove(htmx.config.settlingClass)\n        }\n        triggerEvent(elt, 'htmx:afterSettle', swapOptions.eventInfo)\n      })\n\n      if (swapOptions.anchor) {\n        const anchorTarget = asElement(resolveTarget('#' + swapOptions.anchor))\n        if (anchorTarget) {\n          anchorTarget.scrollIntoView({ block: 'start', behavior: 'auto' })\n        }\n      }\n\n      updateScrollState(settleInfo.elts, swapSpec)\n      if (swapOptions.afterSettleCallback) {\n        swapOptions.afterSettleCallback()\n      }\n    }\n\n    if (swapSpec.settleDelay > 0) {\n      getWindow().setTimeout(doSettle, swapSpec.settleDelay)\n    } else {\n      doSettle()\n    }\n  }\n\n  /**\n   * @param {XMLHttpRequest} xhr\n   * @param {string} header\n   * @param {EventTarget} elt\n   */\n  function handleTriggerHeader(xhr, header, elt) {\n    const triggerBody = xhr.getResponseHeader(header)\n    if (triggerBody.indexOf('{') === 0) {\n      const triggers = parseJSON(triggerBody)\n      for (const eventName in triggers) {\n        if (triggers.hasOwnProperty(eventName)) {\n          let detail = triggers[eventName]\n          if (isRawObject(detail)) {\n            // @ts-ignore\n            elt = detail.target !== undefined ? detail.target : elt\n          } else {\n            detail = { value: detail }\n          }\n          triggerEvent(elt, eventName, detail)\n        }\n      }\n    } else {\n      const eventNames = triggerBody.split(',')\n      for (let i = 0; i < eventNames.length; i++) {\n        triggerEvent(elt, eventNames[i].trim(), [])\n      }\n    }\n  }\n\n  const WHITESPACE = /\\s/\n  const WHITESPACE_OR_COMMA = /[\\s,]/\n  const SYMBOL_START = /[_$a-zA-Z]/\n  const SYMBOL_CONT = /[_$a-zA-Z0-9]/\n  const STRINGISH_START = ['\"', \"'\", '/']\n  const NOT_WHITESPACE = /[^\\s]/\n  const COMBINED_SELECTOR_START = /[{(]/\n  const COMBINED_SELECTOR_END = /[})]/\n\n  /**\n   * @param {string} str\n   * @returns {string[]}\n   */\n  function tokenizeString(str) {\n    /** @type string[] */\n    const tokens = []\n    let position = 0\n    while (position < str.length) {\n      if (SYMBOL_START.exec(str.charAt(position))) {\n        var startPosition = position\n        while (SYMBOL_CONT.exec(str.charAt(position + 1))) {\n          position++\n        }\n        tokens.push(str.substr(startPosition, position - startPosition + 1))\n      } else if (STRINGISH_START.indexOf(str.charAt(position)) !== -1) {\n        const startChar = str.charAt(position)\n        var startPosition = position\n        position++\n        while (position < str.length && str.charAt(position) !== startChar) {\n          if (str.charAt(position) === '\\\\') {\n            position++\n          }\n          position++\n        }\n        tokens.push(str.substr(startPosition, position - startPosition + 1))\n      } else {\n        const symbol = str.charAt(position)\n        tokens.push(symbol)\n      }\n      position++\n    }\n    return tokens\n  }\n\n  /**\n   * @param {string} token\n   * @param {string|null} last\n   * @param {string} paramName\n   * @returns {boolean}\n   */\n  function isPossibleRelativeReference(token, last, paramName) {\n    return SYMBOL_START.exec(token.charAt(0)) &&\n      token !== 'true' &&\n      token !== 'false' &&\n      token !== 'this' &&\n      token !== paramName &&\n      last !== '.'\n  }\n\n  /**\n   * @param {EventTarget|string} elt\n   * @param {string[]} tokens\n   * @param {string} paramName\n   * @returns {ConditionalFunction|null}\n   */\n  function maybeGenerateConditional(elt, tokens, paramName) {\n    if (tokens[0] === '[') {\n      tokens.shift()\n      let bracketCount = 1\n      let conditionalSource = ' return (function(' + paramName + '){ return ('\n      let last = null\n      while (tokens.length > 0) {\n        const token = tokens[0]\n        // @ts-ignore For some reason tsc doesn't understand the shift call, and thinks we're comparing the same value here, i.e. '[' vs ']'\n        if (token === ']') {\n          bracketCount--\n          if (bracketCount === 0) {\n            if (last === null) {\n              conditionalSource = conditionalSource + 'true'\n            }\n            tokens.shift()\n            conditionalSource += ')})'\n            try {\n              const conditionFunction = maybeEval(elt, function() {\n                return Function(conditionalSource)()\n              },\n              function() { return true })\n              conditionFunction.source = conditionalSource\n              return conditionFunction\n            } catch (e) {\n              triggerErrorEvent(getDocument().body, 'htmx:syntax:error', { error: e, source: conditionalSource })\n              return null\n            }\n          }\n        } else if (token === '[') {\n          bracketCount++\n        }\n        if (isPossibleRelativeReference(token, last, paramName)) {\n          conditionalSource += '((' + paramName + '.' + token + ') ? (' + paramName + '.' + token + ') : (window.' + token + '))'\n        } else {\n          conditionalSource = conditionalSource + token\n        }\n        last = tokens.shift()\n      }\n    }\n  }\n\n  /**\n   * @param {string[]} tokens\n   * @param {RegExp} match\n   * @returns {string}\n   */\n  function consumeUntil(tokens, match) {\n    let result = ''\n    while (tokens.length > 0 && !match.test(tokens[0])) {\n      result += tokens.shift()\n    }\n    return result\n  }\n\n  /**\n   * @param {string[]} tokens\n   * @returns {string}\n   */\n  function consumeCSSSelector(tokens) {\n    let result\n    if (tokens.length > 0 && COMBINED_SELECTOR_START.test(tokens[0])) {\n      tokens.shift()\n      result = consumeUntil(tokens, COMBINED_SELECTOR_END).trim()\n      tokens.shift()\n    } else {\n      result = consumeUntil(tokens, WHITESPACE_OR_COMMA)\n    }\n    return result\n  }\n\n  const INPUT_SELECTOR = 'input, textarea, select'\n\n  /**\n   * @param {Element} elt\n   * @param {string} explicitTrigger\n   * @param {Object} cache for trigger specs\n   * @returns {HtmxTriggerSpecification[]}\n   */\n  function parseAndCacheTrigger(elt, explicitTrigger, cache) {\n    /** @type HtmxTriggerSpecification[] */\n    const triggerSpecs = []\n    const tokens = tokenizeString(explicitTrigger)\n    do {\n      consumeUntil(tokens, NOT_WHITESPACE)\n      const initialLength = tokens.length\n      const trigger = consumeUntil(tokens, /[,\\[\\s]/)\n      if (trigger !== '') {\n        if (trigger === 'every') {\n          /** @type HtmxTriggerSpecification */\n          const every = { trigger: 'every' }\n          consumeUntil(tokens, NOT_WHITESPACE)\n          every.pollInterval = parseInterval(consumeUntil(tokens, /[,\\[\\s]/))\n          consumeUntil(tokens, NOT_WHITESPACE)\n          var eventFilter = maybeGenerateConditional(elt, tokens, 'event')\n          if (eventFilter) {\n            every.eventFilter = eventFilter\n          }\n          triggerSpecs.push(every)\n        } else {\n          /** @type HtmxTriggerSpecification */\n          const triggerSpec = { trigger }\n          var eventFilter = maybeGenerateConditional(elt, tokens, 'event')\n          if (eventFilter) {\n            triggerSpec.eventFilter = eventFilter\n          }\n          while (tokens.length > 0 && tokens[0] !== ',') {\n            consumeUntil(tokens, NOT_WHITESPACE)\n            const token = tokens.shift()\n            if (token === 'changed') {\n              triggerSpec.changed = true\n            } else if (token === 'once') {\n              triggerSpec.once = true\n            } else if (token === 'consume') {\n              triggerSpec.consume = true\n            } else if (token === 'delay' && tokens[0] === ':') {\n              tokens.shift()\n              triggerSpec.delay = parseInterval(consumeUntil(tokens, WHITESPACE_OR_COMMA))\n            } else if (token === 'from' && tokens[0] === ':') {\n              tokens.shift()\n              if (COMBINED_SELECTOR_START.test(tokens[0])) {\n                var from_arg = consumeCSSSelector(tokens)\n              } else {\n                var from_arg = consumeUntil(tokens, WHITESPACE_OR_COMMA)\n                if (from_arg === 'closest' || from_arg === 'find' || from_arg === 'next' || from_arg === 'previous') {\n                  tokens.shift()\n                  const selector = consumeCSSSelector(tokens)\n                  // `next` and `previous` allow a selector-less syntax\n                  if (selector.length > 0) {\n                    from_arg += ' ' + selector\n                  }\n                }\n              }\n              triggerSpec.from = from_arg\n            } else if (token === 'target' && tokens[0] === ':') {\n              tokens.shift()\n              triggerSpec.target = consumeCSSSelector(tokens)\n            } else if (token === 'throttle' && tokens[0] === ':') {\n              tokens.shift()\n              triggerSpec.throttle = parseInterval(consumeUntil(tokens, WHITESPACE_OR_COMMA))\n            } else if (token === 'queue' && tokens[0] === ':') {\n              tokens.shift()\n              triggerSpec.queue = consumeUntil(tokens, WHITESPACE_OR_COMMA)\n            } else if (token === 'root' && tokens[0] === ':') {\n              tokens.shift()\n              triggerSpec[token] = consumeCSSSelector(tokens)\n            } else if (token === 'threshold' && tokens[0] === ':') {\n              tokens.shift()\n              triggerSpec[token] = consumeUntil(tokens, WHITESPACE_OR_COMMA)\n            } else {\n              triggerErrorEvent(elt, 'htmx:syntax:error', { token: tokens.shift() })\n            }\n          }\n          triggerSpecs.push(triggerSpec)\n        }\n      }\n      if (tokens.length === initialLength) {\n        triggerErrorEvent(elt, 'htmx:syntax:error', { token: tokens.shift() })\n      }\n      consumeUntil(tokens, NOT_WHITESPACE)\n    } while (tokens[0] === ',' && tokens.shift())\n    if (cache) {\n      cache[explicitTrigger] = triggerSpecs\n    }\n    return triggerSpecs\n  }\n\n  /**\n   * @param {Element} elt\n   * @returns {HtmxTriggerSpecification[]}\n   */\n  function getTriggerSpecs(elt) {\n    const explicitTrigger = getAttributeValue(elt, 'hx-trigger')\n    let triggerSpecs = []\n    if (explicitTrigger) {\n      const cache = htmx.config.triggerSpecsCache\n      triggerSpecs = (cache && cache[explicitTrigger]) || parseAndCacheTrigger(elt, explicitTrigger, cache)\n    }\n\n    if (triggerSpecs.length > 0) {\n      return triggerSpecs\n    } else if (matches(elt, 'form')) {\n      return [{ trigger: 'submit' }]\n    } else if (matches(elt, 'input[type=\"button\"], input[type=\"submit\"]')) {\n      return [{ trigger: 'click' }]\n    } else if (matches(elt, INPUT_SELECTOR)) {\n      return [{ trigger: 'change' }]\n    } else {\n      return [{ trigger: 'click' }]\n    }\n  }\n\n  /**\n   * @param {Element} elt\n   */\n  function cancelPolling(elt) {\n    getInternalData(elt).cancelled = true\n  }\n\n  /**\n   * @param {Element} elt\n   * @param {TriggerHandler} handler\n   * @param {HtmxTriggerSpecification} spec\n   */\n  function processPolling(elt, handler, spec) {\n    const nodeData = getInternalData(elt)\n    nodeData.timeout = getWindow().setTimeout(function() {\n      if (bodyContains(elt) && nodeData.cancelled !== true) {\n        if (!maybeFilterEvent(spec, elt, makeEvent('hx:poll:trigger', {\n          triggerSpec: spec,\n          target: elt\n        }))) {\n          handler(elt)\n        }\n        processPolling(elt, handler, spec)\n      }\n    }, spec.pollInterval)\n  }\n\n  /**\n   * @param {HTMLAnchorElement} elt\n   * @returns {boolean}\n   */\n  function isLocalLink(elt) {\n    return location.hostname === elt.hostname &&\n      getRawAttribute(elt, 'href') &&\n      getRawAttribute(elt, 'href').indexOf('#') !== 0\n  }\n\n  /**\n   * @param {Element} elt\n   */\n  function eltIsDisabled(elt) {\n    return closest(elt, htmx.config.disableSelector)\n  }\n\n  /**\n   * @param {Element} elt\n   * @param {HtmxNodeInternalData} nodeData\n   * @param {HtmxTriggerSpecification[]} triggerSpecs\n   */\n  function boostElement(elt, nodeData, triggerSpecs) {\n    if ((elt instanceof HTMLAnchorElement && isLocalLink(elt) && (elt.target === '' || elt.target === '_self')) || (elt.tagName === 'FORM' && String(getRawAttribute(elt, 'method')).toLowerCase() !== 'dialog')) {\n      nodeData.boosted = true\n      let verb, path\n      if (elt.tagName === 'A') {\n        verb = 'get'\n        path = getRawAttribute(elt, 'href')\n      } else {\n        const rawAttribute = getRawAttribute(elt, 'method')\n        verb = rawAttribute ? rawAttribute.toLowerCase() : 'get'\n        if (verb === 'get') {\n        }\n        path = getRawAttribute(elt, 'action')\n      }\n      triggerSpecs.forEach(function(triggerSpec) {\n        addEventListener(elt, function(node, evt) {\n          const elt = asElement(node)\n          if (eltIsDisabled(elt)) {\n            cleanUpElement(elt)\n            return\n          }\n          issueAjaxRequest(verb, path, elt, evt)\n        }, nodeData, triggerSpec, true)\n      })\n    }\n  }\n\n  /**\n   * @param {Event} evt\n   * @param {Node} node\n   * @returns {boolean}\n   */\n  function shouldCancel(evt, node) {\n    const elt = asElement(node)\n    if (!elt) {\n      return false\n    }\n    if (evt.type === 'submit' || evt.type === 'click') {\n      if (elt.tagName === 'FORM') {\n        return true\n      }\n      if (matches(elt, 'input[type=\"submit\"], button') && closest(elt, 'form') !== null) {\n        return true\n      }\n      if (elt instanceof HTMLAnchorElement && elt.href &&\n        (elt.getAttribute('href') === '#' || elt.getAttribute('href').indexOf('#') !== 0)) {\n        return true\n      }\n    }\n    return false\n  }\n\n  /**\n   * @param {Node} elt\n   * @param {Event|MouseEvent|KeyboardEvent|TouchEvent} evt\n   * @returns {boolean}\n   */\n  function ignoreBoostedAnchorCtrlClick(elt, evt) {\n    return getInternalData(elt).boosted && elt instanceof HTMLAnchorElement && evt.type === 'click' &&\n      // @ts-ignore this will resolve to undefined for events that don't define those properties, which is fine\n      (evt.ctrlKey || evt.metaKey)\n  }\n\n  /**\n   * @param {HtmxTriggerSpecification} triggerSpec\n   * @param {Node} elt\n   * @param {Event} evt\n   * @returns {boolean}\n   */\n  function maybeFilterEvent(triggerSpec, elt, evt) {\n    const eventFilter = triggerSpec.eventFilter\n    if (eventFilter) {\n      try {\n        return eventFilter.call(elt, evt) !== true\n      } catch (e) {\n        const source = eventFilter.source\n        triggerErrorEvent(getDocument().body, 'htmx:eventFilter:error', { error: e, source })\n        return true\n      }\n    }\n    return false\n  }\n\n  /**\n   * @param {Node} elt\n   * @param {TriggerHandler} handler\n   * @param {HtmxNodeInternalData} nodeData\n   * @param {HtmxTriggerSpecification} triggerSpec\n   * @param {boolean} [explicitCancel]\n   */\n  function addEventListener(elt, handler, nodeData, triggerSpec, explicitCancel) {\n    const elementData = getInternalData(elt)\n    /** @type {(Node|Window)[]} */\n    let eltsToListenOn\n    if (triggerSpec.from) {\n      eltsToListenOn = querySelectorAllExt(elt, triggerSpec.from)\n    } else {\n      eltsToListenOn = [elt]\n    }\n    // store the initial values of the elements, so we can tell if they change\n    if (triggerSpec.changed) {\n      eltsToListenOn.forEach(function(eltToListenOn) {\n        const eltToListenOnData = getInternalData(eltToListenOn)\n        // @ts-ignore value will be undefined for non-input elements, which is fine\n        eltToListenOnData.lastValue = eltToListenOn.value\n      })\n    }\n    forEach(eltsToListenOn, function(eltToListenOn) {\n      /** @type EventListener */\n      const eventListener = function(evt) {\n        if (!bodyContains(elt)) {\n          eltToListenOn.removeEventListener(triggerSpec.trigger, eventListener)\n          return\n        }\n        if (ignoreBoostedAnchorCtrlClick(elt, evt)) {\n          return\n        }\n        if (explicitCancel || shouldCancel(evt, elt)) {\n          evt.preventDefault()\n        }\n        if (maybeFilterEvent(triggerSpec, elt, evt)) {\n          return\n        }\n        const eventData = getInternalData(evt)\n        eventData.triggerSpec = triggerSpec\n        if (eventData.handledFor == null) {\n          eventData.handledFor = []\n        }\n        if (eventData.handledFor.indexOf(elt) < 0) {\n          eventData.handledFor.push(elt)\n          if (triggerSpec.consume) {\n            evt.stopPropagation()\n          }\n          if (triggerSpec.target && evt.target) {\n            if (!matches(asElement(evt.target), triggerSpec.target)) {\n              return\n            }\n          }\n          if (triggerSpec.once) {\n            if (elementData.triggeredOnce) {\n              return\n            } else {\n              elementData.triggeredOnce = true\n            }\n          }\n          if (triggerSpec.changed) {\n            const eltToListenOnData = getInternalData(eltToListenOn)\n            // @ts-ignore value will be undefined for non-input elements, which is fine\n            const value = eltToListenOn.value\n            if (eltToListenOnData.lastValue === value) {\n              return\n            }\n            eltToListenOnData.lastValue = value\n          }\n          if (elementData.delayed) {\n            clearTimeout(elementData.delayed)\n          }\n          if (elementData.throttle) {\n            return\n          }\n\n          if (triggerSpec.throttle > 0) {\n            if (!elementData.throttle) {\n              triggerEvent(elt, 'htmx:trigger')\n              handler(elt, evt)\n              elementData.throttle = getWindow().setTimeout(function() {\n                elementData.throttle = null\n              }, triggerSpec.throttle)\n            }\n          } else if (triggerSpec.delay > 0) {\n            elementData.delayed = getWindow().setTimeout(function() {\n              triggerEvent(elt, 'htmx:trigger')\n              handler(elt, evt)\n            }, triggerSpec.delay)\n          } else {\n            triggerEvent(elt, 'htmx:trigger')\n            handler(elt, evt)\n          }\n        }\n      }\n      if (nodeData.listenerInfos == null) {\n        nodeData.listenerInfos = []\n      }\n      nodeData.listenerInfos.push({\n        trigger: triggerSpec.trigger,\n        listener: eventListener,\n        on: eltToListenOn\n      })\n      eltToListenOn.addEventListener(triggerSpec.trigger, eventListener)\n    })\n  }\n\n  let windowIsScrolling = false // used by initScrollHandler\n  let scrollHandler = null\n  function initScrollHandler() {\n    if (!scrollHandler) {\n      scrollHandler = function() {\n        windowIsScrolling = true\n      }\n      window.addEventListener('scroll', scrollHandler)\n      setInterval(function() {\n        if (windowIsScrolling) {\n          windowIsScrolling = false\n          forEach(getDocument().querySelectorAll(\"[hx-trigger*='revealed'],[data-hx-trigger*='revealed']\"), function(elt) {\n            maybeReveal(elt)\n          })\n        }\n      }, 200)\n    }\n  }\n\n  /**\n   * @param {Element} elt\n   */\n  function maybeReveal(elt) {\n    if (!hasAttribute(elt, 'data-hx-revealed') && isScrolledIntoView(elt)) {\n      elt.setAttribute('data-hx-revealed', 'true')\n      const nodeData = getInternalData(elt)\n      if (nodeData.initHash) {\n        triggerEvent(elt, 'revealed')\n      } else {\n        // if the node isn't initialized, wait for it before triggering the request\n        elt.addEventListener('htmx:afterProcessNode', function() { triggerEvent(elt, 'revealed') }, { once: true })\n      }\n    }\n  }\n\n  //= ===================================================================\n\n  /**\n   * @param {Element} elt\n   * @param {TriggerHandler} handler\n   * @param {HtmxNodeInternalData} nodeData\n   * @param {number} delay\n   */\n  function loadImmediately(elt, handler, nodeData, delay) {\n    const load = function() {\n      if (!nodeData.loaded) {\n        nodeData.loaded = true\n        handler(elt)\n      }\n    }\n    if (delay > 0) {\n      getWindow().setTimeout(load, delay)\n    } else {\n      load()\n    }\n  }\n\n  /**\n   * @param {Element} elt\n   * @param {HtmxNodeInternalData} nodeData\n   * @param {HtmxTriggerSpecification[]} triggerSpecs\n   * @returns {boolean}\n   */\n  function processVerbs(elt, nodeData, triggerSpecs) {\n    let explicitAction = false\n    forEach(VERBS, function(verb) {\n      if (hasAttribute(elt, 'hx-' + verb)) {\n        const path = getAttributeValue(elt, 'hx-' + verb)\n        explicitAction = true\n        nodeData.path = path\n        nodeData.verb = verb\n        triggerSpecs.forEach(function(triggerSpec) {\n          addTriggerHandler(elt, triggerSpec, nodeData, function(node, evt) {\n            const elt = asElement(node)\n            if (closest(elt, htmx.config.disableSelector)) {\n              cleanUpElement(elt)\n              return\n            }\n            issueAjaxRequest(verb, path, elt, evt)\n          })\n        })\n      }\n    })\n    return explicitAction\n  }\n\n  /**\n   * @callback TriggerHandler\n   * @param {Node} elt\n   * @param {Event} [evt]\n   */\n\n  /**\n   * @param {Node} elt\n   * @param {HtmxTriggerSpecification} triggerSpec\n   * @param {HtmxNodeInternalData} nodeData\n   * @param {TriggerHandler} handler\n   */\n  function addTriggerHandler(elt, triggerSpec, nodeData, handler) {\n    if (triggerSpec.trigger === 'revealed') {\n      initScrollHandler()\n      addEventListener(elt, handler, nodeData, triggerSpec)\n      maybeReveal(asElement(elt))\n    } else if (triggerSpec.trigger === 'intersect') {\n      const observerOptions = {}\n      if (triggerSpec.root) {\n        observerOptions.root = querySelectorExt(elt, triggerSpec.root)\n      }\n      if (triggerSpec.threshold) {\n        observerOptions.threshold = parseFloat(triggerSpec.threshold)\n      }\n      const observer = new IntersectionObserver(function(entries) {\n        for (let i = 0; i < entries.length; i++) {\n          const entry = entries[i]\n          if (entry.isIntersecting) {\n            triggerEvent(elt, 'intersect')\n            break\n          }\n        }\n      }, observerOptions)\n      observer.observe(asElement(elt))\n      addEventListener(asElement(elt), handler, nodeData, triggerSpec)\n    } else if (triggerSpec.trigger === 'load') {\n      if (!maybeFilterEvent(triggerSpec, elt, makeEvent('load', { elt }))) {\n        loadImmediately(asElement(elt), handler, nodeData, triggerSpec.delay)\n      }\n    } else if (triggerSpec.pollInterval > 0) {\n      nodeData.polling = true\n      processPolling(asElement(elt), handler, triggerSpec)\n    } else {\n      addEventListener(elt, handler, nodeData, triggerSpec)\n    }\n  }\n\n  /**\n   * @param {Node} node\n   * @returns {boolean}\n   */\n  function shouldProcessHxOn(node) {\n    const elt = asElement(node)\n    if (!elt) {\n      return false\n    }\n    const attributes = elt.attributes\n    for (let j = 0; j < attributes.length; j++) {\n      const attrName = attributes[j].name\n      if (startsWith(attrName, 'hx-on:') || startsWith(attrName, 'data-hx-on:') ||\n        startsWith(attrName, 'hx-on-') || startsWith(attrName, 'data-hx-on-')) {\n        return true\n      }\n    }\n    return false\n  }\n\n  /**\n   * @param {Node} elt\n   * @returns {Element[]}\n   */\n  const HX_ON_QUERY = new XPathEvaluator()\n    .createExpression('.//*[@*[ starts-with(name(), \"hx-on:\") or starts-with(name(), \"data-hx-on:\") or' +\n      ' starts-with(name(), \"hx-on-\") or starts-with(name(), \"data-hx-on-\") ]]')\n\n  function processHXOnRoot(elt, elements) {\n    if (shouldProcessHxOn(elt)) {\n      elements.push(asElement(elt))\n    }\n    const iter = HX_ON_QUERY.evaluate(elt)\n    let node = null\n    while (node = iter.iterateNext()) elements.push(asElement(node))\n  }\n\n  function findHxOnWildcardElements(elt) {\n    /** @type {Element[]} */\n    const elements = []\n    if (elt instanceof DocumentFragment) {\n      for (const child of elt.childNodes) {\n        processHXOnRoot(child, elements)\n      }\n    } else {\n      processHXOnRoot(elt, elements)\n    }\n    return elements\n  }\n\n  /**\n   * @param {Element} elt\n   * @returns {NodeListOf<Element>|[]}\n   */\n  function findElementsToProcess(elt) {\n    if (elt.querySelectorAll) {\n      const boostedSelector = ', [hx-boost] a, [data-hx-boost] a, a[hx-boost], a[data-hx-boost]'\n\n      const extensionSelectors = []\n      for (const e in extensions) {\n        const extension = extensions[e]\n        if (extension.getSelectors) {\n          var selectors = extension.getSelectors()\n          if (selectors) {\n            extensionSelectors.push(selectors)\n          }\n        }\n      }\n\n      const results = elt.querySelectorAll(VERB_SELECTOR + boostedSelector + \", form, [type='submit'],\" +\n        ' [hx-ext], [data-hx-ext], [hx-trigger], [data-hx-trigger]' + extensionSelectors.flat().map(s => ', ' + s).join(''))\n\n      return results\n    } else {\n      return []\n    }\n  }\n\n  /**\n   * Handle submit buttons/inputs that have the form attribute set\n   * see https://developer.mozilla.org/docs/Web/HTML/Element/button\n   * @param {Event} evt\n   */\n  function maybeSetLastButtonClicked(evt) {\n    const elt = /** @type {HTMLButtonElement|HTMLInputElement} */ (closest(asElement(evt.target), \"button, input[type='submit']\"))\n    const internalData = getRelatedFormData(evt)\n    if (internalData) {\n      internalData.lastButtonClicked = elt\n    }\n  }\n\n  /**\n   * @param {Event} evt\n   */\n  function maybeUnsetLastButtonClicked(evt) {\n    const internalData = getRelatedFormData(evt)\n    if (internalData) {\n      internalData.lastButtonClicked = null\n    }\n  }\n\n  /**\n   * @param {Event} evt\n   * @returns {HtmxNodeInternalData|undefined}\n   */\n  function getRelatedFormData(evt) {\n    const elt = closest(asElement(evt.target), \"button, input[type='submit']\")\n    if (!elt) {\n      return\n    }\n    const form = resolveTarget('#' + getRawAttribute(elt, 'form'), elt.getRootNode()) || closest(elt, 'form')\n    if (!form) {\n      return\n    }\n    return getInternalData(form)\n  }\n\n  /**\n   * @param {EventTarget} elt\n   */\n  function initButtonTracking(elt) {\n    // need to handle both click and focus in:\n    //   focusin - in case someone tabs in to a button and hits the space bar\n    //   click - on OSX buttons do not focus on click see https://bugs.webkit.org/show_bug.cgi?id=13724\n    elt.addEventListener('click', maybeSetLastButtonClicked)\n    elt.addEventListener('focusin', maybeSetLastButtonClicked)\n    elt.addEventListener('focusout', maybeUnsetLastButtonClicked)\n  }\n\n  /**\n   * @param {Element} elt\n   * @param {string} eventName\n   * @param {string} code\n   */\n  function addHxOnEventHandler(elt, eventName, code) {\n    const nodeData = getInternalData(elt)\n    if (!Array.isArray(nodeData.onHandlers)) {\n      nodeData.onHandlers = []\n    }\n    let func\n    /** @type EventListener */\n    const listener = function(e) {\n      maybeEval(elt, function() {\n        if (eltIsDisabled(elt)) {\n          return\n        }\n        if (!func) {\n          func = new Function('event', code)\n        }\n        func.call(elt, e)\n      })\n    }\n    elt.addEventListener(eventName, listener)\n    nodeData.onHandlers.push({ event: eventName, listener })\n  }\n\n  /**\n   * @param {Element} elt\n   */\n  function processHxOnWildcard(elt) {\n    // wipe any previous on handlers so that this function takes precedence\n    deInitOnHandlers(elt)\n\n    for (let i = 0; i < elt.attributes.length; i++) {\n      const name = elt.attributes[i].name\n      const value = elt.attributes[i].value\n      if (startsWith(name, 'hx-on') || startsWith(name, 'data-hx-on')) {\n        const afterOnPosition = name.indexOf('-on') + 3\n        const nextChar = name.slice(afterOnPosition, afterOnPosition + 1)\n        if (nextChar === '-' || nextChar === ':') {\n          let eventName = name.slice(afterOnPosition + 1)\n          // if the eventName starts with a colon or dash, prepend \"htmx\" for shorthand support\n          if (startsWith(eventName, ':')) {\n            eventName = 'htmx' + eventName\n          } else if (startsWith(eventName, '-')) {\n            eventName = 'htmx:' + eventName.slice(1)\n          } else if (startsWith(eventName, 'htmx-')) {\n            eventName = 'htmx:' + eventName.slice(5)\n          }\n\n          addHxOnEventHandler(elt, eventName, value)\n        }\n      }\n    }\n  }\n\n  /**\n   * @param {Element|HTMLInputElement} elt\n   */\n  function initNode(elt) {\n    if (closest(elt, htmx.config.disableSelector)) {\n      cleanUpElement(elt)\n      return\n    }\n    const nodeData = getInternalData(elt)\n    if (nodeData.initHash !== attributeHash(elt)) {\n      // clean up any previously processed info\n      deInitNode(elt)\n\n      nodeData.initHash = attributeHash(elt)\n\n      triggerEvent(elt, 'htmx:beforeProcessNode')\n\n      // @ts-ignore value will be undefined for non-input elements, which is fine\n      if (elt.value) {\n        // @ts-ignore\n        nodeData.lastValue = elt.value\n      }\n\n      const triggerSpecs = getTriggerSpecs(elt)\n      const hasExplicitHttpAction = processVerbs(elt, nodeData, triggerSpecs)\n\n      if (!hasExplicitHttpAction) {\n        if (getClosestAttributeValue(elt, 'hx-boost') === 'true') {\n          boostElement(elt, nodeData, triggerSpecs)\n        } else if (hasAttribute(elt, 'hx-trigger')) {\n          triggerSpecs.forEach(function(triggerSpec) {\n            // For \"naked\" triggers, don't do anything at all\n            addTriggerHandler(elt, triggerSpec, nodeData, function() {\n            })\n          })\n        }\n      }\n\n      // Handle submit buttons/inputs that have the form attribute set\n      // see https://developer.mozilla.org/docs/Web/HTML/Element/button\n      if (elt.tagName === 'FORM' || (getRawAttribute(elt, 'type') === 'submit' && hasAttribute(elt, 'form'))) {\n        initButtonTracking(elt)\n      }\n\n      triggerEvent(elt, 'htmx:afterProcessNode')\n    }\n  }\n\n  /**\n   * Processes new content, enabling htmx behavior. This can be useful if you have content that is added to the DOM outside of the normal htmx request cycle but still want htmx attributes to work.\n   *\n   * @see https://htmx.org/api/#process\n   *\n   * @param {Element|string} elt element to process\n   */\n  function processNode(elt) {\n    elt = resolveTarget(elt)\n    if (closest(elt, htmx.config.disableSelector)) {\n      cleanUpElement(elt)\n      return\n    }\n    initNode(elt)\n    forEach(findElementsToProcess(elt), function(child) { initNode(child) })\n    forEach(findHxOnWildcardElements(elt), processHxOnWildcard)\n  }\n\n  //= ===================================================================\n  // Event/Log Support\n  //= ===================================================================\n\n  /**\n   * @param {string} str\n   * @returns {string}\n   */\n  function kebabEventName(str) {\n    return str.replace(/([a-z0-9])([A-Z])/g, '$1-$2').toLowerCase()\n  }\n\n  /**\n   * @param {string} eventName\n   * @param {any} detail\n   * @returns {CustomEvent}\n   */\n  function makeEvent(eventName, detail) {\n    let evt\n    if (window.CustomEvent && typeof window.CustomEvent === 'function') {\n      // TODO: `composed: true` here is a hack to make global event handlers work with events in shadow DOM\n      // This breaks expected encapsulation but needs to be here until decided otherwise by core devs\n      evt = new CustomEvent(eventName, { bubbles: true, cancelable: true, composed: true, detail })\n    } else {\n      evt = getDocument().createEvent('CustomEvent')\n      evt.initCustomEvent(eventName, true, true, detail)\n    }\n    return evt\n  }\n\n  /**\n   * @param {EventTarget|string} elt\n   * @param {string} eventName\n   * @param {any=} detail\n   */\n  function triggerErrorEvent(elt, eventName, detail) {\n    triggerEvent(elt, eventName, mergeObjects({ error: eventName }, detail))\n  }\n\n  /**\n   * @param {string} eventName\n   * @returns {boolean}\n   */\n  function ignoreEventForLogging(eventName) {\n    return eventName === 'htmx:afterProcessNode'\n  }\n\n  /**\n   * `withExtensions` locates all active extensions for a provided element, then\n   * executes the provided function using each of the active extensions.  It should\n   * be called internally at every extendable execution point in htmx.\n   *\n   * @param {Element} elt\n   * @param {(extension:HtmxExtension) => void} toDo\n   * @returns void\n   */\n  function withExtensions(elt, toDo) {\n    forEach(getExtensions(elt), function(extension) {\n      try {\n        toDo(extension)\n      } catch (e) {\n        logError(e)\n      }\n    })\n  }\n\n  function logError(msg) {\n    if (console.error) {\n      console.error(msg)\n    } else if (console.log) {\n      console.log('ERROR: ', msg)\n    }\n  }\n\n  /**\n   * Triggers a given event on an element\n   *\n   * @see https://htmx.org/api/#trigger\n   *\n   * @param {EventTarget|string} elt the element to trigger the event on\n   * @param {string} eventName the name of the event to trigger\n   * @param {any=} detail details for the event\n   * @returns {boolean}\n   */\n  function triggerEvent(elt, eventName, detail) {\n    elt = resolveTarget(elt)\n    if (detail == null) {\n      detail = {}\n    }\n    detail.elt = elt\n    const event = makeEvent(eventName, detail)\n    if (htmx.logger && !ignoreEventForLogging(eventName)) {\n      htmx.logger(elt, eventName, detail)\n    }\n    if (detail.error) {\n      logError(detail.error)\n      triggerEvent(elt, 'htmx:error', { errorInfo: detail })\n    }\n    let eventResult = elt.dispatchEvent(event)\n    const kebabName = kebabEventName(eventName)\n    if (eventResult && kebabName !== eventName) {\n      const kebabedEvent = makeEvent(kebabName, event.detail)\n      eventResult = eventResult && elt.dispatchEvent(kebabedEvent)\n    }\n    withExtensions(asElement(elt), function(extension) {\n      eventResult = eventResult && (extension.onEvent(eventName, event) !== false && !event.defaultPrevented)\n    })\n    return eventResult\n  }\n\n  //= ===================================================================\n  // History Support\n  //= ===================================================================\n  let currentPathForHistory = location.pathname + location.search\n\n  /**\n   * @returns {Element}\n   */\n  function getHistoryElement() {\n    const historyElt = getDocument().querySelector('[hx-history-elt],[data-hx-history-elt]')\n    return historyElt || getDocument().body\n  }\n\n  /**\n   * @param {string} url\n   * @param {Element} rootElt\n   */\n  function saveToHistoryCache(url, rootElt) {\n    if (!canAccessLocalStorage()) {\n      return\n    }\n\n    // get state to save\n    const innerHTML = cleanInnerHtmlForHistory(rootElt)\n    const title = getDocument().title\n    const scroll = window.scrollY\n\n    if (htmx.config.historyCacheSize <= 0) {\n      // make sure that an eventually already existing cache is purged\n      localStorage.removeItem('htmx-history-cache')\n      return\n    }\n\n    url = normalizePath(url)\n\n    const historyCache = parseJSON(localStorage.getItem('htmx-history-cache')) || []\n    for (let i = 0; i < historyCache.length; i++) {\n      if (historyCache[i].url === url) {\n        historyCache.splice(i, 1)\n        break\n      }\n    }\n\n    /** @type HtmxHistoryItem */\n    const newHistoryItem = { url, content: innerHTML, title, scroll }\n\n    triggerEvent(getDocument().body, 'htmx:historyItemCreated', { item: newHistoryItem, cache: historyCache })\n\n    historyCache.push(newHistoryItem)\n    while (historyCache.length > htmx.config.historyCacheSize) {\n      historyCache.shift()\n    }\n\n    // keep trying to save the cache until it succeeds or is empty\n    while (historyCache.length > 0) {\n      try {\n        localStorage.setItem('htmx-history-cache', JSON.stringify(historyCache))\n        break\n      } catch (e) {\n        triggerErrorEvent(getDocument().body, 'htmx:historyCacheError', { cause: e, cache: historyCache })\n        historyCache.shift() // shrink the cache and retry\n      }\n    }\n  }\n\n  /**\n   * @typedef {Object} HtmxHistoryItem\n   * @property {string} url\n   * @property {string} content\n   * @property {string} title\n   * @property {number} scroll\n   */\n\n  /**\n   * @param {string} url\n   * @returns {HtmxHistoryItem|null}\n   */\n  function getCachedHistory(url) {\n    if (!canAccessLocalStorage()) {\n      return null\n    }\n\n    url = normalizePath(url)\n\n    const historyCache = parseJSON(localStorage.getItem('htmx-history-cache')) || []\n    for (let i = 0; i < historyCache.length; i++) {\n      if (historyCache[i].url === url) {\n        return historyCache[i]\n      }\n    }\n    return null\n  }\n\n  /**\n   * @param {Element} elt\n   * @returns {string}\n   */\n  function cleanInnerHtmlForHistory(elt) {\n    const className = htmx.config.requestClass\n    const clone = /** @type Element */ (elt.cloneNode(true))\n    forEach(findAll(clone, '.' + className), function(child) {\n      removeClassFromElement(child, className)\n    })\n    // remove the disabled attribute for any element disabled due to an htmx request\n    forEach(findAll(clone, '[data-disabled-by-htmx]'), function(child) {\n      child.removeAttribute('disabled')\n    })\n    return clone.innerHTML\n  }\n\n  function saveCurrentPageToHistory() {\n    const elt = getHistoryElement()\n    const path = currentPathForHistory || location.pathname + location.search\n\n    // Allow history snapshot feature to be disabled where hx-history=\"false\"\n    // is present *anywhere* in the current document we're about to save,\n    // so we can prevent privileged data entering the cache.\n    // The page will still be reachable as a history entry, but htmx will fetch it\n    // live from the server onpopstate rather than look in the localStorage cache\n    let disableHistoryCache\n    try {\n      disableHistoryCache = getDocument().querySelector('[hx-history=\"false\" i],[data-hx-history=\"false\" i]')\n    } catch (e) {\n    // IE11: insensitive modifier not supported so fallback to case sensitive selector\n      disableHistoryCache = getDocument().querySelector('[hx-history=\"false\"],[data-hx-history=\"false\"]')\n    }\n    if (!disableHistoryCache) {\n      triggerEvent(getDocument().body, 'htmx:beforeHistorySave', { path, historyElt: elt })\n      saveToHistoryCache(path, elt)\n    }\n\n    if (htmx.config.historyEnabled) history.replaceState({ htmx: true }, getDocument().title, window.location.href)\n  }\n\n  /**\n   * @param {string} path\n   */\n  function pushUrlIntoHistory(path) {\n  // remove the cache buster parameter, if any\n    if (htmx.config.getCacheBusterParam) {\n      path = path.replace(/org\\.htmx\\.cache-buster=[^&]*&?/, '')\n      if (endsWith(path, '&') || endsWith(path, '?')) {\n        path = path.slice(0, -1)\n      }\n    }\n    if (htmx.config.historyEnabled) {\n      history.pushState({ htmx: true }, '', path)\n    }\n    currentPathForHistory = path\n  }\n\n  /**\n   * @param {string} path\n   */\n  function replaceUrlInHistory(path) {\n    if (htmx.config.historyEnabled) history.replaceState({ htmx: true }, '', path)\n    currentPathForHistory = path\n  }\n\n  /**\n   * @param {HtmxSettleTask[]} tasks\n   */\n  function settleImmediately(tasks) {\n    forEach(tasks, function(task) {\n      task.call(undefined)\n    })\n  }\n\n  /**\n   * @param {string} path\n   */\n  function loadHistoryFromServer(path) {\n    const request = new XMLHttpRequest()\n    const details = { path, xhr: request }\n    triggerEvent(getDocument().body, 'htmx:historyCacheMiss', details)\n    request.open('GET', path, true)\n    request.setRequestHeader('HX-Request', 'true')\n    request.setRequestHeader('HX-History-Restore-Request', 'true')\n    request.setRequestHeader('HX-Current-URL', getDocument().location.href)\n    request.onload = function() {\n      if (this.status >= 200 && this.status < 400) {\n        triggerEvent(getDocument().body, 'htmx:historyCacheMissLoad', details)\n        const fragment = makeFragment(this.response)\n        /** @type ParentNode */\n        const content = fragment.querySelector('[hx-history-elt],[data-hx-history-elt]') || fragment\n        const historyElement = getHistoryElement()\n        const settleInfo = makeSettleInfo(historyElement)\n        handleTitle(fragment.title)\n\n        swapInnerHTML(historyElement, content, settleInfo)\n        settleImmediately(settleInfo.tasks)\n        currentPathForHistory = path\n        triggerEvent(getDocument().body, 'htmx:historyRestore', { path, cacheMiss: true, serverResponse: this.response })\n      } else {\n        triggerErrorEvent(getDocument().body, 'htmx:historyCacheMissLoadError', details)\n      }\n    }\n    request.send()\n  }\n\n  /**\n   * @param {string} [path]\n   */\n  function restoreHistory(path) {\n    saveCurrentPageToHistory()\n    path = path || location.pathname + location.search\n    const cached = getCachedHistory(path)\n    if (cached) {\n      const fragment = makeFragment(cached.content)\n      const historyElement = getHistoryElement()\n      const settleInfo = makeSettleInfo(historyElement)\n      handleTitle(fragment.title)\n      swapInnerHTML(historyElement, fragment, settleInfo)\n      settleImmediately(settleInfo.tasks)\n      getWindow().setTimeout(function() {\n        window.scrollTo(0, cached.scroll)\n      }, 0) // next 'tick', so browser has time to render layout\n      currentPathForHistory = path\n      triggerEvent(getDocument().body, 'htmx:historyRestore', { path, item: cached })\n    } else {\n      if (htmx.config.refreshOnHistoryMiss) {\n        // @ts-ignore: optional parameter in reload() function throws error\n        // noinspection JSUnresolvedReference\n        window.location.reload(true)\n      } else {\n        loadHistoryFromServer(path)\n      }\n    }\n  }\n\n  /**\n   * @param {Element} elt\n   * @returns {Element[]}\n   */\n  function addRequestIndicatorClasses(elt) {\n    let indicators = /** @type Element[] */ (findAttributeTargets(elt, 'hx-indicator'))\n    if (indicators == null) {\n      indicators = [elt]\n    }\n    forEach(indicators, function(ic) {\n      const internalData = getInternalData(ic)\n      internalData.requestCount = (internalData.requestCount || 0) + 1\n      ic.classList.add.call(ic.classList, htmx.config.requestClass)\n    })\n    return indicators\n  }\n\n  /**\n   * @param {Element} elt\n   * @returns {Element[]}\n   */\n  function disableElements(elt) {\n    let disabledElts = /** @type Element[] */ (findAttributeTargets(elt, 'hx-disabled-elt'))\n    if (disabledElts == null) {\n      disabledElts = []\n    }\n    forEach(disabledElts, function(disabledElement) {\n      const internalData = getInternalData(disabledElement)\n      internalData.requestCount = (internalData.requestCount || 0) + 1\n      disabledElement.setAttribute('disabled', '')\n      disabledElement.setAttribute('data-disabled-by-htmx', '')\n    })\n    return disabledElts\n  }\n\n  /**\n   * @param {Element[]} indicators\n   * @param {Element[]} disabled\n   */\n  function removeRequestIndicators(indicators, disabled) {\n    forEach(indicators, function(ic) {\n      const internalData = getInternalData(ic)\n      internalData.requestCount = (internalData.requestCount || 0) - 1\n      if (internalData.requestCount === 0) {\n        ic.classList.remove.call(ic.classList, htmx.config.requestClass)\n      }\n    })\n    forEach(disabled, function(disabledElement) {\n      const internalData = getInternalData(disabledElement)\n      internalData.requestCount = (internalData.requestCount || 0) - 1\n      if (internalData.requestCount === 0) {\n        disabledElement.removeAttribute('disabled')\n        disabledElement.removeAttribute('data-disabled-by-htmx')\n      }\n    })\n  }\n\n  //= ===================================================================\n  // Input Value Processing\n  //= ===================================================================\n\n  /**\n   * @param {Element[]} processed\n   * @param {Element} elt\n   * @returns {boolean}\n   */\n  function haveSeenNode(processed, elt) {\n    for (let i = 0; i < processed.length; i++) {\n      const node = processed[i]\n      if (node.isSameNode(elt)) {\n        return true\n      }\n    }\n    return false\n  }\n\n  /**\n   * @param {Element} element\n   * @return {boolean}\n   */\n  function shouldInclude(element) {\n    // Cast to trick tsc, undefined values will work fine here\n    const elt = /** @type {HTMLInputElement} */ (element)\n    if (elt.name === '' || elt.name == null || elt.disabled || closest(elt, 'fieldset[disabled]')) {\n      return false\n    }\n    // ignore \"submitter\" types (see jQuery src/serialize.js)\n    if (elt.type === 'button' || elt.type === 'submit' || elt.tagName === 'image' || elt.tagName === 'reset' || elt.tagName === 'file') {\n      return false\n    }\n    if (elt.type === 'checkbox' || elt.type === 'radio') {\n      return elt.checked\n    }\n    return true\n  }\n\n  /** @param {string} name\n   * @param {string|Array|FormDataEntryValue} value\n   * @param {FormData} formData */\n  function addValueToFormData(name, value, formData) {\n    if (name != null && value != null) {\n      if (Array.isArray(value)) {\n        value.forEach(function(v) { formData.append(name, v) })\n      } else {\n        formData.append(name, value)\n      }\n    }\n  }\n\n  /** @param {string} name\n   * @param {string|Array} value\n   * @param {FormData} formData */\n  function removeValueFromFormData(name, value, formData) {\n    if (name != null && value != null) {\n      let values = formData.getAll(name)\n      if (Array.isArray(value)) {\n        values = values.filter(v => value.indexOf(v) < 0)\n      } else {\n        values = values.filter(v => v !== value)\n      }\n      formData.delete(name)\n      forEach(values, v => formData.append(name, v))\n    }\n  }\n\n  /**\n   * @param {Element[]} processed\n   * @param {FormData} formData\n   * @param {HtmxElementValidationError[]} errors\n   * @param {Element|HTMLInputElement|HTMLSelectElement|HTMLFormElement} elt\n   * @param {boolean} validate\n   */\n  function processInputValue(processed, formData, errors, elt, validate) {\n    if (elt == null || haveSeenNode(processed, elt)) {\n      return\n    } else {\n      processed.push(elt)\n    }\n    if (shouldInclude(elt)) {\n      const name = getRawAttribute(elt, 'name')\n      // @ts-ignore value will be undefined for non-input elements, which is fine\n      let value = elt.value\n      if (elt instanceof HTMLSelectElement && elt.multiple) {\n        value = toArray(elt.querySelectorAll('option:checked')).map(function(e) { return (/** @type HTMLOptionElement */(e)).value })\n      }\n      // include file inputs\n      if (elt instanceof HTMLInputElement && elt.files) {\n        value = toArray(elt.files)\n      }\n      addValueToFormData(name, value, formData)\n      if (validate) {\n        validateElement(elt, errors)\n      }\n    }\n    if (elt instanceof HTMLFormElement) {\n      forEach(elt.elements, function(input) {\n        if (processed.indexOf(input) >= 0) {\n          // The input has already been processed and added to the values, but the FormData that will be\n          //  constructed right after on the form, will include it once again. So remove that input's value\n          //  now to avoid duplicates\n          removeValueFromFormData(input.name, input.value, formData)\n        } else {\n          processed.push(input)\n        }\n        if (validate) {\n          validateElement(input, errors)\n        }\n      })\n      new FormData(elt).forEach(function(value, name) {\n        if (value instanceof File && value.name === '') {\n          return // ignore no-name files\n        }\n        addValueToFormData(name, value, formData)\n      })\n    }\n  }\n\n  /**\n   *\n   * @param {Element} elt\n   * @param {HtmxElementValidationError[]} errors\n   */\n  function validateElement(elt, errors) {\n    const element = /** @type {HTMLElement & ElementInternals} */ (elt)\n    if (element.willValidate) {\n      triggerEvent(element, 'htmx:validation:validate')\n      if (!element.checkValidity()) {\n        errors.push({ elt: element, message: element.validationMessage, validity: element.validity })\n        triggerEvent(element, 'htmx:validation:failed', { message: element.validationMessage, validity: element.validity })\n      }\n    }\n  }\n\n  /**\n   * Override values in the one FormData with those from another.\n   * @param {FormData} receiver the formdata that will be mutated\n   * @param {FormData} donor the formdata that will provide the overriding values\n   * @returns {FormData} the {@linkcode receiver}\n   */\n  function overrideFormData(receiver, donor) {\n    for (const key of donor.keys()) {\n      receiver.delete(key)\n    }\n    donor.forEach(function(value, key) {\n      receiver.append(key, value)\n    })\n    return receiver\n  }\n\n  /**\n * @param {Element|HTMLFormElement} elt\n * @param {HttpVerb} verb\n * @returns {{errors: HtmxElementValidationError[], formData: FormData, values: Object}}\n */\n  function getInputValues(elt, verb) {\n    /** @type Element[] */\n    const processed = []\n    const formData = new FormData()\n    const priorityFormData = new FormData()\n    /** @type HtmxElementValidationError[] */\n    const errors = []\n    const internalData = getInternalData(elt)\n    if (internalData.lastButtonClicked && !bodyContains(internalData.lastButtonClicked)) {\n      internalData.lastButtonClicked = null\n    }\n\n    // only validate when form is directly submitted and novalidate or formnovalidate are not set\n    // or if the element has an explicit hx-validate=\"true\" on it\n    let validate = (elt instanceof HTMLFormElement && elt.noValidate !== true) || getAttributeValue(elt, 'hx-validate') === 'true'\n    if (internalData.lastButtonClicked) {\n      validate = validate && internalData.lastButtonClicked.formNoValidate !== true\n    }\n\n    // for a non-GET include the closest form\n    if (verb !== 'get') {\n      processInputValue(processed, priorityFormData, errors, closest(elt, 'form'), validate)\n    }\n\n    // include the element itself\n    processInputValue(processed, formData, errors, elt, validate)\n\n    // if a button or submit was clicked last, include its value\n    if (internalData.lastButtonClicked || elt.tagName === 'BUTTON' ||\n    (elt.tagName === 'INPUT' && getRawAttribute(elt, 'type') === 'submit')) {\n      const button = internalData.lastButtonClicked || (/** @type HTMLInputElement|HTMLButtonElement */(elt))\n      const name = getRawAttribute(button, 'name')\n      addValueToFormData(name, button.value, priorityFormData)\n    }\n\n    // include any explicit includes\n    const includes = findAttributeTargets(elt, 'hx-include')\n    forEach(includes, function(node) {\n      processInputValue(processed, formData, errors, asElement(node), validate)\n      // if a non-form is included, include any input values within it\n      if (!matches(node, 'form')) {\n        forEach(asParentNode(node).querySelectorAll(INPUT_SELECTOR), function(descendant) {\n          processInputValue(processed, formData, errors, descendant, validate)\n        })\n      }\n    })\n\n    // values from a <form> take precedence, overriding the regular values\n    overrideFormData(formData, priorityFormData)\n\n    return { errors, formData, values: formDataProxy(formData) }\n  }\n\n  /**\n   * @param {string} returnStr\n   * @param {string} name\n   * @param {any} realValue\n   * @returns {string}\n   */\n  function appendParam(returnStr, name, realValue) {\n    if (returnStr !== '') {\n      returnStr += '&'\n    }\n    if (String(realValue) === '[object Object]') {\n      realValue = JSON.stringify(realValue)\n    }\n    const s = encodeURIComponent(realValue)\n    returnStr += encodeURIComponent(name) + '=' + s\n    return returnStr\n  }\n\n  /**\n   * @param {FormData|Object} values\n   * @returns string\n   */\n  function urlEncode(values) {\n    values = formDataFromObject(values)\n    let returnStr = ''\n    values.forEach(function(value, key) {\n      returnStr = appendParam(returnStr, key, value)\n    })\n    return returnStr\n  }\n\n  //= ===================================================================\n  // Ajax\n  //= ===================================================================\n\n  /**\n * @param {Element} elt\n * @param {Element} target\n * @param {string} prompt\n * @returns {HtmxHeaderSpecification}\n */\n  function getHeaders(elt, target, prompt) {\n    /** @type HtmxHeaderSpecification */\n    const headers = {\n      'HX-Request': 'true',\n      'HX-Trigger': getRawAttribute(elt, 'id'),\n      'HX-Trigger-Name': getRawAttribute(elt, 'name'),\n      'HX-Target': getAttributeValue(target, 'id'),\n      'HX-Current-URL': getDocument().location.href\n    }\n    getValuesForElement(elt, 'hx-headers', false, headers)\n    if (prompt !== undefined) {\n      headers['HX-Prompt'] = prompt\n    }\n    if (getInternalData(elt).boosted) {\n      headers['HX-Boosted'] = 'true'\n    }\n    return headers\n  }\n\n  /**\n * filterValues takes an object containing form input values\n * and returns a new object that only contains keys that are\n * specified by the closest \"hx-params\" attribute\n * @param {FormData} inputValues\n * @param {Element} elt\n * @returns {FormData}\n */\n  function filterValues(inputValues, elt) {\n    const paramsValue = getClosestAttributeValue(elt, 'hx-params')\n    if (paramsValue) {\n      if (paramsValue === 'none') {\n        return new FormData()\n      } else if (paramsValue === '*') {\n        return inputValues\n      } else if (paramsValue.indexOf('not ') === 0) {\n        forEach(paramsValue.substr(4).split(','), function(name) {\n          name = name.trim()\n          inputValues.delete(name)\n        })\n        return inputValues\n      } else {\n        const newValues = new FormData()\n        forEach(paramsValue.split(','), function(name) {\n          name = name.trim()\n          if (inputValues.has(name)) {\n            inputValues.getAll(name).forEach(function(value) { newValues.append(name, value) })\n          }\n        })\n        return newValues\n      }\n    } else {\n      return inputValues\n    }\n  }\n\n  /**\n   * @param {Element} elt\n   * @return {boolean}\n   */\n  function isAnchorLink(elt) {\n    return !!getRawAttribute(elt, 'href') && getRawAttribute(elt, 'href').indexOf('#') >= 0\n  }\n\n  /**\n * @param {Element} elt\n * @param {HtmxSwapStyle} [swapInfoOverride]\n * @returns {HtmxSwapSpecification}\n */\n  function getSwapSpecification(elt, swapInfoOverride) {\n    const swapInfo = swapInfoOverride || getClosestAttributeValue(elt, 'hx-swap')\n    /** @type HtmxSwapSpecification */\n    const swapSpec = {\n      swapStyle: getInternalData(elt).boosted ? 'innerHTML' : htmx.config.defaultSwapStyle,\n      swapDelay: htmx.config.defaultSwapDelay,\n      settleDelay: htmx.config.defaultSettleDelay\n    }\n    if (htmx.config.scrollIntoViewOnBoost && getInternalData(elt).boosted && !isAnchorLink(elt)) {\n      swapSpec.show = 'top'\n    }\n    if (swapInfo) {\n      const split = splitOnWhitespace(swapInfo)\n      if (split.length > 0) {\n        for (let i = 0; i < split.length; i++) {\n          const value = split[i]\n          if (value.indexOf('swap:') === 0) {\n            swapSpec.swapDelay = parseInterval(value.substr(5))\n          } else if (value.indexOf('settle:') === 0) {\n            swapSpec.settleDelay = parseInterval(value.substr(7))\n          } else if (value.indexOf('transition:') === 0) {\n            swapSpec.transition = value.substr(11) === 'true'\n          } else if (value.indexOf('ignoreTitle:') === 0) {\n            swapSpec.ignoreTitle = value.substr(12) === 'true'\n          } else if (value.indexOf('scroll:') === 0) {\n            const scrollSpec = value.substr(7)\n            var splitSpec = scrollSpec.split(':')\n            const scrollVal = splitSpec.pop()\n            var selectorVal = splitSpec.length > 0 ? splitSpec.join(':') : null\n            // @ts-ignore\n            swapSpec.scroll = scrollVal\n            swapSpec.scrollTarget = selectorVal\n          } else if (value.indexOf('show:') === 0) {\n            const showSpec = value.substr(5)\n            var splitSpec = showSpec.split(':')\n            const showVal = splitSpec.pop()\n            var selectorVal = splitSpec.length > 0 ? splitSpec.join(':') : null\n            swapSpec.show = showVal\n            swapSpec.showTarget = selectorVal\n          } else if (value.indexOf('focus-scroll:') === 0) {\n            const focusScrollVal = value.substr('focus-scroll:'.length)\n            swapSpec.focusScroll = focusScrollVal == 'true'\n          } else if (i == 0) {\n            swapSpec.swapStyle = value\n          } else {\n            logError('Unknown modifier in hx-swap: ' + value)\n          }\n        }\n      }\n    }\n    return swapSpec\n  }\n\n  /**\n   * @param {Element} elt\n   * @return {boolean}\n   */\n  function usesFormData(elt) {\n    return getClosestAttributeValue(elt, 'hx-encoding') === 'multipart/form-data' ||\n    (matches(elt, 'form') && getRawAttribute(elt, 'enctype') === 'multipart/form-data')\n  }\n\n  /**\n   * @param {XMLHttpRequest} xhr\n   * @param {Element} elt\n   * @param {FormData} filteredParameters\n   * @returns {*|string|null}\n   */\n  function encodeParamsForBody(xhr, elt, filteredParameters) {\n    let encodedParameters = null\n    withExtensions(elt, function(extension) {\n      if (encodedParameters == null) {\n        encodedParameters = extension.encodeParameters(xhr, filteredParameters, elt)\n      }\n    })\n    if (encodedParameters != null) {\n      return encodedParameters\n    } else {\n      if (usesFormData(elt)) {\n        // Force conversion to an actual FormData object in case filteredParameters is a formDataProxy\n        // See https://github.com/bigskysoftware/htmx/issues/2317\n        return overrideFormData(new FormData(), formDataFromObject(filteredParameters))\n      } else {\n        return urlEncode(filteredParameters)\n      }\n    }\n  }\n\n  /**\n *\n * @param {Element} target\n * @returns {HtmxSettleInfo}\n */\n  function makeSettleInfo(target) {\n    return { tasks: [], elts: [target] }\n  }\n\n  /**\n   * @param {Element[]} content\n   * @param {HtmxSwapSpecification} swapSpec\n   */\n  function updateScrollState(content, swapSpec) {\n    const first = content[0]\n    const last = content[content.length - 1]\n    if (swapSpec.scroll) {\n      var target = null\n      if (swapSpec.scrollTarget) {\n        target = asElement(querySelectorExt(first, swapSpec.scrollTarget))\n      }\n      if (swapSpec.scroll === 'top' && (first || target)) {\n        target = target || first\n        target.scrollTop = 0\n      }\n      if (swapSpec.scroll === 'bottom' && (last || target)) {\n        target = target || last\n        target.scrollTop = target.scrollHeight\n      }\n    }\n    if (swapSpec.show) {\n      var target = null\n      if (swapSpec.showTarget) {\n        let targetStr = swapSpec.showTarget\n        if (swapSpec.showTarget === 'window') {\n          targetStr = 'body'\n        }\n        target = asElement(querySelectorExt(first, targetStr))\n      }\n      if (swapSpec.show === 'top' && (first || target)) {\n        target = target || first\n        // @ts-ignore For some reason tsc doesn't recognize \"instant\" as a valid option for now\n        target.scrollIntoView({ block: 'start', behavior: htmx.config.scrollBehavior })\n      }\n      if (swapSpec.show === 'bottom' && (last || target)) {\n        target = target || last\n        // @ts-ignore For some reason tsc doesn't recognize \"instant\" as a valid option for now\n        target.scrollIntoView({ block: 'end', behavior: htmx.config.scrollBehavior })\n      }\n    }\n  }\n\n  /**\n * @param {Element} elt\n * @param {string} attr\n * @param {boolean=} evalAsDefault\n * @param {Object=} values\n * @returns {Object}\n */\n  function getValuesForElement(elt, attr, evalAsDefault, values) {\n    if (values == null) {\n      values = {}\n    }\n    if (elt == null) {\n      return values\n    }\n    const attributeValue = getAttributeValue(elt, attr)\n    if (attributeValue) {\n      let str = attributeValue.trim()\n      let evaluateValue = evalAsDefault\n      if (str === 'unset') {\n        return null\n      }\n      if (str.indexOf('javascript:') === 0) {\n        str = str.substr(11)\n        evaluateValue = true\n      } else if (str.indexOf('js:') === 0) {\n        str = str.substr(3)\n        evaluateValue = true\n      }\n      if (str.indexOf('{') !== 0) {\n        str = '{' + str + '}'\n      }\n      let varsValues\n      if (evaluateValue) {\n        varsValues = maybeEval(elt, function() { return Function('return (' + str + ')')() }, {})\n      } else {\n        varsValues = parseJSON(str)\n      }\n      for (const key in varsValues) {\n        if (varsValues.hasOwnProperty(key)) {\n          if (values[key] == null) {\n            values[key] = varsValues[key]\n          }\n        }\n      }\n    }\n    return getValuesForElement(asElement(parentElt(elt)), attr, evalAsDefault, values)\n  }\n\n  /**\n   * @param {EventTarget|string} elt\n   * @param {() => any} toEval\n   * @param {any=} defaultVal\n   * @returns {any}\n   */\n  function maybeEval(elt, toEval, defaultVal) {\n    if (htmx.config.allowEval) {\n      return toEval()\n    } else {\n      triggerErrorEvent(elt, 'htmx:evalDisallowedError')\n      return defaultVal\n    }\n  }\n\n  /**\n * @param {Element} elt\n * @param {*?} expressionVars\n * @returns\n */\n  function getHXVarsForElement(elt, expressionVars) {\n    return getValuesForElement(elt, 'hx-vars', true, expressionVars)\n  }\n\n  /**\n * @param {Element} elt\n * @param {*?} expressionVars\n * @returns\n */\n  function getHXValsForElement(elt, expressionVars) {\n    return getValuesForElement(elt, 'hx-vals', false, expressionVars)\n  }\n\n  /**\n * @param {Element} elt\n * @returns {FormData}\n */\n  function getExpressionVars(elt) {\n    return mergeObjects(getHXVarsForElement(elt), getHXValsForElement(elt))\n  }\n\n  /**\n   * @param {XMLHttpRequest} xhr\n   * @param {string} header\n   * @param {string|null} headerValue\n   */\n  function safelySetHeaderValue(xhr, header, headerValue) {\n    if (headerValue !== null) {\n      try {\n        xhr.setRequestHeader(header, headerValue)\n      } catch (e) {\n      // On an exception, try to set the header URI encoded instead\n        xhr.setRequestHeader(header, encodeURIComponent(headerValue))\n        xhr.setRequestHeader(header + '-URI-AutoEncoded', 'true')\n      }\n    }\n  }\n\n  /**\n   * @param {XMLHttpRequest} xhr\n   * @return {string}\n   */\n  function getPathFromResponse(xhr) {\n  // NB: IE11 does not support this stuff\n    if (xhr.responseURL && typeof (URL) !== 'undefined') {\n      try {\n        const url = new URL(xhr.responseURL)\n        return url.pathname + url.search\n      } catch (e) {\n        triggerErrorEvent(getDocument().body, 'htmx:badResponseUrl', { url: xhr.responseURL })\n      }\n    }\n  }\n\n  /**\n   * @param {XMLHttpRequest} xhr\n   * @param {RegExp} regexp\n   * @return {boolean}\n   */\n  function hasHeader(xhr, regexp) {\n    return regexp.test(xhr.getAllResponseHeaders())\n  }\n\n  /**\n   * Issues an htmx-style AJAX request\n   *\n   * @see https://htmx.org/api/#ajax\n   *\n   * @param {HttpVerb} verb\n   * @param {string} path the URL path to make the AJAX\n   * @param {Element|string|HtmxAjaxHelperContext} context the element to target (defaults to the **body**) | a selector for the target | a context object that contains any of the following\n   * @return {Promise<void>} Promise that resolves immediately if no request is sent, or when the request is complete\n   */\n  function ajaxHelper(verb, path, context) {\n    verb = (/** @type HttpVerb */(verb.toLowerCase()))\n    if (context) {\n      if (context instanceof Element || typeof context === 'string') {\n        return issueAjaxRequest(verb, path, null, null, {\n          targetOverride: resolveTarget(context),\n          returnPromise: true\n        })\n      } else {\n        return issueAjaxRequest(verb, path, resolveTarget(context.source), context.event,\n          {\n            handler: context.handler,\n            headers: context.headers,\n            values: context.values,\n            targetOverride: resolveTarget(context.target),\n            swapOverride: context.swap,\n            select: context.select,\n            returnPromise: true\n          })\n      }\n    } else {\n      return issueAjaxRequest(verb, path, null, null, {\n        returnPromise: true\n      })\n    }\n  }\n\n  /**\n   * @param {Element} elt\n   * @return {Element[]}\n   */\n  function hierarchyForElt(elt) {\n    const arr = []\n    while (elt) {\n      arr.push(elt)\n      elt = elt.parentElement\n    }\n    return arr\n  }\n\n  /**\n   * @param {Element} elt\n   * @param {string} path\n   * @param {HtmxRequestConfig} requestConfig\n   * @return {boolean}\n   */\n  function verifyPath(elt, path, requestConfig) {\n    let sameHost\n    let url\n    if (typeof URL === 'function') {\n      url = new URL(path, document.location.href)\n      const origin = document.location.origin\n      sameHost = origin === url.origin\n    } else {\n    // IE11 doesn't support URL\n      url = path\n      sameHost = startsWith(path, document.location.origin)\n    }\n\n    if (htmx.config.selfRequestsOnly) {\n      if (!sameHost) {\n        return false\n      }\n    }\n    return triggerEvent(elt, 'htmx:validateUrl', mergeObjects({ url, sameHost }, requestConfig))\n  }\n\n  /**\n   * @param {Object|FormData} obj\n   * @return {FormData}\n   */\n  function formDataFromObject(obj) {\n    if (obj instanceof FormData) return obj\n    const formData = new FormData()\n    for (const key in obj) {\n      if (obj.hasOwnProperty(key)) {\n        if (typeof obj[key].forEach === 'function') {\n          obj[key].forEach(function(v) { formData.append(key, v) })\n        } else if (typeof obj[key] === 'object' && !(obj[key] instanceof Blob)) {\n          formData.append(key, JSON.stringify(obj[key]))\n        } else {\n          formData.append(key, obj[key])\n        }\n      }\n    }\n    return formData\n  }\n\n  /**\n   * @param {FormData} formData\n   * @param {string} name\n   * @param {Array} array\n   * @returns {Array}\n   */\n  function formDataArrayProxy(formData, name, array) {\n    // mutating the array should mutate the underlying form data\n    return new Proxy(array, {\n      get: function(target, key) {\n        if (typeof key === 'number') return target[key]\n        if (key === 'length') return target.length\n        if (key === 'push') {\n          return function(value) {\n            target.push(value)\n            formData.append(name, value)\n          }\n        }\n        if (typeof target[key] === 'function') {\n          return function() {\n            target[key].apply(target, arguments)\n            formData.delete(name)\n            target.forEach(function(v) { formData.append(name, v) })\n          }\n        }\n\n        if (target[key] && target[key].length === 1) {\n          return target[key][0]\n        } else {\n          return target[key]\n        }\n      },\n      set: function(target, index, value) {\n        target[index] = value\n        formData.delete(name)\n        target.forEach(function(v) { formData.append(name, v) })\n        return true\n      }\n    })\n  }\n\n  /**\n   * @param {FormData} formData\n   * @returns {Object}\n   */\n  function formDataProxy(formData) {\n    return new Proxy(formData, {\n      get: function(target, name) {\n        if (typeof name === 'symbol') {\n          // Forward symbol calls to the FormData itself directly\n          return Reflect.get(target, name)\n        }\n        if (name === 'toJSON') {\n          // Support JSON.stringify call on proxy\n          return () => Object.fromEntries(formData)\n        }\n        if (name in target) {\n          // Wrap in function with apply to correctly bind the FormData context, as a direct call would result in an illegal invocation error\n          if (typeof target[name] === 'function') {\n            return function() {\n              return formData[name].apply(formData, arguments)\n            }\n          } else {\n            return target[name]\n          }\n        }\n        const array = formData.getAll(name)\n        // Those 2 undefined & single value returns are for retro-compatibility as we weren't using FormData before\n        if (array.length === 0) {\n          return undefined\n        } else if (array.length === 1) {\n          return array[0]\n        } else {\n          return formDataArrayProxy(target, name, array)\n        }\n      },\n      set: function(target, name, value) {\n        if (typeof name !== 'string') {\n          return false\n        }\n        target.delete(name)\n        if (typeof value.forEach === 'function') {\n          value.forEach(function(v) { target.append(name, v) })\n        } else if (typeof value === 'object' && !(value instanceof Blob)) {\n          target.append(name, JSON.stringify(value))\n        } else {\n          target.append(name, value)\n        }\n        return true\n      },\n      deleteProperty: function(target, name) {\n        if (typeof name === 'string') {\n          target.delete(name)\n        }\n        return true\n      },\n      // Support Object.assign call from proxy\n      ownKeys: function(target) {\n        return Reflect.ownKeys(Object.fromEntries(target))\n      },\n      getOwnPropertyDescriptor: function(target, prop) {\n        return Reflect.getOwnPropertyDescriptor(Object.fromEntries(target), prop)\n      }\n    })\n  }\n\n  /**\n   * @param {HttpVerb} verb\n   * @param {string} path\n   * @param {Element} elt\n   * @param {Event} event\n   * @param {HtmxAjaxEtc} [etc]\n   * @param {boolean} [confirmed]\n   * @return {Promise<void>}\n   */\n  function issueAjaxRequest(verb, path, elt, event, etc, confirmed) {\n    let resolve = null\n    let reject = null\n    etc = etc != null ? etc : {}\n    if (etc.returnPromise && typeof Promise !== 'undefined') {\n      var promise = new Promise(function(_resolve, _reject) {\n        resolve = _resolve\n        reject = _reject\n      })\n    }\n    if (elt == null) {\n      elt = getDocument().body\n    }\n    const responseHandler = etc.handler || handleAjaxResponse\n    const select = etc.select || null\n\n    if (!bodyContains(elt)) {\n    // do not issue requests for elements removed from the DOM\n      maybeCall(resolve)\n      return promise\n    }\n    const target = etc.targetOverride || asElement(getTarget(elt))\n    if (target == null || target == DUMMY_ELT) {\n      triggerErrorEvent(elt, 'htmx:targetError', { target: getAttributeValue(elt, 'hx-target') })\n      maybeCall(reject)\n      return promise\n    }\n\n    let eltData = getInternalData(elt)\n    const submitter = eltData.lastButtonClicked\n\n    if (submitter) {\n      const buttonPath = getRawAttribute(submitter, 'formaction')\n      if (buttonPath != null) {\n        path = buttonPath\n      }\n\n      const buttonVerb = getRawAttribute(submitter, 'formmethod')\n      if (buttonVerb != null) {\n      // ignore buttons with formmethod=\"dialog\"\n        if (buttonVerb.toLowerCase() !== 'dialog') {\n          verb = (/** @type HttpVerb */(buttonVerb))\n        }\n      }\n    }\n\n    const confirmQuestion = getClosestAttributeValue(elt, 'hx-confirm')\n    // allow event-based confirmation w/ a callback\n    if (confirmed === undefined) {\n      const issueRequest = function(skipConfirmation) {\n        return issueAjaxRequest(verb, path, elt, event, etc, !!skipConfirmation)\n      }\n      const confirmDetails = { target, elt, path, verb, triggeringEvent: event, etc, issueRequest, question: confirmQuestion }\n      if (triggerEvent(elt, 'htmx:confirm', confirmDetails) === false) {\n        maybeCall(resolve)\n        return promise\n      }\n    }\n\n    let syncElt = elt\n    let syncStrategy = getClosestAttributeValue(elt, 'hx-sync')\n    let queueStrategy = null\n    let abortable = false\n    if (syncStrategy) {\n      const syncStrings = syncStrategy.split(':')\n      const selector = syncStrings[0].trim()\n      if (selector === 'this') {\n        syncElt = findThisElement(elt, 'hx-sync')\n      } else {\n        syncElt = asElement(querySelectorExt(elt, selector))\n      }\n      // default to the drop strategy\n      syncStrategy = (syncStrings[1] || 'drop').trim()\n      eltData = getInternalData(syncElt)\n      if (syncStrategy === 'drop' && eltData.xhr && eltData.abortable !== true) {\n        maybeCall(resolve)\n        return promise\n      } else if (syncStrategy === 'abort') {\n        if (eltData.xhr) {\n          maybeCall(resolve)\n          return promise\n        } else {\n          abortable = true\n        }\n      } else if (syncStrategy === 'replace') {\n        triggerEvent(syncElt, 'htmx:abort') // abort the current request and continue\n      } else if (syncStrategy.indexOf('queue') === 0) {\n        const queueStrArray = syncStrategy.split(' ')\n        queueStrategy = (queueStrArray[1] || 'last').trim()\n      }\n    }\n\n    if (eltData.xhr) {\n      if (eltData.abortable) {\n        triggerEvent(syncElt, 'htmx:abort') // abort the current request and continue\n      } else {\n        if (queueStrategy == null) {\n          if (event) {\n            const eventData = getInternalData(event)\n            if (eventData && eventData.triggerSpec && eventData.triggerSpec.queue) {\n              queueStrategy = eventData.triggerSpec.queue\n            }\n          }\n          if (queueStrategy == null) {\n            queueStrategy = 'last'\n          }\n        }\n        if (eltData.queuedRequests == null) {\n          eltData.queuedRequests = []\n        }\n        if (queueStrategy === 'first' && eltData.queuedRequests.length === 0) {\n          eltData.queuedRequests.push(function() {\n            issueAjaxRequest(verb, path, elt, event, etc)\n          })\n        } else if (queueStrategy === 'all') {\n          eltData.queuedRequests.push(function() {\n            issueAjaxRequest(verb, path, elt, event, etc)\n          })\n        } else if (queueStrategy === 'last') {\n          eltData.queuedRequests = [] // dump existing queue\n          eltData.queuedRequests.push(function() {\n            issueAjaxRequest(verb, path, elt, event, etc)\n          })\n        }\n        maybeCall(resolve)\n        return promise\n      }\n    }\n\n    const xhr = new XMLHttpRequest()\n    eltData.xhr = xhr\n    eltData.abortable = abortable\n    const endRequestLock = function() {\n      eltData.xhr = null\n      eltData.abortable = false\n      if (eltData.queuedRequests != null &&\n      eltData.queuedRequests.length > 0) {\n        const queuedRequest = eltData.queuedRequests.shift()\n        queuedRequest()\n      }\n    }\n    const promptQuestion = getClosestAttributeValue(elt, 'hx-prompt')\n    if (promptQuestion) {\n      var promptResponse = prompt(promptQuestion)\n      // prompt returns null if cancelled and empty string if accepted with no entry\n      if (promptResponse === null ||\n      !triggerEvent(elt, 'htmx:prompt', { prompt: promptResponse, target })) {\n        maybeCall(resolve)\n        endRequestLock()\n        return promise\n      }\n    }\n\n    if (confirmQuestion && !confirmed) {\n      if (!confirm(confirmQuestion)) {\n        maybeCall(resolve)\n        endRequestLock()\n        return promise\n      }\n    }\n\n    let headers = getHeaders(elt, target, promptResponse)\n\n    if (verb !== 'get' && !usesFormData(elt)) {\n      headers['Content-Type'] = 'application/x-www-form-urlencoded'\n    }\n\n    if (etc.headers) {\n      headers = mergeObjects(headers, etc.headers)\n    }\n    const results = getInputValues(elt, verb)\n    let errors = results.errors\n    const rawFormData = results.formData\n    if (etc.values) {\n      overrideFormData(rawFormData, formDataFromObject(etc.values))\n    }\n    const expressionVars = formDataFromObject(getExpressionVars(elt))\n    const allFormData = overrideFormData(rawFormData, expressionVars)\n    let filteredFormData = filterValues(allFormData, elt)\n\n    if (htmx.config.getCacheBusterParam && verb === 'get') {\n      filteredFormData.set('org.htmx.cache-buster', getRawAttribute(target, 'id') || 'true')\n    }\n\n    // behavior of anchors w/ empty href is to use the current URL\n    if (path == null || path === '') {\n      path = getDocument().location.href\n    }\n\n    /**\n     * @type {Object}\n     * @property {boolean} [credentials]\n     * @property {number} [timeout]\n     * @property {boolean} [noHeaders]\n     */\n    const requestAttrValues = getValuesForElement(elt, 'hx-request')\n\n    const eltIsBoosted = getInternalData(elt).boosted\n\n    let useUrlParams = htmx.config.methodsThatUseUrlParams.indexOf(verb) >= 0\n\n    /** @type HtmxRequestConfig */\n    const requestConfig = {\n      boosted: eltIsBoosted,\n      useUrlParams,\n      formData: filteredFormData,\n      parameters: formDataProxy(filteredFormData),\n      unfilteredFormData: allFormData,\n      unfilteredParameters: formDataProxy(allFormData),\n      headers,\n      target,\n      verb,\n      errors,\n      withCredentials: etc.credentials || requestAttrValues.credentials || htmx.config.withCredentials,\n      timeout: etc.timeout || requestAttrValues.timeout || htmx.config.timeout,\n      path,\n      triggeringEvent: event\n    }\n\n    if (!triggerEvent(elt, 'htmx:configRequest', requestConfig)) {\n      maybeCall(resolve)\n      endRequestLock()\n      return promise\n    }\n\n    // copy out in case the object was overwritten\n    path = requestConfig.path\n    verb = requestConfig.verb\n    headers = requestConfig.headers\n    filteredFormData = formDataFromObject(requestConfig.parameters)\n    errors = requestConfig.errors\n    useUrlParams = requestConfig.useUrlParams\n\n    if (errors && errors.length > 0) {\n      triggerEvent(elt, 'htmx:validation:halted', requestConfig)\n      maybeCall(resolve)\n      endRequestLock()\n      return promise\n    }\n\n    const splitPath = path.split('#')\n    const pathNoAnchor = splitPath[0]\n    const anchor = splitPath[1]\n\n    let finalPath = path\n    if (useUrlParams) {\n      finalPath = pathNoAnchor\n      const hasValues = !filteredFormData.keys().next().done\n      if (hasValues) {\n        if (finalPath.indexOf('?') < 0) {\n          finalPath += '?'\n        } else {\n          finalPath += '&'\n        }\n        finalPath += urlEncode(filteredFormData)\n        if (anchor) {\n          finalPath += '#' + anchor\n        }\n      }\n    }\n\n    if (!verifyPath(elt, finalPath, requestConfig)) {\n      triggerErrorEvent(elt, 'htmx:invalidPath', requestConfig)\n      maybeCall(reject)\n      return promise\n    }\n\n    xhr.open(verb.toUpperCase(), finalPath, true)\n    xhr.overrideMimeType('text/html')\n    xhr.withCredentials = requestConfig.withCredentials\n    xhr.timeout = requestConfig.timeout\n\n    // request headers\n    if (requestAttrValues.noHeaders) {\n    // ignore all headers\n    } else {\n      for (const header in headers) {\n        if (headers.hasOwnProperty(header)) {\n          const headerValue = headers[header]\n          safelySetHeaderValue(xhr, header, headerValue)\n        }\n      }\n    }\n\n    /** @type {HtmxResponseInfo} */\n    const responseInfo = {\n      xhr,\n      target,\n      requestConfig,\n      etc,\n      boosted: eltIsBoosted,\n      select,\n      pathInfo: {\n        requestPath: path,\n        finalRequestPath: finalPath,\n        responsePath: null,\n        anchor\n      }\n    }\n\n    xhr.onload = function() {\n      try {\n        const hierarchy = hierarchyForElt(elt)\n        responseInfo.pathInfo.responsePath = getPathFromResponse(xhr)\n        responseHandler(elt, responseInfo)\n        if (responseInfo.keepIndicators !== true) {\n          removeRequestIndicators(indicators, disableElts)\n        }\n        triggerEvent(elt, 'htmx:afterRequest', responseInfo)\n        triggerEvent(elt, 'htmx:afterOnLoad', responseInfo)\n        // if the body no longer contains the element, trigger the event on the closest parent\n        // remaining in the DOM\n        if (!bodyContains(elt)) {\n          let secondaryTriggerElt = null\n          while (hierarchy.length > 0 && secondaryTriggerElt == null) {\n            const parentEltInHierarchy = hierarchy.shift()\n            if (bodyContains(parentEltInHierarchy)) {\n              secondaryTriggerElt = parentEltInHierarchy\n            }\n          }\n          if (secondaryTriggerElt) {\n            triggerEvent(secondaryTriggerElt, 'htmx:afterRequest', responseInfo)\n            triggerEvent(secondaryTriggerElt, 'htmx:afterOnLoad', responseInfo)\n          }\n        }\n        maybeCall(resolve)\n        endRequestLock()\n      } catch (e) {\n        triggerErrorEvent(elt, 'htmx:onLoadError', mergeObjects({ error: e }, responseInfo))\n        throw e\n      }\n    }\n    xhr.onerror = function() {\n      removeRequestIndicators(indicators, disableElts)\n      triggerErrorEvent(elt, 'htmx:afterRequest', responseInfo)\n      triggerErrorEvent(elt, 'htmx:sendError', responseInfo)\n      maybeCall(reject)\n      endRequestLock()\n    }\n    xhr.onabort = function() {\n      removeRequestIndicators(indicators, disableElts)\n      triggerErrorEvent(elt, 'htmx:afterRequest', responseInfo)\n      triggerErrorEvent(elt, 'htmx:sendAbort', responseInfo)\n      maybeCall(reject)\n      endRequestLock()\n    }\n    xhr.ontimeout = function() {\n      removeRequestIndicators(indicators, disableElts)\n      triggerErrorEvent(elt, 'htmx:afterRequest', responseInfo)\n      triggerErrorEvent(elt, 'htmx:timeout', responseInfo)\n      maybeCall(reject)\n      endRequestLock()\n    }\n    if (!triggerEvent(elt, 'htmx:beforeRequest', responseInfo)) {\n      maybeCall(resolve)\n      endRequestLock()\n      return promise\n    }\n    var indicators = addRequestIndicatorClasses(elt)\n    var disableElts = disableElements(elt)\n\n    forEach(['loadstart', 'loadend', 'progress', 'abort'], function(eventName) {\n      forEach([xhr, xhr.upload], function(target) {\n        target.addEventListener(eventName, function(event) {\n          triggerEvent(elt, 'htmx:xhr:' + eventName, {\n            lengthComputable: event.lengthComputable,\n            loaded: event.loaded,\n            total: event.total\n          })\n        })\n      })\n    })\n    triggerEvent(elt, 'htmx:beforeSend', responseInfo)\n    const params = useUrlParams ? null : encodeParamsForBody(xhr, elt, filteredFormData)\n    xhr.send(params)\n    return promise\n  }\n\n  /**\n   * @typedef {Object} HtmxHistoryUpdate\n   * @property {string|null} [type]\n   * @property {string|null} [path]\n   */\n\n  /**\n   * @param {Element} elt\n   * @param {HtmxResponseInfo} responseInfo\n   * @return {HtmxHistoryUpdate}\n   */\n  function determineHistoryUpdates(elt, responseInfo) {\n    const xhr = responseInfo.xhr\n\n    //= ==========================================\n    // First consult response headers\n    //= ==========================================\n    let pathFromHeaders = null\n    let typeFromHeaders = null\n    if (hasHeader(xhr, /HX-Push:/i)) {\n      pathFromHeaders = xhr.getResponseHeader('HX-Push')\n      typeFromHeaders = 'push'\n    } else if (hasHeader(xhr, /HX-Push-Url:/i)) {\n      pathFromHeaders = xhr.getResponseHeader('HX-Push-Url')\n      typeFromHeaders = 'push'\n    } else if (hasHeader(xhr, /HX-Replace-Url:/i)) {\n      pathFromHeaders = xhr.getResponseHeader('HX-Replace-Url')\n      typeFromHeaders = 'replace'\n    }\n\n    // if there was a response header, that has priority\n    if (pathFromHeaders) {\n      if (pathFromHeaders === 'false') {\n        return {}\n      } else {\n        return {\n          type: typeFromHeaders,\n          path: pathFromHeaders\n        }\n      }\n    }\n\n    //= ==========================================\n    // Next resolve via DOM values\n    //= ==========================================\n    const requestPath = responseInfo.pathInfo.finalRequestPath\n    const responsePath = responseInfo.pathInfo.responsePath\n\n    const pushUrl = getClosestAttributeValue(elt, 'hx-push-url')\n    const replaceUrl = getClosestAttributeValue(elt, 'hx-replace-url')\n    const elementIsBoosted = getInternalData(elt).boosted\n\n    let saveType = null\n    let path = null\n\n    if (pushUrl) {\n      saveType = 'push'\n      path = pushUrl\n    } else if (replaceUrl) {\n      saveType = 'replace'\n      path = replaceUrl\n    } else if (elementIsBoosted) {\n      saveType = 'push'\n      path = responsePath || requestPath // if there is no response path, go with the original request path\n    }\n\n    if (path) {\n    // false indicates no push, return empty object\n      if (path === 'false') {\n        return {}\n      }\n\n      // true indicates we want to follow wherever the server ended up sending us\n      if (path === 'true') {\n        path = responsePath || requestPath // if there is no response path, go with the original request path\n      }\n\n      // restore any anchor associated with the request\n      if (responseInfo.pathInfo.anchor && path.indexOf('#') === -1) {\n        path = path + '#' + responseInfo.pathInfo.anchor\n      }\n\n      return {\n        type: saveType,\n        path\n      }\n    } else {\n      return {}\n    }\n  }\n\n  /**\n   * @param {HtmxResponseHandlingConfig} responseHandlingConfig\n   * @param {number} status\n   * @return {boolean}\n   */\n  function codeMatches(responseHandlingConfig, status) {\n    var regExp = new RegExp(responseHandlingConfig.code)\n    return regExp.test(status.toString(10))\n  }\n\n  /**\n   * @param {XMLHttpRequest} xhr\n   * @return {HtmxResponseHandlingConfig}\n   */\n  function resolveResponseHandling(xhr) {\n    for (var i = 0; i < htmx.config.responseHandling.length; i++) {\n      /** @type HtmxResponseHandlingConfig */\n      var responseHandlingElement = htmx.config.responseHandling[i]\n      if (codeMatches(responseHandlingElement, xhr.status)) {\n        return responseHandlingElement\n      }\n    }\n    // no matches, return no swap\n    return {\n      swap: false\n    }\n  }\n\n  /**\n   * @param {string} title\n   */\n  function handleTitle(title) {\n    if (title) {\n      const titleElt = find('title')\n      if (titleElt) {\n        titleElt.innerHTML = title\n      } else {\n        window.document.title = title\n      }\n    }\n  }\n\n  /**\n   * @param {Element} elt\n   * @param {HtmxResponseInfo} responseInfo\n   */\n  function handleAjaxResponse(elt, responseInfo) {\n    const xhr = responseInfo.xhr\n    let target = responseInfo.target\n    const etc = responseInfo.etc\n    const responseInfoSelect = responseInfo.select\n\n    if (!triggerEvent(elt, 'htmx:beforeOnLoad', responseInfo)) return\n\n    if (hasHeader(xhr, /HX-Trigger:/i)) {\n      handleTriggerHeader(xhr, 'HX-Trigger', elt)\n    }\n\n    if (hasHeader(xhr, /HX-Location:/i)) {\n      saveCurrentPageToHistory()\n      let redirectPath = xhr.getResponseHeader('HX-Location')\n      /** @type {HtmxAjaxHelperContext&{path:string}} */\n      var redirectSwapSpec\n      if (redirectPath.indexOf('{') === 0) {\n        redirectSwapSpec = parseJSON(redirectPath)\n        // what's the best way to throw an error if the user didn't include this\n        redirectPath = redirectSwapSpec.path\n        delete redirectSwapSpec.path\n      }\n      ajaxHelper('get', redirectPath, redirectSwapSpec).then(function() {\n        pushUrlIntoHistory(redirectPath)\n      })\n      return\n    }\n\n    const shouldRefresh = hasHeader(xhr, /HX-Refresh:/i) && xhr.getResponseHeader('HX-Refresh') === 'true'\n\n    if (hasHeader(xhr, /HX-Redirect:/i)) {\n      responseInfo.keepIndicators = true\n      location.href = xhr.getResponseHeader('HX-Redirect')\n      shouldRefresh && location.reload()\n      return\n    }\n\n    if (shouldRefresh) {\n      responseInfo.keepIndicators = true\n      location.reload()\n      return\n    }\n\n    if (hasHeader(xhr, /HX-Retarget:/i)) {\n      if (xhr.getResponseHeader('HX-Retarget') === 'this') {\n        responseInfo.target = elt\n      } else {\n        responseInfo.target = asElement(querySelectorExt(elt, xhr.getResponseHeader('HX-Retarget')))\n      }\n    }\n\n    const historyUpdate = determineHistoryUpdates(elt, responseInfo)\n\n    const responseHandling = resolveResponseHandling(xhr)\n    const shouldSwap = responseHandling.swap\n    let isError = !!responseHandling.error\n    let ignoreTitle = htmx.config.ignoreTitle || responseHandling.ignoreTitle\n    let selectOverride = responseHandling.select\n    if (responseHandling.target) {\n      responseInfo.target = asElement(querySelectorExt(elt, responseHandling.target))\n    }\n    var swapOverride = etc.swapOverride\n    if (swapOverride == null && responseHandling.swapOverride) {\n      swapOverride = responseHandling.swapOverride\n    }\n\n    // response headers override response handling config\n    if (hasHeader(xhr, /HX-Retarget:/i)) {\n      if (xhr.getResponseHeader('HX-Retarget') === 'this') {\n        responseInfo.target = elt\n      } else {\n        responseInfo.target = asElement(querySelectorExt(elt, xhr.getResponseHeader('HX-Retarget')))\n      }\n    }\n    if (hasHeader(xhr, /HX-Reswap:/i)) {\n      swapOverride = xhr.getResponseHeader('HX-Reswap')\n    }\n\n    var serverResponse = xhr.response\n    /** @type HtmxBeforeSwapDetails */\n    var beforeSwapDetails = mergeObjects({\n      shouldSwap,\n      serverResponse,\n      isError,\n      ignoreTitle,\n      selectOverride\n    }, responseInfo)\n\n    if (responseHandling.event && !triggerEvent(target, responseHandling.event, beforeSwapDetails)) return\n\n    if (!triggerEvent(target, 'htmx:beforeSwap', beforeSwapDetails)) return\n\n    target = beforeSwapDetails.target // allow re-targeting\n    serverResponse = beforeSwapDetails.serverResponse // allow updating content\n    isError = beforeSwapDetails.isError // allow updating error\n    ignoreTitle = beforeSwapDetails.ignoreTitle // allow updating ignoring title\n    selectOverride = beforeSwapDetails.selectOverride // allow updating select override\n\n    responseInfo.target = target // Make updated target available to response events\n    responseInfo.failed = isError // Make failed property available to response events\n    responseInfo.successful = !isError // Make successful property available to response events\n\n    if (beforeSwapDetails.shouldSwap) {\n      if (xhr.status === 286) {\n        cancelPolling(elt)\n      }\n\n      withExtensions(elt, function(extension) {\n        serverResponse = extension.transformResponse(serverResponse, xhr, elt)\n      })\n\n      // Save current page if there will be a history update\n      if (historyUpdate.type) {\n        saveCurrentPageToHistory()\n      }\n\n      if (hasHeader(xhr, /HX-Reswap:/i)) {\n        swapOverride = xhr.getResponseHeader('HX-Reswap')\n      }\n      var swapSpec = getSwapSpecification(elt, swapOverride)\n\n      if (!swapSpec.hasOwnProperty('ignoreTitle')) {\n        swapSpec.ignoreTitle = ignoreTitle\n      }\n\n      target.classList.add(htmx.config.swappingClass)\n\n      // optional transition API promise callbacks\n      let settleResolve = null\n      let settleReject = null\n\n      if (responseInfoSelect) {\n        selectOverride = responseInfoSelect\n      }\n\n      if (hasHeader(xhr, /HX-Reselect:/i)) {\n        selectOverride = xhr.getResponseHeader('HX-Reselect')\n      }\n\n      const selectOOB = getClosestAttributeValue(elt, 'hx-select-oob')\n      const select = getClosestAttributeValue(elt, 'hx-select')\n\n      let doSwap = function() {\n        try {\n          // if we need to save history, do so, before swapping so that relative resources have the correct base URL\n          if (historyUpdate.type) {\n            triggerEvent(getDocument().body, 'htmx:beforeHistoryUpdate', mergeObjects({ history: historyUpdate }, responseInfo))\n            if (historyUpdate.type === 'push') {\n              pushUrlIntoHistory(historyUpdate.path)\n              triggerEvent(getDocument().body, 'htmx:pushedIntoHistory', { path: historyUpdate.path })\n            } else {\n              replaceUrlInHistory(historyUpdate.path)\n              triggerEvent(getDocument().body, 'htmx:replacedInHistory', { path: historyUpdate.path })\n            }\n          }\n\n          swap(target, serverResponse, swapSpec, {\n            select: selectOverride || select,\n            selectOOB,\n            eventInfo: responseInfo,\n            anchor: responseInfo.pathInfo.anchor,\n            contextElement: elt,\n            afterSwapCallback: function() {\n              if (hasHeader(xhr, /HX-Trigger-After-Swap:/i)) {\n                let finalElt = elt\n                if (!bodyContains(elt)) {\n                  finalElt = getDocument().body\n                }\n                handleTriggerHeader(xhr, 'HX-Trigger-After-Swap', finalElt)\n              }\n            },\n            afterSettleCallback: function() {\n              if (hasHeader(xhr, /HX-Trigger-After-Settle:/i)) {\n                let finalElt = elt\n                if (!bodyContains(elt)) {\n                  finalElt = getDocument().body\n                }\n                handleTriggerHeader(xhr, 'HX-Trigger-After-Settle', finalElt)\n              }\n              maybeCall(settleResolve)\n            }\n          })\n        } catch (e) {\n          triggerErrorEvent(elt, 'htmx:swapError', responseInfo)\n          maybeCall(settleReject)\n          throw e\n        }\n      }\n\n      let shouldTransition = htmx.config.globalViewTransitions\n      if (swapSpec.hasOwnProperty('transition')) {\n        shouldTransition = swapSpec.transition\n      }\n\n      if (shouldTransition &&\n              triggerEvent(elt, 'htmx:beforeTransition', responseInfo) &&\n              typeof Promise !== 'undefined' &&\n              // @ts-ignore experimental feature atm\n              document.startViewTransition) {\n        const settlePromise = new Promise(function(_resolve, _reject) {\n          settleResolve = _resolve\n          settleReject = _reject\n        })\n        // wrap the original doSwap() in a call to startViewTransition()\n        const innerDoSwap = doSwap\n        doSwap = function() {\n          // @ts-ignore experimental feature atm\n          document.startViewTransition(function() {\n            innerDoSwap()\n            return settlePromise\n          })\n        }\n      }\n\n      if (swapSpec.swapDelay > 0) {\n        getWindow().setTimeout(doSwap, swapSpec.swapDelay)\n      } else {\n        doSwap()\n      }\n    }\n    if (isError) {\n      triggerErrorEvent(elt, 'htmx:responseError', mergeObjects({ error: 'Response Status Error Code ' + xhr.status + ' from ' + responseInfo.pathInfo.requestPath }, responseInfo))\n    }\n  }\n\n  //= ===================================================================\n  // Extensions API\n  //= ===================================================================\n\n  /** @type {Object<string, HtmxExtension>} */\n  const extensions = {}\n\n  /**\n   * extensionBase defines the default functions for all extensions.\n   * @returns {HtmxExtension}\n   */\n  function extensionBase() {\n    return {\n      init: function(api) { return null },\n      getSelectors: function() { return null },\n      onEvent: function(name, evt) { return true },\n      transformResponse: function(text, xhr, elt) { return text },\n      isInlineSwap: function(swapStyle) { return false },\n      handleSwap: function(swapStyle, target, fragment, settleInfo) { return false },\n      encodeParameters: function(xhr, parameters, elt) { return null }\n    }\n  }\n\n  /**\n   * defineExtension initializes the extension and adds it to the htmx registry\n   *\n   * @see https://htmx.org/api/#defineExtension\n   *\n   * @param {string} name the extension name\n   * @param {HtmxExtension} extension the extension definition\n   */\n  function defineExtension(name, extension) {\n    if (extension.init) {\n      extension.init(internalAPI)\n    }\n    extensions[name] = mergeObjects(extensionBase(), extension)\n  }\n\n  /**\n   * removeExtension removes an extension from the htmx registry\n   *\n   * @see https://htmx.org/api/#removeExtension\n   *\n   * @param {string} name\n   */\n  function removeExtension(name) {\n    delete extensions[name]\n  }\n\n  /**\n   * getExtensions searches up the DOM tree to return all extensions that can be applied to a given element\n   *\n   * @param {Element} elt\n   * @param {HtmxExtension[]=} extensionsToReturn\n   * @param {string[]=} extensionsToIgnore\n   * @returns {HtmxExtension[]}\n   */\n  function getExtensions(elt, extensionsToReturn, extensionsToIgnore) {\n    if (extensionsToReturn == undefined) {\n      extensionsToReturn = []\n    }\n    if (elt == undefined) {\n      return extensionsToReturn\n    }\n    if (extensionsToIgnore == undefined) {\n      extensionsToIgnore = []\n    }\n    const extensionsForElement = getAttributeValue(elt, 'hx-ext')\n    if (extensionsForElement) {\n      forEach(extensionsForElement.split(','), function(extensionName) {\n        extensionName = extensionName.replace(/ /g, '')\n        if (extensionName.slice(0, 7) == 'ignore:') {\n          extensionsToIgnore.push(extensionName.slice(7))\n          return\n        }\n        if (extensionsToIgnore.indexOf(extensionName) < 0) {\n          const extension = extensions[extensionName]\n          if (extension && extensionsToReturn.indexOf(extension) < 0) {\n            extensionsToReturn.push(extension)\n          }\n        }\n      })\n    }\n    return getExtensions(asElement(parentElt(elt)), extensionsToReturn, extensionsToIgnore)\n  }\n\n  //= ===================================================================\n  // Initialization\n  //= ===================================================================\n  var isReady = false\n  getDocument().addEventListener('DOMContentLoaded', function() {\n    isReady = true\n  })\n\n  /**\n   * Execute a function now if DOMContentLoaded has fired, otherwise listen for it.\n   *\n   * This function uses isReady because there is no reliable way to ask the browser whether\n   * the DOMContentLoaded event has already been fired; there's a gap between DOMContentLoaded\n   * firing and readystate=complete.\n   */\n  function ready(fn) {\n    // Checking readyState here is a failsafe in case the htmx script tag entered the DOM by\n    // some means other than the initial page load.\n    if (isReady || getDocument().readyState === 'complete') {\n      fn()\n    } else {\n      getDocument().addEventListener('DOMContentLoaded', fn)\n    }\n  }\n\n  function insertIndicatorStyles() {\n    if (htmx.config.includeIndicatorStyles !== false) {\n      const nonceAttribute = htmx.config.inlineStyleNonce ? ` nonce=\"${htmx.config.inlineStyleNonce}\"` : ''\n      getDocument().head.insertAdjacentHTML('beforeend',\n        '<style' + nonceAttribute + '>\\\n      .' + htmx.config.indicatorClass + '{opacity:0}\\\n      .' + htmx.config.requestClass + ' .' + htmx.config.indicatorClass + '{opacity:1; transition: opacity 200ms ease-in;}\\\n      .' + htmx.config.requestClass + '.' + htmx.config.indicatorClass + '{opacity:1; transition: opacity 200ms ease-in;}\\\n      </style>')\n    }\n  }\n\n  function getMetaConfig() {\n    /** @type HTMLMetaElement */\n    const element = getDocument().querySelector('meta[name=\"htmx-config\"]')\n    if (element) {\n      return parseJSON(element.content)\n    } else {\n      return null\n    }\n  }\n\n  function mergeMetaConfig() {\n    const metaConfig = getMetaConfig()\n    if (metaConfig) {\n      htmx.config = mergeObjects(htmx.config, metaConfig)\n    }\n  }\n\n  // initialize the document\n  ready(function() {\n    mergeMetaConfig()\n    insertIndicatorStyles()\n    let body = getDocument().body\n    processNode(body)\n    const restoredElts = getDocument().querySelectorAll(\n      \"[hx-trigger='restored'],[data-hx-trigger='restored']\"\n    )\n    body.addEventListener('htmx:abort', function(evt) {\n      const target = evt.target\n      const internalData = getInternalData(target)\n      if (internalData && internalData.xhr) {\n        internalData.xhr.abort()\n      }\n    })\n    /** @type {(ev: PopStateEvent) => any} */\n    const originalPopstate = window.onpopstate ? window.onpopstate.bind(window) : null\n    /** @type {(ev: PopStateEvent) => any} */\n    window.onpopstate = function(event) {\n      if (event.state && event.state.htmx) {\n        restoreHistory()\n        forEach(restoredElts, function(elt) {\n          triggerEvent(elt, 'htmx:restored', {\n            document: getDocument(),\n            triggerEvent\n          })\n        })\n      } else {\n        if (originalPopstate) {\n          originalPopstate(event)\n        }\n      }\n    }\n    getWindow().setTimeout(function() {\n      triggerEvent(body, 'htmx:load', {}) // give ready handlers a chance to load up before firing this event\n      body = null // kill reference for gc\n    }, 0)\n  })\n\n  return htmx\n})()\n\n/** @typedef {'get'|'head'|'post'|'put'|'delete'|'connect'|'options'|'trace'|'patch'} HttpVerb */\n\n/**\n * @typedef {Object} SwapOptions\n * @property {string} [select]\n * @property {string} [selectOOB]\n * @property {*} [eventInfo]\n * @property {string} [anchor]\n * @property {Element} [contextElement]\n * @property {swapCallback} [afterSwapCallback]\n * @property {swapCallback} [afterSettleCallback]\n */\n\n/**\n * @callback swapCallback\n */\n\n/**\n * @typedef {'innerHTML' | 'outerHTML' | 'beforebegin' | 'afterbegin' | 'beforeend' | 'afterend' | 'delete' | 'none' | string} HtmxSwapStyle\n */\n\n/**\n * @typedef HtmxSwapSpecification\n * @property {HtmxSwapStyle} swapStyle\n * @property {number} swapDelay\n * @property {number} settleDelay\n * @property {boolean} [transition]\n * @property {boolean} [ignoreTitle]\n * @property {string} [head]\n * @property {'top' | 'bottom'} [scroll]\n * @property {string} [scrollTarget]\n * @property {string} [show]\n * @property {string} [showTarget]\n * @property {boolean} [focusScroll]\n */\n\n/**\n * @typedef {((this:Node, evt:Event) => boolean) & {source: string}} ConditionalFunction\n */\n\n/**\n * @typedef {Object} HtmxTriggerSpecification\n * @property {string} trigger\n * @property {number} [pollInterval]\n * @property {ConditionalFunction} [eventFilter]\n * @property {boolean} [changed]\n * @property {boolean} [once]\n * @property {boolean} [consume]\n * @property {number} [delay]\n * @property {string} [from]\n * @property {string} [target]\n * @property {number} [throttle]\n * @property {string} [queue]\n * @property {string} [root]\n * @property {string} [threshold]\n */\n\n/**\n * @typedef {{elt: Element, message: string, validity: ValidityState}} HtmxElementValidationError\n */\n\n/**\n * @typedef {Record<string, string>} HtmxHeaderSpecification\n * @property {'true'} HX-Request\n * @property {string|null} HX-Trigger\n * @property {string|null} HX-Trigger-Name\n * @property {string|null} HX-Target\n * @property {string} HX-Current-URL\n * @property {string} [HX-Prompt]\n * @property {'true'} [HX-Boosted]\n * @property {string} [Content-Type]\n * @property {'true'} [HX-History-Restore-Request]\n */\n\n/** @typedef HtmxAjaxHelperContext\n * @property {Element|string} [source]\n * @property {Event} [event]\n * @property {HtmxAjaxHandler} [handler]\n * @property {Element|string} [target]\n * @property {HtmxSwapStyle} [swap]\n * @property {Object|FormData} [values]\n * @property {Record<string,string>} [headers]\n * @property {string} [select]\n */\n\n/**\n * @typedef {Object} HtmxRequestConfig\n * @property {boolean} boosted\n * @property {boolean} useUrlParams\n * @property {FormData} formData\n * @property {Object} parameters formData proxy\n * @property {FormData} unfilteredFormData\n * @property {Object} unfilteredParameters unfilteredFormData proxy\n * @property {HtmxHeaderSpecification} headers\n * @property {Element} target\n * @property {HttpVerb} verb\n * @property {HtmxElementValidationError[]} errors\n * @property {boolean} withCredentials\n * @property {number} timeout\n * @property {string} path\n * @property {Event} triggeringEvent\n */\n\n/**\n * @typedef {Object} HtmxResponseInfo\n * @property {XMLHttpRequest} xhr\n * @property {Element} target\n * @property {HtmxRequestConfig} requestConfig\n * @property {HtmxAjaxEtc} etc\n * @property {boolean} boosted\n * @property {string} select\n * @property {{requestPath: string, finalRequestPath: string, responsePath: string|null, anchor: string}} pathInfo\n * @property {boolean} [failed]\n * @property {boolean} [successful]\n * @property {boolean} [keepIndicators]\n */\n\n/**\n * @typedef {Object} HtmxAjaxEtc\n * @property {boolean} [returnPromise]\n * @property {HtmxAjaxHandler} [handler]\n * @property {string} [select]\n * @property {Element} [targetOverride]\n * @property {HtmxSwapStyle} [swapOverride]\n * @property {Record<string,string>} [headers]\n * @property {Object|FormData} [values]\n * @property {boolean} [credentials]\n * @property {number} [timeout]\n */\n\n/**\n * @typedef {Object} HtmxResponseHandlingConfig\n * @property {string} [code]\n * @property {boolean} swap\n * @property {boolean} [error]\n * @property {boolean} [ignoreTitle]\n * @property {string} [select]\n * @property {string} [target]\n * @property {string} [swapOverride]\n * @property {string} [event]\n */\n\n/**\n * @typedef {HtmxResponseInfo & {shouldSwap: boolean, serverResponse: any, isError: boolean, ignoreTitle: boolean, selectOverride:string}} HtmxBeforeSwapDetails\n */\n\n/**\n * @callback HtmxAjaxHandler\n * @param {Element} elt\n * @param {HtmxResponseInfo} responseInfo\n */\n\n/**\n * @typedef {(() => void)} HtmxSettleTask\n */\n\n/**\n * @typedef {Object} HtmxSettleInfo\n * @property {HtmxSettleTask[]} tasks\n * @property {Element[]} elts\n * @property {string} [title]\n */\n\n/**\n * @see https://github.com/bigskysoftware/htmx-extensions/blob/main/README.md\n * @typedef {Object} HtmxExtension\n * @property {(api: any) => void} init\n * @property {(name: string, event: Event|CustomEvent) => boolean} onEvent\n * @property {(text: string, xhr: XMLHttpRequest, elt: Element) => string} transformResponse\n * @property {(swapStyle: HtmxSwapStyle) => boolean} isInlineSwap\n * @property {(swapStyle: HtmxSwapStyle, target: Node, fragment: Node, settleInfo: HtmxSettleInfo) => boolean|Node[]} handleSwap\n * @property {(xhr: XMLHttpRequest, parameters: FormData, elt: Node) => *|string|null} encodeParameters\n * @property {() => string[]|null} getSelectors\n */\nexport default htmx\n","import htmx from \"htmx.org\";\n\nfunction dependsOn(pathSpec: any, url: string) {\n  if (pathSpec === \"ignore\") {\n    return false;\n  }\n  const dependencyPath = pathSpec.split(\"/\");\n  const urlPath = url.split(\"/\");\n  for (let i = 0; i < urlPath.length; i++) {\n    const dependencyElement = dependencyPath.shift();\n    const pathElement = urlPath[i];\n    if (dependencyElement !== pathElement && dependencyElement !== \"*\") {\n      return false;\n    }\n    if (\n      dependencyPath.length === 0 ||\n      (dependencyPath.length === 1 && dependencyPath[0] === \"\")\n    ) {\n      return true;\n    }\n  }\n  return false;\n}\n\nfunction refreshPath(path: string) {\n  const eltsWithDeps = htmx.findAll(\"[path-deps]\");\n  for (let i = 0; i < eltsWithDeps.length; i++) {\n    const elt = eltsWithDeps[i];\n    if (dependsOn(elt.getAttribute(\"path-deps\"), path)) {\n      htmx.trigger(elt, \"path-deps\", null);\n    }\n  }\n}\n\nhtmx.defineExtension(\"path-deps\", {\n  // @ts-ignore\n  onEvent: function (name, evt) {\n    if (!(evt instanceof CustomEvent)) {\n      return false;\n    }\n    if (name === \"htmx:beforeOnLoad\") {\n      const config = evt.detail.requestConfig;\n      // mutating call\n      if (\n        config &&\n        config.verb !== \"get\" &&\n        evt.target != null &&\n        evt.target instanceof Element &&\n        evt.target.getAttribute(\"path-deps\") !== \"ignore\"\n      ) {\n        refreshPath(config.path);\n      }\n    }\n  },\n});\n","import htmx from \"htmx.org\";\n\nfunction kebabEventName(str: string) {\n    return str.replace(/([a-z0-9])([A-Z])/g, '$1-$2').toLowerCase()\n}\n\nconst ignoredEvents = ['htmx:beforeProcessNode', 'htmx:afterProcessNode', 'htmx:configRequest', 'htmx:configResponse', 'htmx:responseError'];\n\nfunction makeEvent(eventName: string, detail: any) {\n    let evt\n    if (window.CustomEvent && typeof window.CustomEvent === 'function') {\n        // TODO: `composed: true` here is a hack to make global event handlers work with events in shadow DOM\n        evt = new CustomEvent(eventName, { bubbles: false, cancelable: true, composed: true, detail })\n    } else {\n        evt = document.createEvent('CustomEvent')\n        evt.initCustomEvent(eventName, true, true, detail)\n    }\n    return evt\n}\n\nfunction triggerChildren(target: HTMLElement, name: string, event: CustomEvent, triggered: Set<HTMLElement>) {\n    if(ignoredEvents.includes(name)) {\n        return\n    }\n    if (target && target.children) {\n        Array.from(target.children).forEach((e) => {\n            const kehab = kebabEventName(name);\n            const eventName = kehab.replace(\"htmx:\", \"hx-on::\")\n            if (!triggered.has(e as HTMLElement)) {\n                if(e.hasAttribute(eventName)) {\n                    setTimeout(() => {\n                        const newEvent = makeEvent(eventName.replace(\"hx-on::\", \"htmx:\"), {\n                            ...event.detail,\n                            target: e,\n                        })\n                        newEvent.detail.meta = 'trigger-children'\n                        e.dispatchEvent(newEvent)\n                        triggered.add(e as HTMLElement);\n                    }, 1)\n                }\n                if (e.children) {\n                    triggerChildren(e as HTMLElement, name, event, triggered);\n                }\n            }\n        });\n    }\n}\n\n\n// @ts-ignore\nhtmx.defineExtension(\"trigger-children\", {\n    onEvent: (name, evt: Event | CustomEvent) => {\n        if (!(evt instanceof CustomEvent)) {\n            return false;\n        }\n        if(evt.detail.meta === 'trigger-children') {\n            return false;\n        }\n        const triggered = new Set<HTMLElement>();\n        const target = evt.target as HTMLElement || evt.detail.target as HTMLElement;\n        triggerChildren(target, name, evt, triggered);\n        return true;\n    },\n});\n","import htmx from \"htmx.org\";\n\nhtmx.defineExtension(\"debug\", {\n  // @ts-ignore\n  onEvent: function (name, evt) {\n    if (console.debug) {\n      console.debug(name, evt);\n    } else if (console) {\n      console.log(\"DEBUG:\", name, evt);\n    } else {\n      // noop\n    }\n  },\n});\n","import htmx from \"htmx.org\";\nconst config: any = htmx.config;\n\n/** @type {import(\"../htmx\").HtmxInternalApi} */\nlet api: any;\n\nconst attrPrefix = \"hx-target-\";\n\n// IE11 doesn't support string.startsWith\nfunction startsWith(str: string, prefix: string) {\n  return str.substring(0, prefix.length) === prefix;\n}\n\n/**\n * @param {HTMLElement} elt\n * @param respCodeNumber\n * @returns {HTMLElement | null}\n */\nfunction getRespCodeTarget(elt: Element, respCodeNumber: number) {\n  if (!elt || !respCodeNumber) return null;\n\n  const respCode = respCodeNumber.toString();\n\n  // '*' is the original syntax, as the obvious character for a wildcard.\n  // The 'x' alternative was added for maximum compatibility with HTML\n  // templating engines, due to ambiguity around which characters are\n  // supported in HTML attributes.\n  //\n  // Start with the most specific possible attribute and generalize from\n  // there.\n  const attrPossibilities = [\n    respCode,\n\n    respCode.substr(0, 2) + \"*\",\n    respCode.substr(0, 2) + \"x\",\n\n    respCode.substr(0, 1) + \"*\",\n    respCode.substr(0, 1) + \"x\",\n    respCode.substr(0, 1) + \"**\",\n    respCode.substr(0, 1) + \"xx\",\n\n    \"*\",\n    \"x\",\n    \"***\",\n    \"xxx\",\n  ];\n  if (startsWith(respCode, \"4\") || startsWith(respCode, \"5\")) {\n    attrPossibilities.push(\"error\");\n  }\n\n  for (let i = 0; i < attrPossibilities.length; i++) {\n    const attr = attrPrefix + attrPossibilities[i];\n    const attrValue = api.getClosestAttributeValue(elt, attr);\n    if (attrValue) {\n      if (attrValue === \"this\") {\n        return api.findThisElement(elt, attr);\n      } else {\n        return api.querySelectorExt(elt, attrValue);\n      }\n    }\n  }\n\n  return null;\n}\n\n/** @param {Event} evt */\nfunction handleErrorFlag(evt: CustomEvent) {\n  if (evt.detail.isError) {\n    if (config.responseTargetUnsetsError) {\n      evt.detail.isError = false;\n    }\n  } else if (config.responseTargetSetsError) {\n    evt.detail.isError = true;\n  }\n}\n\nhtmx.defineExtension(\"response-targets\", {\n  // @ts-ignore\n  init: (apiRef) => {\n    api = apiRef;\n\n    if (config.responseTargetUnsetsError === undefined) {\n      config.responseTargetUnsetsError = true;\n    }\n    if (config.responseTargetSetsError === undefined) {\n      config.responseTargetSetsError = false;\n    }\n    if (config.responseTargetPrefersExisting === undefined) {\n      config.responseTargetPrefersExisting = false;\n    }\n    if (config.responseTargetPrefersRetargetHeader === undefined) {\n      config.responseTargetPrefersRetargetHeader = true;\n    }\n  },\n\n  // @ts-ignore\n  onEvent: (name, evt) => {\n    if (!(evt instanceof CustomEvent)) {\n      return false;\n    }\n    if (\n      name === \"htmx:beforeSwap\" &&\n      evt.detail.xhr &&\n      evt.detail.xhr.status !== 200\n    ) {\n      if (evt.detail.target) {\n        if (config.responseTargetPrefersExisting) {\n          evt.detail.shouldSwap = true;\n          handleErrorFlag(evt);\n          return true;\n        }\n        if (\n          config.responseTargetPrefersRetargetHeader &&\n          evt.detail.xhr.getAllResponseHeaders().match(/HX-Retarget:/i)\n        ) {\n          evt.detail.shouldSwap = true;\n          handleErrorFlag(evt);\n          return true;\n        }\n      }\n      if (!evt.detail.requestConfig) {\n        return true;\n      }\n      const target = getRespCodeTarget(\n        evt.detail.requestConfig.elt,\n        evt.detail.xhr.status,\n      );\n      if (target) {\n        handleErrorFlag(evt);\n        evt.detail.shouldSwap = true;\n        evt.detail.target = target;\n      }\n      return true;\n    }\n  },\n});\n","import htmx from \"htmx.org\";\n\nhtmx.defineExtension(\"mutation-error\", {\n  // @ts-ignore\n  onEvent: (name, evt) => {\n    if (!(evt instanceof CustomEvent)) {\n      return false;\n    }\n    if (name === \"htmx:afterRequest\") {\n      if (!evt.detail || !evt.detail.xhr) {\n        return;\n      }\n      const status = evt.detail.xhr.status;\n      if (status >= 400) {\n        htmx.findAll(\"[hx-on\\\\:\\\\:mutation-error]\").forEach((element) => {\n          htmx.trigger(element, \"htmx:mutation-error\", { status });\n        });\n      }\n    }\n  },\n});\n","import htmx from \"htmx.org\";\n\nlet lastVersion = \"\";\n\nhtmx.defineExtension(\"livereload\", {\n    init: function () {\n\n        let enabled = false\n        for (const element of Array.from(htmx.findAll(\"[hx-ext]\"))) {\n            const value = element.getAttribute(\"hx-ext\");\n            if(value?.split(\" \").includes(\"livereload\")) {\n                enabled = true\n                break;\n            }\n        }\n\n        if(!enabled) {\n            return\n        }\n\n        console.log('livereload extension initialized.');\n        // Create a new EventSource object and point it to your SSE endpoint\n        const eventSource = new EventSource('/dev/livereload');\n        // Listen for messages from the server\n        eventSource.onmessage = function(event) {\n            const message = event.data\n            // Log the message data received from the server\n            if(lastVersion === \"\") {\n                lastVersion = message;\n            }\n            if(lastVersion !== message) {\n                lastVersion = message;\n                reload()\n            }\n        };\n        // Handle errors (e.g., when the connection is closed)\n        eventSource.onerror = function(error) {\n            console.error('EventSource error:', error);\n        };\n\n    },\n    // @ts-ignore\n    onEvent: function (name, evt) {\n\n    },\n});\n\nfunction reload() {\n    window.location.reload()\n}\n","import htmx from \"htmx.org\";\n\nconst evalFuncRegex =/__eval_[A-Za-z0-9]+\\([a-z]+\\)/gm\n\nhtmx.defineExtension(\"htmgo\", {\n    // @ts-ignore\n    onEvent: function (name, evt) {\n       if(name === \"htmx:beforeCleanupElement\" && evt.target) {\n           removeAssociatedScripts(evt.target as HTMLElement);\n       }\n    },\n});\n\nexport function removeAssociatedScripts(element: HTMLElement) {\n   const attributes = Array.from(element.attributes)\n    for (let attribute of attributes) {\n       const matches = attribute.value.match(evalFuncRegex) || []\n        for (let match of matches) {\n            const id = match.replace(\"()\", \"\").replace(\"(this)\", \"\").replace(\";\", \"\")\n            const ele = document.getElementById(id)\n            if(ele && ele.tagName === \"SCRIPT\") {\n                console.debug(\"removing associated script with id\", id)\n                ele.remove()\n            }\n        }\n    }\n}\n","import htmx from 'htmx.org'\nimport {removeAssociatedScripts} from \"./htmgo\";\n\nlet api : any = null;\nlet processed = new Set<string>()\n\nhtmx.defineExtension(\"sse\", {\n    init: function (apiRef) {\n        api = apiRef;\n    },\n    // @ts-ignore\n    onEvent: function (name, evt) {\n        const target = evt.target;\n        if(!(target instanceof HTMLElement)) {\n            return\n        }\n\n        if(name === 'htmx:beforeCleanupElement') {\n            removeAssociatedScripts(target);\n        }\n\n        if(name === 'htmx:beforeProcessNode') {\n            const elements = document.querySelectorAll('[sse-connect]');\n            for (let element of Array.from(elements)) {\n                const url = element.getAttribute(\"sse-connect\")!;\n                if(url && !processed.has(url)) {\n                    connectEventSource(element, url)\n                    processed.add(url)\n                }\n            }\n        }\n    }\n})\n\nfunction connectEventSource(ele: Element, url: string) {\n    if(!url) {\n        return\n    }\n    console.info('Connecting to EventSource', url)\n    const eventSource = new EventSource(url);\n\n    eventSource.addEventListener(\"close\", function(event) {\n        htmx.trigger(ele, \"htmx:sseClose\", {event: event});\n    })\n\n    eventSource.onopen = function(event) {\n        htmx.trigger(ele, \"htmx:sseOpen\", {event: event});\n    }\n\n    eventSource.onerror = function(event) {\n        htmx.trigger(ele, \"htmx:sseError\", {event: event});\n        if (eventSource.readyState == EventSource.CLOSED) {\n            htmx.trigger(ele, \"htmx:sseClose\", {event: event});\n        }\n    }\n\n    eventSource.onmessage = function(event) {\n        const settleInfo = api.makeSettleInfo(ele);\n        htmx.trigger(ele, \"htmx:sseBeforeMessage\", {event: event});\n        const response = event.data\n        const fragment = api.makeFragment(response) as DocumentFragment;\n        const children = Array.from(fragment.children);\n        for (let child of children) {\n            api.oobSwap(api.getAttributeValue(child, 'hx-swap-oob') || 'true', child, settleInfo);\n            // support htmgo eval__ scripts\n            if(child.tagName === 'SCRIPT' && child.id.startsWith(\"__eval\")) {\n                document.body.appendChild(child);\n            }\n        }\n        htmx.trigger(ele, \"htmx:sseAfterMessage\", {event: event});\n    }\n}\n","import htmx from \"htmx.org\";\nimport \"./htmxextensions/pathdeps\";\nimport \"./htmxextensions/trigger-children\";\nimport \"./htmxextensions/debug\";\nimport \"./htmxextensions/response-targets\";\nimport \"./htmxextensions/mutation-error\";\nimport \"./htmxextensions/livereload\"\nimport \"./htmxextensions/htmgo\";\nimport \"./htmxextensions/sse\"\n\n/**\n * Browser doesn't support onload for all elements, so we need to manually trigger it\n * this is useful for locality of behavior\n */\nwindow.onload = function() {\n  const ignored = ['SCRIPT', 'LINK', 'STYLE', 'META', 'BASE', 'TITLE', 'HEAD', 'HTML', 'BODY'];\n  for (let element of Array.from(document.querySelectorAll(`[onload]`))) {\n    if(element != null && element instanceof HTMLElement) {\n      if(ignored.includes(element.tagName)) {\n         continue\n      }\n      element.onload!(new Event(\"load\"));\n    }\n  }\n}\n\n// @ts-ignore\nwindow.htmx = htmx;\n\nfunction watchUrl(callback: (oldUrl: string, newUrl: string) => void) {\n  let lastUrl = window.location.href;\n  setInterval(() => {\n    if (window.location.href !== lastUrl) {\n      callback(lastUrl, window.location.href);\n      lastUrl = window.location.href;\n    }\n  }, 100);\n}\n\nwatchUrl((_, newUrl) => {\n  onUrlChange(newUrl);\n});\n\nfunction onUrlChange(newUrl: string) {\n  let url = new URL(newUrl);\n\n  document.querySelectorAll(\"[hx-trigger]\").forEach(function (element) {\n    const triggers = element.getAttribute(\"hx-trigger\");\n    if (!triggers) {\n      return;\n    }\n    const split = triggers.split(\", \");\n    if (split.find((s) => s === \"url\")) {\n      htmx.swap(element, \"url\", {\n        swapStyle: \"outerHTML\",\n        swapDelay: 0,\n        settleDelay: 0,\n      });\n    } else {\n      for (let [key, values] of url.searchParams) {\n        let eventName = \"qs:\" + key;\n        if (triggers.includes(eventName)) {\n          console.log(\"triggering\", eventName);\n          htmx.trigger(element, eventName, null);\n          break;\n        }\n      }\n    }\n  });\n\n  document.querySelectorAll(\"[hx-match-qp]\").forEach((el) => {\n    let hasMatch = false;\n    for (let name of el.getAttributeNames()) {\n      if (name.startsWith(\"hx-match-qp-mapping:\")) {\n        let match = name.replace(\"hx-match-qp-mapping:\", \"\");\n        let value = url.searchParams.get(match);\n        if (value) {\n          htmx.swap(el, el.getAttribute(name) ?? \"\", {\n            swapStyle: \"innerHTML\",\n            swapDelay: 0,\n            settleDelay: 0,\n          });\n          hasMatch = true;\n          break;\n        }\n      }\n    }\n    if (!hasMatch) {\n      let defaultKey = el.getAttribute(\"hx-match-qp-default\");\n      if (defaultKey) {\n        htmx.swap(\n          el,\n          el.getAttribute(\"hx-match-qp-mapping:\" + defaultKey) ?? \"\",\n          { swapStyle: \"innerHTML\", swapDelay: 0, settleDelay: 0 },\n        );\n      }\n    }\n  });\n}\n"]} \ No newline at end of file diff --git a/framework/assets/js/htmgo.ts b/framework/assets/js/htmgo.ts index 29cb709..308da9b 100644 --- a/framework/assets/js/htmgo.ts +++ b/framework/assets/js/htmgo.ts @@ -8,6 +8,22 @@ import "./htmxextensions/livereload" import "./htmxextensions/htmgo"; import "./htmxextensions/sse" +/** + * Browser doesn't support onload for all elements, so we need to manually trigger it + * this is useful for locality of behavior + */ +window.onload = function() { + const ignored = ['SCRIPT', 'LINK', 'STYLE', 'META', 'BASE', 'TITLE', 'HEAD', 'HTML', 'BODY']; + for (let element of Array.from(document.querySelectorAll(`[onload]`))) { + if(element != null && element instanceof HTMLElement) { + if(ignored.includes(element.tagName)) { + continue + } + element.onload!(new Event("load")); + } + } +} + // @ts-ignore window.htmx = htmx; diff --git a/framework/assets/js/htmxextensions/trigger-children.ts b/framework/assets/js/htmxextensions/trigger-children.ts index 7f5b8b5..c32c738 100644 --- a/framework/assets/js/htmxextensions/trigger-children.ts +++ b/framework/assets/js/htmxextensions/trigger-children.ts @@ -4,7 +4,7 @@ function kebabEventName(str: string) { return str.replace(/([a-z0-9])([A-Z])/g, '$1-$2').toLowerCase() } -const ignoredEvents = ['htmx:beforeProcessNode', 'htmx:afterProcessNode', 'htmx:beforeSwap', 'htmx:afterSwap', 'htmx:beforeOnLoad', 'htmx:afterOnLoad', 'htmx:configRequest', 'htmx:configResponse', 'htmx:responseError']; +const ignoredEvents = ['htmx:beforeProcessNode', 'htmx:afterProcessNode', 'htmx:configRequest', 'htmx:configResponse', 'htmx:responseError']; function makeEvent(eventName: string, detail: any) { let evt @@ -28,13 +28,15 @@ function triggerChildren(target: HTMLElement, name: string, event: CustomEvent, const eventName = kehab.replace("htmx:", "hx-on::") if (!triggered.has(e as HTMLElement)) { if(e.hasAttribute(eventName)) { - const newEvent = makeEvent(eventName.replace("hx-on::", "htmx:"), { - ...event.detail, - target: e, - }) - newEvent.detail.meta = 'trigger-children' - e.dispatchEvent(newEvent) - triggered.add(e as HTMLElement); + setTimeout(() => { + const newEvent = makeEvent(eventName.replace("hx-on::", "htmx:"), { + ...event.detail, + target: e, + }) + newEvent.detail.meta = 'trigger-children' + e.dispatchEvent(newEvent) + triggered.add(e as HTMLElement); + }, 1) } if (e.children) { triggerChildren(e as HTMLElement, name, event, triggered); diff --git a/templates/starter/pages/root.go b/templates/starter/pages/root.go index cb3e629..bacdd61 100644 --- a/templates/starter/pages/root.go +++ b/templates/starter/pages/root.go @@ -6,7 +6,7 @@ import ( func RootPage(children ...h.Ren) h.Ren { return h.Html( - h.HxExtension(h.BaseExtensions()), + h.HxExtensions(h.BaseExtensions()), h.Head( h.Meta("viewport", "width=device-width, initial-scale=1"), h.Link("/public/favicon.ico", "icon"),